Re: [patch] lockdep: special s390 print_symbol() version

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



> --- linux-2.6.17-mm3.orig/include/linux/kallsyms.h
> +++ linux-2.6.17-mm3/include/linux/kallsyms.h
> @@ -57,11 +57,20 @@ do {						\
>  #define print_fn_descriptor_symbol(fmt, addr) print_symbol(fmt, addr)
>  #endif
>  
> +/* need to clear the most significant bit on s390 31bit */
> +#if defined(CONFIG_S390) && !defined(CONFIG_64BIT)
> +#define print_symbol(fmt, addr)			\
> +do {						\
> +	__check_printsym_format(fmt, "");	\
> +	__print_symbol(fmt, addr & 0x7fffffff);	\
> +} while(0)
> +#else
>  #define print_symbol(fmt, addr)			\
>  do {						\
>  	__check_printsym_format(fmt, "");	\
>  	__print_symbol(fmt, addr);		\
>  } while(0)
> +#endif

Martin made me just aware of __builtin_extract_return_addr() which will
do the trick as well and avoids adding yet another ifdef.
So, how about this one instead:

From: Heiko Carstens <[email protected]>

Use __builtin_extract_return_addr() in print_symbol() to deal with s390 which
has the most significant bit set in instruction pointers.

Without this the output would look like:

hardirqs last  enabled at (30907): [<80018c6a>] 0x80018c6a
hardirqs last disabled at (30908): [<8001e48c>] 0x8001e48c
softirqs last  enabled at (30904): [<8001dc96>] 0x8001dc96
softirqs last disabled at (30897): [<8001dc50>] 0x8001dc50

instead of this:

hardirqs last  enabled at (19421): [<80018c72>] cpu_idle+0x176/0x1c4
hardirqs last disabled at (19422): [<8001e494>] io_no_vtime+0xa/0x1a
softirqs last  enabled at (19418): [<8001dc9e>] do_softirq+0xa6/0xe8
softirqs last disabled at (19411): [<8001dc58>] do_softirq+0x60/0xe8

Cc: Ingo Molnar <[email protected]>
Cc: Arjan van de Ven <[email protected]>
Cc: Martin Schwidefsky <[email protected]>
Signed-off-by: Heiko Carstens <[email protected]>
---

 include/linux/kallsyms.h |   11 ++++++-----
 1 file changed, 6 insertions(+), 5 deletions(-)

Index: linux-2.6.17-mm3/include/linux/kallsyms.h
===================================================================
--- linux-2.6.17-mm3.orig/include/linux/kallsyms.h
+++ linux-2.6.17-mm3/include/linux/kallsyms.h
@@ -57,11 +57,12 @@ do {						\
 #define print_fn_descriptor_symbol(fmt, addr) print_symbol(fmt, addr)
 #endif
 
-#define print_symbol(fmt, addr)			\
-do {						\
-	__check_printsym_format(fmt, "");	\
-	__print_symbol(fmt, addr);		\
-} while(0)
+static inline void print_symbol(const char *fmt, unsigned long addr)
+{
+	__check_printsym_format(fmt, "");
+	__print_symbol(fmt, (unsigned long)
+		       __builtin_extract_return_addr((void *)addr));
+}
 
 #ifndef CONFIG_64BIT
 #define print_ip_sym(ip)		\
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

[Index of Archives]     [Kernel Newbies]     [Netfilter]     [Bugtraq]     [Photo]     [Stuff]     [Gimp]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Video 4 Linux]     [Linux for the blind]     [Linux Resources]
  Powered by Linux