get_user_pages的作用是得到用户的页面,作为参数返回,注意,得到的是一个page结构数组而不是别的,这些page最起码 在当前记录着用户进程的数据,一般情况下,内核在调用此函数得到用户页面以后,会再将它们映射到内核空间的一个虚拟地址,然后操作这些页面的数据。这样的话在调用完get_user_pages之后然后映射到内核的的页面就最少在两个地方有映射,一个是用户空间,一个是内核空间。这时问题出来了,这些页面可能会被换出,get_user_pages并没有做任何事情比如锁住页面以保证页面不被换出,在页面换出的时候,用户映射的页表项的存在位会被清除,但是这可能不会通知该页面的内核映射的页表项,如果内核继续读写该页面,那么结果将是错误的,因此,内核不应该长时间的保持get_user_pages的映射,请看下面的例子,在2.6内核的aio中:
...
info->nr_pages = get_user_pages(current, ctx->mm, info->mmap_base, nr_pages, 1, 0, info->ring_pages, NULL);