10
#include "qemu/cutils.h"
11
#include "qemu/selfmap.h"
13
IntervalTreeRoot *read_self_maps(void)
15
IntervalTreeRoot *root;
19
if (!g_file_get_contents("/proc/self/maps", &maps, NULL, NULL)) {
23
root = g_new0(IntervalTreeRoot, 1);
24
lines = g_strsplit(maps, "\n", 0);
25
nlines = g_strv_length(lines);
27
for (i = 0; i < nlines; i++) {
28
gchar **fields = g_strsplit(lines[i], " ", 6);
29
guint nfields = g_strv_length(fields);
32
uint64_t start, end, offset, inode;
33
unsigned dev_maj, dev_min;
37
errors |= qemu_strtou64(fields[0], &p, 16, &start);
38
errors |= qemu_strtou64(p + 1, NULL, 16, &end);
39
errors |= qemu_strtou64(fields[2], NULL, 16, &offset);
40
errors |= qemu_strtoui(fields[3], &p, 16, &dev_maj);
41
errors |= qemu_strtoui(p + 1, NULL, 16, &dev_min);
42
errors |= qemu_strtou64(fields[4], NULL, 10, &inode);
51
path_len = strlen(p) + 1;
57
e = g_malloc0(sizeof(*e) + path_len);
59
e->itree.start = start;
60
e->itree.last = end - 1;
62
e->dev = makedev(dev_maj, dev_min);
65
e->is_read = fields[1][0] == 'r';
66
e->is_write = fields[1][1] == 'w';
67
e->is_exec = fields[1][2] == 'x';
68
e->is_priv = fields[1][3] == 'p';
71
e->path = memcpy(e + 1, p, path_len);
74
interval_tree_insert(&e->itree, root);
94
static void free_rbnode(RBNode *n)
97
free_rbnode(n->rb_left);
98
free_rbnode(n->rb_right);
103
void free_self_maps(IntervalTreeRoot *root)
106
free_rbnode(root->rb_root.rb_node);