作者srx78 (srx)
看板LinuxDev
標題[問題] 中斷處理的問題請教
時間Sat Feb 25 21:12:44 2012
想要請問一下
我碰到的問題是這樣
如果遇到二個device 共用同一個interrupt pin
因此必須透過i2c去讀pin的address來判別是誰發出的中斷
可是在irqreturn_t這個中斷處理函式
又不能去做i2c任何事情
我只好開一個workqueue去做ISR
這時候又遇到一個問題
在開完workqeue後, irqreturn_t立刻回傳IRQ_HANDLED 告訴上層
但實際上我的workqueue事情卻還沒做完
導致系統當掉
一定要去判別發出的interrupt是哪個device
又必須立刻回傳IRQ_HANDLED
這樣該怎麼做?
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 111.255.9.235
1F:→ gkk886:不清楚為何你先回傳會當掉 也許可以試試等中斷處理的部分用 02/25 23:42
2F:→ gkk886:wait_for_completion 然後workqueue處理時去complete? 02/25 23:43
3F:→ srx78:在中斷處理不是不可休眠嗎?可以使用wait_for_completion ? 02/26 01:13
4F:→ srx78:想再請問一下 02/26 22:10
5F:→ srx78:在irqreturn_t的function內,是不是真的不能使用i2c去讀 02/26 22:11
6F:→ srx78:register的值,還是需要利用其他技巧才能使用i2c?? 02/26 22:11
7F:推 askacis:開一個kernel thread,中斷來時喚醒該kthread去讀值 02/26 23:30
8F:→ srx78:我現在就是這麼做,interrupt來我就利用一個work queue去讀值 02/26 23:33
9F:→ srx78:根據讀值結果,決定做哪個interrupt function 02/26 23:34
10F:→ srx78:可是問題是讀值過程 我已經回傳IRQ_HANDLED 02/26 23:35
11F:→ srx78:我要如何確保事情都做完了才回傳IRQ_HANDLED 02/26 23:37
12F:→ gkk886:我的意思是你需要等i2c讀值出來的部分去wait 02/27 01:12
13F:→ gkk886:中斷時排工作到queue 然後工作被拿出來後讀i2c值並complete 02/27 01:15
14F:→ admon:是不是因你把消除中斷的code也挪進workqueue 所以中斷一直發 02/27 17:30
15F:→ WPC001:disable_irq/enable_irq 02/27 19:07
16F:→ WPC001:disable_irq_no_sync 02/27 19:08
17F:→ admon:我說的code是 "清某個register"的動作 和樓上說的不同 02/27 20:56
18F:→ srx78:的確是把清register的動作在queue裡面做 02/27 21:59
19F:→ srx78:不過本來就預期中斷要一直過來~不懂為何要disable_irq?? 02/27 22:00
20F:→ srx78:中斷連續過來是正常行為, 02/27 22:03
21F:→ srx78:可是卡在還沒做完就回傳IRQ_HANDLED,不知道如何等queue做完 02/27 22:03
22F:→ srx78:再回傳~ 因為irqreturn_t內不能清register,所以必須開queue 02/27 22:04
23F:→ admon:1.消除中斷的code必要留在isr內 否則workqueue可能沒機會跑 02/28 11:14
24F:→ admon:2.如果只為了判斷是否回IRQ_HANDLED,乾脆直接回IRQ_HANDLED 02/28 11:17
25F:→ admon:負面影響為randomness不準 (參考kernel/irq/handle.c) 02/28 11:21
26F:→ admon:那條irq line都不要設IRQF_SAMPLE_RANDOM罷了 02/28 11:22
27F:→ srx78:清中斷的動作要用i2c,不能在isr裡面做,kernel會當掉~ 02/28 16:22
28F:→ srx78:所以我才在work queue做,不過又變成我內文講的狀況 02/28 16:23
29F:→ srx78:work queue在清中斷(判別中斷),可是driver已回傳IRQ_HANDLE 02/28 16:24
30F:→ admon:若不能從isr清中斷, 那只能暫時把那條irq line disable, 02/28 21:48
31F:→ admon:直到你的workqueue跑完再enable那條irq line 02/28 21:49