x86_64cpuid.pl 3.2 KB
Newer Older
1 2
#!/usr/bin/env perl

3 4 5
$flavour = shift;
$output  = shift;
if ($flavour =~ /\./) { $output = $flavour; undef $flavour; }
6

7
$win64=0; $win64=1 if ($flavour =~ /[nm]asm|mingw64/ || $output =~ /\.asm$/);
8

9 10
$0 =~ m/(.*[\/\\])[^\/\\]+$/; $dir=$1;
open STDOUT,"| $^X ${dir}perlasm/x86_64-xlate.pl $flavour $output";
11

12 13 14 15 16 17
if ($win64)	{ $arg1="%rcx"; $arg2="%rdx"; }
else		{ $arg1="%rdi"; $arg2="%rsi"; }
print<<___;
.extern		OPENSSL_cpuid_setup
.section	.init
	call	OPENSSL_cpuid_setup
A
Andy Polyakov 已提交
18

19
.text
20 21

.globl	OPENSSL_atomic_add
22
.type	OPENSSL_atomic_add,\@abi-omnipotent
23 24
.align	16
OPENSSL_atomic_add:
25 26 27 28
	movl	($arg1),%eax
.Lspin:	leaq	($arg2,%rax),%r8
	.byte	0xf0		# lock
	cmpxchgl	%r8d,($arg1)
29
	jne	.Lspin
30
	movl	%r8d,%eax
31
	.byte	0x48,0x98	# cltq/cdqe
32 33 34
	ret
.size	OPENSSL_atomic_add,.-OPENSSL_atomic_add

A
Andy Polyakov 已提交
35 36 37 38 39 40 41 42 43 44
.globl	OPENSSL_rdtsc
.type	OPENSSL_rdtsc,\@abi-omnipotent
.align	16
OPENSSL_rdtsc:
	rdtsc
	shl	\$32,%rdx
	or	%rdx,%rax
	ret
.size	OPENSSL_rdtsc,.-OPENSSL_rdtsc

45
.globl	OPENSSL_ia32_cpuid
A
Andy Polyakov 已提交
46
.type	OPENSSL_ia32_cpuid,\@abi-omnipotent
47 48
.align	16
OPENSSL_ia32_cpuid:
A
Andy Polyakov 已提交
49
	mov	%rbx,%r8
50 51 52 53 54 55 56 57 58 59 60 61 62 63

	xor	%eax,%eax
	cpuid
	xor	%eax,%eax
	cmp	\$0x756e6547,%ebx	# "Genu"
	setne	%al
	mov	%eax,%r9d
	cmp	\$0x49656e69,%edx	# "ineI"
	setne	%al
	or	%eax,%r9d
	cmp	\$0x6c65746e,%ecx	# "ntel"
	setne	%al
	or	%eax,%r9d

A
Andy Polyakov 已提交
64
	mov	\$1,%eax
65
	cpuid
A
Andy Polyakov 已提交
66
	cmp	\$0,%r9d
67
	jne	.Lnotintel
68
	or	\$0x00100000,%edx	# use reserved 20th bit to engage RC4_CHAR
69 70 71
	and	\$15,%ah
	cmp	\$15,%ah		# examine Family ID
	je	.Lnotintel
72
	or	\$0x40000000,%edx	# use reserved bit to skip unrolled loop
73
.Lnotintel:
A
Andy Polyakov 已提交
74 75
	bt	\$28,%edx		# test hyper-threading bit
	jnc	.Ldone
76 77 78
	shr	\$16,%ebx
	cmp	\$1,%bl			# see if cache is shared
	ja	.Ldone
A
Andy Polyakov 已提交
79
	and	\$0xefffffff,%edx	# ~(1<<28)
80
.Ldone:
A
Andy Polyakov 已提交
81 82 83 84
	shl	\$32,%rcx
	mov	%edx,%eax
	mov	%r8,%rbx
	or	%rcx,%rax
85 86
	ret
.size	OPENSSL_ia32_cpuid,.-OPENSSL_ia32_cpuid
87 88

.globl  OPENSSL_cleanse
89
.type   OPENSSL_cleanse,\@abi-omnipotent
90 91 92
.align  16
OPENSSL_cleanse:
	xor	%rax,%rax
93
	cmp	\$15,$arg2
94 95
	jae	.Lot
.Little:
96 97 98
	mov	%al,($arg1)
	sub	\$1,$arg2
	lea	1($arg1),$arg1
99 100 101 102
	jnz	.Little
	ret
.align	16
.Lot:
103
	test	\$7,$arg1
104
	jz	.Laligned
105 106 107
	mov	%al,($arg1)
	lea	-1($arg2),$arg2
	lea	1($arg1),$arg1
108 109
	jmp	.Lot
.Laligned:
110 111 112 113
	mov	%rax,($arg1)
	lea	-8($arg2),$arg2
	test	\$-8,$arg2
	lea	8($arg1),$arg1
114
	jnz	.Laligned
115
	cmp	\$0,$arg2
116 117 118
	jne	.Little
	ret
.size	OPENSSL_cleanse,.-OPENSSL_cleanse
119
___
120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175

print<<___ if (!$win64);
.globl	OPENSSL_wipe_cpu
.type	OPENSSL_wipe_cpu,\@abi-omnipotent
.align	16
OPENSSL_wipe_cpu:
	pxor	%xmm0,%xmm0
	pxor	%xmm1,%xmm1
	pxor	%xmm2,%xmm2
	pxor	%xmm3,%xmm3
	pxor	%xmm4,%xmm4
	pxor	%xmm5,%xmm5
	pxor	%xmm6,%xmm6
	pxor	%xmm7,%xmm7
	pxor	%xmm8,%xmm8
	pxor	%xmm9,%xmm9
	pxor	%xmm10,%xmm10
	pxor	%xmm11,%xmm11
	pxor	%xmm12,%xmm12
	pxor	%xmm13,%xmm13
	pxor	%xmm14,%xmm14
	pxor	%xmm15,%xmm15
	xorq	%rcx,%rcx
	xorq	%rdx,%rdx
	xorq	%rsi,%rsi
	xorq	%rdi,%rdi
	xorq	%r8,%r8
	xorq	%r9,%r9
	xorq	%r10,%r10
	xorq	%r11,%r11
	leaq	8(%rsp),%rax
	ret
.size	OPENSSL_wipe_cpu,.-OPENSSL_wipe_cpu
___
print<<___ if ($win64);
.globl	OPENSSL_wipe_cpu
.type	OPENSSL_wipe_cpu,\@abi-omnipotent
.align	16
OPENSSL_wipe_cpu:
	pxor	%xmm0,%xmm0
	pxor	%xmm1,%xmm1
	pxor	%xmm2,%xmm2
	pxor	%xmm3,%xmm3
	pxor	%xmm4,%xmm4
	pxor	%xmm5,%xmm5
	xorq	%rcx,%rcx
	xorq	%rdx,%rdx
	xorq	%r8,%r8
	xorq	%r9,%r9
	xorq	%r10,%r10
	xorq	%r11,%r11
	leaq	8(%rsp),%rax
	ret
.size	OPENSSL_wipe_cpu,.-OPENSSL_wipe_cpu
___

A
Andy Polyakov 已提交
176
close STDOUT;	# flush