diff options
Diffstat (limited to 'src/env')
-rw-r--r-- | src/env/__init_security.c | 19 | ||||
-rw-r--r-- | src/env/__init_tls.c | 11 | ||||
-rw-r--r-- | src/env/__libc_start_main.c | 26 | ||||
-rw-r--r-- | src/env/__stack_chk_fail.c | 5 |
4 files changed, 30 insertions, 31 deletions
diff --git a/src/env/__init_security.c b/src/env/__init_security.c index f9de9c62..91b9b100 100644 --- a/src/env/__init_security.c +++ b/src/env/__init_security.c @@ -6,31 +6,26 @@ #include "libc.h" #include "atomic.h" -#define AUX_CNT 24 - -static void dummy(size_t *auxv) +static void dummy(void *ent) { } weak_alias(dummy, __init_ssp); -void __init_security(size_t *auxv) +void __init_security(size_t *aux) { - size_t i, aux[AUX_CNT] = { 0 }; struct pollfd pfd[3] = { {.fd=0}, {.fd=1}, {.fd=2} }; + int i; #ifndef SHARED - __init_ssp(auxv); + __init_ssp((void *)aux[AT_RANDOM]); #endif - for (; auxv[0]; auxv+=2) if (auxv[0]<AUX_CNT) aux[auxv[0]] = auxv[1]; - __hwcap = aux[AT_HWCAP]; if (aux[AT_UID]==aux[AT_EUID] && aux[AT_GID]==aux[AT_EGID] && !aux[AT_SECURE]) return; __syscall(SYS_poll, pfd, 3, 0); - for (i=0; i<3; i++) - if (pfd[i].revents&POLLNVAL) - if (__syscall(SYS_open, "/dev/null", O_RDWR|O_LARGEFILE)<0) - a_crash(); + for (i=0; i<3; i++) if (pfd[i].revents&POLLNVAL) + if (__syscall(SYS_open, "/dev/null", O_RDWR|O_LARGEFILE)<0) + a_crash(); libc.secure = 1; } diff --git a/src/env/__init_tls.c b/src/env/__init_tls.c index 6b3cd28b..e70025d7 100644 --- a/src/env/__init_tls.c +++ b/src/env/__init_tls.c @@ -46,19 +46,14 @@ typedef Elf32_Phdr Phdr; typedef Elf64_Phdr Phdr; #endif -#define AUX_CNT 6 - -void __init_tls(size_t *auxv) +void __init_tls(size_t *aux) { - size_t i, aux[AUX_CNT] = { 0 }; unsigned char *p, *mem; size_t n, d; Phdr *phdr, *tls_phdr=0; size_t base = 0; - for (; auxv[0]; auxv+=2) if (auxv[0]<AUX_CNT) aux[auxv[0]] = auxv[1]; - p = (void *)aux[AT_PHDR]; - for (p=(void *)aux[AT_PHDR]; aux[AT_PHNUM]--; p+=aux[AT_PHENT]) { + for (p=(void *)aux[AT_PHDR],n=aux[AT_PHNUM]; n; n--,p+=aux[AT_PHENT]) { phdr = (void *)p; if (phdr->p_type == PT_PHDR) base = aux[AT_PHDR] - phdr->p_vaddr; @@ -79,8 +74,6 @@ void __init_tls(size_t *auxv) mem = __mmap(0, libc.tls_size, PROT_READ|PROT_WRITE, MAP_ANONYMOUS|MAP_PRIVATE, -1, 0); - if (mem == MAP_FAILED) a_crash(); - if (!__install_initial_tls(__copy_tls(mem))) a_crash(); } #else diff --git a/src/env/__libc_start_main.c b/src/env/__libc_start_main.c index a38569d5..07613a52 100644 --- a/src/env/__libc_start_main.c +++ b/src/env/__libc_start_main.c @@ -1,24 +1,36 @@ +#include <elf.h> #include "libc.h" void __init_tls(size_t *); void __init_security(size_t *); +#define AUX_CNT 38 + +void __init_libc(char **envp) +{ + size_t i, *auxv, aux[AUX_CNT]; + __environ = envp; + for (i=0; envp[i]; i++); + libc.auxv = auxv = (void *)(envp+i+1); + for (i=0; auxv[i]; i+=2) if (auxv[i]<AUX_CNT) aux[auxv[i]] = auxv[i+1]; + __hwcap = aux[AT_HWCAP]; + + __init_tls(aux); + __init_security(aux); +} + int __libc_start_main( int (*main)(int, char **, char **), int argc, char **argv, int (*init)(int, char **, char **), void (*fini)(void), void (*ldso_fini)(void)) { - char **envp = argv+argc+1, **auxv = envp; + char **envp = argv+argc+1; + + __init_libc(envp); - __environ = envp; - do auxv++; while (*auxv); - libc.auxv = (void *)++auxv; libc.ldso_fini = ldso_fini; libc.fini = fini; - __init_tls((void *)auxv); - __init_security((void *)auxv); - /* Execute constructors (static) linked into the application */ if (init) init(argc, argv, envp); diff --git a/src/env/__stack_chk_fail.c b/src/env/__stack_chk_fail.c index eac852b7..3e2e4b6d 100644 --- a/src/env/__stack_chk_fail.c +++ b/src/env/__stack_chk_fail.c @@ -6,13 +6,12 @@ uintptr_t __stack_chk_guard; -void __init_ssp(size_t *auxv) +void __init_ssp(void *entropy) { size_t i; pthread_t self = __pthread_self_init(); uintptr_t canary; - for (i=0; auxv[i] && auxv[i]!=AT_RANDOM; i+=2); - if (auxv[i]) memcpy(&canary, (void *)auxv[i+1], sizeof canary); + if (entropy) memcpy(&canary, entropy, sizeof canary); else canary = (uintptr_t)&canary * 1103515245; a_cas_l(&__stack_chk_guard, 0, canary); self->canary = __stack_chk_guard; |