summaryrefslogtreecommitdiffstats
path: root/libcxx/benchmarks
diff options
context:
space:
mode:
authorAditya Kumar <hiraditya@msn.com>2017-06-14 23:17:45 +0000
committerAditya Kumar <hiraditya@msn.com>2017-06-14 23:17:45 +0000
commit38bc3df8a3a124ec7db1117269d69f7890af64f5 (patch)
tree4b17015c8fa8f3b44c6ab79df2445fc7871e0050 /libcxx/benchmarks
parentad94b452f59deb7b2854afd4c3a6464f36dd1808 (diff)
downloadbcm5719-llvm-38bc3df8a3a124ec7db1117269d69f7890af64f5.tar.gz
bcm5719-llvm-38bc3df8a3a124ec7db1117269d69f7890af64f5.zip
[locale] Avoid copy of __atoms when char_type is char
The function num_get<_CharT>::stage2_int_prep makes unnecessary copy of src into atoms when char_type is char. This can be avoided by creating a switch on type and just returning __src when char_type is char. Added the test case to demonstrate performance improvement. In order to avoid ABI incompatibilities, the changes are guarded with a macro _LIBCPP_ABI_OPTIMIZED_LOCALE_NUM_GET Differential Revision: https://reviews.llvm.org/D30268 Reviewed by: EricWF llvm-svn: 305427
Diffstat (limited to 'libcxx/benchmarks')
-rw-r--r--libcxx/benchmarks/stringstream.bench.cpp38
1 files changed, 38 insertions, 0 deletions
diff --git a/libcxx/benchmarks/stringstream.bench.cpp b/libcxx/benchmarks/stringstream.bench.cpp
new file mode 100644
index 00000000000..6023cf775bc
--- /dev/null
+++ b/libcxx/benchmarks/stringstream.bench.cpp
@@ -0,0 +1,38 @@
+#include "benchmark/benchmark_api.h"
+
+#include <sstream>
+double __attribute__((noinline)) istream_numbers();
+
+double istream_numbers() {
+ const char *a[] = {
+ "-6 69 -71 2.4882e-02 -100 101 -2.00005 5000000 -50000000",
+ "-25 71 7 -9.3262e+01 -100 101 -2.00005 5000000 -50000000",
+ "-14 53 46 -6.7026e-02 -100 101 -2.00005 5000000 -50000000"
+ };
+
+ int a1, a2, a3, a4, a5, a6, a7;
+ double f1 = 0.0, f2 = 0.0, q = 0.0;
+ for (int i=0; i < 3; i++) {
+ std::istringstream s(a[i]);
+ s >> a1
+ >> a2
+ >> a3
+ >> f1
+ >> a4
+ >> a5
+ >> f2
+ >> a6
+ >> a7;
+ q += (a1 + a2 + a3 + a4 + a5 + a6 + a7 + f1 + f2)/1000000;
+ }
+ return q;
+}
+
+static void BM_Istream_numbers(benchmark::State &state) {
+ double i = 0;
+ while (state.KeepRunning())
+ benchmark::DoNotOptimize(i += istream_numbers());
+}
+
+BENCHMARK(BM_Istream_numbers)->RangeMultiplier(2)->Range(1024, 4096);
+BENCHMARK_MAIN()
OpenPOWER on IntegriCloud