usb device driver 때문에 kernel 이 멈춥니다.

rapperdo의 이미지

안녕하세요.

현재 제가 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 라는 프로그램과 충돌을 일으키는 건가요??

bushi의 이미지

2.6.24 커널이고, 어플에서 ioctl() 을 호출했고요.

드라이버에서 .unlocked_ioctl 콜백을 제공한다면 바로 드라이버의 콜백이 호출되지만,
그렇지 않고 .ioctl 콜백을 제공한다면 lock_kernel()이 먼저 수행된 후에 드라이버의 ioctl 콜백이 호출됩니다.
(spin_lock() 과 마찬가지의 상태가됩니다)

이유가 뭐든간에 spin_lock 상태로 진입했다면,
conditional/semaphore wait 등 스케쥴러에 간섭해 들어갈 수 있는 모든 설비를 사용하면 안됩니다.
단순한 예로 msleep() 도 해당됩니다.

OTL

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.