enable/disable stack unwinding in performance tests

This commit is contained in:
Oliver Kowalke
2014-01-26 11:16:31 +01:00
parent 7b6bba07c0
commit e74929f66a
4 changed files with 33 additions and 15 deletions

View File

@@ -22,6 +22,7 @@ typedef preallocated_stack_allocator< 64 * 1024 > stack_allocator;
typedef boost::coroutines::coroutine< void, stack_allocator > coroutine;
boost::coroutines::flag_fpu_t preserve_fpu = boost::coroutines::fpu_not_preserved;
boost::coroutines::flag_unwind_t unwind_stack = boost::coroutines::stack_unwind;
boost::uint64_t jobs = 1000;
void fn( coroutine::push_type & c)
@@ -33,13 +34,13 @@ duration_type measure_time()
// cache warum-up
coroutine::pull_type c( fn,
boost::coroutines::attributes( stack_allocator::default_stacksize(), preserve_fpu),
boost::coroutines::attributes( stack_allocator::default_stacksize(), unwind_stack, preserve_fpu),
stack_alloc);
time_point_type start( clock_type::now() );
for ( std::size_t i = 0; i < jobs; ++i) {
coroutine::pull_type c( fn,
boost::coroutines::attributes( stack_allocator::default_stacksize(), preserve_fpu),
boost::coroutines::attributes( stack_allocator::default_stacksize(), unwind_stack, preserve_fpu),
stack_alloc);
}
duration_type total = clock_type::now() - start;
@@ -56,13 +57,13 @@ cycle_type measure_cycles()
// cache warum-up
coroutine::pull_type c( fn,
boost::coroutines::attributes( stack_allocator::default_stacksize(), preserve_fpu),
boost::coroutines::attributes( stack_allocator::default_stacksize(), unwind_stack, preserve_fpu),
stack_alloc);
cycle_type start( cycles() );
for ( std::size_t i = 0; i < jobs; ++i) {
coroutine::pull_type c( fn,
boost::coroutines::attributes( stack_allocator::default_stacksize(), preserve_fpu),
boost::coroutines::attributes( stack_allocator::default_stacksize(), unwind_stack, preserve_fpu),
stack_alloc);
}
cycle_type total = cycles() - start;
@@ -79,11 +80,12 @@ int main( int argc, char * argv[])
{
bind_to_processor( 0);
bool preserve = false;
bool preserve = false, unwind = true;
boost::program_options::options_description desc("allowed options");
desc.add_options()
("help", "help message")
("fpu,f", boost::program_options::value< bool >( & preserve), "preserve FPU registers")
("unwind,u", boost::program_options::value< bool >( & unwind), "unwind stack")
("jobs,j", boost::program_options::value< boost::uint64_t >( & jobs), "jobs to run");
boost::program_options::variables_map vm;
@@ -101,6 +103,7 @@ int main( int argc, char * argv[])
}
if ( preserve) preserve_fpu = boost::coroutines::fpu_preserved;
if ( ! unwind) unwind_stack = boost::coroutines::no_stack_unwind;
boost::uint64_t res = measure_time().count();
std::cout << "average of " << res << " nano seconds" << std::endl;