Merge tag 'trace-printf-v6.13' of git://git.kernel.org/pub/scm/linux/kernel/git/trace...
[drm/drm-misc.git] / tools / lib / symbol / kallsyms.c
blobe335ac2b9e19725790b347e5aee4a30d9f04e738
1 // SPDX-License-Identifier: GPL-2.0
2 #include "symbol/kallsyms.h"
3 #include "api/io.h"
4 #include <stdio.h>
5 #include <sys/stat.h>
6 #include <fcntl.h>
8 u8 kallsyms2elf_type(char type)
10 type = tolower(type);
11 return (type == 't' || type == 'w') ? STT_FUNC : STT_OBJECT;
14 bool kallsyms__is_function(char symbol_type)
16 symbol_type = toupper(symbol_type);
17 return symbol_type == 'T' || symbol_type == 'W';
20 static void read_to_eol(struct io *io)
22 int ch;
24 for (;;) {
25 ch = io__get_char(io);
26 if (ch < 0 || ch == '\n')
27 return;
31 int kallsyms__parse(const char *filename, void *arg,
32 int (*process_symbol)(void *arg, const char *name,
33 char type, u64 start))
35 struct io io;
36 char bf[BUFSIZ];
37 int err;
39 io.fd = open(filename, O_RDONLY, 0);
41 if (io.fd < 0)
42 return -1;
44 io__init(&io, io.fd, bf, sizeof(bf));
46 err = 0;
47 while (!io.eof) {
48 __u64 start;
49 int ch;
50 size_t i;
51 char symbol_type;
52 char symbol_name[KSYM_NAME_LEN + 1];
54 if (io__get_hex(&io, &start) != ' ') {
55 read_to_eol(&io);
56 continue;
58 symbol_type = io__get_char(&io);
59 if (io__get_char(&io) != ' ') {
60 read_to_eol(&io);
61 continue;
63 for (i = 0; i < sizeof(symbol_name); i++) {
64 ch = io__get_char(&io);
65 if (ch < 0 || ch == '\n')
66 break;
67 symbol_name[i] = ch;
69 symbol_name[i] = '\0';
71 err = process_symbol(arg, symbol_name, symbol_type, start);
72 if (err)
73 break;
76 close(io.fd);
77 return err;