pawosm-arm wrote: > > I took a look and I think it may be too awkward to do, as we'd want to run > > e.g. readelf afterwards. But an example is > > `lld/test/ELF/as-needed-not-in-regular.s`. The idea being: if > > `-Wl,--as-needed` is in the config file, do we correctly prune an > > unnecessary library from a built object, or is the order wrong? We can > > check that with `llvm-readelf`. > > There are two problems here. First, following the readelf path goes too far > into the linker competences, whatever is set for the linker, the linker is > obliged to do, and the order of whatever is set for the linker is already > tested by other `-Wl,` occurrences in the currently available test cases. > > Yet your request also exposes another problem, and I can see that further > comments also mention it. With my patch, there is no way to affect the user's > command line linker input parameters. So if a config file is a mean for > turning clang's behavior into the gcc's behavior (AFAIR, gcc always emits > `-Wl,--as-needed` at the beginning of the linker invocation command line, > while clang doesn't do that), this patch rejects such possibility. Something > more clever is needed, the positional idea seems the right one, I could see > it like this (a config file example, notice the pipe `|` character): > > ``` > -Wall -Wl,--as-needed | -lm -Wl,-Bstatic -lhappy -Wl,-Bdynamic > ``` > > ...things after the pipe would be appended at the end of the parameters list > and only when it is known that there will be the linking. But this would > require a modification in the config file reading routine, the second list of > config options would have to be created much earlier than my patch proposes. > > Back to the drawing board then.
Actually, it was easy to implement, I've presented it here. https://github.com/llvm/llvm-project/pull/117573 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits