summaryrefslogtreecommitdiffstats
path: root/libclc
diff options
context:
space:
mode:
authorPeter Collingbourne <peter@pcc.me.uk>2012-05-29 13:35:54 +0000
committerPeter Collingbourne <peter@pcc.me.uk>2012-05-29 13:35:54 +0000
commit9acfba3322a9e2f4766ff79d105098f407c6a9d3 (patch)
tree9da02e45e4d8e62a067899044466c1f6dcce1b96 /libclc
parent20a5813a5f611ee32249615d26ccf607f6cf4252 (diff)
downloadbcm5719-llvm-9acfba3322a9e2f4766ff79d105098f407c6a9d3.tar.gz
bcm5719-llvm-9acfba3322a9e2f4766ff79d105098f407c6a9d3.zip
Enable cl_khr_fp64 when building the library, and fix several bugs
uncovered when doing so. llvm-svn: 157617
Diffstat (limited to 'libclc')
-rwxr-xr-xlibclc/compile-test.sh2
-rwxr-xr-xlibclc/configure.py1
-rw-r--r--libclc/generic/lib/geometric/length.cl4
-rw-r--r--libclc/generic/lib/geometric/length.inc2
-rw-r--r--libclc/generic/lib/geometric/normalize.cl4
-rw-r--r--libclc/generic/lib/math/mad.cl4
6 files changed, 15 insertions, 2 deletions
diff --git a/libclc/compile-test.sh b/libclc/compile-test.sh
index d0f4bb4a451..74618110d5a 100755
--- a/libclc/compile-test.sh
+++ b/libclc/compile-test.sh
@@ -1,3 +1,3 @@
#!/bin/sh
-clang -ccc-host-triple nvptx--nvidiacl -Iptx-nvidiacl/include -Igeneric/include -Xclang -mlink-bitcode-file -Xclang nvptx--nvidiacl/lib/builtins.bc -include clc/clc.h -Dcl_clang_storage_class_specifiers "$@"
+clang -ccc-host-triple nvptx--nvidiacl -Iptx-nvidiacl/include -Igeneric/include -Xclang -mlink-bitcode-file -Xclang nvptx--nvidiacl/lib/builtins.bc -include clc/clc.h -Dcl_clang_storage_class_specifiers -Dcl_khr_fp64 "$@"
diff --git a/libclc/configure.py b/libclc/configure.py
index 829ce6b0818..ab84a0d4263 100755
--- a/libclc/configure.py
+++ b/libclc/configure.py
@@ -93,6 +93,7 @@ for target in targets:
# The rule for building a .bc file for the specified architecture using clang.
clang_bc_flags = "-ccc-host-triple %s -I`dirname $in` %s " \
"-Dcl_clang_storage_class_specifiers " \
+ "-Dcl_khr_fp64 " \
"-emit-llvm" % (target, clang_cl_includes)
clang_bc_rule = "CLANG_CL_BC_" + target
c_compiler_rule(b, clang_bc_rule, "LLVM-CC", llvm_clang, clang_bc_flags)
diff --git a/libclc/generic/lib/geometric/length.cl b/libclc/generic/lib/geometric/length.cl
index 957fbfdea0d..cbe84a0308e 100644
--- a/libclc/generic/lib/geometric/length.cl
+++ b/libclc/generic/lib/geometric/length.cl
@@ -1,4 +1,8 @@
#include <clc/clc.h>
+#ifdef cl_khr_fp64
+#pragma OPENCL EXTENSION cl_khr_fp64 : enable
+#endif
+
#define BODY "length.inc"
#include <clc/geometric/floatn.inc>
diff --git a/libclc/generic/lib/geometric/length.inc b/libclc/generic/lib/geometric/length.inc
index 66d160475aa..494789c033b 100644
--- a/libclc/generic/lib/geometric/length.inc
+++ b/libclc/generic/lib/geometric/length.inc
@@ -1,3 +1,3 @@
-_CLC_OVERLOAD _CLC_DEF float length(FLOATN p) {
+_CLC_OVERLOAD _CLC_DEF FLOAT length(FLOATN p) {
return native_sqrt(dot(p, p));
}
diff --git a/libclc/generic/lib/geometric/normalize.cl b/libclc/generic/lib/geometric/normalize.cl
index 95d327cfa6d..e5a521fcdc4 100644
--- a/libclc/generic/lib/geometric/normalize.cl
+++ b/libclc/generic/lib/geometric/normalize.cl
@@ -1,4 +1,8 @@
#include <clc/clc.h>
+#ifdef cl_khr_fp64
+#pragma OPENCL EXTENSION cl_khr_fp64 : enable
+#endif
+
#define BODY "normalize.inc"
#include <clc/geometric/floatn.inc>
diff --git a/libclc/generic/lib/math/mad.cl b/libclc/generic/lib/math/mad.cl
index ff0cdbbecf0..e66e2046bb9 100644
--- a/libclc/generic/lib/math/mad.cl
+++ b/libclc/generic/lib/math/mad.cl
@@ -1,4 +1,8 @@
#include <clc/clc.h>
+#ifdef cl_khr_fp64
+#pragma OPENCL EXTENSION cl_khr_fp64 : enable
+#endif
+
#define BODY <mad.inc>
#include <clc/math/gentype.inc>
OpenPOWER on IntegriCloud