consistently use hidden visibility for cancellable syscall internals
authorRich Felker <dalias@aerifal.cx>
Tue, 14 Apr 2015 15:18:59 +0000 (11:18 -0400)
committerRich Felker <dalias@aerifal.cx>
Tue, 14 Apr 2015 15:18:59 +0000 (11:18 -0400)
in a few places, non-hidden symbols were referenced from asm in ways
that assumed ld-time binding. while these is no semantic reason these
symbols need to be hidden, fixing the references without making them
hidden was going to be ugly, and hidden reduces some bloat anyway.

in the asm files, .global/.hidden directives have been moved to the
top to unclutter the actual code.

12 files changed:
arch/x32/src/syscall_cp_fixup.c
src/thread/aarch64/syscall_cp.s
src/thread/arm/syscall_cp.s
src/thread/i386/syscall_cp.s
src/thread/microblaze/syscall_cp.s
src/thread/mips/syscall_cp.s
src/thread/or1k/syscall_cp.s
src/thread/powerpc/syscall_cp.s
src/thread/pthread_cancel.c
src/thread/sh/syscall_cp.s
src/thread/x32/syscall_cp.s
src/thread/x86_64/syscall_cp.s

index 470597d13c1e7ef5f49a85a66b50d76bd669c82f..07d39b527d7b3547516bf06f18ce223319fb1993 100644 (file)
@@ -1,4 +1,8 @@
 #include <sys/syscall.h>
+
+#ifdef SHARED
+__attribute__((__visibility__("hidden")))
+#endif
 long __syscall_cp_internal(volatile void*, long long, long long, long long, long long,
                              long long, long long, long long);
 
@@ -8,6 +12,9 @@ struct __timespec_kernel { long long tv_sec; long long tv_nsec; };
 #define __fixup(X) do { if(X) X = (unsigned long) (&(struct __timespec_kernel) \
                    { .tv_sec = __tsc(X)->tv_sec, .tv_nsec = __tsc(X)->tv_nsec}); } while(0)
 
+#ifdef SHARED
+__attribute__((__visibility__("hidden")))
+#endif
 long __syscall_cp_asm (volatile void * foo, long long n, long long a1, long long a2, long long a3,
                             long long a4, long long a5, long long a6) {
        switch (n) {
index 6302a0bdebd70c24cf5951cfeaa8fe5b3b0632c3..30e677ce522fe48949f08e423800988f2b8434d8 100644 (file)
@@ -4,10 +4,17 @@
 // syscall(nr, u, v, w, x, y, z)
 //         x8  x0 x1 x2 x3 x4 x5
 
+.global __cp_begin
+.hidden __cp_begin
+.global __cp_end
+.hidden __cp_end
+.global __cp_cancel
+.hidden __cp_cancel
+.hidden __cancel
 .global __syscall_cp_asm
+.hidden __syscall_cp_asm
 .type __syscall_cp_asm,%function
 __syscall_cp_asm:
-.global __cp_begin
 __cp_begin:
        ldr w0,[x0]
        cbnz w0,1f
@@ -19,7 +26,6 @@ __cp_begin:
        mov x4,x6
        mov x5,x7
        svc 0
-.global __cp_end
 __cp_end:
        ret
 
index 66c5ecbd5f5e16e05fde427af7649fd037c40fbe..96ce6135ec14c5948c652ae87784970c1b6aff0b 100644 (file)
@@ -1,9 +1,16 @@
+.global __cp_begin
+.hidden __cp_begin
+.global __cp_end
+.hidden __cp_end
+.global __cp_cancel
+.hidden __cp_cancel
+.hidden __cancel
 .global __syscall_cp_asm
+.hidden __syscall_cp_asm
 .type __syscall_cp_asm,%function
 __syscall_cp_asm:
        mov ip,sp
        stmfd sp!,{r4,r5,r6,r7,lr}
-.global __cp_begin
 __cp_begin:
        ldr r0,[r0]
        cmp r0,#0
@@ -13,13 +20,11 @@ __cp_begin:
        mov r1,r3
        ldmfd ip,{r2,r3,r4,r5,r6}
        svc 0
-.global __cp_end
 __cp_end:
        ldmfd sp!,{r4,r5,r6,r7,lr}
        tst lr,#1
        moveq pc,lr
        bx lr
-.global __cp_cancel
 __cp_cancel:
        ldmfd sp!,{r4,r5,r6,r7,lr}
        b __cancel
index 71ce63f71575707a48219b95b4e6f2e0f124000f..7dce1eb3ae9ebc0c3d701567376adfeb4faf98f4 100644 (file)
@@ -1,5 +1,13 @@
 .text
+.global __cp_begin
+.hidden __cp_begin
+.global __cp_end
+.hidden __cp_end
+.global __cp_cancel
+.hidden __cp_cancel
+.hidden __cancel
 .global __syscall_cp_asm
+.hidden __syscall_cp_asm
 .type   __syscall_cp_asm,@function
 __syscall_cp_asm:
        mov 4(%esp),%ecx
@@ -7,7 +15,6 @@ __syscall_cp_asm:
        pushl %esi
        pushl %edi
        pushl %ebp
-.global __cp_begin
 __cp_begin:
        movl (%ecx),%eax
        testl %eax,%eax
@@ -20,14 +27,12 @@ __cp_begin:
        movl 44(%esp),%edi
        movl 48(%esp),%ebp
        int $128
-.global __cp_end
 __cp_end:
        popl %ebp
        popl %edi
        popl %esi
        popl %ebx
        ret
-.global __cp_cancel
 __cp_cancel:
        popl %ebp
        popl %edi
index ce38b56cefcce56aa5147e211e926133a2d31d5f..51599c912ac0a0e7fbf9e1840077aa69286d7839 100644 (file)
@@ -1,10 +1,17 @@
+.global __cp_begin
+.hidden __cp_begin
+.global __cp_end
+.hidden __cp_end
+.global __cp_cancel
+.hidden __cp_cancel
+.hidden __cancel
 .global __syscall_cp_asm
+.hidden __syscall_cp_asm
 .type   __syscall_cp_asm,@function
 __syscall_cp_asm:
-.global __cp_begin
 __cp_begin:
        lwi     r5, r5, 0
-       bnei    r5, __cancel@PLT
+       bnei    r5, __cancel
        addi    r12, r6, 0
        add     r5, r7, r0
        add     r6, r8, r0
@@ -13,7 +20,6 @@ __cp_begin:
        lwi     r9, r1, 28
        lwi     r10, r1, 32
        brki    r14, 0x8
-.global __cp_end
 __cp_end:
        rtsd    r15, 8
        nop
index d903794de305bf9f436c61204fd9c57dc6f03114..399289e3134b83125a75809a712802d8a3938d69 100644 (file)
@@ -1,10 +1,17 @@
 .set    noreorder
 
+.global __cp_begin
+.hidden __cp_begin
+.global __cp_end
+.hidden __cp_end
+.global __cp_cancel
+.hidden __cp_cancel
+.hidden __cancel
 .global __syscall_cp_asm
+.hidden __syscall_cp_asm
 .type   __syscall_cp_asm,@function
 __syscall_cp_asm:
        subu    $sp, $sp, 32
-.global __cp_begin
 __cp_begin:
        lw      $4, 0($4)
        bne     $4, $0, __cp_cancel
@@ -22,7 +29,6 @@ __cp_begin:
        sw      $2, 28($sp)
        lw      $2, 28($sp)
        syscall
-.global __cp_end
 __cp_end:
        beq     $7, $0, 1f
        addu    $sp, $sp, 32
@@ -30,7 +36,6 @@ __cp_end:
 1:     jr      $ra
        nop
 
-.global __cp_cancel
 __cp_cancel:
        addu    $sp, $sp, 32
        lw      $25, %call16(__cancel)($gp)
index 02d4cd7946726b189c65e3b39f2eae0596ebbef7..2c0bf0e8ff8f2e10ee1e98fe328d90521458898f 100644 (file)
@@ -1,11 +1,18 @@
+.global __cp_begin
+.hidden __cp_begin
+.global __cp_end
+.hidden __cp_end
+.global __cp_cancel
+.hidden __cp_cancel
+.hidden __cancel
 .global __syscall_cp_asm
+.hidden __syscall_cp_asm
 .type   __syscall_cp_asm,@function
 __syscall_cp_asm:
-.global __cp_begin
 __cp_begin:
        l.lwz   r3, 0(r3)
        l.sfeqi r3, 0
-       l.bnf   plt(__cancel)
+       l.bnf   __cancel
         l.ori  r11, r4, 0
        l.ori   r3, r5, 0
        l.ori   r4, r6, 0
@@ -14,7 +21,6 @@ __cp_begin:
        l.lwz   r7, 0(r1)
        l.lwz   r8, 4(r1)
        l.sys   1
-.global __cp_end
 __cp_end:
        l.jr    r9
         l.nop
index 0c7869cc19f07cc4caddcd752ebb7233fa62b2f7..20b5e0acc29d7804e9a174bff5d79dbc69e15709 100644 (file)
@@ -1,3 +1,13 @@
+.global __cp_begin
+.hidden __cp_begin
+.global __cp_end
+.hidden __cp_end
+.global __cp_cancel
+.hidden __cp_cancel
+.hidden __cancel
+.global __syscall_cp_asm
+.hidden __syscall_cp_asm
+
 #r0: volatile. may be modified during linkage.
 #r1: stack frame: 16 byte alignment.
 #r2: tls/thread pointer on pp32
 #the fields CR2,CR2,CR4 of the cond reg must be preserved
 #LR (link reg) shall contain the funcs return address
        .text
-       .global __syscall_cp_asm
        .type   __syscall_cp_asm,%function
 __syscall_cp_asm:
        # at enter: r3 = pointer to self->cancel, r4: syscall no, r5: first arg, r6: 2nd, r7: 3rd, r8: 4th, r9: 5th, r10: 6th
-       .global __cp_begin
 __cp_begin:
        # r3 holds first argument, its a pointer to self->cancel. 
        # we must compare the dereferenced value with 0 and jump to __cancel if its not
@@ -42,7 +50,6 @@ __cp_begin:
        mr      7, 9                  # arg5
        mr      8, 10                  # arg6
        sc
-       .global __cp_end
 __cp_end:
        bnslr+ # return if no summary overflow. 
        #else negate result.
index 7c5dda31b0b69f410ed201e4ef399c71e00ac481..fde090809c03b39e7226b8ac64701ca62e81231c 100644 (file)
@@ -3,7 +3,13 @@
 #include "syscall.h"
 #include "libc.h"
 
-long __cancel()
+#ifdef SHARED
+#define hidden __attribute__((__visibility__("hidden")))
+#else
+#define hidden
+#endif
+
+hidden long __cancel()
 {
        pthread_t self = __pthread_self();
        if (self->canceldisable == PTHREAD_CANCEL_ENABLE || self->cancelasync)
@@ -16,12 +22,14 @@ long __cancel()
  * definition of __cp_cancel to undo those adjustments and call __cancel.
  * Otherwise, __cancel provides a definition for __cp_cancel. */
 
-weak_alias(__cancel, __cp_cancel);
+hidden weak_alias(__cancel, __cp_cancel);
 
+hidden
 long __syscall_cp_asm(volatile void *, syscall_arg_t,
                       syscall_arg_t, syscall_arg_t, syscall_arg_t,
                       syscall_arg_t, syscall_arg_t, syscall_arg_t);
 
+hidden
 long __syscall_cp_c(syscall_arg_t nr,
                     syscall_arg_t u, syscall_arg_t v, syscall_arg_t w,
                     syscall_arg_t x, syscall_arg_t y, syscall_arg_t z)
@@ -52,7 +60,7 @@ static void cancel_handler(int sig, siginfo_t *si, void *ctx)
        pthread_t self = __pthread_self();
        ucontext_t *uc = ctx;
        const char *ip = ((char **)&uc->uc_mcontext)[CANCEL_REG_IP];
-       extern const char __cp_begin[1], __cp_end[1];
+       hidden extern const char __cp_begin[1], __cp_end[1];
 
        a_barrier();
        if (!self->cancel || self->canceldisable == PTHREAD_CANCEL_DISABLE) return;
index 5677b9c0a9a751819eaec9cd5c5b3e1562725fee..c783ca053e66c5766e5b231c24fccb132359f3fa 100644 (file)
@@ -1,9 +1,16 @@
 .text
+.global __cp_begin
+.hidden __cp_begin
+.global __cp_end
+.hidden __cp_end
+.global __cp_cancel
+.hidden __cp_cancel
+.hidden __cancel
 .global __syscall_cp_asm
+.hidden __syscall_cp_asm
 .type   __syscall_cp_asm, @function
 __syscall_cp_asm:
 
-.global __cp_begin
 __cp_begin:
        mov.l @r4, r4
        tst   r4, r4
@@ -15,7 +22,7 @@ __cp_begin:
 1:
 
 .align 2
-L1:    .long __cancel@PLT-(1b-.)
+L1:    .long __cancel-(1b-.)
 
 2:     mov   r5, r3
        mov   r6, r4
@@ -26,7 +33,6 @@ L1:   .long __cancel@PLT-(1b-.)
        mov.l @(12,r15), r1
        trapa #22
 
-.global __cp_end
 __cp_end:
        ! work around hardware bug
        or   r0, r0
index 70605c197b21f306a49325e78b5cc210135fe493..79709a550a2b36f2e7741eb377a0d401b72fd70e 100644 (file)
@@ -1,9 +1,16 @@
 .text
+.global __cp_begin
+.hidden __cp_begin
+.global __cp_end
+.hidden __cp_end
+.global __cp_cancel
+.hidden __cp_cancel
+.hidden __cancel
 .global __syscall_cp_internal
+.hidden __syscall_cp_internal
 .type   __syscall_cp_internal,@function
 __syscall_cp_internal:
 
-.global __cp_begin
 __cp_begin:
        mov (%rdi),%eax
        test %eax,%eax
@@ -18,6 +25,5 @@ __cp_begin:
        mov 16(%rsp),%r9
        mov %r11,8(%rsp)
        syscall
-.global __cp_end
 __cp_end:
        ret
index 788c53cc756fdf866a48c8e6ed6dea8f7a106e43..1a0fd5d20c7665bd431183718dce6d5ba0db4998 100644 (file)
@@ -1,9 +1,16 @@
 .text
+.global __cp_begin
+.hidden __cp_begin
+.global __cp_end
+.hidden __cp_end
+.global __cp_cancel
+.hidden __cp_cancel
+.hidden __cancel
 .global __syscall_cp_asm
+.hidden __syscall_cp_asm
 .type   __syscall_cp_asm,@function
 __syscall_cp_asm:
 
-.global __cp_begin
 __cp_begin:
        mov (%rdi),%eax
        test %eax,%eax
@@ -18,6 +25,5 @@ __cp_begin:
        mov 16(%rsp),%r9
        mov %r11,8(%rsp)
        syscall
-.global __cp_end
 __cp_end:
        ret