새로만든 시스템콜에 관련해서 나오는 에러메세지입니다. 부탁드
글쓴이: 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를 훑어 보면서 원인을 짐작해 나가는 수순으로 디버깅합니다.
댓글 달기