On Wed, Sep 19, 2007 at 12:48:26AM +0200, Gabriel C wrote:
> Gabriel C wrote:
> > Sam Ravnborg wrote:
> >> On Tue, Sep 18, 2007 at 03:42:58PM -0400, Miles Lane wrote:
> >>> On 9/18/07, Sam Ravnborg <[EMAIL PROTECTED]> wrote:
> >>>> Hi Miles.
> >>>> On Tue, Sep 18, 2007 at 11:27:23AM -0400, Miles Lane wrote:
> >>>>> Selecting Help for "Subarchitecture Type" causes "make menuconfig" to
> >>>>> crash, and the bash display settings have to be reset.
> >>>> Not reproduceable here.
> >>>> But I noticed that we pass a null pointer to a vsprintf function which
> >>>> in the cases you pointed out printed a (null) at my system.
> >>>> Could you plase try if attached patch fix your system.
> >>> Sorry, it still crashes.  I am running Ubuntu pre-6.10 (Gutsy -- the
> >>> development version of the distro).  Maybe I should try "make
> >>> mrproper" first?
> >> make mrproper should not do any difference here.
> >> I rather think you hit some ncurses bug.
> >>
> >> If you could add '-g' to HOSTCFLAGS in top-level Makefile
> >> and then do:
> >> rm scripts/kconfig/mconf.o scripts/kconfig/mconf
> >> make menuconfig
> >>
> >> (to build mconf and to check that the error is still reproduceable).
> >> And then run it in a debugger like this:
> >> gdb scripts/kconfig/mconf
> >> run arch/x86_64/Kconfig
> >>          ^^^^^^ replace with your actual arch
> >>
> >> Provoke the error and get a back-trace with 'bt'.
> > 
> > Hi Sam,
> > 
> > I can reproduce this bug on Frugalware Linux. 
> > 
> > Here the bt:
> > 
> > Program received signal SIGSEGV, Segmentation fault.                        
> >                              
> > 0xb7dc4143 in strlen () from /lib/libc.so.6                                 
> >                                                                             
> >                           
> > (gdb) bt                                                                    
> >                                                                             
> >                           
> > #0  0xb7dc4143 in strlen () from /lib/libc.so.6                             
> >                                                                             
> >                           
> > #1  0x0804fd60 in str_append (gs=0xbfe4f6e8, s=0x0) at 
> > scripts/kconfig/util.c:87                                                   
> >                                                
> > #2  0x0804e0cb in expr_print (e=0x8e22df8, fn=0x804fda0 
> > <expr_print_gstr_helper>, data=0xbfe4f6e8, prevtoken=0) at 
> > scripts/kconfig/expr.c:1037                                    
> > #3  0x0804e1e7 in expr_gstr_print (e=0x8e22df8, gs=0xbfe4f6e8) at 
> > scripts/kconfig/expr.c:1099                                                 
> >                                     
> > #4  0x0804a07e in get_symbol_str (r=0xbfe4f6e8, sym=0x8b54ee8) at 
> > scripts/kconfig/mconf.c:334                                                 
> >                                     
> > #5  0x0804a363 in show_help (menu=0x8b54f88) at scripts/kconfig/mconf.c:738 
> >                                                                             
> >                           
> > #6  0x0804acec in conf (menu=0x8b69480) at scripts/kconfig/mconf.c:781      
> >                                                                             
> >                           
> > #7  0x0804a971 in conf (menu=0x8063c40) at scripts/kconfig/mconf.c:703      
> >                                                                             
> >                           
> > #8  0x0804af8a in main (ac=Cannot access memory at address 0x0              
> >                                                                             
> >                           
> > ) at scripts/kconfig/mconf.c:917
> > 
> > 
> > Looks somewhat strange -> http://194.231.229.228/menuconfig.png
> > 
> > PS: Is without the patch you posted , I'll try with in a bit
> 
> The crash is still there but the (null)'s are all fixed by this patch.

Got it. We sometimes get a numm pointer when printing the expression (in 
expr.c).
I have queued following fix.

Thanks for reporting!

        Sam

Patch is copy'n'pased due to temporary setup troubles after upgradign to Gutsy.
Will be at kbuil.git in a few minutes.

>From 69d39ec036b4fca541efc3c9ee31ec65d6b95bd4 Mon Sep 17 00:00:00 2001
From: Sam Ravnborg <[EMAIL PROTECTED]>
Date: Wed, 19 Sep 2007 21:23:09 +0200
Subject: [PATCH] kconfig: fix segv fault in menuconfig

With specific configurations requesting help for certain
menu lines caused menuconfig to crash.
This was tracked down to a null pointer bug.
Thanks to "Miles Lane" <[EMAIL PROTECTED]> for inital reporting
and to Gabriel C <[EMAIL PROTECTED]> for the backtrace
that helped me locating the bug.

Signed-off-by: Sam Ravnborg <[EMAIL PROTECTED]>
---
 scripts/kconfig/mconf.c |    5 +++--
 scripts/kconfig/util.c  |   13 ++++++++-----
 2 files changed, 11 insertions(+), 7 deletions(-)

diff --git a/scripts/kconfig/mconf.c b/scripts/kconfig/mconf.c
index 2ee12a7..1935818 100644
--- a/scripts/kconfig/mconf.c
+++ b/scripts/kconfig/mconf.c
@@ -357,8 +357,9 @@ static void get_symbol_str(struct gstr *r, struct symbol 
*sym)
        bool hit;
        struct property *prop;
 
-       str_printf(r, "Symbol: %s [=%s]\n", sym->name,
-                                      sym_get_string_value(sym));
+       if (sym && sym->name)
+               str_printf(r, "Symbol: %s [=%s]\n", sym->name,
+                                                   sym_get_string_value(sym));
        for_all_prompts(sym, prop)
                get_prompt_str(r, prop);
        hit = false;
diff --git a/scripts/kconfig/util.c b/scripts/kconfig/util.c
index e3f28b9..e1cad92 100644
--- a/scripts/kconfig/util.c
+++ b/scripts/kconfig/util.c
@@ -84,12 +84,15 @@ void str_free(struct gstr *gs)
 /* Append to growable string */
 void str_append(struct gstr *gs, const char *s)
 {
-       size_t l = strlen(gs->s) + strlen(s) + 1;
-       if (l > gs->len) {
-               gs->s   = realloc(gs->s, l);
-               gs->len = l;
+       size_t l;
+       if (s) {
+               l = strlen(gs->s) + strlen(s) + 1;
+               if (l > gs->len) {
+                       gs->s   = realloc(gs->s, l);
+                       gs->len = l;
+               }
+               strcat(gs->s, s);
        }
-       strcat(gs->s, s);
 }
 
 /* Append printf formatted string to growable string */

-
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/

Reply via email to