Re: [問題] memory stack 的問題

作者: descent (「雄辯是銀,沉默是金」)   2016-08-27 23:51:58
※ 引述《kyuudonut (善良老百姓)》之銘言:
: 最近寫 c code 一直想釐清一些問題
: 跟c程式沒有很直接相關,若發在這不妥再請麻煩版友告知了 m(_ _)m
: 最近在研讀virtual memory相關知識,大致上了解paging的運作模式
: 但仍不太懂 stack 往下長的實際情況是如何運作?
: stack就我的理解基本上是:
: 程式在執行 function call 時,堆疊便會一直往下長
: [問題一] process 是在 loading 時才知道分配到的 stack 的起始位置嗎?
載入一個 執行檔時, 要做一些事情, 設定這個 process sp 暫存器這是其中一件事。
: [問題二] stack overflow 如何判定? 在此 stack 的大小是由誰決定的呢?
編譯器可以插入檢查碼, 請參考
http://descent-incoming.blogspot.tw/2013/05/gcc-fstack-protector.html
作業系統可以運用 page fault 來知道 process stack 爆了。
stack 大小由作業系統決定, 執行檔格式可能也可以帶這個資訊, 讓作業系統參考。
: [問題二] 如果有多個 process 同時運作,各自 stack 的起始位置又是如何分配呢?
: (一直往下長不會撞到嗎@@)
在 process 切換時, sp 暫存器會被存起來, 作業系統會為每個
process 規劃好其 stack 使用大小, 在 context switch 時,
把 sp 指到分配好的那個 stack 區域。
看 os 設定, 可以設計成讓 process stack 相互蓋到,
也可以不要蓋到。你一定選那種不會蓋到的 os 吧
: (當某 process 需要的 stack 大小超過兩個 page 又是如何維護?
: page 如果不連續怎麼辦?)
沒研究, 但應該要連續的 page 才可以。
: [問題三] 一個程式有code, text區段,是直接從 heap 下面開始剩餘記憶體
: 隨機取一page各自載入嗎?還是 memory 還有在更細分區塊?
看不懂這個問題。你是要問載入執行檔時, code, text segment 怎麼被分配的
嗎?
: 還請各位前輩指教,或是指引我關鍵字QQ 我會去查資料
: 小弟目前正在研讀"程式設計師的自我修養-連結,載入,程式庫"
: 這本書寫的很詳細,卻又引出更多疑問 orz
你有2個問題二
作者: Eleina (艾琳娜)   2016-08-28 00:02:00
當需要的 stack 大小超過兩個 page... 看到 seg fault 改stack size 不是嗎 XD
作者: kyuudonut (善良老百姓)   2016-08-28 17:37:00
謝謝前輩回文回覆我的問題,以下是我的理解:所以OS會替各個process分配好其stack之大小與起始位置,以避免process各自蓋到,如果超過大小即stackoverflow.另外我的問題三是指,OS是否還會在記憶體另外劃分code,data的記憶體區段, 等process需要載入時,再從上面的ssection各自取page載入process的code, data section?
作者: askacis (ASKA)   2016-08-28 20:14:00
Linux 下可以打pmap [pid]觀察各Section
作者: kyuudonut (善良老百姓)   2016-08-30 14:50:00
前輩您好,最近我也在Taiwan Linux Kernel Hackers所舉辦的讀書會剛好也是選用這本書想請問這本書的操作需要購買額外的硬體還是有模擬器可以操作呢?抱歉...我看錯了,不是同一本

Links booklink

Contact Us: admin [ a t ] ucptt.com