Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(192)

Unified Diff: crosstest/test_cast.cpp

Issue 265703002: Add Om1 lowering with no optimizations (Closed) Base URL: https://gerrit.chromium.org/gerrit/p/native_client/pnacl-subzero.git@master
Patch Set: Merge changed from Karl's committed CL Created 6 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « crosstest/test_cast.h ('k') | crosstest/test_cast_main.cpp » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: crosstest/test_cast.cpp
diff --git a/crosstest/test_cast.cpp b/crosstest/test_cast.cpp
new file mode 100644
index 0000000000000000000000000000000000000000..1035109259b8ae912877cbab35255c26075bce4e
--- /dev/null
+++ b/crosstest/test_cast.cpp
@@ -0,0 +1,61 @@
+// This aims to test all the conversion bitcode instructions across
+// all PNaCl primitive data types.
+
+#include <stdint.h>
+#include "test_cast.h"
+
+template <typename FromType, typename ToType>
+ToType __attribute__((noinline)) cast(FromType a) {
+ return (ToType)a;
+}
+
+template <typename FromType, typename ToType>
+ToType __attribute__((noinline)) castBits(FromType a) {
+ return *(ToType *)&a;
+}
+
+// The purpose of the following sets of templates is to force
+// cast<A,B>() to be instantiated in the resulting bitcode file for
+// all <A,B>, so that they can be called from the driver.
+template <typename ToType> class Caster {
+ static ToType f(bool a) { return cast<bool, ToType>(a); }
+ static ToType f(int8_t a) { return cast<int8_t, ToType>(a); }
+ static ToType f(uint8_t a) { return cast<uint8_t, ToType>(a); }
+ static ToType f(int16_t a) { return cast<int16_t, ToType>(a); }
+ static ToType f(uint16_t a) { return cast<uint16_t, ToType>(a); }
+ static ToType f(int32_t a) { return cast<int32_t, ToType>(a); }
+ static ToType f(uint32_t a) { return cast<uint32_t, ToType>(a); }
+ static ToType f(int64_t a) { return cast<int64_t, ToType>(a); }
+ static ToType f(uint64_t a) { return cast<uint64_t, ToType>(a); }
+ static ToType f(float a) { return cast<float, ToType>(a); }
+ static ToType f(double a) { return cast<double, ToType>(a); }
+};
+
+// Comment out the definition of Caster<bool> because clang compiles
+// casts to bool using icmp instead of the desired cast instruction.
+// The corrected definitions are in test_cast_to_u1.ll.
+
+// template class Caster<bool>;
+
+template class Caster<int8_t>;
+template class Caster<uint8_t>;
+template class Caster<int16_t>;
+template class Caster<uint16_t>;
+template class Caster<int32_t>;
+template class Caster<uint32_t>;
+template class Caster<int64_t>;
+template class Caster<uint64_t>;
+template class Caster<float>;
+template class Caster<double>;
+
+// This function definition forces castBits<A,B>() to be instantiated
+// in the resulting bitcode file for the 4 relevant <A,B>
+// combinations, so that they can be called from the driver.
+double makeBitCasters() {
+ double Result = 0;
+ Result += castBits<uint32_t, float>(0);
+ Result += castBits<uint64_t, double>(0);
+ Result += castBits<float, uint32_t>(0);
+ Result += castBits<double, uint64_t>(0);
+ return Result;
+}
« no previous file with comments | « crosstest/test_cast.h ('k') | crosstest/test_cast_main.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698