推 TWkobe: 你說的沒錯 課本這說法很有問題 假設c.s問題最低要求是04/25 10:18
推 TWkobe: 只要自增自減某個變數 那用atomic instr和disable interr04/25 10:21
→ TWkobe: upt有機會做到04/25 10:21
推 TWkobe: 更別說要扯到亂序、mem、cache的影響 我猜課本是理想的假04/25 10:24
→ TWkobe: 設04/25 10:24
推 TMDTMD2487: 一般而言單核會使用interrupt disable + preemtion04/25 10:40
→ TMDTMD2487: disable04/25 10:40
想請問一下:Interrupt disable跟Preemption disable有什麼差別嗎?preempt別人不是
就要先Interrupt嗎
→ TMDTMD2487: 然而你說的沒有錯除非你綁定在同一顆cpu不然沒有用04/25 10:41
→ TMDTMD2487: 至於out of order/ cache,TLB flush 的問題在hardware04/25 10:42
→ TMDTMD2487: 會解決掉 04/25 10:42
→ TMDTMD2487: 另外值得注意的事情是補習班不會跟你說的,所謂的spin04/25 10:43
→ TMDTMD2487: lock 本身會帶有disable preemtion的效果04/25 10:44
→ TMDTMD2487: 所以spinlock裡面不能sleep,而且在單核的狀態下spinl04/25 10:44
→ TMDTMD2487: ock也純粹只是disable preemtion 04/25 10:45
→ TMDTMD2487: 然後我發現一直把preemption打錯字XD04/25 10:46
推 TWkobe: 樓上說的沒錯 至於爲什麼spinlock 不能sleep 考量有二:04/25 10:52
→ TWkobe: 第一 要是睡了就沒人能取回了 第二 spinlock就是要快 要04/25 10:52
→ TWkobe: 睡處理時間長請改用semaphore04/25 10:52
原來如此!小弟受益良多XD,謝謝兩位的回答!
推 DLHZ: 推04/25 10:59
※ 編輯: gash55025502 (180.217.206.150), 04/25/2019 12:17:19
→ TMDTMD2487: preemption是指能不能去做task switch 04/25 12:39
→ TMDTMD2487: timer可以發interrupt近來然後cpu跳去處理interrupt 04/25 12:42
→ TMDTMD2487: routine,但如果結束時去call sched,會因為preemptio 04/25 12:43
→ TMDTMD2487: n關掉,所以sched繼續回去執行原本的task 04/25 12:44
→ TMDTMD2487: disable interrupt跟disable preemption是不一樣的事 04/25 12:45
→ TMDTMD2487: 另外一點是spin lock通常是kernel implement在用的 04/25 12:48
推 TWkobe: 補充一下 spinlock 本來是kernel structure不適合直接用 04/25 13:16
→ TWkobe: 在 user space , user space請用pthread spinlock 04/25 13:16