改變內存空間的方法,主要就是set_fs(),get_ds()這兩個函數來完成內存空間切換。一般定義的宏如下:
#define BEGIN_KMEM {mm_segment_t old = get_fs();set_fs(get_ds())}
#define END_KMEM {set_fs(old);}
前面一個宏主要是先記錄下內存空間的首地址,再設置內存空間的首地址為用戶空間首地址,進行內存空間切換。
後一個宏主要是將內存空間切換回去.
舉例如下:
struct file *filep = NULL;
int wsize;
filep = filp_open("/opt/scst.dat",O_RDWR | O_APPEND,0);
if(IS_ERR(filep))
TRACE_DBG("Open file /opt/scst.dat error");
csm_bvec = &bio->bi_io_vec[0];/*要寫的page地址*/
if(filep != NULL)
{
BEGIN_KMEM
wsize = vfs_write(filep,
(const char __user *)(page_address(csm_bvec->bv_page) + csm_bvec->bv_offset),
csm_bvec->bv_len, &filep->f_pos);/*寫數據到文件*/
if(wsize != csm_bvec->bv_len)
TRACE_DBG("write file error,size %d(should be %d)",size,csm_bvec->bv_len);
else
TRACE_DBG("write file ok,size %d",wsize);
END_KMEM
}
filp_close(filep,NULL);/*關閉*/