mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-23 02:32:11 +00:00
When using inline asm constraints representing
non-floating point general registers allow 8 and 16-bit elements. Patch by Jack Carter. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@156277 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
f09769067f
commit
3ccbd47ecb
@ -3054,7 +3054,7 @@ getRegForInlineAsmConstraint(const std::string &Constraint, EVT VT) const
|
|||||||
case 'd': // Address register. Same as 'r' unless generating MIPS16 code.
|
case 'd': // Address register. Same as 'r' unless generating MIPS16 code.
|
||||||
case 'y': // Same as 'r'. Exists for compatibility.
|
case 'y': // Same as 'r'. Exists for compatibility.
|
||||||
case 'r':
|
case 'r':
|
||||||
if (VT == MVT::i32)
|
if (VT == MVT::i32 || VT == MVT::i16 || VT == MVT::i8)
|
||||||
return std::make_pair(0U, &Mips::CPURegsRegClass);
|
return std::make_pair(0U, &Mips::CPURegsRegClass);
|
||||||
assert(VT == MVT::i64 && "Unexpected type.");
|
assert(VT == MVT::i64 && "Unexpected type.");
|
||||||
return std::make_pair(0U, &Mips::CPU64RegsRegClass);
|
return std::make_pair(0U, &Mips::CPU64RegsRegClass);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user