This is an archive of the discontinued LLVM Phabricator instance.

[ELF] - Linkerscript - fix handling of OUTPUT_ARCH command.
ClosedPublic

Authored by grimar on Feb 7 2017, 7:13 AM.

Details

Summary

OUTPUT_ARCH command can contain architecture valuse separated with ":", like:

OUTPUT_ARCH(i386:x86-64)

I think r294006 "Handle numbers followed by ":" in linker scripts." broke that,
because handles ":" as separate token. So now LLD does not accept that.

This trivial patch fixes the issue, now whole expression inside OUTPUT_ARCH is just ignored.

Diff Detail

Event Timeline

grimar created this revision.Feb 7 2017, 7:13 AM
grimar updated this revision to Diff 87429.Feb 7 2017, 7:16 AM
  • Removed llvm-readobj, probably no need to check output here.
ruiu added inline comments.Feb 7 2017, 7:29 AM
ELF/LinkerScript.cpp
1251–1254

This is too specific to your test case. In general, you want to skip until a matching closing parenthesis.

expect("(");
while (!Error && !consume(")")
  skip();
grimar added inline comments.Feb 7 2017, 7:40 AM
ELF/LinkerScript.cpp
1251–1254

That would conflict with testcase we have I think:

# RUN: echo "OUTPUT_ARCH(x, y)" > %t.script
# RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-freebsd %s -o %t1
# RUN: not ld.lld -shared -o %t2 %t1 %t.script
# RUN: llvm-readobj %t2 > /dev/null

Isn't that too permissive ?

ruiu added inline comments.Feb 7 2017, 8:19 AM
ELF/LinkerScript.cpp
1251–1254

No, since we do not really parse it, tweaking this too hard to adopt existing test cases doesn't make much sense.

grimar updated this revision to Diff 87467.Feb 7 2017, 9:13 AM
grimar edited the summary of this revision. (Show Details)
  • Addressed review comments.
grimar updated this revision to Diff 87468.Feb 7 2017, 9:15 AM
  • Simplified testcase.
ruiu accepted this revision.Feb 7 2017, 1:47 PM

LGTM

ELF/LinkerScript.cpp
1249

// OUTPUT_ARCH is ignored for now.

This revision is now accepted and ready to land.Feb 7 2017, 1:47 PM
This revision was automatically updated to reflect the committed changes.