1
0
mirror of https://github.com/physwizz/a155-U-u1.git synced 2025-10-07 10:09:34 +00:00
Files
physwizz 99537be4e2 first
2024-03-11 06:53:12 +11:00

74 lines
1.6 KiB
C

/* SPDX-License-Identifier: GPL-2.0 */
/*
* Copyright (c) 2015-2019, MICROTRUST Incorporated
*
*
*/
#define ENABLE_LOG_PERF 0
static inline uint64_t read_cntvct(void)
{
uint64_t val;
asm volatile("mrs %0, cntvct_el0" : "=r" (val));
return val;
}
#if ENABLE_LOG_PERF == 1
#define LOG_MEASURE_START 0x7c40407c /* |@@| */
#define LOG_MEASURE_END 0x7c2d2d7c /* |--| */
static unsigned int received_tz_log_chars;
static unsigned int received_tz_log_lines;
static bool tz_log_timer_started;
static uint64_t start_log_timer_counter, end_log_timer_counter;
static void reset_tz_log_counter(void)
{
received_tz_log_chars = 0;
received_tz_log_lines = 0;
}
static void add_tz_log_counter(unsigned int num_chars)
{
received_tz_log_chars += num_chars;
received_tz_log_lines++;
}
static void measure_log_perf(const char *tag, int log_len, uint32_t log_prefix)
{
if (log_len > 0) {
if (log_prefix == LOG_MEASURE_START) {
if (!tz_log_timer_started) {
start_log_timer_counter = read_cntvct();
tz_log_timer_started = true;
reset_tz_log_counter();
}
add_tz_log_counter(log_len-1);
}
if (log_prefix == LOG_MEASURE_END) {
if (!tz_log_timer_started)
IMSG_WARN("[BUG] log timer not start yet!\n");
else {
end_log_timer_counter = read_cntvct();
tz_log_timer_started = false;
IMSG_PRINTK("%s[RLOG] Recv Log (%u)/(%u)\n",
tag, received_tz_log_chars,
received_tz_log_lines);
IMSG_PRINTK("%s[RLOG] (%llu)~(%llu)/(%llu)\n",
tag, start_log_timer_counter,
end_log_timer_counter,
end_log_timer_counter - start_log_timer_counter);
}
}
}
}
#endif