1*46dbe239SXin Li #include <benchmark/benchmark.h> 2*46dbe239SXin Li 3*46dbe239SXin Li #include <fxdiv.h> 4*46dbe239SXin Li fxdiv_mulext_uint32_t(benchmark::State & state)5*46dbe239SXin Listatic void fxdiv_mulext_uint32_t(benchmark::State& state) { 6*46dbe239SXin Li uint32_t c = UINT32_C(0x1971DB6B); 7*46dbe239SXin Li benchmark::DoNotOptimize(&c); 8*46dbe239SXin Li uint32_t d = c; 9*46dbe239SXin Li while (state.KeepRunning()) { 10*46dbe239SXin Li const uint64_t product = fxdiv_mulext_uint32_t(c, d++); 11*46dbe239SXin Li benchmark::DoNotOptimize(product); 12*46dbe239SXin Li } 13*46dbe239SXin Li } 14*46dbe239SXin Li BENCHMARK(fxdiv_mulext_uint32_t); 15*46dbe239SXin Li native_mulext_uint32_t(benchmark::State & state)16*46dbe239SXin Listatic void native_mulext_uint32_t(benchmark::State& state) { 17*46dbe239SXin Li uint32_t c = UINT32_C(0x1971DB6B); 18*46dbe239SXin Li benchmark::DoNotOptimize(&c); 19*46dbe239SXin Li uint32_t d = c; 20*46dbe239SXin Li while (state.KeepRunning()) { 21*46dbe239SXin Li const uint64_t product = (uint64_t) c * (uint64_t) (d++); 22*46dbe239SXin Li benchmark::DoNotOptimize(product); 23*46dbe239SXin Li } 24*46dbe239SXin Li } 25*46dbe239SXin Li BENCHMARK(native_mulext_uint32_t); 26*46dbe239SXin Li fxdiv_mulhi_uint32_t(benchmark::State & state)27*46dbe239SXin Listatic void fxdiv_mulhi_uint32_t(benchmark::State& state) { 28*46dbe239SXin Li const uint32_t c = UINT32_C(0x1971DB6B); 29*46dbe239SXin Li uint32_t x = c; 30*46dbe239SXin Li while (state.KeepRunning()) { 31*46dbe239SXin Li const uint32_t product = fxdiv_mulhi_uint32_t(c, x++); 32*46dbe239SXin Li benchmark::DoNotOptimize(product); 33*46dbe239SXin Li } 34*46dbe239SXin Li } 35*46dbe239SXin Li BENCHMARK(fxdiv_mulhi_uint32_t); 36*46dbe239SXin Li fxdiv_mulhi_uint64_t(benchmark::State & state)37*46dbe239SXin Listatic void fxdiv_mulhi_uint64_t(benchmark::State& state) { 38*46dbe239SXin Li const uint64_t c = UINT64_C(0x425E892B38148FAD); 39*46dbe239SXin Li uint64_t x = c; 40*46dbe239SXin Li while (state.KeepRunning()) { 41*46dbe239SXin Li const uint64_t product = fxdiv_mulhi_uint64_t(c, x++); 42*46dbe239SXin Li benchmark::DoNotOptimize(product); 43*46dbe239SXin Li } 44*46dbe239SXin Li } 45*46dbe239SXin Li BENCHMARK(fxdiv_mulhi_uint64_t); 46*46dbe239SXin Li 47*46dbe239SXin Li BENCHMARK_MAIN(); 48