File: bmi2.s

package info (click to toggle)
binutils 2.31.1-16
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 309,412 kB
  • sloc: ansic: 1,161,194; asm: 638,508; cpp: 128,829; exp: 68,580; makefile: 55,828; sh: 22,360; yacc: 14,238; lisp: 13,272; perl: 2,111; ada: 1,681; lex: 1,652; pascal: 1,446; cs: 879; sed: 195; python: 154; xml: 95; awk: 25
file content (59 lines) | stat: -rw-r--r-- 1,165 bytes parent folder | download | duplicates (21)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
# Check 32bit BMI2 instructions

	.allow_index_reg
	.text
_start:

# Test for op r32, r/m32, imm8
	rorx $7,%eax,%ebx
	rorx $7,(%ecx),%ebx

# Test for op r32, r32, r/m32
	mulx %eax,%ebx,%esi
	mulx (%ecx),%ebx,%esi
	pdep %eax,%ebx,%esi
	pdep (%ecx),%ebx,%esi
	pext %eax,%ebx,%esi
	pext (%ecx),%ebx,%esi

# Test for op r32, r/m32, r32
	bzhi %eax,%ebx,%esi
	bzhi %ebx,(%ecx),%esi
	sarx %eax,%ebx,%esi
	sarx %ebx,(%ecx),%esi
	shlx %eax,%ebx,%esi
	shlx %ebx,(%ecx),%esi
	shrx %eax,%ebx,%esi
	shrx %ebx,(%ecx),%esi

	.intel_syntax noprefix

# Test for op r32, r/m32, imm8
	rorx ebx,eax,7
	rorx ebx,DWORD PTR [ecx],7
	rorx ebx,[ecx],7

# Test for op r32, r32, r/m32
	mulx esi,ebx,eax
	mulx esi,ebx,DWORD PTR [ecx]
	mulx esi,ebx,[ecx]
	pdep esi,ebx,eax
	pdep esi,ebx,DWORD PTR [ecx]
	pdep esi,ebx,[ecx]
	pext esi,ebx,eax
	pext esi,ebx,DWORD PTR [ecx]
	pext esi,ebx,[ecx]

# Test for op r32, r/m32, r32
	bzhi esi,ebx,eax
	bzhi esi,DWORD PTR [ecx],ebx
	bzhi esi,[ecx],ebx
	sarx esi,ebx,eax
	sarx esi,DWORD PTR [ecx],ebx
	sarx esi,[ecx],ebx
	shlx esi,ebx,eax
	shlx esi,DWORD PTR [ecx],ebx
	shlx esi,[ecx],ebx
	shrx esi,ebx,eax
	shrx esi,DWORD PTR [ecx],ebx
	shrx esi,[ecx],ebx