Loading scripts/kallsyms.c +61 −26 Original line number Diff line number Diff line Loading @@ -23,6 +23,10 @@ #include <string.h> #include <ctype.h> #ifndef ARRAY_SIZE #define ARRAY_SIZE(arr) (sizeof(arr) / sizeof(arr[0])) #endif #define KSYM_NAME_LEN 128 struct sym_entry { Loading @@ -32,10 +36,23 @@ struct sym_entry { unsigned char *sym; }; struct text_range { const char *stext, *etext; unsigned long long start, end; }; static unsigned long long _text; static struct text_range text_ranges[] = { { "_stext", "_etext" }, { "_sinittext", "_einittext" }, { "_stext_l1", "_etext_l1" }, /* Blackfin on-chip L1 inst SRAM */ { "_stext_l2", "_etext_l2" }, /* Blackfin on-chip L2 SRAM */ }; #define text_range_text (&text_ranges[0]) #define text_range_inittext (&text_ranges[1]) static struct sym_entry *table; static unsigned int table_size, table_cnt; static unsigned long long _text, _stext, _etext, _sinittext, _einittext; static unsigned long long _stext_l1, _etext_l1, _stext_l2, _etext_l2; static int all_symbols = 0; static char symbol_prefix_char = '\0'; Loading @@ -62,6 +79,26 @@ static inline int is_arm_mapping_symbol(const char *str) && (str[2] == '\0' || str[2] == '.'); } static int read_symbol_tr(const char *sym, unsigned long long addr) { size_t i; struct text_range *tr; for (i = 0; i < ARRAY_SIZE(text_ranges); ++i) { tr = &text_ranges[i]; if (strcmp(sym, tr->stext) == 0) { tr->start = addr; return 0; } else if (strcmp(sym, tr->etext) == 0) { tr->end = addr; return 0; } } return 1; } static int read_symbol(FILE *in, struct sym_entry *s) { char str[500]; Loading @@ -85,22 +122,8 @@ static int read_symbol(FILE *in, struct sym_entry *s) /* Ignore most absolute/undefined (?) symbols. */ if (strcmp(sym, "_text") == 0) _text = s->addr; else if (strcmp(sym, "_stext") == 0) _stext = s->addr; else if (strcmp(sym, "_etext") == 0) _etext = s->addr; else if (strcmp(sym, "_sinittext") == 0) _sinittext = s->addr; else if (strcmp(sym, "_einittext") == 0) _einittext = s->addr; else if (strcmp(sym, "_stext_l1") == 0) _stext_l1 = s->addr; else if (strcmp(sym, "_etext_l1") == 0) _etext_l1 = s->addr; else if (strcmp(sym, "_stext_l2") == 0) _stext_l2 = s->addr; else if (strcmp(sym, "_etext_l2") == 0) _etext_l2 = s->addr; else if (read_symbol_tr(sym, s->addr) == 0) /* nothing to do */; else if (toupper(stype) == 'A') { /* Keep these useful absolute symbols */ Loading Loading @@ -136,6 +159,21 @@ static int read_symbol(FILE *in, struct sym_entry *s) return 0; } static int symbol_valid_tr(struct sym_entry *s) { size_t i; struct text_range *tr; for (i = 0; i < ARRAY_SIZE(text_ranges); ++i) { tr = &text_ranges[i]; if (s->addr >= tr->start && s->addr < tr->end) return 0; } return 1; } static int symbol_valid(struct sym_entry *s) { /* Symbols which vary between passes. Passes 1 and 2 must have Loading Loading @@ -165,10 +203,7 @@ static int symbol_valid(struct sym_entry *s) /* if --all-symbols is not specified, then symbols outside the text * and inittext sections are discarded */ if (!all_symbols) { if ((s->addr < _stext || s->addr > _etext) && (s->addr < _sinittext || s->addr > _einittext) && (s->addr < _stext_l1 || s->addr > _etext_l1) && (s->addr < _stext_l2 || s->addr > _etext_l2)) if (symbol_valid_tr(s) == 0) return 0; /* Corner case. Discard any symbols with the same value as * _etext _einittext; they can move between pass 1 and 2 when Loading @@ -176,10 +211,10 @@ static int symbol_valid(struct sym_entry *s) * they may get dropped in pass 2, which breaks the kallsyms * rules. */ if ((s->addr == _etext && strcmp((char *)s->sym + offset, "_etext")) || (s->addr == _einittext && strcmp((char *)s->sym + offset, "_einittext"))) if ((s->addr == text_range_text->end && strcmp((char *)s->sym + offset, text_range_text->etext)) || (s->addr == text_range_inittext->end && strcmp((char *)s->sym + offset, text_range_inittext->etext))) return 0; } Loading Loading
scripts/kallsyms.c +61 −26 Original line number Diff line number Diff line Loading @@ -23,6 +23,10 @@ #include <string.h> #include <ctype.h> #ifndef ARRAY_SIZE #define ARRAY_SIZE(arr) (sizeof(arr) / sizeof(arr[0])) #endif #define KSYM_NAME_LEN 128 struct sym_entry { Loading @@ -32,10 +36,23 @@ struct sym_entry { unsigned char *sym; }; struct text_range { const char *stext, *etext; unsigned long long start, end; }; static unsigned long long _text; static struct text_range text_ranges[] = { { "_stext", "_etext" }, { "_sinittext", "_einittext" }, { "_stext_l1", "_etext_l1" }, /* Blackfin on-chip L1 inst SRAM */ { "_stext_l2", "_etext_l2" }, /* Blackfin on-chip L2 SRAM */ }; #define text_range_text (&text_ranges[0]) #define text_range_inittext (&text_ranges[1]) static struct sym_entry *table; static unsigned int table_size, table_cnt; static unsigned long long _text, _stext, _etext, _sinittext, _einittext; static unsigned long long _stext_l1, _etext_l1, _stext_l2, _etext_l2; static int all_symbols = 0; static char symbol_prefix_char = '\0'; Loading @@ -62,6 +79,26 @@ static inline int is_arm_mapping_symbol(const char *str) && (str[2] == '\0' || str[2] == '.'); } static int read_symbol_tr(const char *sym, unsigned long long addr) { size_t i; struct text_range *tr; for (i = 0; i < ARRAY_SIZE(text_ranges); ++i) { tr = &text_ranges[i]; if (strcmp(sym, tr->stext) == 0) { tr->start = addr; return 0; } else if (strcmp(sym, tr->etext) == 0) { tr->end = addr; return 0; } } return 1; } static int read_symbol(FILE *in, struct sym_entry *s) { char str[500]; Loading @@ -85,22 +122,8 @@ static int read_symbol(FILE *in, struct sym_entry *s) /* Ignore most absolute/undefined (?) symbols. */ if (strcmp(sym, "_text") == 0) _text = s->addr; else if (strcmp(sym, "_stext") == 0) _stext = s->addr; else if (strcmp(sym, "_etext") == 0) _etext = s->addr; else if (strcmp(sym, "_sinittext") == 0) _sinittext = s->addr; else if (strcmp(sym, "_einittext") == 0) _einittext = s->addr; else if (strcmp(sym, "_stext_l1") == 0) _stext_l1 = s->addr; else if (strcmp(sym, "_etext_l1") == 0) _etext_l1 = s->addr; else if (strcmp(sym, "_stext_l2") == 0) _stext_l2 = s->addr; else if (strcmp(sym, "_etext_l2") == 0) _etext_l2 = s->addr; else if (read_symbol_tr(sym, s->addr) == 0) /* nothing to do */; else if (toupper(stype) == 'A') { /* Keep these useful absolute symbols */ Loading Loading @@ -136,6 +159,21 @@ static int read_symbol(FILE *in, struct sym_entry *s) return 0; } static int symbol_valid_tr(struct sym_entry *s) { size_t i; struct text_range *tr; for (i = 0; i < ARRAY_SIZE(text_ranges); ++i) { tr = &text_ranges[i]; if (s->addr >= tr->start && s->addr < tr->end) return 0; } return 1; } static int symbol_valid(struct sym_entry *s) { /* Symbols which vary between passes. Passes 1 and 2 must have Loading Loading @@ -165,10 +203,7 @@ static int symbol_valid(struct sym_entry *s) /* if --all-symbols is not specified, then symbols outside the text * and inittext sections are discarded */ if (!all_symbols) { if ((s->addr < _stext || s->addr > _etext) && (s->addr < _sinittext || s->addr > _einittext) && (s->addr < _stext_l1 || s->addr > _etext_l1) && (s->addr < _stext_l2 || s->addr > _etext_l2)) if (symbol_valid_tr(s) == 0) return 0; /* Corner case. Discard any symbols with the same value as * _etext _einittext; they can move between pass 1 and 2 when Loading @@ -176,10 +211,10 @@ static int symbol_valid(struct sym_entry *s) * they may get dropped in pass 2, which breaks the kallsyms * rules. */ if ((s->addr == _etext && strcmp((char *)s->sym + offset, "_etext")) || (s->addr == _einittext && strcmp((char *)s->sym + offset, "_einittext"))) if ((s->addr == text_range_text->end && strcmp((char *)s->sym + offset, text_range_text->etext)) || (s->addr == text_range_inittext->end && strcmp((char *)s->sym + offset, text_range_inittext->etext))) return 0; } Loading