mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-30 04:35:00 +00:00
Properly constrain register classes for sub-registers.
Not all GR64 registers have sub_8bit sub-registers. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@157150 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
8e86929e3c
commit
ee0d5d4398
@ -1345,6 +1345,8 @@ unsigned FastISel::FastEmitInst_extractsubreg(MVT RetVT,
|
||||
unsigned ResultReg = createResultReg(TLI.getRegClassFor(RetVT));
|
||||
assert(TargetRegisterInfo::isVirtualRegister(Op0) &&
|
||||
"Cannot yet extract from physregs");
|
||||
const TargetRegisterClass *RC = MRI.getRegClass(Op0);
|
||||
MRI.constrainRegClass(Op0, TRI.getSubClassWithSubReg(RC, Idx));
|
||||
BuildMI(*FuncInfo.MBB, FuncInfo.InsertPt,
|
||||
DL, TII.get(TargetOpcode::COPY), ResultReg)
|
||||
.addReg(Op0, getKillRegState(Op0IsKill), Idx);
|
||||
|
@ -1,5 +1,5 @@
|
||||
; RUN: llc < %s -fast-isel -fast-isel-abort -march=x86 -mattr=sse2
|
||||
; RUN: llc < %s -fast-isel -fast-isel-abort -mtriple=x86_64-apple-darwin10
|
||||
; RUN: llc < %s -fast-isel -fast-isel-abort -verify-machineinstrs -march=x86 -mattr=sse2
|
||||
; RUN: llc < %s -fast-isel -fast-isel-abort -verify-machineinstrs -mtriple=x86_64-apple-darwin10
|
||||
|
||||
; This tests very minimal fast-isel functionality.
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user