File: bmi2.s

package info (click to toggle)
binutils-riscv64-unknown-elf 2.32.2019.08+dfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye, sid
  • size: 413,812 kB
  • sloc: ansic: 2,327,452; asm: 982,944; exp: 218,246; cpp: 147,855; makefile: 63,075; sh: 33,816; yacc: 27,082; lisp: 15,389; perl: 6,480; xml: 5,239; ada: 5,117; python: 4,996; pascal: 3,266; lex: 2,272; cs: 879; f90: 535; sed: 334; awk: 165; objc: 134; fortran: 43
file content (59 lines) | stat: -rw-r--r-- 1,165 bytes parent folder | download | duplicates (27)
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