-
Notifications
You must be signed in to change notification settings - Fork 15
Expand file tree
/
Copy pathpageset_trace.c
More file actions
83 lines (72 loc) · 2.34 KB
/
pageset_trace.c
File metadata and controls
83 lines (72 loc) · 2.34 KB
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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
/*
* Copyright 2024 Morse Micro
*/
#include <linux/ktime.h>
#include "pageset_trace.h"
#include "morse.h"
#include "firmware.h"
static const char *trace_id_to_string(enum pageset_trace_event_id id)
{
switch (id) {
case PAGESET_TRACE_EVENT_ID_INIT:
return "init";
case PAGESET_TRACE_EVENT_ID_CACHE_PUT_PAGES:
return "cache put pages";
case PAGESET_TRACE_EVENT_ID_POP_PAGE:
return "pop";
case PAGESET_TRACE_EVENT_ID_CACHE_GET:
return "cache get";
case PAGESET_TRACE_EVENT_ID_PUT_PAGE:
return "put";
case PAGESET_TRACE_EVENT_ID_STORE_PAGE_BULK:
return "store bit bulk";
case PAGESET_TRACE_EVENT_ID_NOTIFY:
return "notify";
case PAGESET_TRACE_EVENT_ID_WRITE_PAGE:
return "write page";
case PAGESET_TRACE_EVENT_ID_READ_PAGE:
return "read page";
}
return "unknown";
}
static const char *pager_flags_to_string(u32 flags)
{
if (flags & MORSE_PAGER_FLAGS_DIR_TO_HOST) {
return (flags & MORSE_PAGER_FLAGS_FREE) ?
"to_host(free)" : "to_host(populated)";
} else if (flags & MORSE_PAGER_FLAGS_DIR_TO_CHIP) {
return (flags & MORSE_PAGER_FLAGS_FREE) ?
"from_host(free)" : "from_host(populated)";
}
return "unknown";
}
void pageset_trace_dump(const struct morse_pageset *pageset, ktime_t reference)
{
unsigned int count;
unsigned int i = pageset->trace.trace_index; /* start at oldest */
for (count = 0; count < ARRAY_SIZE(pageset->trace.events); count++) {
const struct pageset_trace_event *event = &pageset->trace.events[i];
pr_info("[%9llu] %-20s : %15s : 0x%08x",
ktime_to_us(ktime_sub(reference, event->ts)),
pager_flags_to_string(event->flags),
trace_id_to_string(event->id),
event->argument);
i = (i + 1) % ARRAY_SIZE(pageset->trace.events);
}
}
void pageset_trace_log(const struct morse_pager *pager, enum pageset_trace_event_id id,
unsigned int argument)
{
struct morse_pageset *pageset = (struct morse_pageset *)pager->parent;
unsigned int index = pageset->trace.trace_index;
pageset->trace.events[index].ts = ktime_get_boottime();
pageset->trace.events[index].id = id;
pageset->trace.events[index].flags = pager->flags;
pageset->trace.events[index].argument = argument;
pageset->trace.trace_index = (index + 1) % ARRAY_SIZE(pageset->trace.events);
}
void pageset_trace_init(struct morse_pageset *pageset)
{
pageset->trace.trace_index = 0;
memset(&pageset->trace.events, 0, sizeof(pageset->trace.events));
}