2012-09-08 08:43:18 +08:00
|
|
|
.file "x86cpuid.s"
|
|
|
|
.text
|
|
|
|
.globl _OPENSSL_ia32_cpuid
|
|
|
|
.align 4
|
|
|
|
_OPENSSL_ia32_cpuid:
|
|
|
|
L_OPENSSL_ia32_cpuid_begin:
|
|
|
|
pushl %ebp
|
|
|
|
pushl %ebx
|
|
|
|
pushl %esi
|
|
|
|
pushl %edi
|
|
|
|
xorl %edx,%edx
|
|
|
|
pushfl
|
|
|
|
popl %eax
|
|
|
|
movl %eax,%ecx
|
|
|
|
xorl $2097152,%eax
|
|
|
|
pushl %eax
|
|
|
|
popfl
|
|
|
|
pushfl
|
|
|
|
popl %eax
|
|
|
|
xorl %eax,%ecx
|
2013-04-26 20:49:54 +08:00
|
|
|
xorl %eax,%eax
|
2013-04-29 20:15:07 +08:00
|
|
|
btl $21,%ecx
|
|
|
|
jnc L000nocpuid
|
2012-09-08 08:43:18 +08:00
|
|
|
.byte 0x0f,0xa2
|
|
|
|
movl %eax,%edi
|
|
|
|
xorl %eax,%eax
|
|
|
|
cmpl $1970169159,%ebx
|
|
|
|
setne %al
|
|
|
|
movl %eax,%ebp
|
|
|
|
cmpl $1231384169,%edx
|
|
|
|
setne %al
|
|
|
|
orl %eax,%ebp
|
|
|
|
cmpl $1818588270,%ecx
|
|
|
|
setne %al
|
|
|
|
orl %eax,%ebp
|
|
|
|
jz L001intel
|
|
|
|
cmpl $1752462657,%ebx
|
|
|
|
setne %al
|
|
|
|
movl %eax,%esi
|
|
|
|
cmpl $1769238117,%edx
|
|
|
|
setne %al
|
|
|
|
orl %eax,%esi
|
|
|
|
cmpl $1145913699,%ecx
|
|
|
|
setne %al
|
|
|
|
orl %eax,%esi
|
|
|
|
jnz L001intel
|
|
|
|
movl $2147483648,%eax
|
|
|
|
.byte 0x0f,0xa2
|
2013-04-29 20:15:07 +08:00
|
|
|
cmpl $2147483649,%eax
|
|
|
|
jb L001intel
|
|
|
|
movl %eax,%esi
|
|
|
|
movl $2147483649,%eax
|
|
|
|
.byte 0x0f,0xa2
|
|
|
|
orl %ecx,%ebp
|
|
|
|
andl $2049,%ebp
|
|
|
|
cmpl $2147483656,%esi
|
2012-09-08 08:43:18 +08:00
|
|
|
jb L001intel
|
|
|
|
movl $2147483656,%eax
|
|
|
|
.byte 0x0f,0xa2
|
|
|
|
movzbl %cl,%esi
|
|
|
|
incl %esi
|
|
|
|
movl $1,%eax
|
|
|
|
.byte 0x0f,0xa2
|
|
|
|
btl $28,%edx
|
2013-04-29 20:15:07 +08:00
|
|
|
jnc L002generic
|
2012-09-08 08:43:18 +08:00
|
|
|
shrl $16,%ebx
|
|
|
|
andl $255,%ebx
|
|
|
|
cmpl %esi,%ebx
|
2013-04-29 20:15:07 +08:00
|
|
|
ja L002generic
|
2012-09-08 08:43:18 +08:00
|
|
|
andl $4026531839,%edx
|
2013-04-29 20:15:07 +08:00
|
|
|
jmp L002generic
|
2012-09-08 08:43:18 +08:00
|
|
|
L001intel:
|
|
|
|
cmpl $4,%edi
|
|
|
|
movl $-1,%edi
|
2013-04-29 20:15:07 +08:00
|
|
|
jb L003nocacheinfo
|
2012-09-08 08:43:18 +08:00
|
|
|
movl $4,%eax
|
|
|
|
movl $0,%ecx
|
|
|
|
.byte 0x0f,0xa2
|
|
|
|
movl %eax,%edi
|
|
|
|
shrl $14,%edi
|
|
|
|
andl $4095,%edi
|
2013-04-29 20:15:07 +08:00
|
|
|
L003nocacheinfo:
|
2012-09-08 08:43:18 +08:00
|
|
|
movl $1,%eax
|
|
|
|
.byte 0x0f,0xa2
|
2013-04-29 20:15:07 +08:00
|
|
|
andl $3220176895,%edx
|
2012-09-08 08:43:18 +08:00
|
|
|
cmpl $0,%ebp
|
2013-04-29 20:15:07 +08:00
|
|
|
jne L004notintel
|
|
|
|
orl $1073741824,%edx
|
2012-09-08 08:43:18 +08:00
|
|
|
andb $15,%ah
|
|
|
|
cmpb $15,%ah
|
2013-04-29 20:15:07 +08:00
|
|
|
jne L004notintel
|
2012-09-08 08:43:18 +08:00
|
|
|
orl $1048576,%edx
|
2013-04-29 20:15:07 +08:00
|
|
|
L004notintel:
|
2012-09-08 08:43:18 +08:00
|
|
|
btl $28,%edx
|
2013-04-29 20:15:07 +08:00
|
|
|
jnc L002generic
|
2012-09-08 08:43:18 +08:00
|
|
|
andl $4026531839,%edx
|
|
|
|
cmpl $0,%edi
|
2013-04-29 20:15:07 +08:00
|
|
|
je L002generic
|
2012-09-08 08:43:18 +08:00
|
|
|
orl $268435456,%edx
|
|
|
|
shrl $16,%ebx
|
|
|
|
cmpb $1,%bl
|
2013-04-29 20:15:07 +08:00
|
|
|
ja L002generic
|
2012-09-08 08:43:18 +08:00
|
|
|
andl $4026531839,%edx
|
2013-04-29 20:15:07 +08:00
|
|
|
L002generic:
|
|
|
|
andl $2048,%ebp
|
|
|
|
andl $4294965247,%ecx
|
|
|
|
movl %edx,%esi
|
|
|
|
orl %ecx,%ebp
|
|
|
|
btl $27,%ecx
|
|
|
|
jnc L005clear_avx
|
|
|
|
xorl %ecx,%ecx
|
|
|
|
.byte 15,1,208
|
|
|
|
andl $6,%eax
|
|
|
|
cmpl $6,%eax
|
|
|
|
je L006done
|
|
|
|
cmpl $2,%eax
|
|
|
|
je L005clear_avx
|
|
|
|
L007clear_xmm:
|
|
|
|
andl $4261412861,%ebp
|
|
|
|
andl $4278190079,%esi
|
|
|
|
L005clear_avx:
|
|
|
|
andl $4026525695,%ebp
|
|
|
|
L006done:
|
|
|
|
movl %esi,%eax
|
|
|
|
movl %ebp,%edx
|
|
|
|
L000nocpuid:
|
2012-09-08 08:43:18 +08:00
|
|
|
popl %edi
|
|
|
|
popl %esi
|
|
|
|
popl %ebx
|
|
|
|
popl %ebp
|
|
|
|
ret
|
|
|
|
.globl _OPENSSL_rdtsc
|
|
|
|
.align 4
|
|
|
|
_OPENSSL_rdtsc:
|
|
|
|
L_OPENSSL_rdtsc_begin:
|
|
|
|
xorl %eax,%eax
|
|
|
|
xorl %edx,%edx
|
2013-04-29 20:15:07 +08:00
|
|
|
call L008PIC_me_up
|
|
|
|
L008PIC_me_up:
|
|
|
|
popl %ecx
|
|
|
|
movl L_OPENSSL_ia32cap_P$non_lazy_ptr-L008PIC_me_up(%ecx),%ecx
|
2012-09-08 08:43:18 +08:00
|
|
|
btl $4,(%ecx)
|
2013-04-29 20:15:07 +08:00
|
|
|
jnc L009notsc
|
2012-09-08 08:43:18 +08:00
|
|
|
.byte 0x0f,0x31
|
2013-04-29 20:15:07 +08:00
|
|
|
L009notsc:
|
2012-09-08 08:43:18 +08:00
|
|
|
ret
|
|
|
|
.globl _OPENSSL_instrument_halt
|
|
|
|
.align 4
|
|
|
|
_OPENSSL_instrument_halt:
|
|
|
|
L_OPENSSL_instrument_halt_begin:
|
2013-04-29 20:15:07 +08:00
|
|
|
call L010PIC_me_up
|
|
|
|
L010PIC_me_up:
|
|
|
|
popl %ecx
|
|
|
|
movl L_OPENSSL_ia32cap_P$non_lazy_ptr-L010PIC_me_up(%ecx),%ecx
|
2012-09-08 08:43:18 +08:00
|
|
|
btl $4,(%ecx)
|
2013-04-29 20:15:07 +08:00
|
|
|
jnc L011nohalt
|
2012-09-08 08:43:18 +08:00
|
|
|
.long 2421723150
|
|
|
|
andl $3,%eax
|
2013-04-29 20:15:07 +08:00
|
|
|
jnz L011nohalt
|
2012-09-08 08:43:18 +08:00
|
|
|
pushfl
|
|
|
|
popl %eax
|
|
|
|
btl $9,%eax
|
2013-04-29 20:15:07 +08:00
|
|
|
jnc L011nohalt
|
2012-09-08 08:43:18 +08:00
|
|
|
.byte 0x0f,0x31
|
|
|
|
pushl %edx
|
|
|
|
pushl %eax
|
|
|
|
hlt
|
|
|
|
.byte 0x0f,0x31
|
|
|
|
subl (%esp),%eax
|
|
|
|
sbbl 4(%esp),%edx
|
|
|
|
addl $8,%esp
|
|
|
|
ret
|
2013-04-29 20:15:07 +08:00
|
|
|
L011nohalt:
|
2012-09-08 08:43:18 +08:00
|
|
|
xorl %eax,%eax
|
|
|
|
xorl %edx,%edx
|
|
|
|
ret
|
|
|
|
.globl _OPENSSL_far_spin
|
|
|
|
.align 4
|
|
|
|
_OPENSSL_far_spin:
|
|
|
|
L_OPENSSL_far_spin_begin:
|
|
|
|
pushfl
|
|
|
|
popl %eax
|
|
|
|
btl $9,%eax
|
2013-04-29 20:15:07 +08:00
|
|
|
jnc L012nospin
|
2012-09-08 08:43:18 +08:00
|
|
|
movl 4(%esp),%eax
|
|
|
|
movl 8(%esp),%ecx
|
|
|
|
.long 2430111262
|
|
|
|
xorl %eax,%eax
|
|
|
|
movl (%ecx),%edx
|
2013-04-29 20:15:07 +08:00
|
|
|
jmp L013spin
|
2012-09-08 08:43:18 +08:00
|
|
|
.align 4,0x90
|
2013-04-29 20:15:07 +08:00
|
|
|
L013spin:
|
2012-09-08 08:43:18 +08:00
|
|
|
incl %eax
|
|
|
|
cmpl (%ecx),%edx
|
2013-04-29 20:15:07 +08:00
|
|
|
je L013spin
|
2012-09-08 08:43:18 +08:00
|
|
|
.long 529567888
|
|
|
|
ret
|
2013-04-29 20:15:07 +08:00
|
|
|
L012nospin:
|
2012-09-08 08:43:18 +08:00
|
|
|
xorl %eax,%eax
|
|
|
|
xorl %edx,%edx
|
|
|
|
ret
|
|
|
|
.globl _OPENSSL_wipe_cpu
|
|
|
|
.align 4
|
|
|
|
_OPENSSL_wipe_cpu:
|
|
|
|
L_OPENSSL_wipe_cpu_begin:
|
|
|
|
xorl %eax,%eax
|
|
|
|
xorl %edx,%edx
|
2013-04-29 20:15:07 +08:00
|
|
|
call L014PIC_me_up
|
|
|
|
L014PIC_me_up:
|
|
|
|
popl %ecx
|
|
|
|
movl L_OPENSSL_ia32cap_P$non_lazy_ptr-L014PIC_me_up(%ecx),%ecx
|
2012-09-08 08:43:18 +08:00
|
|
|
movl (%ecx),%ecx
|
|
|
|
btl $1,(%ecx)
|
2013-04-29 20:15:07 +08:00
|
|
|
jnc L015no_x87
|
2012-09-08 08:43:18 +08:00
|
|
|
.long 4007259865,4007259865,4007259865,4007259865,2430851995
|
2013-04-29 20:15:07 +08:00
|
|
|
L015no_x87:
|
2012-09-08 08:43:18 +08:00
|
|
|
leal 4(%esp),%eax
|
|
|
|
ret
|
|
|
|
.globl _OPENSSL_atomic_add
|
|
|
|
.align 4
|
|
|
|
_OPENSSL_atomic_add:
|
|
|
|
L_OPENSSL_atomic_add_begin:
|
|
|
|
movl 4(%esp),%edx
|
|
|
|
movl 8(%esp),%ecx
|
|
|
|
pushl %ebx
|
|
|
|
nop
|
|
|
|
movl (%edx),%eax
|
2013-04-29 20:15:07 +08:00
|
|
|
L016spin:
|
2012-09-08 08:43:18 +08:00
|
|
|
leal (%eax,%ecx,1),%ebx
|
|
|
|
nop
|
|
|
|
.long 447811568
|
2013-04-29 20:15:07 +08:00
|
|
|
jne L016spin
|
2012-09-08 08:43:18 +08:00
|
|
|
movl %ebx,%eax
|
|
|
|
popl %ebx
|
|
|
|
ret
|
|
|
|
.globl _OPENSSL_indirect_call
|
|
|
|
.align 4
|
|
|
|
_OPENSSL_indirect_call:
|
|
|
|
L_OPENSSL_indirect_call_begin:
|
|
|
|
pushl %ebp
|
|
|
|
movl %esp,%ebp
|
|
|
|
subl $28,%esp
|
|
|
|
movl 12(%ebp),%ecx
|
|
|
|
movl %ecx,(%esp)
|
|
|
|
movl 16(%ebp),%edx
|
|
|
|
movl %edx,4(%esp)
|
|
|
|
movl 20(%ebp),%eax
|
|
|
|
movl %eax,8(%esp)
|
|
|
|
movl 24(%ebp),%eax
|
|
|
|
movl %eax,12(%esp)
|
|
|
|
movl 28(%ebp),%eax
|
|
|
|
movl %eax,16(%esp)
|
|
|
|
movl 32(%ebp),%eax
|
|
|
|
movl %eax,20(%esp)
|
|
|
|
movl 36(%ebp),%eax
|
|
|
|
movl %eax,24(%esp)
|
|
|
|
call *8(%ebp)
|
|
|
|
movl %ebp,%esp
|
|
|
|
popl %ebp
|
|
|
|
ret
|
|
|
|
.globl _OPENSSL_cleanse
|
|
|
|
.align 4
|
|
|
|
_OPENSSL_cleanse:
|
|
|
|
L_OPENSSL_cleanse_begin:
|
|
|
|
movl 4(%esp),%edx
|
|
|
|
movl 8(%esp),%ecx
|
|
|
|
xorl %eax,%eax
|
|
|
|
cmpl $7,%ecx
|
2013-04-29 20:15:07 +08:00
|
|
|
jae L017lot
|
2012-09-08 08:43:18 +08:00
|
|
|
cmpl $0,%ecx
|
2013-04-29 20:15:07 +08:00
|
|
|
je L018ret
|
|
|
|
L019little:
|
2012-09-08 08:43:18 +08:00
|
|
|
movb %al,(%edx)
|
|
|
|
subl $1,%ecx
|
|
|
|
leal 1(%edx),%edx
|
2013-04-29 20:15:07 +08:00
|
|
|
jnz L019little
|
|
|
|
L018ret:
|
2012-09-08 08:43:18 +08:00
|
|
|
ret
|
|
|
|
.align 4,0x90
|
2013-04-29 20:15:07 +08:00
|
|
|
L017lot:
|
2012-09-08 08:43:18 +08:00
|
|
|
testl $3,%edx
|
2013-04-29 20:15:07 +08:00
|
|
|
jz L020aligned
|
2012-09-08 08:43:18 +08:00
|
|
|
movb %al,(%edx)
|
|
|
|
leal -1(%ecx),%ecx
|
|
|
|
leal 1(%edx),%edx
|
2013-04-29 20:15:07 +08:00
|
|
|
jmp L017lot
|
|
|
|
L020aligned:
|
2012-09-08 08:43:18 +08:00
|
|
|
movl %eax,(%edx)
|
|
|
|
leal -4(%ecx),%ecx
|
|
|
|
testl $-4,%ecx
|
|
|
|
leal 4(%edx),%edx
|
2013-04-29 20:15:07 +08:00
|
|
|
jnz L020aligned
|
2012-09-08 08:43:18 +08:00
|
|
|
cmpl $0,%ecx
|
2013-04-29 20:15:07 +08:00
|
|
|
jne L019little
|
|
|
|
ret
|
|
|
|
.globl _OPENSSL_ia32_rdrand
|
|
|
|
.align 4
|
|
|
|
_OPENSSL_ia32_rdrand:
|
|
|
|
L_OPENSSL_ia32_rdrand_begin:
|
|
|
|
movl $8,%ecx
|
|
|
|
L021loop:
|
|
|
|
.byte 15,199,240
|
|
|
|
jc L022break
|
|
|
|
loop L021loop
|
|
|
|
L022break:
|
|
|
|
cmpl $0,%eax
|
|
|
|
cmovel %ecx,%eax
|
2012-09-08 08:43:18 +08:00
|
|
|
ret
|
2013-04-29 20:15:07 +08:00
|
|
|
.section __IMPORT,__pointers,non_lazy_symbol_pointers
|
|
|
|
L_OPENSSL_ia32cap_P$non_lazy_ptr:
|
|
|
|
.indirect_symbol _OPENSSL_ia32cap_P
|
|
|
|
.long 0
|
|
|
|
.comm _OPENSSL_ia32cap_P,8,2
|
2012-09-08 08:43:18 +08:00
|
|
|
.mod_init_func
|
|
|
|
.align 2
|
|
|
|
.long _OPENSSL_cpuid_setup
|