123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 |
- .section ".tbss", "awT", @nobits
- .globl bg1, bg2, bg3, bg4, bg5, bg6, bg7, bg8
- bg1: .space 4
- bg2: .space 4
- bg3: .space 4
- bg4: .space 4
- bg5: .space 4
- bg6: .space 4
- bg7: .space 4
- bg8: .space 4
- bl1: .space 4
- bl2: .space 4
- bl3: .space 4
- bl4: .space 4
- bl5: .space 4
- bl6: .space 4
- bl7: .space 4
- bl8: .space 4
- .text
- .globl _start
- .type _start,@function
- _start:
- pushq %rbp
- movq %rsp, %rbp
- /* IE against global var */
- movq %fs:0, %r11
- nop;nop
- addq sG6@gottpoff(%rip), %r11
- nop;nop;nop;nop
- /* IE -> LE against global var defined in exec */
- movq %fs:0, %rdx
- nop;nop
- addq bg6@gottpoff(%rip), %rdx
- nop;nop;nop;nop
- /* IE -> LE against local var */
- movq %fs:0, %r12
- nop;nop
- addq bl6@gottpoff(%rip), %r12
- nop;nop;nop;nop
- /* direct %fs access IE -> LE against local var */
- movq bl8@gottpoff(%rip), %rdx
- nop;nop
- movq %fs:(%rdx), %rax
- nop;nop;nop;nop
- /* IE -> LE against hidden but not local var */
- movq %fs:0, %rdx
- nop;nop
- addq sh6@gottpoff(%rip), %rdx
- nop;nop;nop;nop
- /* direct %fs access IE -> LE against hidden but not local var */
- movq sh8@gottpoff(%rip), %rdx
- nop;nop
- movq %fs:(%rdx), %rax
- nop;nop;nop;nop
- /* LE, global var defined in exec */
- movq %fs:0, %rax
- nop;nop
- leaq sg2@tpoff(%rax), %rdx
- nop;nop;nop;nop
- /* LE, local var, non-canonical sequence */
- movq $2+bl2@tpoff, %r9
- nop;nop
- movq %fs:0, %rdx
- nop;nop
- addq %r9, %rdx
- nop;nop;nop;nop
- /* LE, hidden var defined in exec, non-canonical sequence */
- movq %fs:0, %rdx
- nop;nop
- addq $sh2@tpoff+1, %rdx
- nop;nop;nop;nop
- /* Direct %fs access */
- /* LE, global var defined in exec */
- movq %fs:sg3@tpoff, %rax
- nop;nop;nop;nop
- /* LE, local var */
- movq %fs:bl3@tpoff+3, %r10
- nop;nop;nop;nop
- /* LE, hidden var defined in exec */
- movq %fs:1+sh3@tpoff, %rdx
- nop;nop;nop;nop
- /* LE, large model */
- movabsq $sh2@tpoff+1, %rdx
- leave
- ret
|