Sha256: aa9f54fc5c822178d2440ccd1df9e66439d903be8fc10b0b8d5a2f73b1f80e74

Contents?: true

Size: 1.85 KB

Versions: 20

Compression:

Stored size: 1.85 KB

Contents

/* Copyright (C) 2005-2019 Shugo Maeda <shugo@ruby-lang.org> and Charlie Savage <cfis@savagexi.com>
   Please see the LICENSE file for copyright and distribution information */

   /* :nodoc: */
#include "rp_measurement.h"

#if defined(__APPLE__)
#include <mach/mach_time.h>
#elif !defined(_WIN32)
#include <time.h>
#endif

static VALUE cMeasureWallTime;

static double measure_wall_time(rb_trace_arg_t* trace_arg)
{
#if defined(_WIN32)
    LARGE_INTEGER time;
    QueryPerformanceCounter(&time);
    return (double)time.QuadPart;
#elif defined(__APPLE__)
    return mach_absolute_time();// * (uint64_t)mach_timebase.numer / (uint64_t)mach_timebase.denom;
#elif defined(__linux__)
    struct timespec tv;
    clock_gettime(CLOCK_MONOTONIC, &tv);
    return tv.tv_sec + (tv.tv_nsec / 1000000000.0);
#else
    struct timeval tv;
    gettimeofday(&tv, NULL);
    return tv.tv_sec + (tv.tv_usec / 1000000.0);
#endif
}

static double multiplier_wall_time(void)
{
#if defined(_WIN32)
    LARGE_INTEGER frequency;
    QueryPerformanceFrequency(&frequency);
    return 1.0 / frequency.QuadPart;
#elif defined(__APPLE__)
    mach_timebase_info_data_t mach_timebase;
    mach_timebase_info(&mach_timebase);
    return (uint64_t)mach_timebase.numer / (uint64_t)mach_timebase.denom / 1000000000.0;
#else
    return 1.0;
#endif
}

prof_measurer_t* prof_measurer_wall_time(bool track_allocations)
{
    prof_measurer_t* measure = ALLOC(prof_measurer_t);
    measure->mode = MEASURE_WALL_TIME;
    measure->measure = measure_wall_time;
    measure->multiplier = multiplier_wall_time();
    measure->track_allocations = track_allocations;
    return measure;
}

void rp_init_measure_wall_time()
{
    rb_define_const(mProf, "WALL_TIME", INT2NUM(MEASURE_WALL_TIME));

    cMeasureWallTime = rb_define_class_under(mMeasure, "WallTime", rb_cObject);
}

Version data entries

20 entries across 20 versions & 1 rubygems

Version Path
ruby-prof-1.6.3-x64-mingw-ucrt ext/ruby_prof/rp_measure_wall_time.c
ruby-prof-1.6.3 ext/ruby_prof/rp_measure_wall_time.c
ruby-prof-1.6.2-x64-mingw-ucrt ext/ruby_prof/rp_measure_wall_time.c
ruby-prof-1.6.2 ext/ruby_prof/rp_measure_wall_time.c
ruby-prof-1.6.1 ext/ruby_prof/rp_measure_wall_time.c
ruby-prof-1.6.1-x64-mingw-ucrt ext/ruby_prof/rp_measure_wall_time.c
ruby-prof-1.5.0-x64-mingw-ucrt ext/ruby_prof/rp_measure_wall_time.c
ruby-prof-1.5.0 ext/ruby_prof/rp_measure_wall_time.c
ruby-prof-1.4.5-x64-mingw-ucrt ext/ruby_prof/rp_measure_wall_time.c
ruby-prof-1.4.5 ext/ruby_prof/rp_measure_wall_time.c
ruby-prof-1.4.4-x64-mingw-ucrt ext/ruby_prof/rp_measure_wall_time.c
ruby-prof-1.4.4 ext/ruby_prof/rp_measure_wall_time.c
ruby-prof-1.4.3-x64-mingw32 ext/ruby_prof/rp_measure_wall_time.c
ruby-prof-1.4.3 ext/ruby_prof/rp_measure_wall_time.c
ruby-prof-1.4.2-x64-mingw32 ext/ruby_prof/rp_measure_wall_time.c
ruby-prof-1.4.2 ext/ruby_prof/rp_measure_wall_time.c
ruby-prof-1.4.1-x64-mingw32 ext/ruby_prof/rp_measure_wall_time.c
ruby-prof-1.4.1 ext/ruby_prof/rp_measure_wall_time.c
ruby-prof-1.4.0-x64-mingw32 ext/ruby_prof/rp_measure_wall_time.c
ruby-prof-1.4.0 ext/ruby_prof/rp_measure_wall_time.c