summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen/MachineRegisterInfo.cpp
diff options
context:
space:
mode:
authorJakob Stoklund Olesen <stoklund@2pi.dk>2013-01-05 05:00:09 +0000
committerJakob Stoklund Olesen <stoklund@2pi.dk>2013-01-05 05:00:09 +0000
commit1bfeecb491060af8fb0a69451f10cd535e2d2e1c (patch)
treea6e3c8cfe67f9c3935daa9e62b000570627f3163 /llvm/lib/CodeGen/MachineRegisterInfo.cpp
parentfe445cd6468822b84e322f7cf4839b4c7ee832d5 (diff)
downloadbcm5719-llvm-1bfeecb491060af8fb0a69451f10cd535e2d2e1c.tar.gz
bcm5719-llvm-1bfeecb491060af8fb0a69451f10cd535e2d2e1c.zip
Use ArrayRecycler for MachineInstr operand lists.
Instead of an std::vector<MachineOperand>, use MachineOperand arrays from an ArrayRecycler living in MachineFunction. This has several advantages: - MachineInstr now has a trivial destructor, making it possible to delete them in batches when destroying MachineFunction. This will be enabled in a later patch. - Bypassing malloc() and free() can be faster, depending on the system library. - MachineInstr objects and their operands are allocated from the same BumpPtrAllocator, so they will usually be next to each other in memory, providing better locality of reference. - Reduce MachineInstr footprint. A std::vector is 24 bytes, the new operand array representation only uses 8+4+1 bytes in MachineInstr. - Better control over operand array reallocations. In the old representation, the use-def chains would be reordered whenever a std::vector reached its capacity. The new implementation never changes the use-def chain order. Note that some decisions in the code generator depend on the use-def chain orders, so this patch may cause different assembly to be produced in a few cases. llvm-svn: 171598
Diffstat (limited to 'llvm/lib/CodeGen/MachineRegisterInfo.cpp')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud