mirror of
https://github.com/mirror/tinycc.git
synced 2024-12-28 04:00:06 +08:00
macos: Fix GOT access to local defined symbols
if a GOT slot is required (due to codegen, indicated by presence of some relocation types), then it needs to contain the address of the wanted symbol, also when it's local and defined, i.e. not overridable. For simplicity we use a GOT slot for that as well (other storage would require rewriting relocs and symbols, as resolving of GOT relocs is hardwired to be based on s1->got). But that means we need to fill in its indirect symbol mapping slot as well, for which Mach-O provides a mean to say "not symbol based, resolved locally". So this fixes this testcase: static int loc; int _start(void) { loc = 42; return loc - 42; } (where our codegen currently uses a GOT-based access for the write by accident)
This commit is contained in:
parent
6ebd463021
commit
fab8787b23
10
tccmacho.c
10
tccmacho.c
@ -321,6 +321,16 @@ static void check_relocs(TCCState *s1, struct macho *mo)
|
||||
attr->got_offset = s1->got->data_offset;
|
||||
attr->plt_offset = 1; /* used as flag */
|
||||
section_ptr_add(s1->got, PTR_SIZE);
|
||||
if (ELFW(ST_BIND)(sym->st_info) == STB_LOCAL) {
|
||||
if (sym->st_shndx == SHN_UNDEF)
|
||||
tcc_error("undefined local symbol???");
|
||||
*pi = 0x80000000; /* INDIRECT_SYMBOL_LOCAL */
|
||||
/* The pointer slot we generated must point to the
|
||||
symbol, whose address is only known after layout,
|
||||
so register a simply relocation for that. */
|
||||
put_elf_reloc (s1->symtab, s1->got, attr->got_offset,
|
||||
R_DATA_PTR, sym_index);
|
||||
} else
|
||||
*pi = mo->e2msym[sym_index];
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user