+ kallsyms-report-consistent-types-for-non-exported.patch added to -mm tree

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

 



The patch titled

     kallsyms: report consistent types for non-exported symbols

has been added to the -mm tree.  Its filename is

     kallsyms-report-consistent-types-for-non-exported.patch

See http://www.zip.com.au/~akpm/linux/patches/stuff/added-to-mm.txt to find
out what to do about this

------------------------------------------------------
Subject: kallsyms: report consistent types for non-exported symbols
From: Adam B. Jerome <abj@xxxxxxxxxx>

Address incorrect symbol type information reported through /proc/kallsyms.

A lowercase character should designate the symbol as local (or
non-exported).  An uppercase character should designate the symbol as
global (or external).  Without this patch, some non-exported symbols are
incorrectly assigned an upper-case designation in /proc/kallsyms.  This
patch corrects this condition by converting non-exported symbols types to
lower case when appropriate and eliminates the superfluous upcase_if_global
function.

Signed-off-by: Adam B. Jerome <abj@xxxxxxxxxx>
Cc: "Randy.Dunlap" <rdunlap@xxxxxxxxxxxx>
Signed-off-by: Andrew Morton <akpm@xxxxxxxx>
---

 kernel/kallsyms.c |   13 +++++--------
 1 files changed, 5 insertions(+), 8 deletions(-)

diff -puN kernel/kallsyms.c~kallsyms-report-consistent-types-for-non-exported kernel/kallsyms.c
--- a/kernel/kallsyms.c~kallsyms-report-consistent-types-for-non-exported
+++ a/kernel/kallsyms.c
@@ -20,6 +20,7 @@
 #include <linux/proc_fs.h>
 #include <linux/sched.h>	/* for cond_resched */
 #include <linux/mm.h>
+#include <linux/ctype.h>
 
 #include <asm/sections.h>
 
@@ -301,13 +302,6 @@ struct kallsym_iter
 	char name[KSYM_NAME_LEN+1];
 };
 
-/* Only label it "global" if it is exported. */
-static void upcase_if_global(struct kallsym_iter *iter)
-{
-	if (is_exported(iter->name, iter->owner))
-		iter->type += 'A' - 'a';
-}
-
 static int get_ksymbol_mod(struct kallsym_iter *iter)
 {
 	iter->owner = module_get_kallsym(iter->pos - kallsyms_num_syms,
@@ -316,7 +310,10 @@ static int get_ksymbol_mod(struct kallsy
 	if (iter->owner == NULL)
 		return 0;
 
-	upcase_if_global(iter);
+	/* Label it "global" if it ix exported, "local" if not exported. */
+	iter->type = is_exported(iter->name, iter->owner)
+		? toupper(iter->type) : tolower(iter->type);
+
 	return 1;
 }
 
_

Patches currently in -mm which might be from abj@xxxxxxxxxx are

kernel-proc-kallsyms-reports-lower-case.patch
kallsyms-report-consistent-types-for-non-exported.patch

-
To unsubscribe from this list: send the line "unsubscribe mm-commits" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Kernel Newbies FAQ]     [Kernel Archive]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [Bugtraq]     [Photo]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]

  Powered by Linux