1 /* Rewritten and vastly simplified by Rusty Russell for in-kernel
 
   3  *   Copyright 2002 Rusty Russell <rusty@rustcorp.com.au> IBM Corporation
 
   5 #ifndef _LINUX_KALLSYMS_H
 
   6 #define _LINUX_KALLSYMS_H
 
   8 #include <linux/errno.h>
 
   9 #include <linux/stddef.h>
 
  11 #define KSYM_NAME_LEN 128
 
  12 #define KSYM_SYMBOL_LEN (sizeof("%s+%#lx/%#lx [%s]") + (KSYM_NAME_LEN - 1) + \
 
  13                          2*(BITS_PER_LONG*3/10) + (MODULE_NAME_LEN - 1) + 1)
 
  15 #ifdef CONFIG_KALLSYMS
 
  16 /* Lookup the address for a symbol. Returns 0 if not found. */
 
  17 unsigned long kallsyms_lookup_name(const char *name);
 
  19 extern int kallsyms_lookup_size_offset(unsigned long addr,
 
  20                                   unsigned long *symbolsize,
 
  21                                   unsigned long *offset);
 
  23 /* Lookup an address.  modname is set to NULL if it's in the kernel. */
 
  24 const char *kallsyms_lookup(unsigned long addr,
 
  25                             unsigned long *symbolsize,
 
  26                             unsigned long *offset,
 
  27                             char **modname, char *namebuf);
 
  29 /* Look up a kernel symbol and return it in a text buffer. */
 
  30 extern int sprint_symbol(char *buffer, unsigned long address);
 
  32 /* Look up a kernel symbol and print it to the kernel messages. */
 
  33 extern void __print_symbol(const char *fmt, unsigned long address);
 
  35 int lookup_symbol_name(unsigned long addr, char *symname);
 
  36 int lookup_symbol_attrs(unsigned long addr, unsigned long *size, unsigned long *offset, char *modname, char *name);
 
  38 #else /* !CONFIG_KALLSYMS */
 
  40 static inline unsigned long kallsyms_lookup_name(const char *name)
 
  45 static inline int kallsyms_lookup_size_offset(unsigned long addr,
 
  46                                               unsigned long *symbolsize,
 
  47                                               unsigned long *offset)
 
  52 static inline const char *kallsyms_lookup(unsigned long addr,
 
  53                                           unsigned long *symbolsize,
 
  54                                           unsigned long *offset,
 
  55                                           char **modname, char *namebuf)
 
  60 static inline int sprint_symbol(char *buffer, unsigned long addr)
 
  66 static inline int lookup_symbol_name(unsigned long addr, char *symname)
 
  71 static inline int lookup_symbol_attrs(unsigned long addr, unsigned long *size, unsigned long *offset, char *modname, char *name)
 
  76 /* Stupid that this does nothing, but I didn't create this mess. */
 
  77 #define __print_symbol(fmt, addr)
 
  78 #endif /*CONFIG_KALLSYMS*/
 
  80 /* This macro allows us to keep printk typechecking */
 
  81 static void __check_printsym_format(const char *fmt, ...)
 
  82 __attribute__((format(printf,1,2)));
 
  83 static inline void __check_printsym_format(const char *fmt, ...)
 
  86 /* ia64 and ppc64 use function descriptors, which contain the real address */
 
  87 #if defined(CONFIG_IA64) || defined(CONFIG_PPC64)
 
  88 #define print_fn_descriptor_symbol(fmt, addr)           \
 
  90         unsigned long *__faddr = (unsigned long*) addr;         \
 
  91         print_symbol(fmt, __faddr[0]);          \
 
  94 #define print_fn_descriptor_symbol(fmt, addr) print_symbol(fmt, addr)
 
  97 static inline void print_symbol(const char *fmt, unsigned long addr)
 
  99         __check_printsym_format(fmt, "");
 
 100         __print_symbol(fmt, (unsigned long)
 
 101                        __builtin_extract_return_addr((void *)addr));
 
 105 #define print_ip_sym(ip)                \
 
 107         printk("[<%08lx>]", ip);        \
 
 108         print_symbol(" %s\n", ip);      \
 
 111 #define print_ip_sym(ip)                \
 
 113         printk("[<%016lx>]", ip);       \
 
 114         print_symbol(" %s\n", ip);      \
 
 118 #endif /*_LINUX_KALLSYMS_H*/