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 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116
|
! RUN: llvm-mc %s -triple=sparc -show-encoding | FileCheck %s --check-prefixes=CHECK,V8
! RUN: llvm-mc %s -triple=sparcv9 -show-encoding | FileCheck %s --check-prefixes=CHECK,V9
! CHECK: rd %y, %i0 ! encoding: [0xb1,0x40,0x00,0x00]
rd %y, %i0
! CHECK: rd %asr1, %i0 ! encoding: [0xb1,0x40,0x40,0x00]
rd %asr1, %i0
! CHECK: wr %i0, 5, %y ! encoding: [0x81,0x86,0x20,0x05]
wr %i0, 5, %y
! CHECK: wr %i0, %i1, %asr15 ! encoding: [0x9f,0x86,0x00,0x19]
wr %i0, %i1, %asr15
! CHECK: rd %asr15, %g0 ! encoding: [0x81,0x43,0xc0,0x00]
rd %asr15, %g0
! CHECK: rd %psr, %i0 ! encoding: [0xb1,0x48,0x00,0x00]
rd %psr, %i0
! CHECK: rd %wim, %i0 ! encoding: [0xb1,0x50,0x00,0x00]
rd %wim, %i0
! CHECK: rd %tbr, %i0 ! encoding: [0xb1,0x58,0x00,0x00]
rd %tbr, %i0
! CHECK: wr %i0, 5, %psr ! encoding: [0x81,0x8e,0x20,0x05]
wr %i0, 5, %psr
! CHECK: wr %i0, 5, %wim ! encoding: [0x81,0x96,0x20,0x05]
wr %i0, 5, %wim
! CHECK: wr %i0, 5, %tbr ! encoding: [0x81,0x9e,0x20,0x05]
wr %i0, 5, %tbr
! CHECK: ld [%g2+20], %fsr ! encoding: [0xc1,0x08,0xa0,0x14]
ld [%g2 + 20],%fsr
! CHECK: ld [%g2+%i5], %fsr ! encoding: [0xc1,0x08,0x80,0x1d]
ld [%g2 + %i5],%fsr
! CHECK: st %fsr, [%g2+20] ! encoding: [0xc1,0x28,0xa0,0x14]
st %fsr,[%g2 + 20]
! CHECK: st %fsr, [%g2+%i5] ! encoding: [0xc1,0x28,0x80,0x1d]
st %fsr,[%g2 + %i5]
! CHECK: std %fq, [%g6+%i2] ! encoding: [0xc1,0x31,0x80,0x1a]
std %fq, [%g6 + %i2]
!! Those instructions are processed differently on V8 and V9.
! V8: rd %asr2, %i0 ! encoding: [0xb1,0x40,0x80,0x00]
! V9: rd %ccr, %i0 ! encoding: [0xb1,0x40,0x80,0x00]
rd %asr2, %i0
! V8: wr %i0, 7, %asr2 ! encoding: [0x85,0x86,0x20,0x07]
! V9: wr %i0, 7, %ccr ! encoding: [0x85,0x86,0x20,0x07]
wr %i0, 7, %asr2
! V8: rd %asr3, %i0 ! encoding: [0xb1,0x40,0xc0,0x00]
! V9: rd %asi, %i0 ! encoding: [0xb1,0x40,0xc0,0x00]
rd %asr3, %i0
! V8: wr %i0, 7, %asr3 ! encoding: [0x87,0x86,0x20,0x07]
! V9: wr %i0, 7, %asi ! encoding: [0x87,0x86,0x20,0x07]
wr %i0, 7, %asr3
! V8: rd %asr4, %i0 ! encoding: [0xb1,0x41,0x00,0x00]
! V9: rd %tick, %i0 ! encoding: [0xb1,0x41,0x00,0x00]
rd %asr4, %i0
! V8: wr %i0, 7, %asr4 ! encoding: [0x89,0x86,0x20,0x07]
! V9: wr %i0, 7, %tick ! encoding: [0x89,0x86,0x20,0x07]
wr %i0, 7, %asr4
! V8: rd %asr5, %i0 ! encoding: [0xb1,0x41,0x40,0x00]
! V9: rd %pc, %i0 ! encoding: [0xb1,0x41,0x40,0x00]
rd %asr5, %i0
! V8: wr %i0, 7, %asr5 ! encoding: [0x8b,0x86,0x20,0x07]
! V9: wr %i0, 7, %pc ! encoding: [0x8b,0x86,0x20,0x07]
wr %i0, 7, %asr5
! V8: rd %asr6, %i0 ! encoding: [0xb1,0x41,0x80,0x00]
! V9: rd %fprs, %i0 ! encoding: [0xb1,0x41,0x80,0x00]
rd %asr6, %i0
! V8: wr %i0, 7, %asr6 ! encoding: [0x8d,0x86,0x20,0x07]
! V9: wr %i0, 7, %fprs ! encoding: [0x8d,0x86,0x20,0x07]
wr %i0, 7, %asr6
!! Alternate names for %asr2-%asr6 are only for V9.
!! TODO: make sure that using alternate names returns
!! an error on V8 (currently it doesn't, see SparcRegisterInfo.td).
! V9: rd %ccr, %i0 ! encoding: [0xb1,0x40,0x80,0x00]
rd %ccr, %i0
! V9: wr %i0, 7, %ccr ! encoding: [0x85,0x86,0x20,0x07]
wr %i0, 7, %ccr
! V9: rd %asi, %i0 ! encoding: [0xb1,0x40,0xc0,0x00]
rd %asi, %i0
! V9: wr %i0, 7, %asi ! encoding: [0x87,0x86,0x20,0x07]
wr %i0, 7, %asi
! V9: rd %tick, %i0 ! encoding: [0xb1,0x41,0x00,0x00]
rd %tick, %i0
! V9: wr %i0, 7, %tick ! encoding: [0x89,0x86,0x20,0x07]
wr %i0, 7, %tick
! V9: rd %pc, %i0 ! encoding: [0xb1,0x41,0x40,0x00]
rd %pc, %i0
! V9: wr %i0, 7, %pc ! encoding: [0x8b,0x86,0x20,0x07]
wr %i0, 7, %pc
! V9: rd %fprs, %i0 ! encoding: [0xb1,0x41,0x80,0x00]
rd %fprs, %i0
! V9: wr %i0, 7, %fprs ! encoding: [0x8d,0x86,0x20,0x07]
wr %i0, 7, %fprs
|