Linux0.11内核--内核空间、用户空间之间的数据传输

内核空间、用户空间之间的数据传输

内核空间数据段的选择符为0x10,用户空间数据段选择符为0x17。内核空间、用户空间之间的数据传输,是段间数据传输。C语言中的赋值语句编译成汇编后,“=”两边的变量默认段选择符都是DS,因此只能用于同一段内数据传输。

segment.h中定义了一系列用于内核空间和用户空间传输数据的函数。从用户空间取得数据的函数中, mov指令的源操作数段寄存器都明确指出是fs,向用户空间写数据的函数中, mov指令的目的操作数段寄存器都是fs。当系统调用发生时,int 0x80处理函数会把fs设成用户数据段选择符(0x17),参见中断异常处理和系统调用一章。

下面分析一组对byte操作的函数,其他的对wordlong操作的函数与之类似。

<!-- @page { margin: 0.79in } P { margin-bottom: 0.08in } -->

get_fs_byte()

  1. // 功能:从用户空间中addr地址处取出一个字节  
  2. // 参数:addr   用户空间中的逻辑地址  
  3. // 返回:fs:[addr]处的一个字节内容  
  4. extern inline unsigned char get_fs_byte(const char * addr)  
  5. {  
  6.     unsigned register char _v;  
  7.     // addr是逻辑地址,也就是用户数据段内的偏移。  
  8. // 而当前数据段为内核数据段,所以要写成fs:[addr],这是虚拟地址  
  9.     __asm__ ("movb %%fs:%1,%0":"=r" (_v):"m" (*addr));  
  10.     return _v;  
  11. }  
 


put_fs_byte()

  1. // 功能:向用户空间中addr地址处写一个字节的内容  
  2. // 参数:val   要写入的数据  
  3. //      addr     用户空间中的逻辑地址  
  4. // 返回:(无)  
  5. extern inline void put_fs_byte(char val,char *addr)  
  6. {   // addr是相对于用户数据段的偏移,而当前数据段为内核数据段  
  7.     // 所以要写成fs:[addr]的形式  
  8. __asm__ ("movb %0,%%fs:%1"::"r" (val),"m" (*addr));  
  9. }  
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值