[llvm] [Hexagon] Order objects on the stack by their alignments (PR #81280)
Ikhlas Ajbar via llvm-commits
llvm-commits at lists.llvm.org
Fri Feb 9 18:47:59 PST 2024
================
@@ -2688,3 +2688,66 @@ bool HexagonFrameLowering::mayOverflowFrameOffset(MachineFunction &MF) const {
return false;
}
+
+namespace {
+// Struct used by orderFrameObjects to help sort the stack objects.
+struct HexagonFrameSortingObject {
+ bool IsValid = false;
+ unsigned Index = 0; // Index of Object into MFI list.
+ unsigned Size = 0;
+ Align ObjectAlignment = Align(1); // Alignment of Object in bytes.
+};
+
+struct HexagonFrameSortingComparator {
+ inline bool operator()(const HexagonFrameSortingObject &A,
+ const HexagonFrameSortingObject &B) const {
+ return std::make_tuple(!A.IsValid, A.ObjectAlignment, A.Size) <
+ std::make_tuple(!B.IsValid, B.ObjectAlignment, B.Size);
+ }
+};
+} // namespace
+
+// Sort objects on the stack by alignment value and then by size to minimize
+// padding.
+void HexagonFrameLowering::orderFrameObjects(
+ const MachineFunction &MF, SmallVectorImpl<int> &ObjectsToAllocate) const {
+ const MachineFrameInfo &MFI = MF.getFrameInfo();
+ int NObjects = ObjectsToAllocate.size();
+
+ if (ObjectsToAllocate.empty())
+ return;
+
+ // Create an array of all MFI objects.
+ std::vector<HexagonFrameSortingObject> SortingObjects(
----------------
iajbar wrote:
Done.
https://github.com/llvm/llvm-project/pull/81280
More information about the llvm-commits
mailing list