2019-05-27 14:55:05 +08:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
2005-04-17 06:20:36 +08:00
|
|
|
/* Generate kernel symbol version hashes.
|
|
|
|
Copyright 1996, 1997 Linux International.
|
|
|
|
|
|
|
|
New implementation contributed by Richard Henderson <rth@tamu.edu>
|
|
|
|
Based on original work by Bjorn Ekwall <bj0rn@blox.se>
|
|
|
|
|
|
|
|
This file is part of the Linux modutils.
|
|
|
|
|
2019-05-27 14:55:05 +08:00
|
|
|
*/
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
#ifndef MODUTILS_GENKSYMS_H
|
|
|
|
#define MODUTILS_GENKSYMS_H 1
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
2006-03-13 06:26:29 +08:00
|
|
|
enum symbol_type {
|
2011-02-04 06:57:09 +08:00
|
|
|
SYM_NORMAL, SYM_TYPEDEF, SYM_ENUM, SYM_STRUCT, SYM_UNION,
|
|
|
|
SYM_ENUM_CONST
|
2005-04-17 06:20:36 +08:00
|
|
|
};
|
|
|
|
|
2008-12-02 06:21:01 +08:00
|
|
|
enum symbol_status {
|
|
|
|
STATUS_UNCHANGED, STATUS_DEFINED, STATUS_MODIFIED
|
|
|
|
};
|
|
|
|
|
2006-03-13 06:26:29 +08:00
|
|
|
struct string_list {
|
|
|
|
struct string_list *next;
|
|
|
|
enum symbol_type tag;
|
2011-10-08 07:18:35 +08:00
|
|
|
int in_source_file;
|
2006-03-13 06:26:29 +08:00
|
|
|
char *string;
|
2005-04-17 06:20:36 +08:00
|
|
|
};
|
|
|
|
|
2006-03-13 06:26:29 +08:00
|
|
|
struct symbol {
|
|
|
|
struct symbol *hash_next;
|
|
|
|
const char *name;
|
|
|
|
enum symbol_type type;
|
|
|
|
struct string_list *defn;
|
|
|
|
struct symbol *expansion_trail;
|
kbuild: support for %.symtypes files
Here is a patch that adds a new -T option to genksyms for generating dumps of
the type definition that makes up the symbol version hashes. This allows to
trace modversion changes back to what caused them. The dump format is the
name of the type defined, followed by its definition (which is almost C):
s#list_head struct list_head { s#list_head * next , * prev ; }
The s#, u#, e#, and t# prefixes stand for struct, union, enum, and typedef.
The exported symbols do not define types, and thus do not have an x# prefix:
nfs4_acl_get_whotype int nfs4_acl_get_whotype ( char * , t#u32 )
The symbol type defintion of a single file can be generated with:
make fs/jbd/journal.symtypes
If KBUILD_SYMTYPES is defined, all the *.symtypes of all object files that
export symbols are generated.
The single *.symtypes files can be combined into a single file after a kernel
build with a script like the following:
for f in $(find -name '*.symtypes' | sort); do
f=${f#./}
echo "/* ${f%.symtypes}.o */"
cat $f
echo
done \
| sed -e '\:UNKNOWN:d' \
-e 's:[,;] }:}:g' \
-e 's:\([[({]\) :\1:g' \
-e 's: \([])},;]\):\1:g' \
-e 's: $::' \
$f \
| awk '
/^.#/ { if (defined[$1] == $0) {
print $1
next
}
defined[$1] = $0
}
{ print }
'
When the kernel ABI changes, diffing individual *.symtype files, or the
combined files, against each other will show which symbol changes caused the
ABI changes. This can save a tremendous amount of time.
Dump the types that make up modversions
Signed-off-by: Andreas Gruenbacher <agruen@suse.de>
Signed-off-by: Sam Ravnborg <sam@ravnborg.org>
2006-05-10 02:37:30 +08:00
|
|
|
struct symbol *visited;
|
2006-03-13 06:26:29 +08:00
|
|
|
int is_extern;
|
2008-12-02 06:21:01 +08:00
|
|
|
int is_declared;
|
|
|
|
enum symbol_status status;
|
2008-12-02 06:21:03 +08:00
|
|
|
int is_override;
|
2005-04-17 06:20:36 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
typedef struct string_list **yystype;
|
|
|
|
#define YYSTYPE yystype
|
|
|
|
|
|
|
|
extern int cur_line;
|
2011-10-08 07:18:35 +08:00
|
|
|
extern char *cur_filename, *source_file;
|
|
|
|
extern int in_source_file;
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2011-02-15 22:11:36 +08:00
|
|
|
struct symbol *find_symbol(const char *name, enum symbol_type ns, int exact);
|
2005-04-17 06:20:36 +08:00
|
|
|
struct symbol *add_symbol(const char *name, enum symbol_type type,
|
2006-03-13 06:26:29 +08:00
|
|
|
struct string_list *defn, int is_extern);
|
2005-04-17 06:20:36 +08:00
|
|
|
void export_symbol(const char *);
|
|
|
|
|
|
|
|
void free_node(struct string_list *list);
|
2006-03-13 06:26:29 +08:00
|
|
|
void free_list(struct string_list *s, struct string_list *e);
|
2005-04-17 06:20:36 +08:00
|
|
|
struct string_list *copy_node(struct string_list *);
|
2011-02-04 06:57:09 +08:00
|
|
|
struct string_list *copy_list_range(struct string_list *start,
|
|
|
|
struct string_list *end);
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
int yylex(void);
|
|
|
|
int yyparse(void);
|
|
|
|
|
2017-05-20 19:27:00 +08:00
|
|
|
void error_with_pos(const char *, ...) __attribute__ ((format(printf, 1, 2)));
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
/*----------------------------------------------------------------------*/
|
|
|
|
#define xmalloc(size) ({ void *__ptr = malloc(size); \
|
|
|
|
if(!__ptr && size != 0) { \
|
|
|
|
fprintf(stderr, "out of memory\n"); \
|
|
|
|
exit(1); \
|
|
|
|
} \
|
|
|
|
__ptr; })
|
|
|
|
#define xstrdup(str) ({ char *__str = strdup(str); \
|
|
|
|
if (!__str) { \
|
|
|
|
fprintf(stderr, "out of memory\n"); \
|
|
|
|
exit(1); \
|
|
|
|
} \
|
|
|
|
__str; })
|
|
|
|
|
2006-03-13 06:26:29 +08:00
|
|
|
#endif /* genksyms.h */
|