summaryrefslogtreecommitdiffstats
path: root/test/MC/PowerPC/ppc64-encoding-bookII.s
blob: 9e68a4b3c2540019ca7ea66504d6ed0bdaa2d230 (plain)
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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82

# RUN: llvm-mc -triple powerpc64-unknown-unknown --show-encoding %s | FileCheck %s

# Cache management instruction

# CHECK: icbi 2, 3                       # encoding: [0x7c,0x02,0x1f,0xac]
         icbi 2, 3

# FIXME: dcbt 2, 3, 10
# CHECK: dcbt 2, 3                       # encoding: [0x7c,0x02,0x1a,0x2c]
         dcbt 2, 3
# FIXME: dcbtst 2, 3, 10
# CHECK: dcbtst 2, 3                     # encoding: [0x7c,0x02,0x19,0xec]
         dcbtst 2, 3
# CHECK: dcbz 2, 3                       # encoding: [0x7c,0x02,0x1f,0xec]
         dcbz 2, 3
# CHECK: dcbst 2, 3                      # encoding: [0x7c,0x02,0x18,0x6c]
         dcbst 2, 3
# FIXME: dcbf 2, 3, 1

# Synchronization instructions

# CHECK: isync                           # encoding: [0x4c,0x00,0x01,0x2c]
         isync

# FIXME: lbarx 2, 3, 4, 1
# FIXME: lharx 2, 3, 4, 1
# FIXME: lwarx 2, 3, 4, 1
# FIXME: ldarx 2, 3, 4, 1

# FIXME: stbcx. 2, 3, 4
# FIXME: sthcx. 2, 3, 4
# CHECK: stwcx. 2, 3, 4                  # encoding: [0x7c,0x43,0x21,0x2d]
         stwcx. 2, 3, 4
# CHECK: stdcx. 2, 3, 4                  # encoding: [0x7c,0x43,0x21,0xad]
         stdcx. 2, 3, 4

# CHECK: sync 2                          # encoding: [0x7c,0x40,0x04,0xac]
         sync 2
# CHECK: eieio                           # encoding: [0x7c,0x00,0x06,0xac]
         eieio
# CHECK: wait 2                          # encoding: [0x7c,0x40,0x00,0x7c]
         wait 2

# Extended mnemonics

# CHECK: dcbf 2, 3                       # encoding: [0x7c,0x02,0x18,0xac]
         dcbf 2, 3
# FIXME: dcbfl 2, 3

# FIXME: lbarx 2, 3, 4
# FIXME: lharx 2, 3, 4
# CHECK: lwarx 2, 3, 4                   # encoding: [0x7c,0x43,0x20,0x28]
         lwarx 2, 3, 4
# CHECK: ldarx 2, 3, 4                   # encoding: [0x7c,0x43,0x20,0xa8]
         ldarx 2, 3, 4

# CHECK: sync 0                          # encoding: [0x7c,0x00,0x04,0xac]
         sync
# CHECK: sync 0                          # encoding: [0x7c,0x00,0x04,0xac]
         msync
# CHECK: sync 1                          # encoding: [0x7c,0x20,0x04,0xac]
         lwsync
# CHECK: sync 2                          # encoding: [0x7c,0x40,0x04,0xac]
         ptesync

# CHECK: wait 0                          # encoding: [0x7c,0x00,0x00,0x7c]
         wait
# CHECK: wait 1                          # encoding: [0x7c,0x20,0x00,0x7c]
         waitrsv
# CHECK: wait 2                          # encoding: [0x7c,0x40,0x00,0x7c]
         waitimpl

# Time base instructions

# CHECK: mftb 2, 123                     # encoding: [0x7c,0x5b,0x1a,0xe6]
         mftb 2, 123
# CHECK: mftb 2, 268                     # encoding: [0x7c,0x4c,0x42,0xe6]
         mftb 2
# CHECK: mftb 2, 269                     # encoding: [0x7c,0x4d,0x42,0xe6]
         mftbu 2