diff options
author | Aditya Kumar <hiraditya@msn.com> | 2017-06-14 23:17:45 +0000 |
---|---|---|
committer | Aditya Kumar <hiraditya@msn.com> | 2017-06-14 23:17:45 +0000 |
commit | 38bc3df8a3a124ec7db1117269d69f7890af64f5 (patch) | |
tree | 4b17015c8fa8f3b44c6ab79df2445fc7871e0050 /libcxx/benchmarks | |
parent | ad94b452f59deb7b2854afd4c3a6464f36dd1808 (diff) | |
download | bcm5719-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.cpp | 38 |
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() |