summaryrefslogtreecommitdiff
path: root/arch/mips
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2014-06-16 03:09:07 -0400
committerRich Felker <dalias@aerifal.cx>2014-06-16 03:09:07 -0400
commitbfa09700b927c99cff5263483c1d7a4d1fe766e5 (patch)
tree2cb41b425402212a2916e00d3108edd045552664 /arch/mips
parent4e5c7a2176773c9a1564c6603240337b3ad6b496 (diff)
downloadmusl-bfa09700b927c99cff5263483c1d7a4d1fe766e5.tar.gz
musl-bfa09700b927c99cff5263483c1d7a4d1fe766e5.tar.bz2
musl-bfa09700b927c99cff5263483c1d7a4d1fe766e5.tar.xz
musl-bfa09700b927c99cff5263483c1d7a4d1fe766e5.zip
dynamic linker: permit error returns from arch-specific reloc function
the immediate motivation is supporting TLSDESC relocations which require allocation and thus may fail (unless we pre-allocate), but this mechanism should also be used for throwing an error on unsupported or invalid relocation types, and perhaps in certain cases, for reporting when a relocation is not satisfiable.
Diffstat (limited to 'arch/mips')
-rw-r--r--arch/mips/reloc.h3
1 files changed, 2 insertions, 1 deletions
diff --git a/arch/mips/reloc.h b/arch/mips/reloc.h
index 4ca81257..08d139da 100644
--- a/arch/mips/reloc.h
+++ b/arch/mips/reloc.h
@@ -19,7 +19,7 @@
#define IS_COPY(x) ((x)==R_MIPS_COPY)
#define IS_PLT(x) 1
-static inline void do_single_reloc(
+static inline int do_single_reloc(
struct dso *self, unsigned char *base_addr,
size_t *reloc_addr, int type, size_t addend,
Sym *sym, size_t sym_size,
@@ -48,6 +48,7 @@ static inline void do_single_reloc(
: self->tls_offset - 0x7000;
break;
}
+ return 0;
}
void __reloc_self(int c, size_t *a, size_t *dynv, size_t *got)