On Thu, Jun 25, 2015 at 04:21:40PM +0100, Damien Lespiau wrote: > The master plan would be to get a bit more stats in it, at least the > standard deviation and confidence interval. Just need the average for > now. > > Signed-off-by: Damien Lespiau <damien.lespiau@xxxxxxxxx> gtkdoc is missing for this. -Daniel > --- > lib/Makefile.sources | 2 ++ > lib/igt_stats.c | 56 ++++++++++++++++++++++++++++++++++++++++++++++ > lib/igt_stats.h | 36 +++++++++++++++++++++++++++++ > lib/tests/.gitignore | 1 + > lib/tests/Makefile.sources | 1 + > lib/tests/igt_stats.c | 49 ++++++++++++++++++++++++++++++++++++++++ > 6 files changed, 145 insertions(+) > create mode 100644 lib/igt_stats.c > create mode 100644 lib/igt_stats.h > create mode 100644 lib/tests/igt_stats.c > > diff --git a/lib/Makefile.sources b/lib/Makefile.sources > index 85dc321..f8a1b92 100644 > --- a/lib/Makefile.sources > +++ b/lib/Makefile.sources > @@ -12,6 +12,8 @@ libintel_tools_la_SOURCES = \ > igt_aux.h \ > igt_gt.c \ > igt_gt.h \ > + igt_stats.c \ > + igt_stats.h \ > instdone.c \ > instdone.h \ > intel_batchbuffer.c \ > diff --git a/lib/igt_stats.c b/lib/igt_stats.c > new file mode 100644 > index 0000000..fcf7abe > --- /dev/null > +++ b/lib/igt_stats.c > @@ -0,0 +1,56 @@ > +/* > + * Copyright © 2015 Intel Corporation > + * > + * Permission is hereby granted, free of charge, to any person obtaining a > + * copy of this software and associated documentation files (the "Software"), > + * to deal in the Software without restriction, including without limitation > + * the rights to use, copy, modify, merge, publish, distribute, sublicense, > + * and/or sell copies of the Software, and to permit persons to whom the > + * Software is furnished to do so, subject to the following conditions: > + * > + * The above copyright notice and this permission notice (including the next > + * paragraph) shall be included in all copies or substantial portions of the > + * Software. > + * > + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR > + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, > + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL > + * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER > + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING > + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS > + * IN THE SOFTWARE. > + * > + */ > + > +#include "igt_core.h" > +#include "igt_stats.h" > + > +void igt_stats_init(igt_stats_t *stats, unsigned int capacity) > +{ > + stats->values = calloc(capacity, sizeof(*stats->values)); > + igt_assert(stats->values); > + stats->capacity = capacity; > + stats->n_values = 0; > +} > + > +void igt_stats_fini(igt_stats_t *stats) > +{ > + free(stats->values); > +} > + > +void igt_stats_push(igt_stats_t *stats, uint64_t value) > +{ > + igt_assert(stats->n_values < stats->capacity); > + stats->values[stats->n_values++] = value; > +} > + > +double igt_stats_get_average(igt_stats_t *stats) > +{ > + unsigned int i; > + double a = 0.0; > + > + for (i = 0; i < stats->n_values; i++) > + a += (double)stats->values[i] / stats->n_values; > + > + return a; > +} > diff --git a/lib/igt_stats.h b/lib/igt_stats.h > new file mode 100644 > index 0000000..99dc1c9 > --- /dev/null > +++ b/lib/igt_stats.h > @@ -0,0 +1,36 @@ > +/* > + * Copyright © 2015 Intel Corporation > + * > + * Permission is hereby granted, free of charge, to any person obtaining a > + * copy of this software and associated documentation files (the "Software"), > + * to deal in the Software without restriction, including without limitation > + * the rights to use, copy, modify, merge, publish, distribute, sublicense, > + * and/or sell copies of the Software, and to permit persons to whom the > + * Software is furnished to do so, subject to the following conditions: > + * > + * The above copyright notice and this permission notice (including the next > + * paragraph) shall be included in all copies or substantial portions of the > + * Software. > + * > + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR > + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, > + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL > + * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER > + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING > + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS > + * IN THE SOFTWARE. > + * > + */ > + > +#include <stdint.h> > + > +typedef struct { > + uint64_t *values; > + unsigned int capacity; > + unsigned int n_values; > +} igt_stats_t; > + > +void igt_stats_init(igt_stats_t *stats, unsigned int capacity); > +void igt_stats_fini(igt_stats_t *stats); > +void igt_stats_push(igt_stats_t *stats, uint64_t value); > +double igt_stats_get_average(igt_stats_t *stats); > diff --git a/lib/tests/.gitignore b/lib/tests/.gitignore > index a745a23..5b6b3c4 100644 > --- a/lib/tests/.gitignore > +++ b/lib/tests/.gitignore > @@ -7,4 +7,5 @@ igt_no_exit_list_only > igt_no_subtest > igt_simple_test_subtests > igt_simulation > +igt_stats > igt_timeout > diff --git a/lib/tests/Makefile.sources b/lib/tests/Makefile.sources > index 10e0617..7521228 100644 > --- a/lib/tests/Makefile.sources > +++ b/lib/tests/Makefile.sources > @@ -6,6 +6,7 @@ check_PROGRAMS = \ > igt_no_subtest \ > igt_simulation \ > igt_simple_test_subtests \ > + igt_stats \ > igt_timeout \ > igt_invalid_subtest_name \ > $(NULL) > diff --git a/lib/tests/igt_stats.c b/lib/tests/igt_stats.c > new file mode 100644 > index 0000000..e75a203 > --- /dev/null > +++ b/lib/tests/igt_stats.c > @@ -0,0 +1,49 @@ > +/* > + * Copyright © 2015 Intel Corporation > + * > + * Permission is hereby granted, free of charge, to any person obtaining a > + * copy of this software and associated documentation files (the "Software"), > + * to deal in the Software without restriction, including without limitation > + * the rights to use, copy, modify, merge, publish, distribute, sublicense, > + * and/or sell copies of the Software, and to permit persons to whom the > + * Software is furnished to do so, subject to the following conditions: > + * > + * The above copyright notice and this permission notice (including the next > + * paragraph) shall be included in all copies or substantial portions of the > + * Software. > + * > + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR > + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, > + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL > + * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER > + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING > + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS > + * IN THE SOFTWARE. > + * > + */ > + > +#include "igt_core.h" > +#include "igt_stats.h" > + > +static void test_average(void) > +{ > + igt_stats_t stats; > + double average; > + > + igt_stats_init(&stats, 5); > + > + igt_stats_push(&stats, 2); > + igt_stats_push(&stats, 4); > + igt_stats_push(&stats, 6); > + igt_stats_push(&stats, 8); > + igt_stats_push(&stats, 10); > + > + average = igt_stats_get_average(&stats); > + > + igt_assert(average == (2 + 4 + 6 + 8 + 10) / 5.); > +} > + > +igt_simple_main > +{ > + test_average(); > +} > -- > 2.1.0 > > _______________________________________________ > Intel-gfx mailing list > Intel-gfx@xxxxxxxxxxxxxxxxxxxxx > http://lists.freedesktop.org/mailman/listinfo/intel-gfx -- Daniel Vetter Software Engineer, Intel Corporation http://blog.ffwll.ch _______________________________________________ Intel-gfx mailing list Intel-gfx@xxxxxxxxxxxxxxxxxxxxx http://lists.freedesktop.org/mailman/listinfo/intel-gfx