From 96ecd8625552cd5b4545783db52c0696ded9df93 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Timo=20Ter=C3=A4s?= Date: Fri, 20 Jun 2014 14:05:55 +0300 Subject: main/musl: upgrade to latest git snapshot, fix gethostby*_r error path upstream changes include tlsdesc (gnutls2) support for x86 and x86_64 as well as various optimizations and bug fixes. --- main/musl/0002-66fcde4a-to-3fa2eb2a.patch | 1194 ++++++++++++++++++++ ...ethostby-_r-result-pointer-value-on-error.patch | 43 + main/musl/APKBUILD | 10 +- 3 files changed, 1246 insertions(+), 1 deletion(-) create mode 100644 main/musl/0002-66fcde4a-to-3fa2eb2a.patch create mode 100644 main/musl/1003-fix-gethostby-_r-result-pointer-value-on-error.patch (limited to 'main') diff --git a/main/musl/0002-66fcde4a-to-3fa2eb2a.patch b/main/musl/0002-66fcde4a-to-3fa2eb2a.patch new file mode 100644 index 0000000000..5b30442f06 --- /dev/null +++ b/main/musl/0002-66fcde4a-to-3fa2eb2a.patch @@ -0,0 +1,1194 @@ +diff --git a/Makefile b/Makefile +index 0ab0bfd..d5a64fc 100644 +--- a/Makefile ++++ b/Makefile +@@ -125,7 +125,7 @@ $(foreach s,$(wildcard src/*/$(ARCH)*/*.s),$(eval $(call mkasmdep,$(s)))) + + lib/libc.so: $(LOBJS) + $(CC) $(CFLAGS_ALL_SHARED) $(LDFLAGS) -nostdlib -shared \ +- -Wl,-e,_start -Wl,-Bsymbolic-functions \ ++ -Wl,-e,_dlstart -Wl,-Bsymbolic-functions \ + -o $@ $(LOBJS) $(LIBCC) + + lib/libc.a: $(OBJS) +diff --git a/arch/arm/reloc.h b/arch/arm/reloc.h +index 264b7ab..ee39b7f 100644 +--- a/arch/arm/reloc.h ++++ b/arch/arm/reloc.h +@@ -16,41 +16,29 @@ + + #define LDSO_ARCH "arm" ENDIAN_SUFFIX FP_SUFFIX + +-#define IS_COPY(x) ((x)==R_ARM_COPY) +-#define IS_PLT(x) ((x)==R_ARM_JUMP_SLOT) ++#define NO_LEGACY_INITFINI ++ ++#define TPOFF_K 8 + +-static inline void 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, +- struct symdef def, size_t sym_val) ++static int remap_rel(int type) + { + switch(type) { + case R_ARM_ABS32: +- *reloc_addr += sym_val; +- break; ++ return REL_SYMBOLIC; + case R_ARM_GLOB_DAT: ++ return REL_GOT; + case R_ARM_JUMP_SLOT: +- *reloc_addr = sym_val; +- break; ++ return REL_PLT; + case R_ARM_RELATIVE: +- *reloc_addr += (size_t)base_addr; +- break; ++ return REL_RELATIVE; + case R_ARM_COPY: +- memcpy(reloc_addr, (void *)sym_val, sym_size); +- break; ++ return REL_COPY; + case R_ARM_TLS_DTPMOD32: +- *reloc_addr = def.dso ? def.dso->tls_id : self->tls_id; +- break; ++ return REL_DTPMOD; + case R_ARM_TLS_DTPOFF32: +- *reloc_addr += def.sym->st_value; +- break; ++ return REL_DTPOFF; + case R_ARM_TLS_TPOFF32: +- *reloc_addr += def.sym +- ? def.sym->st_value + def.dso->tls_offset + 8 +- : self->tls_offset + 8; +- break; ++ return REL_TPOFF; + } ++ return 0; + } +- +-#define NO_LEGACY_INITFINI +diff --git a/arch/i386/reloc.h b/arch/i386/reloc.h +index 3923b54..eaf5aae 100644 +--- a/arch/i386/reloc.h ++++ b/arch/i386/reloc.h +@@ -3,47 +3,31 @@ + + #define LDSO_ARCH "i386" + +-#define IS_COPY(x) ((x)==R_386_COPY) +-#define IS_PLT(x) ((x)==R_386_JMP_SLOT) +- +-static inline void 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, +- struct symdef def, size_t sym_val) ++static int remap_rel(int type) + { + switch(type) { + case R_386_32: +- *reloc_addr += sym_val; +- break; ++ return REL_SYMBOLIC; + case R_386_PC32: +- *reloc_addr += sym_val - (size_t)reloc_addr; +- break; ++ return REL_OFFSET; + case R_386_GLOB_DAT: ++ return REL_GOT; + case R_386_JMP_SLOT: +- *reloc_addr = sym_val; +- break; ++ return REL_PLT; + case R_386_RELATIVE: +- *reloc_addr += (size_t)base_addr; +- break; ++ return REL_RELATIVE; + case R_386_COPY: +- memcpy(reloc_addr, (void *)sym_val, sym_size); +- break; ++ return REL_COPY; + case R_386_TLS_DTPMOD32: +- *reloc_addr = def.dso ? def.dso->tls_id : self->tls_id; +- break; ++ return REL_DTPMOD; + case R_386_TLS_DTPOFF32: +- *reloc_addr = def.sym->st_value; +- break; ++ return REL_DTPOFF; + case R_386_TLS_TPOFF: +- *reloc_addr += def.sym +- ? def.sym->st_value - def.dso->tls_offset +- : 0 - self->tls_offset; +- break; ++ return REL_TPOFF; + case R_386_TLS_TPOFF32: +- *reloc_addr += def.sym +- ? def.dso->tls_offset - def.sym->st_value +- : self->tls_offset; +- break; ++ return REL_TPOFF_NEG; ++ case R_386_TLS_DESC: ++ return REL_TLSDESC; + } ++ return 0; + } +diff --git a/arch/microblaze/reloc.h b/arch/microblaze/reloc.h +index 7bf3a5b..71a6219 100644 +--- a/arch/microblaze/reloc.h ++++ b/arch/microblaze/reloc.h +@@ -10,34 +10,27 @@ + + #define LDSO_ARCH "microblaze" ENDIAN_SUFFIX + +-#define IS_COPY(x) ((x)==R_MICROBLAZE_COPY) +-#define IS_PLT(x) ((x)==R_MICROBLAZE_JUMP_SLOT) ++#define TPOFF_K 0 + +-static inline void 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, +- struct symdef def, size_t sym_val) ++static int remap_rel(int type) + { + switch(type) { + case R_MICROBLAZE_32: ++ return REL_SYMBOLIC; + case R_MICROBLAZE_GLOB_DAT: ++ return REL_GOT; + case R_MICROBLAZE_JUMP_SLOT: +- *reloc_addr = sym_val + addend; +- break; ++ return REL_PLT; + case R_MICROBLAZE_REL: +- *reloc_addr = (size_t)base_addr + addend; +- break; ++ return REL_RELATIVE; + case R_MICROBLAZE_COPY: +- memcpy(reloc_addr, (void *)sym_val, sym_size); +- break; ++ return REL_COPY; + case R_MICROBLAZE_TLSDTPMOD32: +- *reloc_addr = def.dso ? def.dso->tls_id : self->tls_id; +- break; ++ return REL_DTPMOD; + case R_MICROBLAZE_TLSDTPREL32: +- *reloc_addr = def.sym->st_value + addend; +- break; ++ return REL_DTPOFF; + } ++ return 0; + } + + #include "syscall.h" +diff --git a/arch/mips/reloc.h b/arch/mips/reloc.h +index 4ca8125..91fa097 100644 +--- a/arch/mips/reloc.h ++++ b/arch/mips/reloc.h +@@ -16,38 +16,25 @@ + + #define LDSO_ARCH "mips" ENDIAN_SUFFIX FP_SUFFIX + +-#define IS_COPY(x) ((x)==R_MIPS_COPY) +-#define IS_PLT(x) 1 ++#define TPOFF_K (-0x7000) + +-static inline void 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, +- struct symdef def, size_t sym_val) ++static int remap_rel(int type) + { + switch(type) { +- case R_MIPS_JUMP_SLOT: +- *reloc_addr = sym_val; +- break; + case R_MIPS_REL32: +- if (sym_val) *reloc_addr += sym_val; +- else *reloc_addr += (size_t)base_addr; +- break; ++ return REL_SYM_OR_REL; ++ case R_MIPS_JUMP_SLOT: ++ return REL_PLT; + case R_MIPS_COPY: +- memcpy(reloc_addr, (void *)sym_val, sym_size); +- break; ++ return REL_COPY; + case R_MIPS_TLS_DTPMOD32: +- *reloc_addr = def.dso ? def.dso->tls_id : self->tls_id; +- break; ++ return REL_DTPMOD; + case R_MIPS_TLS_DTPREL32: +- *reloc_addr += def.sym->st_value; +- break; ++ return REL_DTPOFF; + case R_MIPS_TLS_TPREL32: +- *reloc_addr += def.sym +- ? def.sym->st_value + def.dso->tls_offset - 0x7000 +- : self->tls_offset - 0x7000; +- break; ++ return REL_TPOFF; + } ++ return 0; + } + + void __reloc_self(int c, size_t *a, size_t *dynv, size_t *got) +diff --git a/arch/powerpc/reloc.h b/arch/powerpc/reloc.h +index 38034c5..73c583b 100644 +--- a/arch/powerpc/reloc.h ++++ b/arch/powerpc/reloc.h +@@ -3,40 +3,29 @@ + + #define LDSO_ARCH "powerpc" + +-#define IS_COPY(x) ((x)==R_PPC_COPY) +-#define IS_PLT(x) ((x)==R_PPC_JMP_SLOT) ++#define TPOFF_K (-0x7000) + +-// see linux' arch/powerpc/include/asm/elf.h +-static inline void 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, +- struct symdef def, size_t sym_val) ++static int remap_rel(int type) + { + switch(type) { ++ case R_PPC_ADDR32: ++ return REL_SYMBOLIC; + case R_PPC_GLOB_DAT: ++ return REL_GOT; + case R_PPC_JMP_SLOT: +- case R_PPC_ADDR32: +- *reloc_addr = sym_val + addend; +- break; +- case R_PPC_COPY: +- memcpy(reloc_addr, (void *)sym_val, sym_size); +- break; ++ return REL_PLT; + case R_PPC_RELATIVE: +- *reloc_addr = (size_t)base_addr + addend; +- break; ++ return REL_RELATIVE; ++ case R_PPC_COPY: ++ return REL_COPY; + case R_PPC_DTPMOD32: +- *reloc_addr = def.dso ? def.dso->tls_id : self->tls_id; +- break; ++ return REL_DTPMOD; + case R_PPC_DTPREL32: +- *reloc_addr = def.sym->st_value + addend; +- break; ++ return REL_DTPOFF; + case R_PPC_TPREL32: +- *reloc_addr += def.sym +- ? def.sym->st_value + def.dso->tls_offset - 0x7000 +- : self->tls_offset - 0x7000; +- break; ++ return REL_TPOFF; + } ++ return 0; + } + + void __reloc_self(int c, size_t *a, size_t *dynv) +diff --git a/arch/sh/reloc.h b/arch/sh/reloc.h +index db3de08..aeb02d0 100644 +--- a/arch/sh/reloc.h ++++ b/arch/sh/reloc.h +@@ -6,42 +6,29 @@ + + #define LDSO_ARCH "sh" ENDIAN_SUFFIX + +-#define IS_COPY(x) ((x) == R_SH_COPY) +-#define IS_PLT(x) ((x) == R_SH_JMP_SLOT) ++#define TPOFF_K 8 + +-static inline void 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, +- struct symdef def, size_t sym_val) ++static int remap_rel(int type) + { + switch(type) { ++ case R_SH_DIR32: ++ return REL_SYMBOLIC; ++ case R_SH_REL32: ++ return REL_OFFSET; + case R_SH_GLOB_DAT: ++ return REL_GOT; + case R_SH_JMP_SLOT: +- *reloc_addr = sym_val; +- break; ++ return REL_PLT; + case R_SH_RELATIVE: +- *reloc_addr = (size_t)base_addr + addend; +- break; +- case R_SH_DIR32: +- *reloc_addr = sym_val + addend; +- break; +- case R_SH_REL32: +- *reloc_addr = sym_val + addend - (size_t)reloc_addr + (size_t)base_addr; +- break; ++ return REL_RELATIVE; + case R_SH_COPY: +- memcpy(reloc_addr, (void *)sym_val, sym_size); +- break; ++ return REL_COPY; + case R_SH_TLS_DTPMOD32: +- *reloc_addr += def.dso ? def.dso->tls_id : self->tls_id; +- break; ++ return REL_DTPMOD; + case R_SH_TLS_DTPOFF32: +- *reloc_addr += def.sym->st_value; +- break; ++ return REL_DTPOFF; + case R_SH_TLS_TPOFF32: +- *reloc_addr += def.sym +- ? def.sym->st_value + def.dso->tls_offset + 8 +- : self->tls_offset + 8; +- break; ++ return REL_TPOFF; + } ++ return 0; + } +diff --git a/arch/x32/reloc.h b/arch/x32/reloc.h +index f294eec..fcfbf99 100644 +--- a/arch/x32/reloc.h ++++ b/arch/x32/reloc.h +@@ -4,43 +4,37 @@ + + #define LDSO_ARCH "x32" + +-#define IS_COPY(x) ((x)==R_X86_64_COPY) +-#define IS_PLT(x) ((x)==R_X86_64_JUMP_SLOT) ++/* FIXME: x32 is very strange in its use of 64-bit relocation types in ++ * a 32-bit environment. As long as the memory at reloc_addr is ++ * zero-filled prior to relocations, just treating 64-bit relocations ++ * as operating on 32-bit slots should be fine, but this should be ++ * checked. In particular, R_X86_64_64, R_X86_64_DTPOFF64, and ++ * R_X86_64_TPOFF64 may need checking. */ + +-static inline void 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, +- struct symdef def, size_t sym_val) ++static int remap_rel(int type) + { + switch(type) { +- case R_X86_64_GLOB_DAT: +- case R_X86_64_JUMP_SLOT: + case R_X86_64_64: +- *reloc_addr = sym_val + addend; +- break; + case R_X86_64_32: +- *(uint32_t *)reloc_addr = sym_val + addend; +- break; ++ return REL_SYMBOLIC; + case R_X86_64_PC32: +- *reloc_addr = sym_val + addend - (size_t)reloc_addr + (size_t)base_addr; +- break; ++ return REL_OFFSET; ++ case R_X86_64_GLOB_DAT: ++ return REL_GOT; ++ case R_X86_64_JUMP_SLOT: ++ return REL_PLT; + case R_X86_64_RELATIVE: +- *reloc_addr = (size_t)base_addr + addend; +- break; ++ return REL_RELATIVE; + case R_X86_64_COPY: +- memcpy(reloc_addr, (void *)sym_val, sym_size); +- break; ++ return REL_COPY; + case R_X86_64_DTPMOD64: +- *reloc_addr = def.dso ? def.dso->tls_id : self->tls_id; +- break; ++ return REL_DTPMOD; + case R_X86_64_DTPOFF64: +- *reloc_addr = def.sym->st_value + addend; +- break; ++ case R_X86_64_DTPOFF32: ++ return REL_DTPOFF; + case R_X86_64_TPOFF64: +- *reloc_addr = (def.sym +- ? def.sym->st_value - def.dso->tls_offset +- : 0 - self->tls_offset) + addend; +- break; ++ case R_X86_64_TPOFF32: ++ return REL_TPOFF; + } ++ return 0; + } +diff --git a/arch/x86_64/reloc.h b/arch/x86_64/reloc.h +index 28cf7cc..9bc5849 100644 +--- a/arch/x86_64/reloc.h ++++ b/arch/x86_64/reloc.h +@@ -4,43 +4,29 @@ + + #define LDSO_ARCH "x86_64" + +-#define IS_COPY(x) ((x)==R_X86_64_COPY) +-#define IS_PLT(x) ((x)==R_X86_64_JUMP_SLOT) +- +-static inline void 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, +- struct symdef def, size_t sym_val) ++static int remap_rel(int type) + { + switch(type) { +- case R_X86_64_GLOB_DAT: +- case R_X86_64_JUMP_SLOT: + case R_X86_64_64: +- *reloc_addr = sym_val + addend; +- break; +- case R_X86_64_32: +- *(uint32_t *)reloc_addr = sym_val + addend; +- break; ++ return REL_SYMBOLIC; + case R_X86_64_PC32: +- *reloc_addr = sym_val + addend - (size_t)reloc_addr + (size_t)base_addr; +- break; ++ return REL_OFFSET32; ++ case R_X86_64_GLOB_DAT: ++ return REL_GOT; ++ case R_X86_64_JUMP_SLOT: ++ return REL_PLT; + case R_X86_64_RELATIVE: +- *reloc_addr = (size_t)base_addr + addend; +- break; ++ return REL_RELATIVE; + case R_X86_64_COPY: +- memcpy(reloc_addr, (void *)sym_val, sym_size); +- break; ++ return REL_COPY; + case R_X86_64_DTPMOD64: +- *reloc_addr = def.dso ? def.dso->tls_id : self->tls_id; +- break; ++ return REL_DTPMOD; + case R_X86_64_DTPOFF64: +- *reloc_addr = def.sym->st_value + addend; +- break; ++ return REL_DTPOFF; + case R_X86_64_TPOFF64: +- *reloc_addr = (def.sym +- ? def.sym->st_value - def.dso->tls_offset +- : 0 - self->tls_offset) + addend; +- break; ++ return REL_TPOFF; ++ case R_X86_64_TLSDESC: ++ return REL_TLSDESC; + } ++ return 0; + } +diff --git a/include/sys/socket.h b/include/sys/socket.h +index d752791..b911d6e 100644 +--- a/include/sys/socket.h ++++ b/include/sys/socket.h +@@ -26,6 +26,17 @@ struct ucred + uid_t uid; + gid_t gid; + }; ++ ++struct mmsghdr ++{ ++ struct msghdr msg_hdr; ++ unsigned int msg_len; ++}; ++ ++struct timespec; ++ ++int sendmmsg (int, struct mmsghdr *, unsigned int, unsigned int); ++int recvmmsg (int, struct mmsghdr *, unsigned int, unsigned int, struct timespec *); + #endif + + struct linger +diff --git a/src/env/__init_tls.c b/src/env/__init_tls.c +index f7eab8d..13cf2ee 100644 +--- a/src/env/__init_tls.c ++++ b/src/env/__init_tls.c +@@ -53,11 +53,6 @@ void *__copy_tls(unsigned char *mem) + return td; + } + +-void *__tls_get_addr(size_t *v) +-{ +- return (char *)__pthread_self()->dtv[1]+v[1]; +-} +- + #if ULONG_MAX == 0xffffffff + typedef Elf32_Phdr Phdr; + #else +diff --git a/src/ldso/arm/start.s b/src/ldso/arm/start.s +index dfa3657..5dd93b5 100644 +--- a/src/ldso/arm/start.s ++++ b/src/ldso/arm/start.s +@@ -1,6 +1,6 @@ + .text +-.global _start +-_start: ++.global _dlstart ++_dlstart: + ldr r0,[sp] + add r1,sp,#4 + bl __dynlink +diff --git a/src/ldso/dynlink.c b/src/ldso/dynlink.c +index 1cb3fb4..bc4f2f6 100644 +--- a/src/ldso/dynlink.c ++++ b/src/ldso/dynlink.c +@@ -1,6 +1,8 @@ + #define _GNU_SOURCE + #include + #include ++#include ++#include + #include + #include + #include +@@ -48,6 +50,11 @@ struct debug { + void *base; + }; + ++struct td_index { ++ size_t args[2]; ++ struct td_index *next; ++}; ++ + struct dso { + unsigned char *base; + char *name; +@@ -79,6 +86,7 @@ struct dso { + void **new_dtv; + unsigned char *new_tls; + int new_dtv_idx, new_tls_idx; ++ struct td_index *td_index; + struct dso *fini_next; + char *shortname; + char buf[]; +@@ -89,6 +97,24 @@ struct symdef { + struct dso *dso; + }; + ++enum { ++ REL_ERR, ++ REL_SYMBOLIC, ++ REL_GOT, ++ REL_PLT, ++ REL_RELATIVE, ++ REL_OFFSET, ++ REL_OFFSET32, ++ REL_COPY, ++ REL_SYM_OR_REL, ++ REL_TLS, /* everything past here is TLS */ ++ REL_DTPMOD, ++ REL_DTPOFF, ++ REL_TPOFF, ++ REL_TPOFF_NEG, ++ REL_TLSDESC, ++}; ++ + #include "reloc.h" + + int __init_tp(void *); +@@ -107,6 +133,7 @@ static jmp_buf *rtld_fail; + static pthread_rwlock_t lock; + static struct debug debug; + static size_t tls_cnt, tls_offset, tls_align = 4*sizeof(size_t); ++static size_t static_tls_cnt; + static pthread_mutex_t init_fini_lock = { ._m_type = PTHREAD_MUTEX_RECURSIVE }; + static long long builtin_tls[(sizeof(struct pthread) + 64)/sizeof(long long)]; + +@@ -132,6 +159,17 @@ static int search_vec(size_t *v, size_t *r, size_t key) + return 1; + } + ++static void error(const char *fmt, ...) ++{ ++ va_list ap; ++ va_start(ap, fmt); ++ vsnprintf(errbuf, sizeof errbuf, fmt, ap); ++ va_end(ap); ++ if (runtime) longjmp(*rtld_fail, 1); ++ dprintf(2, "%s\n", errbuf); ++ ldso_fail = 1; ++} ++ + static uint32_t sysv_hash(const char *s0) + { + const unsigned char *s = (void *)s0; +@@ -227,6 +265,10 @@ static struct symdef find_sym(struct dso *dso, const char *s, int need_def) + return def; + } + ++#define NO_INLINE_ADDEND (1<base; +@@ -235,36 +277,116 @@ static void do_relocs(struct dso *dso, size_t *rel, size_t rel_size, size_t stri + Sym *sym; + const char *name; + void *ctx; +- int type; ++ int astype, type; + int sym_index; + struct symdef def; ++ size_t *reloc_addr; ++ size_t sym_val; ++ size_t tls_val; ++ size_t addend; + + for (; rel_size; rel+=stride, rel_size-=stride*sizeof(size_t)) { +- type = R_TYPE(rel[1]); ++ astype = R_TYPE(rel[1]); ++ if (!astype) continue; ++ type = remap_rel(astype); ++ if (!type) { ++ error(errbuf, sizeof errbuf, ++ "Error relocating %s: unsupported relocation type %d", ++ dso->name, astype); ++ continue; ++ } + sym_index = R_SYM(rel[1]); ++ reloc_addr = (void *)(base + rel[0]); + if (sym_index) { + sym = syms + sym_index; + name = strings + sym->st_name; +- ctx = IS_COPY(type) ? head->next : head; +- def = find_sym(ctx, name, IS_PLT(type)); ++ ctx = type==REL_COPY ? head->next : head; ++ def = find_sym(ctx, name, type==REL_PLT); + if (!def.sym && (sym->st_shndx != SHN_UNDEF + || sym->st_info>>4 != STB_WEAK)) { +- snprintf(errbuf, sizeof errbuf, ++ error(errbuf, sizeof errbuf, + "Error relocating %s: %s: symbol not found", + dso->name, name); +- if (runtime) longjmp(*rtld_fail, 1); +- dprintf(2, "%s\n", errbuf); +- ldso_fail = 1; + continue; + } + } else { + sym = 0; + def.sym = 0; +- def.dso = 0; ++ def.dso = dso; ++ } ++ ++ addend = stride>2 ? rel[2] ++ : (1<base+def.sym->st_value : 0; ++ tls_val = def.sym ? def.sym->st_value : 0; ++ ++ switch(type) { ++ case REL_OFFSET: ++ addend -= (size_t)reloc_addr; ++ case REL_SYMBOLIC: ++ case REL_GOT: ++ case REL_PLT: ++ *reloc_addr = sym_val + addend; ++ break; ++ case REL_RELATIVE: ++ *reloc_addr = (size_t)base + addend; ++ break; ++ case REL_SYM_OR_REL: ++ if (sym) *reloc_addr = sym_val + addend; ++ else *reloc_addr = (size_t)base + addend; ++ break; ++ case REL_COPY: ++ memcpy(reloc_addr, (void *)sym_val, sym->st_size); ++ break; ++ case REL_OFFSET32: ++ *(uint32_t *)reloc_addr = sym_val + addend ++ - (size_t)reloc_addr; ++ break; ++ case REL_DTPMOD: ++ *reloc_addr = def.dso->tls_id; ++ break; ++ case REL_DTPOFF: ++ *reloc_addr = tls_val + addend; ++ break; ++#ifdef TLS_ABOVE_TP ++ case REL_TPOFF: ++ *reloc_addr = tls_val + def.dso->tls_offset + TPOFF_K + addend; ++ break; ++#else ++ case REL_TPOFF: ++ *reloc_addr = tls_val - def.dso->tls_offset + addend; ++ break; ++ case REL_TPOFF_NEG: ++ *reloc_addr = def.dso->tls_offset - tls_val + addend; ++ break; ++#endif ++ case REL_TLSDESC: ++ if (stride<3) addend = reloc_addr[1]; ++ if (runtime && def.dso->tls_id >= static_tls_cnt) { ++ struct td_index *new = malloc(sizeof *new); ++ if (!new) error(errbuf, sizeof errbuf, ++ "Error relocating %s: cannot allocate TLSDESC for %s", ++ dso->name, sym ? name : "(local)" ); ++ new->next = dso->td_index; ++ dso->td_index = new; ++ new->args[0] = def.dso->tls_id; ++ new->args[1] = tls_val + addend; ++ reloc_addr[0] = (size_t)__tlsdesc_dynamic; ++ reloc_addr[1] = (size_t)new; ++ } else { ++ reloc_addr[0] = (size_t)__tlsdesc_static; ++#ifdef TLS_ABOVE_TP ++ reloc_addr[1] = tls_val + def.dso->tls_offset ++ + TPOFF_K + addend; ++#else ++ reloc_addr[1] = tls_val - def.dso->tls_offset ++ + addend; ++#endif ++ } ++ break; + } +- do_single_reloc(dso, base, (void *)(base + rel[0]), type, +- stride>2 ? rel[2] : 0, sym, sym?sym->st_size:0, def, +- def.sym?(size_t)(def.dso->base+def.sym->st_value):0); + } + } + +@@ -717,12 +839,9 @@ static void load_deps(struct dso *p) + if (p->dynv[i] != DT_NEEDED) continue; + dep = load_library(p->strings + p->dynv[i+1], p); + if (!dep) { +- snprintf(errbuf, sizeof errbuf, ++ error(errbuf, sizeof errbuf, + "Error loading shared library %s: %m (needed by %s)", + p->strings + p->dynv[i+1], p->name); +- if (runtime) longjmp(*rtld_fail, 1); +- dprintf(2, "%s\n", errbuf); +- ldso_fail = 1; + continue; + } + if (runtime) { +@@ -771,12 +890,9 @@ static void reloc_all(struct dso *p) + + if (p->relro_start != p->relro_end && + mprotect(p->base+p->relro_start, p->relro_end-p->relro_start, PROT_READ) < 0) { +- snprintf(errbuf, sizeof errbuf, ++ error(errbuf, sizeof errbuf, + "Error relocating %s: RELRO protection failed: %m", + p->name); +- if (runtime) longjmp(*rtld_fail, 1); +- dprintf(2, "%s\n", errbuf); +- ldso_fail = 1; + } + + p->relocated = 1; +@@ -915,17 +1031,15 @@ void *__copy_tls(unsigned char *mem) + return td; + } + +-void *__tls_get_addr(size_t *v) ++void *__tls_get_new(size_t *v) + { + pthread_t self = __pthread_self(); +- if (v[0]<=(size_t)self->dtv[0] && self->dtv[v[0]]) +- return (char *)self->dtv[v[0]]+v[1]; + + /* Block signals to make accessing new TLS async-signal-safe */ + sigset_t set; +- pthread_sigmask(SIG_BLOCK, SIGALL_SET, &set); +- if (v[0]<=(size_t)self->dtv[0] && self->dtv[v[0]]) { +- pthread_sigmask(SIG_SETMASK, &set, 0); ++ __block_all_sigs(&set); ++ if (v[0]<=(size_t)self->dtv[0]) { ++ __restore_sigs(&set); + return (char *)self->dtv[v[0]]+v[1]; + } + +@@ -946,13 +1060,19 @@ void *__tls_get_addr(size_t *v) + self->dtv = newdtv; + } + +- /* Get new TLS memory from new DSO */ +- unsigned char *mem = p->new_tls + +- (p->tls_size + p->tls_align) * a_fetch_add(&p->new_tls_idx,1); +- mem += ((uintptr_t)p->tls_image - (uintptr_t)mem) & (p->tls_align-1); +- self->dtv[v[0]] = mem; +- memcpy(mem, p->tls_image, p->tls_len); +- pthread_sigmask(SIG_SETMASK, &set, 0); ++ /* Get new TLS memory from all new DSOs up to the requested one */ ++ unsigned char *mem; ++ for (p=head; ; p=p->next) { ++ if (!p->tls_id || self->dtv[p->tls_id]) continue; ++ mem = p->new_tls + (p->tls_size + p->tls_align) ++ * a_fetch_add(&p->new_tls_idx,1); ++ mem += ((uintptr_t)p->tls_image - (uintptr_t)mem) ++ & (p->tls_align-1); ++ self->dtv[p->tls_id] = mem; ++ memcpy(mem, p->tls_image, p->tls_len); ++ if (p->tls_id == v[0]) break; ++ } ++ __restore_sigs(&set); + return mem + v[1]; + } + +@@ -1196,6 +1316,7 @@ void *__dynlink(int argc, char **argv) + dprintf(2, "%s: Thread-local storage not supported by kernel.\n", argv[0]); + _exit(127); + } ++ static_tls_cnt = tls_cnt; + + if (ldso_fail) _exit(127); + if (ldd_mode) _exit(0); +@@ -1251,6 +1372,11 @@ void *dlopen(const char *file, int mode) + for (p=orig_tail->next; p; p=next) { + next = p->next; + munmap(p->map, p->map_len); ++ while (p->td_index) { ++ void *tmp = p->td_index->next; ++ free(p->td_index); ++ p->td_index = tmp; ++ } + free(p->deps); + free(p); + } +@@ -1314,6 +1440,8 @@ static int invalid_dso_handle(void *h) + return 1; + } + ++void *__tls_get_addr(size_t *); ++ + static void *do_dlsym(struct dso *p, const char *s, void *ra) + { + size_t i; +diff --git a/src/ldso/i386/start.s b/src/ldso/i386/start.s +index b16f8af..c37a1fa 100644 +--- a/src/ldso/i386/start.s ++++ b/src/ldso/i386/start.s +@@ -1,6 +1,6 @@ + .text +-.global _start +-_start: ++.global _dlstart ++_dlstart: + xor %ebp,%ebp + pop %edi + mov %esp,%esi +diff --git a/src/ldso/i386/tlsdesc.s b/src/ldso/i386/tlsdesc.s +new file mode 100644 +index 0000000..3ac6129 +--- /dev/null ++++ b/src/ldso/i386/tlsdesc.s +@@ -0,0 +1,27 @@ ++.text ++.global __tlsdesc_static ++.type __tlsdesc_static,@function ++__tlsdesc_static: ++ mov 4(%eax),%eax ++ ret ++ ++.global __tlsdesc_dynamic ++.type __tlsdesc_dynamic,@function ++__tlsdesc_dynamic: ++ mov 4(%eax),%eax ++ push %edx ++ mov %gs:4,%edx ++ push %ecx ++ mov (%eax),%ecx ++ cmp %ecx,(%edx) ++ jc 1f ++ mov 4(%eax),%eax ++ add (%edx,%ecx,4),%eax ++2: pop %ecx ++ sub %gs:0,%eax ++ pop %edx ++ ret ++1: push %eax ++ call __tls_get_addr ++ pop %ecx ++ jmp 2b +diff --git a/src/ldso/microblaze/start.s b/src/ldso/microblaze/start.s +index 4e0a0e5..067e861 100644 +--- a/src/ldso/microblaze/start.s ++++ b/src/ldso/microblaze/start.s +@@ -1,6 +1,6 @@ + # FIXME: clearing argv entries +-.global _start +-_start: ++.global _dlstart ++_dlstart: + add r19, r0, r0 + + lw r5, r0, r1 +diff --git a/src/ldso/mips/start.s b/src/ldso/mips/start.s +index 2e98529..0cadbf8 100644 +--- a/src/ldso/mips/start.s ++++ b/src/ldso/mips/start.s +@@ -2,9 +2,9 @@ + .hidden __reloc_self + .set noreorder + .set nomacro +-.global _start +-.type _start,@function +-_start: ++.global _dlstart ++.type _dlstart,@function ++_dlstart: + move $fp, $0 + + bgezal $0, 1f +diff --git a/src/ldso/powerpc/start.s b/src/ldso/powerpc/start.s +index 6c499e8..6548d58 100644 +--- a/src/ldso/powerpc/start.s ++++ b/src/ldso/powerpc/start.s +@@ -1,6 +1,6 @@ +- .global _start +- .type _start,@function +-_start: ++ .global _dlstart ++ .type _dlstart,@function ++_dlstart: + bl 1f + 2: .long _DYNAMIC-2b + 1: mflr 5 +diff --git a/src/ldso/sh/start.s b/src/ldso/sh/start.s +index ca6b7fc..0d2d913 100644 +--- a/src/ldso/sh/start.s ++++ b/src/ldso/sh/start.s +@@ -1,7 +1,7 @@ + .text +-.global _start +-.type _start, @function +-_start: ++.global _dlstart ++.type _dlstart, @function ++_dlstart: + mov.l @r15, r4 + mov r15, r5 + mov.l L1, r0 +diff --git a/src/ldso/tlsdesc.c b/src/ldso/tlsdesc.c +new file mode 100644 +index 0000000..031b5b8 +--- /dev/null ++++ b/src/ldso/tlsdesc.c +@@ -0,0 +1,13 @@ ++#ifdef SHARED ++ ++#include ++#include "libc.h" ++ ++ptrdiff_t __tlsdesc_static() ++{ ++ return 0; ++} ++ ++weak_alias(__tlsdesc_static, __tlsdesc_dynamic); ++ ++#endif +diff --git a/src/ldso/x32/start.s b/src/ldso/x32/start.s +index 0fcf46d..3c3800a 100644 +--- a/src/ldso/x32/start.s ++++ b/src/ldso/x32/start.s +@@ -1,6 +1,6 @@ + .text +-.global _start +-_start: ++.global _dlstart ++_dlstart: + mov (%rsp),%rdi /* move argc into 1st argument slot */ + lea 4(%rsp),%rsi /* move argv into 2nd argument slot */ + call __dynlink +diff --git a/src/ldso/x86_64/start.s b/src/ldso/x86_64/start.s +index 80c1d08..1c5598a 100644 +--- a/src/ldso/x86_64/start.s ++++ b/src/ldso/x86_64/start.s +@@ -1,6 +1,6 @@ + .text +-.global _start +-_start: ++.global _dlstart ++_dlstart: + mov (%rsp),%rdi + lea 8(%rsp),%rsi + call __dynlink +diff --git a/src/ldso/x86_64/tlsdesc.s b/src/ldso/x86_64/tlsdesc.s +new file mode 100644 +index 0000000..57b78e0 +--- /dev/null ++++ b/src/ldso/x86_64/tlsdesc.s +@@ -0,0 +1,40 @@ ++.text ++.global __tlsdesc_static ++.type __tlsdesc_static,@function ++__tlsdesc_static: ++ mov 8(%rax),%rax ++ ret ++ ++.global __tlsdesc_dynamic ++.type __tlsdesc_dynamic,@function ++__tlsdesc_dynamic: ++ mov 8(%rax),%rax ++ push %rdx ++ mov %fs:8,%rdx ++ push %rcx ++ mov (%rax),%rcx ++ cmp %rcx,(%rdx) ++ jc 1f ++ mov 8(%rax),%rax ++ add (%rdx,%rcx,8),%rax ++2: pop %rcx ++ sub %fs:0,%rax ++ pop %rdx ++ ret ++1: push %rdi ++ push %rdi ++ push %rsi ++ push %r8 ++ push %r9 ++ push %r10 ++ push %r11 ++ mov %rax,%rdi ++ call __tls_get_addr ++ pop %r11 ++ pop %r10 ++ pop %r9 ++ pop %r8 ++ pop %rsi ++ pop %rdi ++ pop %rdi ++ jmp 2b +diff --git a/src/linux/fanotify.c b/src/linux/fanotify.c +index 1f4ef93..c6211af 100644 +--- a/src/linux/fanotify.c ++++ b/src/linux/fanotify.c +@@ -9,6 +9,6 @@ int fanotify_init(unsigned flags, unsigned event_f_flags) + int fanotify_mark(int fanotify_fd, unsigned flags, unsigned long long mask, + int dfd, const char *pathname) + { +- return syscall(SYS_fanotify_mark, flags, __SYSCALL_LL_O(mask), dfd, pathname); ++ return syscall(SYS_fanotify_mark, fanotify_fd, flags, __SYSCALL_LL_E(mask), dfd, pathname); + } + +diff --git a/src/network/recvmmsg.c b/src/network/recvmmsg.c +new file mode 100644 +index 0000000..58b1b2f +--- /dev/null ++++ b/src/network/recvmmsg.c +@@ -0,0 +1,15 @@ ++#define _GNU_SOURCE ++#include ++#include ++#include "syscall.h" ++ ++int recvmmsg(int fd, struct mmsghdr *msgvec, unsigned int vlen, unsigned int flags, struct timespec *timeout) ++{ ++#if LONG_MAX > INT_MAX ++ struct mmsghdr *mh = msgvec; ++ unsigned int i; ++ for (i = vlen; i; i--, mh++) ++ mh->msg_hdr.__pad1 = mh->msg_hdr.__pad2 = 0; ++#endif ++ return syscall_cp(SYS_recvmmsg, fd, msgvec, vlen, flags, timeout); ++} +diff --git a/src/network/sendmmsg.c b/src/network/sendmmsg.c +new file mode 100644 +index 0000000..ff9f861 +--- /dev/null ++++ b/src/network/sendmmsg.c +@@ -0,0 +1,29 @@ ++#define _GNU_SOURCE ++#include ++#include ++#include ++#include "syscall.h" ++ ++int sendmmsg(int fd, struct mmsghdr *msgvec, unsigned int vlen, unsigned int flags) ++{ ++#if LONG_MAX > INT_MAX ++ /* Can't use the syscall directly because the kernel has the wrong ++ * idea for the types of msg_iovlen, msg_controllen, and cmsg_len, ++ * and the cmsg blocks cannot be modified in-place. */ ++ int i; ++ if (vlen > IOV_MAX) vlen = IOV_MAX; /* This matches the kernel. */ ++ for (i=0; i ++#include "pthread_impl.h" ++#include "libc.h" ++ ++void *__tls_get_new(size_t *) ATTR_LIBC_VISIBILITY; ++ ++void *__tls_get_addr(size_t *v) ++{ ++ pthread_t self = __pthread_self(); ++#ifdef SHARED ++ if (v[0]<=(size_t)self->dtv[0]) ++ return (char *)self->dtv[v[0]]+v[1]; ++ return __tls_get_new(v); ++#else ++ return (char *)self->dtv[1]+v[1]; ++#endif ++} +diff --git a/src/thread/i386/tls.s b/src/thread/i386/tls.s +index e1f2262..6e01adf 100644 +--- a/src/thread/i386/tls.s ++++ b/src/thread/i386/tls.s +@@ -2,7 +2,14 @@ + .global ___tls_get_addr + .type ___tls_get_addr,@function + ___tls_get_addr: +- push %eax ++ mov %gs:4,%edx ++ mov (%eax),%ecx ++ cmp %ecx,(%edx) ++ jc 1f ++ mov 4(%eax),%eax ++ add (%edx,%ecx,4),%eax ++ ret ++1: push %eax + call __tls_get_addr + pop %edx + ret diff --git a/main/musl/1003-fix-gethostby-_r-result-pointer-value-on-error.patch b/main/musl/1003-fix-gethostby-_r-result-pointer-value-on-error.patch new file mode 100644 index 0000000000..e753d7edee --- /dev/null +++ b/main/musl/1003-fix-gethostby-_r-result-pointer-value-on-error.patch @@ -0,0 +1,43 @@ +From a9c5a6208a5afdfbc3f9855887ad39b0d1921514 Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Timo=20Ter=C3=A4s?= +Date: Fri, 20 Jun 2014 13:53:23 +0300 +Subject: [PATCH] fix gethostby*_r result pointer value on error + +man-pages states that the GNU extension functions gethostbyaddr_r, +gethostbyname_r and gethostbyname2_r are guaranteed to set result +pointer to NULL in case of error or no result. E.g. openjdk7 can +crash unless this is not done (it checks for result pointer value +only and ignores the returned error code). +--- + src/network/gethostbyaddr_r.c | 2 ++ + src/network/gethostbyname2_r.c | 1 + + 2 files changed, 3 insertions(+) + +diff --git a/src/network/gethostbyaddr_r.c b/src/network/gethostbyaddr_r.c +index 73e7644..66e0330 100644 +--- a/src/network/gethostbyaddr_r.c ++++ b/src/network/gethostbyaddr_r.c +@@ -18,6 +18,8 @@ int gethostbyaddr_r(const void *a, socklen_t l, int af, + socklen_t sl = af==AF_INET6 ? sizeof sa.sin6 : sizeof sa.sin; + int i; + ++ *res = 0; ++ + /* Load address argument into sockaddr structure */ + if (af==AF_INET6 && l==16) memcpy(&sa.sin6.sin6_addr, a, 16); + else if (af==AF_INET && l==4) memcpy(&sa.sin.sin_addr, a, 4); +diff --git a/src/network/gethostbyname2_r.c b/src/network/gethostbyname2_r.c +index aa8b0a9..81f71d2 100644 +--- a/src/network/gethostbyname2_r.c ++++ b/src/network/gethostbyname2_r.c +@@ -17,6 +17,7 @@ int gethostbyname2_r(const char *name, int af, + int i, cnt; + size_t align, need; + ++ *res = 0; + cnt = __lookup_name(addrs, canon, name, af, AI_CANONNAME); + if (cnt<0) switch (cnt) { + case EAI_NONAME: +-- +2.0.0 + diff --git a/main/musl/APKBUILD b/main/musl/APKBUILD index b0974483f2..22f31c60b9 100644 --- a/main/musl/APKBUILD +++ b/main/musl/APKBUILD @@ -2,7 +2,7 @@ # Maintainer: Timo Teräs pkgname=musl pkgver=1.1.2 -pkgrel=2 +pkgrel=3 pkgdesc="the musl c library (libc) implementation" url="http://www.musl-libc.org/" arch="all" @@ -14,8 +14,10 @@ install="$pkgname.post-upgrade" subpackages="$pkgname-dev $pkgname-utils" source="http://www.musl-libc.org/releases/musl-$pkgver.tar.gz 0001-v1.1.2-to-66fcde4a.patch + 0002-66fcde4a-to-3fa2eb2a.patch 1001-add-basic-dns-record-parsing-functions.patch 1002-reimplement-if_nameindex-and-getifaddrs-using-netlin.patch + 1003-fix-gethostby-_r-result-pointer-value-on-error.patch ldconfig getopt_long.c @@ -118,8 +120,10 @@ utils() { md5sums="a81309e54efdf9c68baf679790fc5678 musl-1.1.2.tar.gz a6a1f5c4f34f80cb1fd4c6e1b7936013 0001-v1.1.2-to-66fcde4a.patch +3a852204b383784506d861b3a307b939 0002-66fcde4a-to-3fa2eb2a.patch a3810683ef61ac27e2f6ec9801280c81 1001-add-basic-dns-record-parsing-functions.patch 83c3bd2a50b1de5ef948704d3f4e0583 1002-reimplement-if_nameindex-and-getifaddrs-using-netlin.patch +b0102f0fb7acda7fca9d93932d144a2b 1003-fix-gethostby-_r-result-pointer-value-on-error.patch 013be8897f27c3909ada59c62020502f ldconfig 61c6c1e84ed1df82abbe6d75e90cf21c getopt_long.c 0df687757221bbb0fc1aa67f1bd646f9 __stack_chk_fail_local.c @@ -128,8 +132,10 @@ cb82d21fed17a116b44b830adba71c5a getconf.c 45f92f8d59cf84d765de698a9578dbf4 iconv.c" sha256sums="dac94112b9a22d2657cd3f36ca0d62ee1eb10707a22bfc97d5746147ef92852b musl-1.1.2.tar.gz 2cd863b8a7d4af3d592607b20479163c1a011cf5a458cf7f0dc2dc9c08f5b57c 0001-v1.1.2-to-66fcde4a.patch +0c09923f514729533992f251b7eaa776c414373b3fa20ec2274257c29323028d 0002-66fcde4a-to-3fa2eb2a.patch 758390768b1bc4159d56908ca332b9640cd0552ed3b4b2b8d4a6d499c54c11a1 1001-add-basic-dns-record-parsing-functions.patch 1c25880095e869b827f02997e864fdf4bf157a4e923e52d97dbd05e657aedb70 1002-reimplement-if_nameindex-and-getifaddrs-using-netlin.patch +5cca6e1b1ab896d47acf48d5f9c0b255191859b6cbeff74d99343d839d088132 1003-fix-gethostby-_r-result-pointer-value-on-error.patch 398dc26ec82cc6af056c738e8ac62da212ba978229d9839eb8b61f7ce536da4a ldconfig d9b644ec20bc33e81a7c52b9fcf7973d835923a69faf50f03db45534b811bd96 getopt_long.c 299a7d75a09de3e2e11e7fb4acc3182e4a14e868093d2f30938fce9bfcff13da __stack_chk_fail_local.c @@ -138,8 +144,10 @@ d9b644ec20bc33e81a7c52b9fcf7973d835923a69faf50f03db45534b811bd96 getopt_long.c f79a2930a2e5bb0624321589edf8b889d1e9b603e01e6b7ae214616605b3fdd7 iconv.c" sha512sums="54d279efea6e122567c936e47401df5c0f1493c42eb3199b0ba3053b1882a864fc1a71d19ad945bc4f328407231c54a7897413e37f4bc33337a243c044a26b4a musl-1.1.2.tar.gz 631b93b875d0b4451e8ab4587d4cd495617fe4b8627387bb7d19af5e9b354ae726e91b24abea87acc63f9b30ea55e1f65d87cf8ecfba2c69e0cdcdab15d84fa9 0001-v1.1.2-to-66fcde4a.patch +a29bc04846875ce54f00ce14c11dfc0075ace05acd15c7c95a14c639fd02d6dad7c57f1fbffea85984d13c089d2620e25238ee377041cf15c742b831c8a1e6f2 0002-66fcde4a-to-3fa2eb2a.patch dad965258daf69371b844f76bfe5a914b0eca0ca76f3fc340b8fd7acf598b5f87bbe6d68b1f43ed0293ee0ed3bfd85d5173ccc169aa6265646248d5b8a906708 1001-add-basic-dns-record-parsing-functions.patch 72cf33738d2cf31f6ec02312bc494d754c17470b519172bb8bd7e2e29ac3b119023088a2b3fbc0dbc2fddd0078ccbae62096106cae361f8c31d6a9950043af25 1002-reimplement-if_nameindex-and-getifaddrs-using-netlin.patch +faa7c2b944d643f271f797077cef9368e16f38bc83a5f96ab18a9e58e781020a06fab7b8fd0622d5394f6a8e5a98ae99784dd994185ceb1c55f5000c734b7a9e 1003-fix-gethostby-_r-result-pointer-value-on-error.patch 33e13d2242063f3dc9ec199ae9528e469a52ccae4d3726faa3c866e0c7dcf546f69294f9c00307324cee05fd965f84350ae100b8b1138f9d9c8c916de04ab0d1 ldconfig 140f3f20d30bd95ebce8c41b8cc7f616c6cbedf4ea06c729c21014e74f6043796825cc40ebc5180620ea38173afdba23f09ebf6d8b11fa05440b14d23764fca9 getopt_long.c 062bb49fa54839010acd4af113e20f7263dde1c8a2ca359b5fb2661ef9ed9d84a0f7c3bc10c25dcfa10bb3c5a4874588dff636ac43d5dbb3d748d75400756d0b __stack_chk_fail_local.c -- cgit v1.2.3