Index: llvm/lib/Target/RISCV/RISCVExpandAtomicPseudoInsts.cpp =================================================================== --- llvm/lib/Target/RISCV/RISCVExpandAtomicPseudoInsts.cpp +++ llvm/lib/Target/RISCV/RISCVExpandAtomicPseudoInsts.cpp @@ -58,15 +58,33 @@ bool expandAtomicCmpXchg(MachineBasicBlock &MBB, MachineBasicBlock::iterator MBBI, bool IsMasked, int Width, MachineBasicBlock::iterator &NextMBBI); + + unsigned getInstSizeInBytes(const MachineFunction &MF) const { + unsigned Size = 0; + for (auto &MBB : MF) + for (auto &MI : MBB) + Size += TII->getInstSizeInBytes(MI); + return Size; + } }; char RISCVExpandAtomicPseudo::ID = 0; bool RISCVExpandAtomicPseudo::runOnMachineFunction(MachineFunction &MF) { TII = static_cast(MF.getSubtarget().getInstrInfo()); + +#ifndef NDEBUG + const unsigned OldSize = getInstSizeInBytes(MF); +#endif + bool Modified = false; for (auto &MBB : MF) Modified |= expandMBB(MBB); + +#ifndef NDEBUG + const unsigned NewSize = getInstSizeInBytes(MF); + assert(OldSize >= NewSize); +#endif return Modified; } Index: llvm/lib/Target/RISCV/RISCVExpandPseudoInsts.cpp =================================================================== --- llvm/lib/Target/RISCV/RISCVExpandPseudoInsts.cpp +++ llvm/lib/Target/RISCV/RISCVExpandPseudoInsts.cpp @@ -50,15 +50,32 @@ bool expandVSetVL(MachineBasicBlock &MBB, MachineBasicBlock::iterator MBBI); bool expandVMSET_VMCLR(MachineBasicBlock &MBB, MachineBasicBlock::iterator MBBI, unsigned Opcode); + unsigned getInstSizeInBytes(const MachineFunction &MF) const { + unsigned Size = 0; + for (auto &MBB : MF) + for (auto &MI : MBB) + Size += TII->getInstSizeInBytes(MI); + return Size; + } }; char RISCVExpandPseudo::ID = 0; bool RISCVExpandPseudo::runOnMachineFunction(MachineFunction &MF) { TII = static_cast(MF.getSubtarget().getInstrInfo()); + +#ifndef NDEBUG + const unsigned OldSize = getInstSizeInBytes(MF); +#endif + bool Modified = false; for (auto &MBB : MF) Modified |= expandMBB(MBB); + +#ifndef NDEBUG + const unsigned NewSize = getInstSizeInBytes(MF); + assert(OldSize >= NewSize); +#endif return Modified; } @@ -271,15 +288,32 @@ bool expandLoadTLSGDAddress(MachineBasicBlock &MBB, MachineBasicBlock::iterator MBBI, MachineBasicBlock::iterator &NextMBBI); + unsigned getInstSizeInBytes(const MachineFunction &MF) const { + unsigned Size = 0; + for (auto &MBB : MF) + for (auto &MI : MBB) + Size += TII->getInstSizeInBytes(MI); + return Size; + } }; char RISCVPreRAExpandPseudo::ID = 0; bool RISCVPreRAExpandPseudo::runOnMachineFunction(MachineFunction &MF) { TII = static_cast(MF.getSubtarget().getInstrInfo()); + +#ifndef NDEBUG + const unsigned OldSize = getInstSizeInBytes(MF); +#endif + bool Modified = false; for (auto &MBB : MF) Modified |= expandMBB(MBB); + +#ifndef NDEBUG + const unsigned NewSize = getInstSizeInBytes(MF); + assert(OldSize >= NewSize); +#endif return Modified; }