[llvm] r176439 - R600: Clean up datalayout strings so they better match hardware capabilities

Tom Stellard thomas.stellard at amd.com
Mon Mar 4 09:40:28 PST 2013


Author: tstellar
Date: Mon Mar  4 11:40:28 2013
New Revision: 176439

URL: http://llvm.org/viewvc/llvm-project?rev=176439&view=rev
Log:
R600: Clean up datalayout strings so they better match hardware capabilities

Modified:
    llvm/trunk/lib/Target/R600/AMDILDevice.cpp
    llvm/trunk/lib/Target/R600/AMDILSIDevice.cpp

Modified: llvm/trunk/lib/Target/R600/AMDILDevice.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/R600/AMDILDevice.cpp?rev=176439&r1=176438&r2=176439&view=diff
==============================================================================
--- llvm/trunk/lib/Target/R600/AMDILDevice.cpp (original)
+++ llvm/trunk/lib/Target/R600/AMDILDevice.cpp Mon Mar  4 11:40:28 2013
@@ -115,10 +115,18 @@ bool AMDGPUDevice::usesSoftware(AMDGPUDe
 
 std::string
 AMDGPUDevice::getDataLayout() const {
-    return std::string("e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16"
-      "-i32:32:32-i64:64:64-f32:32:32-f64:64:64-f80:32:32"
-      "-v16:16:16-v24:32:32-v32:32:32-v48:64:64-v64:64:64"
-      "-v96:128:128-v128:128:128-v192:256:256-v256:256:256"
-      "-v512:512:512-v1024:1024:1024-v2048:2048:2048"
-      "-n8:16:32:64");
+  std::string DataLayout = std::string(
+   "e"
+   "-p:32:32:32"
+   "-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32"
+   "-v16:16:16-v24:32:32-v32:32:32-v48:64:64-v64:64:64-v96:128:128-v128:128:128"
+   "-v192:256:256-v256:256:256-v512:512:512-v1024:1024:1024-v2048:2048:2048"
+   "-n32:64"
+  );
+
+  if (usesHardware(AMDGPUDeviceInfo::DoubleOps)) {
+    DataLayout.append("-f64:64:64");
+  }
+
+  return DataLayout;
 }

Modified: llvm/trunk/lib/Target/R600/AMDILSIDevice.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/R600/AMDILSIDevice.cpp?rev=176439&r1=176438&r2=176439&view=diff
==============================================================================
--- llvm/trunk/lib/Target/R600/AMDILSIDevice.cpp (original)
+++ llvm/trunk/lib/Target/R600/AMDILSIDevice.cpp Mon Mar  4 11:40:28 2013
@@ -36,10 +36,13 @@ AMDGPUSIDevice::getGeneration() const {
 
 std::string
 AMDGPUSIDevice::getDataLayout() const {
-  return std::string("e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16"
-      "-i32:32:32-i64:64:64-f32:32:32-f64:64:64-f80:32:32"
-      "-v16:16:16-v24:32:32-v32:32:32-v48:64:64-v64:64:64"
-      "-v96:128:128-v128:128:128-v192:256:256-v256:256:256"
-      "-v512:512:512-v1024:1024:1024-v2048:2048:2048"
-      "-n8:16:32:64");
+  return std::string(
+    "e"
+    "-p:64:64:64"
+    "-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64"
+    "-v16:16:16-v24:32:32-v32:32:32-v48:64:64-v64:64:64-v96:128:128"
+    "-v128:128:128-v192:256:256-v256:256:256-v512:512:512-v1024:1024:1024"
+    "-v2048:2048:2048"
+    "-n32:64"
+  );
 }





More information about the llvm-commits mailing list