mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-03-02 22:32:08 +00:00
R600: Add a llvm.R600.store.swizzle intrinsics
This intrinsic is translated to ALLOC_EXPORT_WORD1_SWIZ, hence its name. It is used to store vs/fs outputs Patch by: Vincent Lejeune Reviewed-by: Tom Stellard <thomas.stellard@amd.com> git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@173297 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
2a3e0d7e76
commit
254a83e46c
@ -269,8 +269,24 @@ MachineBasicBlock * R600TargetLowering::EmitInstrWithCustomInserter(
|
||||
|
||||
case AMDGPU::EG_ExportSwz:
|
||||
case AMDGPU::R600_ExportSwz: {
|
||||
// Instruction is left unmodified if its not the last one of its type
|
||||
bool isLastInstructionOfItsType = true;
|
||||
unsigned InstExportType = MI->getOperand(1).getImm();
|
||||
for (MachineBasicBlock::iterator NextExportInst = llvm::next(I),
|
||||
EndBlock = BB->end(); NextExportInst != EndBlock;
|
||||
NextExportInst = llvm::next(NextExportInst)) {
|
||||
if (NextExportInst->getOpcode() == AMDGPU::EG_ExportSwz ||
|
||||
NextExportInst->getOpcode() == AMDGPU::R600_ExportSwz) {
|
||||
unsigned CurrentInstExportType = NextExportInst->getOperand(1)
|
||||
.getImm();
|
||||
if (CurrentInstExportType == InstExportType) {
|
||||
isLastInstructionOfItsType = false;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
bool EOP = (llvm::next(I)->getOpcode() == AMDGPU::RETURN)? 1 : 0;
|
||||
if (!EOP)
|
||||
if (!EOP && !isLastInstructionOfItsType)
|
||||
return BB;
|
||||
unsigned CfInst = (MI->getOpcode() == AMDGPU::EG_ExportSwz)? 84 : 40;
|
||||
BuildMI(*BB, I, BB->findDebugLoc(I), TII->get(MI->getOpcode()))
|
||||
@ -282,7 +298,7 @@ MachineBasicBlock * R600TargetLowering::EmitInstrWithCustomInserter(
|
||||
.addOperand(MI->getOperand(5))
|
||||
.addOperand(MI->getOperand(6))
|
||||
.addImm(CfInst)
|
||||
.addImm(1);
|
||||
.addImm(EOP);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
@ -599,6 +599,17 @@ multiclass ExportPattern<Instruction ExportInst, bits<8> cf_inst> {
|
||||
(ExportInst R600_Reg128:$src, imm:$type, imm:$arraybase,
|
||||
0, 1, 2, 3, cf_inst, 0)
|
||||
>;
|
||||
def : Pat<(EXPORT (v4f32 R600_Reg128:$src), (i32 1),
|
||||
(i32 imm:$type), (i32 imm:$arraybase), (i32 imm)),
|
||||
(ExportInst R600_Reg128:$src, imm:$type, imm:$arraybase,
|
||||
0, 1, 2, 3, cf_inst, 0)
|
||||
>;
|
||||
|
||||
def : Pat<(int_R600_store_swizzle (v4f32 R600_Reg128:$src), imm:$arraybase,
|
||||
imm:$type),
|
||||
(ExportInst R600_Reg128:$src, imm:$type, imm:$arraybase,
|
||||
0, 1, 2, 3, cf_inst, 0)
|
||||
>;
|
||||
}
|
||||
|
||||
multiclass SteamOutputExportPattern<Instruction ExportInst,
|
||||
|
@ -19,6 +19,8 @@ let TargetPrefix = "R600", isTarget = 1 in {
|
||||
Intrinsic<[llvm_float_ty], [llvm_i32_ty], [IntrReadMem]>;
|
||||
def int_R600_load_input_linear :
|
||||
Intrinsic<[llvm_float_ty], [llvm_i32_ty], [IntrReadMem]>;
|
||||
def int_R600_store_swizzle :
|
||||
Intrinsic<[], [llvm_v4f32_ty, llvm_i32_ty, llvm_i32_ty], []>;
|
||||
def int_R600_store_stream_output :
|
||||
Intrinsic<[], [llvm_v4f32_ty, llvm_i32_ty, llvm_i32_ty, llvm_i32_ty], []>;
|
||||
def int_R600_store_pixel_color :
|
||||
|
Loading…
x
Reference in New Issue
Block a user