usb device driver 때문에 kernel 이 멈춥니다.
안녕하세요.
현재 제가 TDBD라는 이름의 8 채널 usb audio 입력장치를 쓰고 있습니다. 이 장치를 실행하고 독립된 연산이 많은 다른 프로세스 들을 실행 시키면 리눅스 커널이 멈춰 버립니다.
시스템이 다운되기 전에 동작시킨후 kernel debugging message를 보면 다음과 같은 message가 출력되는데요.
이 메세지를 어떤식으로 분석해야 될지 몰라 이렇게 글을 올립니다. 염치 없지만 답변 부탁 드립니다.
message :
[ 73.465803] tdbd8csusb device open
[ 81.271801] BUG: scheduling while atomic: flowdesigner/5976/0x10010000
[ 81.271806]
[ 81.271809] Pid: 5976, comm: flowdesigner Not tainted (2.6.24-24-generic #1)
[ 81.271811] EIP: 0060:[] EFLAGS: 00200297 CPU: 0
[ 81.271816] EIP is at sysenter_past_esp+0x9/0xa9
[ 81.271818] EAX: 00000036 EBX: 0000000d ECX: c00c5404 EDX: abb942dc
[ 81.271820] ESI: 00000000 EDI: abb94b90 EBP: abb942a8 ESP: f35adff8
[ 81.271821] DS: 007b ES: 007b FS: 0000 GS: 0033 SS: 0068
[ 81.271823] CR0: 8005003b CR2: 08050000 CR3: 375d5000 CR4: 00000690
[ 81.271825] DR0: 00000000 DR1: 00000000 DR2: 00000000 DR3: 00000000
[ 81.271827] DR6: ffff0ff0 DR7: 00000400
[ 81.271843] =======================
[ 81.974596] BUG: scheduling while atomic: flowdesigner/5976/0x10010000
[ 81.974601]
[ 81.974604] Pid: 5976, comm: flowdesigner Not tainted (2.6.24-24-generic #1)
[ 81.974606] EIP: 0060:[] EFLAGS: 00200202 CPU: 0
[ 81.974612] EIP is at fget_light+0x36/0xa0
[ 81.974613] EAX: f76a4cc0 EBX: f76a4cc0 ECX: 00000001 EDX: f35adfa8
[ 81.974615] ESI: 00000000 EDI: 00000002 EBP: f35ac000 ESP: f35adf94
[ 81.974617] DS: 007b ES: 007b FS: 00d8 GS: 0033 SS: 0068
[ 81.974619] CR0: 8005003b CR2: b7e891d0 CR3: 375d5000 CR4: 00000690
[ 81.974620] DR0: 00000000 DR1: 00000000 DR2: 00000000 DR3: 00000000
[ 81.974622] DR6: ffff0ff0 DR7: 00000400
[ 81.974641] [] sys_ioctl+0x17/0x70
[ 81.974648] [] sysenter_past_esp+0x6b/0xa9
[ 81.974657] =======================
[ 82.263093] BUG: scheduling while atomic: flowdesigner/5976/0x10010000
[ 82.263098]
[ 82.263100] Pid: 5976, comm: flowdesigner Not tainted (2.6.24-24-generic #1)
[ 82.263102] EIP: 0060:[] EFLAGS: 00200286 CPU: 0
[ 82.263108] EIP is at do_ioctl+0x6d/0x90
[ 82.263110] EAX: f68b42a8 EBX: f8e27bc0 ECX: c00c5404 EDX: f35ac000
[ 82.263112] ESI: f76a4cc0 EDI: abb942dc EBP: c00c5404 ESP: f35adf70
[ 82.263113] DS: 007b ES: 007b FS: 00d8 GS: 0033 SS: 0068
[ 82.263115] CR0: 8005003b CR2: abbf7000 CR3: 375d5000 CR4: 00000690
[ 82.263117] DR0: 00000000 DR1: 00000000 DR2: 00000000 DR3: 00000000
[ 82.263119] DR6: ffff0ff0 DR7: 00000400
[ 82.263139] [] vfs_ioctl+0x22e/0x2b0
[ 82.263145] [] sys_ioctl+0x56/0x70
[ 82.263150] [] sysenter_past_esp+0x6b/0xa9
[ 82.263158] =======================
현재 사용하고 있는 것은 ubuntu8.04이고 현재 flowdesigner 라는 어플에서 해당 드라이버를 호출하여 사용하고 있습니다.
usb driver 단에서 장치로 부터 데이터를 받아와 버퍼에 저장하는 부분에서 spin_lock를 사용하였는데요(제공되어진 드라이버 소스 입니다.) 이부분이 문제 인건가요?
아니면 제가 쓰는 flowdesigner 라는 프로그램과 충돌을 일으키는 건가요??
2.6.24 커널이고,
2.6.24 커널이고, 어플에서 ioctl() 을 호출했고요.
드라이버에서 .unlocked_ioctl 콜백을 제공한다면 바로 드라이버의 콜백이 호출되지만,
그렇지 않고 .ioctl 콜백을 제공한다면 lock_kernel()이 먼저 수행된 후에 드라이버의 ioctl 콜백이 호출됩니다.
(spin_lock() 과 마찬가지의 상태가됩니다)
이유가 뭐든간에 spin_lock 상태로 진입했다면,
conditional/semaphore wait 등 스케쥴러에 간섭해 들어갈 수 있는 모든 설비를 사용하면 안됩니다.
단순한 예로 msleep() 도 해당됩니다.
OTL
댓글 달기