새로만든 시스템콜에 관련해서 나오는 에러메세지입니다. 부탁드
      글쓴이: munin / 작성시간: 수, 2004/03/31 - 5:06오후    
  
  
Unable to handle kernel NULL pointer dereference at virtual address 00000000
 printing eip:
c011e7d1
*pde = 00000000
Oops: 0000
autofs 3c59x ipt_REJECT iptable_filter ip_tables mousedev keybdev input hid us
CPU:    0
EIP:    0010:[<c011e7d1>]    Not tainted
EFLAGS: 00010297
EIP is at close_files [kernel] 0x21 (2.4.18-14custom)
eax: 00000000   ebx: c2913560   ecx: 00000000   edx: 00000001
esi: 00000000   edi: 00000000   ebp: c2913560   esp: cf139eac
ds: 0018   es: 0018   ss: 0018
Process a.out (pid: 822, stackpage=cf139000)
Stack: 00000300 00000001 00000000 c2913560 00000000 cf138000 0000000b c011d9b8 
       c2913560 cf138000 c1a8fb20 c011e025 c2913560 c1b012dc cf138000 00000000 
       cf139f30 0000000b c012436c 0000000b c0124554 0000000b c2cba8cc 0000000b 
Call Trace: [<c011d9b8>] put_files_struct [kernel] 0x28 (0xcf139ec8))
[<c011e025>] do_exit [kernel] 0xc5 (0xcf139ed8))
[<c012436c>] sig_exit [kernel] 0xac (0xcf139ef4))
[<c0124554>] dequeue_signal [kernel] 0x64 (0xcf139efc))
[<c0108ea7>] do_signal [kernel] 0x1f7 (0xcf139f14))
[<c01168c0>] do_page_fault [kernel] 0x0 (0xcf139fb8))
[<c0109148>] signal_return [kernel] 0x14 (0xcf139fc0))
Code: 8b 1c b8 47 85 db 74 e7 c7 44 24 08 00 e0 ff ff b8 00 e0 ff 
 
보통 printk로 디버깅을 했었는대...
이렇게 나오니 어디서부터 손을 대야할지...;;;
혹시나 어떤 에러인지 아시는 분이 계시면 꼭 부탁드립니다.
그리고 덤으로 이런 경우 어떻게 디버깅을 해야하는지 알려주시면 정말 감사드립니다.
좋은 하루되세요.
Forums: 


이런 경우의 에러는 보통 할당하지 않은 메모리를 접근했을 때 나오는 에러
이런 경우의 에러는 보통 할당하지 않은 메모리를 접근했을 때 나오는 에러인 것 같습니다.
혹시 어떤 변수가 메모리를 할당 받지 못했는지 나와있지는 않나요?
혹시 어떤 변수가 메모리를 할당 받지 못했는지 나와있지는 않나요?
아니면 이런경우 디버깅 하는 요령이라도...^^;;;
꼭 부탇드립니다.
修身齊家治國平天下
대규모 커널/드라이버 프로그래밍을 하는 경우는 crash 툴을 씁니다.
대규모 커널/드라이버 프로그래밍을 하는 경우는 crash 툴을 씁니다. gdb 의 add-on 이죠.
http://oss.missioncriticallinux.com/projects/crash/
스택을 back-trace 한후, 어느 메모리를 액세스하다가 null-pointer dereferecing fault 가 발생했는지를 확인한 후에 data structure를 훑어 보면서 원인을 짐작해 나가는 수순으로 디버깅합니다.
댓글 달기