diff options
author | Craig Topper <craig.topper@gmail.com> | 2013-07-23 00:56:15 +0000 |
---|---|---|
committer | Craig Topper <craig.topper@gmail.com> | 2013-07-23 00:56:15 +0000 |
commit | 1fd6e647bc6093bd455311114b06d8c91c0110c4 (patch) | |
tree | e33ac0726ba0a120411e85bfd63e649c4e45ffdf | |
parent | 0e29eeec278d80048de6cf6605e004bbdefaf38c (diff) | |
download | external_llvm-1fd6e647bc6093bd455311114b06d8c91c0110c4.zip external_llvm-1fd6e647bc6093bd455311114b06d8c91c0110c4.tar.gz external_llvm-1fd6e647bc6093bd455311114b06d8c91c0110c4.tar.bz2 |
Add aliases to map 'imm, mem' form of x86 bts/btr/btc without a size suffix to their 32-bit forms.
This makes them consistent with 'bt' which already had this handling. gas has the same behavior. There have been discussions on the mailing list about determining size based on the immediate, but my goal here was just to remove the inconsistency.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@186904 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Target/X86/X86InstrInfo.td | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/lib/Target/X86/X86InstrInfo.td b/lib/Target/X86/X86InstrInfo.td index 6bc1235..9e5b6ff 100644 --- a/lib/Target/X86/X86InstrInfo.td +++ b/lib/Target/X86/X86InstrInfo.td @@ -1981,8 +1981,15 @@ def : InstAlias<"aad", (AAD8i8 10)>; def : InstAlias<"aam", (AAM8i8 10)>; // Disambiguate the mem/imm form of bt-without-a-suffix as btl. +// Likewise for btc/btr/bts. def : InstAlias<"bt {$imm, $mem|$mem, $imm}", (BT32mi8 i32mem:$mem, i32i8imm:$imm), 0>; +def : InstAlias<"btc {$imm, $mem|$mem, $imm}", + (BTC32mi8 i32mem:$mem, i32i8imm:$imm), 0>; +def : InstAlias<"btr {$imm, $mem|$mem, $imm}", + (BTR32mi8 i32mem:$mem, i32i8imm:$imm), 0>; +def : InstAlias<"bts {$imm, $mem|$mem, $imm}", + (BTS32mi8 i32mem:$mem, i32i8imm:$imm), 0>; // clr aliases. def : InstAlias<"clrb $reg", (XOR8rr GR8 :$reg, GR8 :$reg), 0>; |