Merge "Fix protected symbol lookups for mips"
This commit is contained in:
commit
f3392791bc
@ -187,6 +187,11 @@ typedef struct {
|
|||||||
#define STT_LOPROC 13
|
#define STT_LOPROC 13
|
||||||
#define STT_HIPROC 15
|
#define STT_HIPROC 15
|
||||||
|
|
||||||
|
#define STV_DEFAULT 0
|
||||||
|
#define STV_INTERNAL 1
|
||||||
|
#define STV_HIDDEN 2
|
||||||
|
#define STV_PROTECTED 3
|
||||||
|
|
||||||
/* The kernel uses NT_PRFPREG but glibc also offers NT_FPREGSET */
|
/* The kernel uses NT_PRFPREG but glibc also offers NT_FPREGSET */
|
||||||
#define NT_FPREGSET NT_PRFPREG
|
#define NT_FPREGSET NT_PRFPREG
|
||||||
|
|
||||||
|
@ -157,20 +157,34 @@ bool soinfo::mips_relocate_got(const VersionTracker& version_tracker,
|
|||||||
soinfo* lsi = nullptr;
|
soinfo* lsi = nullptr;
|
||||||
const ElfW(Sym)* s = nullptr;
|
const ElfW(Sym)* s = nullptr;
|
||||||
|
|
||||||
const version_info* vi = nullptr;
|
ElfW(Word) st_visibility = (local_sym->st_other & 0x3);
|
||||||
|
|
||||||
if (!lookup_version_info(version_tracker, sym, sym_name, &vi)) {
|
if (st_visibility == STV_DEFAULT) {
|
||||||
return false;
|
const version_info* vi = nullptr;
|
||||||
}
|
|
||||||
|
|
||||||
if (!soinfo_do_lookup(this, sym_name, vi, &lsi, global_group, local_group, &s)) {
|
if (!lookup_version_info(version_tracker, sym, sym_name, &vi)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!soinfo_do_lookup(this, sym_name, vi, &lsi, global_group, local_group, &s)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
} else if (st_visibility == STV_PROTECTED) {
|
||||||
|
if (local_sym->st_value == 0) {
|
||||||
|
DL_ERR("%s: invalid symbol \"%s\" (PROTECTED/UNDEFINED) ", get_soname(), sym_name);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
s = local_sym;
|
||||||
|
lsi = this;
|
||||||
|
} else {
|
||||||
|
DL_ERR("%s: invalid symbol \"%s\" visibility: 0x%x", get_soname(), sym_name, st_visibility);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (s == nullptr) {
|
if (s == nullptr) {
|
||||||
// We only allow an undefined symbol if this is a weak reference.
|
// We only allow an undefined symbol if this is a weak reference.
|
||||||
if (ELF_ST_BIND(local_sym->st_info) != STB_WEAK) {
|
if (ELF_ST_BIND(local_sym->st_info) != STB_WEAK) {
|
||||||
DL_ERR("cannot locate \"%s\"...", sym_name);
|
DL_ERR("%s: cannot locate \"%s\"...", get_soname(), sym_name);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
*got = 0;
|
*got = 0;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user