Commit b916dc19 authored by Russ Cox's avatar Russ Cox

liblink: more precise literal word comparison on arm

There are fields in the Addr that do not matter for the
purpose of deciding that the same word is already
in the current literal pool. Copy only the fields that
do matter.

This came up when comparing against the Go version
because the way it is invoked doesn't copy a few fields
(like node) that are never directly used by liblink itself.

Also remove a stray print that is not well-defined in
the new liblink. (Cannot use %D outside of %P, because
%D needs the outer Prog*.)

LGTM=minux
R=minux
CC=golang-codereviews
https://golang.org/cl/119000043
parent d4d50b5f
...@@ -953,7 +953,11 @@ addpool(Link *ctxt, Prog *p, Addr *a) ...@@ -953,7 +953,11 @@ addpool(Link *ctxt, Prog *p, Addr *a)
switch(c) { switch(c) {
default: default:
t.to = *a; t.to.offset = a->offset;
t.to.sym = a->sym;
t.to.type = a->type;
t.to.name = a->name;
if(ctxt->flag_shared && t.to.sym != nil) if(ctxt->flag_shared && t.to.sym != nil)
t.pcrel = p; t.pcrel = p;
break; break;
...@@ -1102,7 +1106,6 @@ aclass(Link *ctxt, Addr *a) ...@@ -1102,7 +1106,6 @@ aclass(Link *ctxt, Addr *a)
case D_STATIC: case D_STATIC:
if(a->sym == 0 || a->sym->name == 0) { if(a->sym == 0 || a->sym->name == 0) {
print("null sym external\n"); print("null sym external\n");
print("%D\n", a);
return C_GOK; return C_GOK;
} }
ctxt->instoffset = 0; // s.b. unused but just in case ctxt->instoffset = 0; // s.b. unused but just in case
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment