diff --git a/llvm/include/llvm/IR/IntrinsicsPowerPC.td b/llvm/include/llvm/IR/IntrinsicsPowerPC.td --- a/llvm/include/llvm/IR/IntrinsicsPowerPC.td +++ b/llvm/include/llvm/IR/IntrinsicsPowerPC.td @@ -31,10 +31,12 @@ // Get content from current FPSCR register def int_ppc_readflm : GCCBuiltin<"__builtin_readflm">, - Intrinsic<[llvm_double_ty], [], [IntrNoMem]>; + Intrinsic<[llvm_double_ty], [], + [IntrNoMerge, IntrHasSideEffects]>; // Set FPSCR register, and return previous content def int_ppc_setflm : GCCBuiltin<"__builtin_setflm">, - Intrinsic<[llvm_double_ty], [llvm_double_ty], []>; + Intrinsic<[llvm_double_ty], [llvm_double_ty], + [IntrHasSideEffects]>; // Intrinsics for [double]word extended forms of divide instructions def int_ppc_divwe : GCCBuiltin<"__builtin_divwe">, diff --git a/llvm/lib/Target/PowerPC/PPCInstrInfo.td b/llvm/lib/Target/PowerPC/PPCInstrInfo.td --- a/llvm/lib/Target/PowerPC/PPCInstrInfo.td +++ b/llvm/lib/Target/PowerPC/PPCInstrInfo.td @@ -3108,14 +3108,14 @@ PPC970_DGroup_Single, PPC970_Unit_FPU; } -let Defs = [RM] in { +let Defs = [RM], hasSideEffects = 1 in { let isCodeGenOnly = 1 in def MTFSFb : XFLForm<63, 711, (outs), (ins i32imm:$FM, f8rc:$rT), "mtfsf $FM, $rT", IIC_IntMTFSB0, [(int_ppc_mtfsf timm:$FM, f64:$rT)]>, PPC970_DGroup_Single, PPC970_Unit_FPU; } -let Uses = [RM] in { +let Uses = [RM], hasSideEffects = 1 in { def MFFS : XForm_42<63, 583, (outs f8rc:$rT), (ins), "mffs $rT", IIC_IntMFFS, [(set f64:$rT, (PPCmffs))]>, diff --git a/llvm/test/CodeGen/PowerPC/read-set-flm.ll b/llvm/test/CodeGen/PowerPC/read-set-flm.ll --- a/llvm/test/CodeGen/PowerPC/read-set-flm.ll +++ b/llvm/test/CodeGen/PowerPC/read-set-flm.ll @@ -11,6 +11,7 @@ ; CHECK-NEXT: xsdivdp 1, 1, 2 ; CHECK-NEXT: xsadddp 1, 1, 3 ; CHECK-NEXT: xsadddp 0, 1, 0 +; CHECK-NEXT: mffs 1 ; CHECK-NEXT: mtfsf 255, 4 ; CHECK-NEXT: xsdivdp 1, 3, 4 ; CHECK-NEXT: xsadddp 1, 1, 2 @@ -46,6 +47,7 @@ ; CHECK-NEXT: xsdivdp 1, 1, 2 ; CHECK-NEXT: xsadddp 1, 1, 3 ; CHECK-NEXT: xsadddp 0, 1, 0 +; CHECK-NEXT: mffs 1 ; CHECK-NEXT: mtfsf 255, 4 ; CHECK-NEXT: xsdivdp 1, 3, 4 ; CHECK-NEXT: xsadddp 1, 1, 2 @@ -80,27 +82,26 @@ ; CHECK-NEXT: mflr 0 ; CHECK-NEXT: .cfi_def_cfa_offset 64 ; CHECK-NEXT: .cfi_offset lr, 16 -; CHECK-NEXT: .cfi_offset r30, -32 -; CHECK-NEXT: .cfi_offset f30, -16 +; CHECK-NEXT: .cfi_offset r30, -24 ; CHECK-NEXT: .cfi_offset f31, -8 -; CHECK-NEXT: std 30, -32(1) # 8-byte Folded Spill -; CHECK-NEXT: stfd 30, -16(1) # 8-byte Folded Spill +; CHECK-NEXT: std 30, -24(1) # 8-byte Folded Spill ; CHECK-NEXT: stfd 31, -8(1) # 8-byte Folded Spill ; CHECK-NEXT: std 0, 16(1) ; CHECK-NEXT: stdu 1, -64(1) ; CHECK-NEXT: fmr 31, 1 ; CHECK-NEXT: mr 30, 4 -; CHECK-NEXT: mffs 30 -; CHECK-NEXT: stfd 30, 0(3) +; CHECK-NEXT: mffs 0 +; CHECK-NEXT: stfd 0, 0(3) ; CHECK-NEXT: bl effect_func ; CHECK-NEXT: nop -; CHECK-NEXT: stfd 30, 0(30) +; CHECK-NEXT: mffs 0 +; CHECK-NEXT: stfd 0, 0(30) +; CHECK-NEXT: mffs 0 ; CHECK-NEXT: mtfsf 255, 31 ; CHECK-NEXT: addi 1, 1, 64 ; CHECK-NEXT: ld 0, 16(1) ; CHECK-NEXT: lfd 31, -8(1) # 8-byte Folded Reload -; CHECK-NEXT: lfd 30, -16(1) # 8-byte Folded Reload -; CHECK-NEXT: ld 30, -32(1) # 8-byte Folded Reload +; CHECK-NEXT: ld 30, -24(1) # 8-byte Folded Reload ; CHECK-NEXT: mtlr 0 ; CHECK-NEXT: blr entry: @@ -119,27 +120,26 @@ ; CHECK-NEXT: mflr 0 ; CHECK-NEXT: .cfi_def_cfa_offset 64 ; CHECK-NEXT: .cfi_offset lr, 16 -; CHECK-NEXT: .cfi_offset r30, -32 -; CHECK-NEXT: .cfi_offset f30, -16 +; CHECK-NEXT: .cfi_offset r30, -24 ; CHECK-NEXT: .cfi_offset f31, -8 -; CHECK-NEXT: std 30, -32(1) # 8-byte Folded Spill -; CHECK-NEXT: stfd 30, -16(1) # 8-byte Folded Spill +; CHECK-NEXT: std 30, -24(1) # 8-byte Folded Spill ; CHECK-NEXT: stfd 31, -8(1) # 8-byte Folded Spill ; CHECK-NEXT: std 0, 16(1) ; CHECK-NEXT: stdu 1, -64(1) ; CHECK-NEXT: fmr 31, 1 ; CHECK-NEXT: mr 30, 4 -; CHECK-NEXT: mffs 30 -; CHECK-NEXT: stfd 30, 0(3) +; CHECK-NEXT: mffs 0 +; CHECK-NEXT: stfd 0, 0(3) ; CHECK-NEXT: bl readonly_func ; CHECK-NEXT: nop -; CHECK-NEXT: stfd 30, 0(30) +; CHECK-NEXT: mffs 0 +; CHECK-NEXT: stfd 0, 0(30) +; CHECK-NEXT: mffs 0 ; CHECK-NEXT: mtfsf 255, 31 ; CHECK-NEXT: addi 1, 1, 64 ; CHECK-NEXT: ld 0, 16(1) ; CHECK-NEXT: lfd 31, -8(1) # 8-byte Folded Reload -; CHECK-NEXT: lfd 30, -16(1) # 8-byte Folded Reload -; CHECK-NEXT: ld 30, -32(1) # 8-byte Folded Reload +; CHECK-NEXT: ld 30, -24(1) # 8-byte Folded Reload ; CHECK-NEXT: mtlr 0 ; CHECK-NEXT: blr entry: