作者wzbird (大鳥)
看板LinuxDev
標題[問題] Process在記憶體空間交換資料的問題
時間Wed Feb 8 20:39:48 2012
hi,
我覺得我的標題實在下得不好, 但是又不知道應該怎麼下
我的問題是在"Linux Device Driver Programming驅動程式設計(平田豐)"一書中
提到
----------------------引文開始-----------------------------------------
User process 可透過read()與write()系統呼叫與驅動程式交換資料
前面曾經提過, User process與kernel分別在不同的(虛擬)記憶體空間內運作
因此兩者之前無法直接讀寫記憶體
IA-32版的Linux 在 use context 之內,
是把4GB虛擬記憶體空間的下半部3GB分配給User process使用
上半部1GB給kernel 使用,
如此就能從kernel直接讀寫User process的記憶體空間了.
----------------------引文結束------------------------------------------
1. 這段文字的前半段說, 因為user process和kernel在不同的記憶體空間中
所以不能讀寫, 指得就是前1G和, 後3G的差別嗎?
2. 乘上1., 所以後半段也的確提到前1G和後3G的情況, 和引文中的前半段的
"不同的(虛擬)記憶體空間" 是指同一件事嗎?
3. 乘1.2., 如果這樣, 這段引文為什麼一下說不能讀寫, 一下又說可以讀寫呢?
4. 撇開前三個問題不看的話(可能只是我有哪個地方有誤會, 需要有人點通)
我整理了一下書中這個部分的說法, 大概是這樣
kernel process想要在kernel與user space間搬資料
>>使用kernel 函式, EX: get_user(), put_user(), access_ok()
user space 想要與kernel driver溝通(以char device為例)
>> 透過 device file.
我這樣的整理對嗎?
謝謝大家
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 180.177.12.226
1F:推 alongalone:我的看法的話.大概都跟你說的差不多吧. 02/08 22:18
2F:→ alongalone:kernel space/user space 分開我認為是概念上,可以透過 02/08 22:18
3F:→ alongalone:MMU的機制來做(你提到1G/3G).交換資料就是透過特定函式 02/08 22:20
4F:→ alongalone:來交換.而且ioctl的function 參數是一個unsigned long 02/08 22:21
5F:→ alongalone:的型別.也沒看過有人用這個值還特別分 kernel/user,除 02/08 22:22
6F:→ alongalone:了把它當指標還用 02/08 22:22
7F:推 askacis:MMU的作用是把實體記憶體位置轉換成虛擬記憶體位置,3G/1G 02/08 23:21
8F:→ askacis:都是虛擬記憶體位置,同時1:3這樣的分法可以透過程式定義 02/08 23:22
9F:→ askacis:kernel space的位置在high memory以下幾乎就是一個offset 02/08 23:24
10F:→ askacis:的加減就可以求到真實記憶體,user space的位址就複雜多了 02/08 23:25
11F:→ askacis:當然在kernel space用vmalloc得來的指標只有在邏輯上連續 02/08 23:25
12F:推 shaopin:kmalloc的分配就是連續, 那麼最大可以到多少ㄋㄜ? 02/11 01:28
13F:→ wzbird:感謝大家的回應 02/14 20:13
14F:推 mimi0213:記得是order 12也就是4mb 02/18 22:07
15F:推 askacis:kmalloc最大應該是128KB~ 02/18 23:28
16F:推 Smile365Day:MMU應該是VA->PA ... OS這邊要做的只有初始化pgtable 02/27 00:59
17F:→ Smile365Day:walker都是由硬體做...至於PA->VA則叫做reverse map 02/27 01:00
18F:→ Smile365Day:這邊是由OS做掉...有分anonymous page跟file page 02/27 01:00
19F:→ Smile365Day:資料結構則是用priority tree 02/27 01:01
20F:→ Smile365Day:上面那是給file page使用...anon page是用linked list 02/27 01:02
21F:→ Smile365Day:有興趣的人可以去看professional那本 02/27 01:03