|  | /* | 
|  | * Copyright 2017, Data61 | 
|  | * Commonwealth Scientific and Industrial Research Organisation (CSIRO) | 
|  | * ABN 41 687 119 230. | 
|  | * | 
|  | * This software may be distributed and modified according to the terms of | 
|  | * the BSD 2-Clause license. Note that NO WARRANTY is provided. | 
|  | * See "LICENSE_BSD2.txt" for details. | 
|  | * | 
|  | * @TAG(DATA61_BSD) | 
|  | */ | 
|  |  | 
|  | #pragma once | 
|  | #include <autoconf.h> | 
|  | #include <sel4utils/gen_config.h> | 
|  | #ifdef CONFIG_BENCHMARK_TRACEPOINTS | 
|  | #include <inttypes.h> | 
|  | #include <stdio.h> | 
|  |  | 
|  | #include <sel4/simple_types.h> | 
|  | #include <sel4/benchmark_tracepoints_types.h> | 
|  |  | 
|  | /** | 
|  | * Dump the benchmark log. The kernel must be compiled with CONFIG_MAX_NUM_TRACE_POINTS > 0, | 
|  | * either edit .config manually or add it using "make menuconfig" by selecting | 
|  | * "Kernel" -> "seL4 System Parameters" -> "Adds a log buffer to the kernel for instrumentation." | 
|  | */ | 
|  | static inline void seL4_BenchmarkTraceDumpFullLog(benchmark_tracepoint_log_entry_t *logBuffer, size_t logSize) | 
|  | { | 
|  | seL4_Word index = 0; | 
|  | FILE *fd = stdout; | 
|  |  | 
|  | while ((index * sizeof(benchmark_tracepoint_log_entry_t)) < logSize) { | 
|  | if (logBuffer[index].duration != 0) { | 
|  | fprintf(fd, "tracepoint id = %u \tduration = %u\n", logBuffer[index].id, logBuffer[index].duration); | 
|  | } | 
|  | index++; | 
|  | } | 
|  |  | 
|  | fprintf(fd, "Dumped entire log, size %" PRIu32 "\n", index); | 
|  | } | 
|  | #endif /* CONFIG_BENCHMARK_TRACEPOINTS */ |