bug-ncurses
[Top][All Lists]
Advanced

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

Re: ncurses 20170401 (+) SEGV gdb 7.12.1 in TUI mode on MinGW-w64


From: Allen Hewes
Subject: Re: ncurses 20170401 (+) SEGV gdb 7.12.1 in TUI mode on MinGW-w64
Date: Tue, 13 Jun 2017 05:10:56 +0000

On 6/12/2017 5:40, Johann Klammer wrote:
> On 06/12/2017 04:11 AM, Allen Hewes wrote:
>> Thread 1 received signal SIGSEGV, Segmentation fault.
>> 0x00007ffcd179cdb8 in strncpy () from C:\WINDOWS\System32\msvcrt.dll
>> (gdb) bt full
>> #0  0x00007ffcd179cdb8 in strncpy () from C:\WINDOWS\System32\msvcrt.dll
>> No symbol table info available.
>> #1  0x0000000000742037 in set_curterm_sp (address@hidden, address@hidden)
>>     at ../../../../src/ncurses-6.0-20170401/ncurses/tinfo/lib_cur_term.c:110
>>         TCB = 0x169e7610
>>         oldterm = 0x0
>> #2  0x00000000007436fe in _nc_setupterm_ex (address@hidden, tname=<optimized 
>> out>, address@hidden, Filedes=1,
>>     address@hidden, address@hidden) at 
>> ../../../../src/ncurses-6.0-20170401/ncurses/tinfo/lib_setup.c:777
>>         TCB = 0x169e7610
>>         termp = 0x169e7610
>>         code = 0
>> #3  0x0000000000739ad1 in newterm_sp (sp=<optimized out>, address@hidden, 
>> address@hidden <msvcrt!_iob+48>,
>>     address@hidden <msvcrt!_iob>) at 
>> ../../../../src/ncurses-6.0-20170401/ncurses/base/lib_newterm.c:200
>>         errret = 0
>>         result = 0x0
>>         current = 0x0
>>         its_term = 0x0
>>         _ofp = 0x7ffcd17cf030 <msvcrt!_iob+48>
>>         _ifp = 0x7ffcd17cf000 <msvcrt!_iob>
>>         new_term = 0x169e7610
>> #4  0x0000000000739eb3 in newterm (address@hidden, ofp=0x7ffcd17cf030 
>> <msvcrt!_iob+48>,
>>     address@hidden <msvcrt!_iob>) at 
>> ../../../../src/ncurses-6.0-20170401/ncurses/base/lib_newterm.c:352
>>
>> Using the ncurses 20170325 release GDB 7.12.1 TUI mode works fine.
>>
>> Toolchain I build ncurses with:
>> mingw-w64 v5 (v5 branch)
>> binutils 2.28
>> gcc 6.3.1 (gcc-6-branch)
>> libsystre 1.0.1
>>
>> I don't where / how to do more troubleshooting. Any ideas would be great.
>>
> (gdb) frame 1
> list (or look at the line 110 in a text editor)
> look how the strncpy is called
> print the arguments
> so if it's strncpy(a,b,c)
> enter 
> (gdb) p a
> (gdb) p b
> (gdb) p c
>
> Look for NULL values in pointer variables (here a and b)
> or a missing string terminator.
>
> see where it comes from.
> ahead of the faulting line or
> if necessary searching up the call chain.
>
> (gdb) frame 2
> (gdb) frame 3
>
> etc...
Johann,

It's because termp.type.type_names is empty (0x0):

(gdb) break
../../../../src/ncurses-6.0-20170401/ncurses/tinfo/lib_cur_term.c:110

Breakpoint 1 at 0x748ed2: file
../../../../src/ncurses-6.0-20170401/ncurses/tinfo/lib_cur_term.c, line 110.
Thread 1 hit Breakpoint 1, set_curterm_sp (address@hidden,
address@hidden)
    at ../../../../src/ncurses-6.0-20170401/ncurses/tinfo/lib_cur_term.c:110
110             _nc_STRNCPY(ttytype, termp->type.term_names, MY_SIZE);

(gdb) set termp.type.term_names="#win32console"
(gdb) continue
Continuing.

I don't know enough of ncurses to know why the member
termp->type.term_names would be empty on Windows. But setting the
breakpoint and assigning a value does allow gdb --tui to run. I will
make a local patch to check gdb further.

On another note, I rebuilt ncurses with --with-trace and I didn't get
any output or a trace file. I set NCURSES_TRACE=1. I was expecting to
find a file called trace.log in the current directory.

Thanks,

/allen


reply via email to

[Prev in Thread] Current Thread [Next in Thread]