[PATCH] D26005: AMDGPU: Don't use stack space for SGPR->VGPR spills

Nicolai Hähnle via llvm-commits llvm-commits at lists.llvm.org
Thu Oct 27 03:18:06 PDT 2016


nhaehnle added inline comments.


================
Comment at: lib/Target/AMDGPU/SIFrameLowering.cpp:117-118
+
   // Skip the last 2 elements because the last one is reserved for VCC, and
   // this is the 2nd to last element already.
+  for (MCPhysReg Reg : AllSGPR128s) {
----------------
The comment doesn't match the code anymore. Was the drop_back(2) removed on purpose? It seems like it would still be needed.


================
Comment at: lib/Target/AMDGPU/SIFrameLowering.cpp:238
 
+
   unsigned PreloadedPrivateBufferReg = AMDGPU::NoRegister;
----------------
Spurious whitespace.


================
Comment at: lib/Target/AMDGPU/SIRegisterInfo.cpp:979-988
+    // If more SGPRs are required to support the input user/system SGPRs,
+    // increase to accomodate them.
+    //
+    // FIXME: This really ends up using the requested number of SGPRs + number
+    // of reserved special registers in total. Theoretically you could re-use
+    // the last input registers for these special registers, but this would
+    // require a lot of complexity to deal with the weird aliasing.
----------------
I wonder if this shouldn't be an error condition. After all, the frontend explicitly requested some maximum number of SGPRs, and now we break that request. It depends a bit on the use case for amdgpu-num-sgpr of course.


https://reviews.llvm.org/D26005





More information about the llvm-commits mailing list