-
Notifications
You must be signed in to change notification settings - Fork 8
/
wall_timer.h
52 lines (44 loc) · 2.36 KB
/
wall_timer.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
/*
* Environmental Characterization & Response
* Copyright (C) 2018 Assured Information Security, Inc.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
#ifndef WALL_TIMER_H
#define WALL_TIMER_H
extern uintptr_t *vmem_aligned;
#define TIMING_LOOP(FUNCTION_CALL, PRINT_NAME, LOOP_ITERATIONS) \
getnstimeofday(&ts_start); \
for ( int i = 0; i < LOOP_ITERATIONS; i++ ) { \
FUNCTION_CALL; \
} \
getnstimeofday(&ts_end); \
test_of_time = timespec_sub(ts_end, ts_start); \
pr_info("WALL_%s: %lu\n", PRINT_NAME, test_of_time.tv_nsec);
#define TIMING_LOOP_SUSPEND_INTERRUPTS(FUNCTION_CALL, PRINT_NAME, LOOP_ITERATIONS, FLAGS) \
SUSPEND_INTERRUPTS(FLAGS, TIMING_LOOP(FUNCTION_CALL, PRINT_NAME, LOOP_ITERATIONS))
#define TIMING_LOOP_BOOT_FEATURE_CHECK(FUNCTION_CALL, PRINT_NAME, LOOP_ITERATIONS, FEATURE_NAME) \
if ( boot_cpu_has(FEATURE_NAME) ) { \
TIMING_LOOP(FUNCTION_CALL, PRINT_NAME, LOOP_ITERATIONS) \
}
#define TIMING_LOOP_CHECK_FOR_KMALLOC(FUNCTION_CALL, PRINT_NAME, LOOP_ITERATIONS) \
if ( vmem_aligned ) { \
TIMING_LOOP(FUNCTION_CALL, PRINT_NAME, LOOP_ITERATIONS) \
} else { \
pr_info("WALL_%s: 0\n", PRINT_NAME); \
}
int wall_timing_start(void);
int buffer_flush_start(void);
#endif