亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? mmap.c

?? LINUX設備驅動2源代碼
?? C
字號:
/*  -*- C -*- * mmap.c -- memory mapping for the scullv char module * * $Id: _mmap.c.in,v 1.19 2001/07/11 08:46:28 rubini Exp $ */#ifndef __KERNEL__#  define __KERNEL__#endif#ifndef MODULE#  define MODULE#endif#include <linux/config.h>#define __NO_VERSION__#include <linux/module.h>#include <linux/mm.h>     /* everything */#include <linux/errno.h>  /* error codes */#include <asm/pgtable.h>#include "scullv.h"        /* local definitions */#ifdef LINUX_20static struct mm_struct *init_mm_ptr;#define init_mm (*init_mm_ptr) /* to avoid ifdefs later */static void retrieve_init_mm_ptr(void){    struct task_struct *p;    for (p = current ; (p = p->next_task) != current ; )        if (p->pid == 0)            break;    init_mm_ptr = p->mm;}#endif/* * Given a VMA, get our device pointer from it. */static inline ScullV_Dev *scullv_vma_to_dev (struct vm_area_struct *vma){#if defined(LINUX_24)    return (ScullV_Dev *) vma->vm_private_data;#elif defined(LINUX_22)    struct inode *inode = INODE_FROM_F(vma->vm_file);     return scullv_devices + MINOR(inode->i_rdev);#else /* LINUX_20 */    return scullv_devices + MINOR(vma->vm_inode->i_rdev);#endif}/* * open and close: just keep track of how many times the device is * mapped, to avoid releasing it. */void scullv_vma_open(struct vm_area_struct *vma){    ScullV_Dev *dev = scullv_vma_to_dev(vma);    dev->vmas++;    MOD_INC_USE_COUNT;}void scullv_vma_close(struct vm_area_struct *vma){    ScullV_Dev *dev = scullv_vma_to_dev(vma);    dev->vmas--;    MOD_DEC_USE_COUNT;}/* * The nopage method: the core of the file. It retrieves the * page required from the scullv device and returns it to the * user. The count for the page must be incremented, because * it is automatically decremented at page unmap. * * For this reason, "order" must be zero. Otherwise, only the first * page has its count incremented, and the allocating module must * release it as a whole block. Therefore, it isn't possible to map * pages from a multipage block: when they are unmapped, their count * is individually decreased, and would drop to 0. */struct page *scullv_vma_nopage(struct vm_area_struct *vma,                                unsigned long address, int write){    unsigned long offset;    ScullV_Dev *ptr, *dev = scullv_vma_to_dev(vma);    struct page *page = NOPAGE_SIGBUS;    void *pageptr = NULL; /* default to "missing" */    pgd_t *pgd; pmd_t *pmd; pte_t *pte;    unsigned long lpage;    down(&dev->sem);    offset = (address - vma->vm_start) + VMA_OFFSET(vma);    if (offset >= dev->size) goto out; /* out of range */    /*     * Now retrieve the scullv device from the list,then the page.     * If the device has holes, the process receives a SIGBUS when     * accessing the hole.     */    offset >>= PAGE_SHIFT; /* offset is a number of pages */    for (ptr = dev; ptr && offset >= dev->qset;) {        ptr = ptr->next;        offset -= dev->qset;    }    if (ptr && ptr->data) pageptr = ptr->data[offset];    if (!pageptr) goto out; /* hole or end-of-file */    /*     * After scullv lookup, "page" is now the address of the page     * needed by the current process. Since it's a vmalloc address,     * first retrieve the unsigned long value to be looked up     * in page tables.     */    lpage = VMALLOC_VMADDR(pageptr);#ifdef LINUX_24						    spin_lock(&init_mm.page_table_lock);#endif  						    pgd = pgd_offset(&init_mm, lpage);    pmd = pmd_offset(pgd, lpage);    pte = pte_offset(pmd, lpage);#ifdef LINUX_24  					    page = pte_page(*pte);    spin_unlock(&init_mm.page_table_lock);#else  							    page = mem_map + MAP_NR(pte_page(*pte));  		#endif  						        /* got it, now increment the count */    get_page(page);out:    up(&dev->sem);    return page;}#ifndef LINUX_24unsigned long scullv_vma_nopage_old(struct vm_area_struct *vma,                unsigned long address, int write){    struct page *page = scullv_vma_nopage(vma, address, write);    if (page)#ifdef LINUX_20        return (page->map_nr << PAGE_SHIFT);#else  /* 2.2 */        return (unsigned long) __va ((page - mem_map) << PAGE_SHIFT);#endif    return 0;}#define scullv_vma_nopage scullv_vma_nopage_old /* for the ops table */#endif /* not 2.4 */struct vm_operations_struct scullv_vm_ops = {    open:     scullv_vma_open,    close:  scullv_vma_close,    nopage:   scullv_vma_nopage,};#ifndef LINUX_20int scullv_mmap(struct file *filp, struct vm_area_struct *vma){    struct inode *inode = INODE_FROM_F(filp);    if (VMA_OFFSET(vma) & (PAGE_SIZE-1))                        return -ENXIO; /* need aligned offsets */	    /* don't do anything here: "nopage" will fill the holes */    vma->vm_ops = &scullv_vm_ops;    vma->vm_flags |= VM_RESERVED;#ifdef LINUX_24					    vma->vm_private_data = scullv_devices + MINOR(inode->i_rdev);#else						    vma->vm_file = filp;			#endif						    scullv_vma_open(vma);    return 0;}#else /* LINUX_20 */int scullv_mmap(struct inode *inode, struct file *filp,                struct vm_area_struct *vma){    if (VMA_OFFSET(vma) & (PAGE_SIZE-1))        return -ENXIO; /* need aligned offsets */    /*     * A pointer to init_mm is needed to access page tables     */    if (!init_mm_ptr)        retrieve_init_mm_ptr();    /* don't do anything here: "nopage" will fill the holes */    vma->vm_ops = &scullv_vm_ops;    vma->vm_inode = inode;    inode->i_count++;    scullv_vma_open(vma);    return 0;}#endif /* LINUX_20 */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久国产尿小便嘘嘘尿| 日韩精品久久理论片| 欧美日韩国产综合久久| 国产黄人亚洲片| 视频在线在亚洲| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 欧美日韩国产综合一区二区三区| 成人自拍视频在线观看| 日本不卡123| 亚洲在线中文字幕| 国产精品久久久久久久久动漫| 日韩欧美国产一区二区在线播放| 欧美四级电影网| 99re热视频这里只精品| 成人一区二区三区视频在线观看| 欧美a级一区二区| 亚洲人成精品久久久久久 | 久久蜜桃av一区二区天堂| 欧美性猛片aaaaaaa做受| 99在线精品观看| 国产传媒久久文化传媒| 另类小说综合欧美亚洲| 午夜精品一区二区三区电影天堂 | 美女免费视频一区| 天堂精品中文字幕在线| 亚洲国产欧美在线人成| 樱桃视频在线观看一区| 亚洲图片激情小说| 中文字幕在线不卡一区二区三区| 国产天堂亚洲国产碰碰| 国产午夜精品久久久久久久| 精品黑人一区二区三区久久| 精品人伦一区二区色婷婷| 日韩精品一区二区三区在线 | 欧美日韩另类一区| 欧洲精品中文字幕| 欧美日韩视频专区在线播放| 欧美日韩国产高清一区二区三区| 欧美日韩综合一区| 欧美欧美午夜aⅴ在线观看| 欧美老女人在线| 欧美日韩aaaaaa| 日韩一区二区三区视频在线 | 日韩精品福利网| 日韩高清一区二区| 极品少妇xxxx偷拍精品少妇| 国产一区二区免费视频| 国产精品123| 成人精品视频一区二区三区尤物| 99久免费精品视频在线观看 | 99国产精品久久久久久久久久久| www.欧美精品一二区| 91视频.com| 欧美视频一区二| 精品日韩欧美在线| 日本一区二区免费在线| 依依成人综合视频| 男男成人高潮片免费网站| 国产综合久久久久影院| 成人伦理片在线| 色综合视频一区二区三区高清| 欧美性欧美巨大黑白大战| 91精品国产麻豆国产自产在线| 精品精品欲导航| 国产精品传媒视频| 午夜精品久久久久久久久久 | 欧美亚洲动漫精品| 日韩欧美区一区二| 18涩涩午夜精品.www| 日韩精品一卡二卡三卡四卡无卡| 精品一区二区久久| 99精品久久久久久| 欧美一区二区三区公司| 国产蜜臀av在线一区二区三区| 亚洲欧美韩国综合色| 免费看日韩a级影片| 99综合电影在线视频| 欧美高清性hdvideosex| 久久久精品黄色| 亚洲成人一区在线| 成人性生交大片免费看中文| 欧美日韩一区二区在线观看视频 | 中文字幕国产一区二区| 亚洲狠狠爱一区二区三区| 九九精品视频在线看| 91热门视频在线观看| 欧美成人性战久久| 亚洲精品乱码久久久久久久久| 久久成人羞羞网站| 91搞黄在线观看| 国产性天天综合网| 青娱乐精品视频| 一本大道久久精品懂色aⅴ| 精品美女一区二区| 亚洲成人资源网| 成年人午夜久久久| 久久人人爽爽爽人久久久| 亚洲国产一区视频| 国产传媒久久文化传媒| 欧美一级理论片| 亚洲午夜精品在线| aaa国产一区| 久久久www成人免费无遮挡大片| 亚洲国产aⅴ成人精品无吗| 懂色av噜噜一区二区三区av| 日韩欧美综合一区| 亚洲国产精品欧美一二99| 高清不卡一二三区| 精品国产网站在线观看| 亚洲福利视频一区| 色婷婷av一区二区| 综合色天天鬼久久鬼色| 国产v综合v亚洲欧| 精品国产乱码久久久久久夜甘婷婷 | 亚洲精品久久久久久国产精华液| 国产美女在线精品| 亚洲精品在线电影| 美女一区二区三区在线观看| 欧美日韩精品欧美日韩精品一 | 日韩一区在线看| 国产成人免费xxxxxxxx| www国产成人免费观看视频 深夜成人网| 亚洲电影中文字幕在线观看| 91啦中文在线观看| 亚洲日本va在线观看| 成人久久18免费网站麻豆| 久久精品一区蜜桃臀影院| 精品综合免费视频观看| 日韩一区二区中文字幕| 秋霞影院一区二区| 日韩免费视频一区| 精品一区二区综合| 久久久蜜臀国产一区二区| 国产精品综合一区二区三区| 日韩久久免费av| 国产一区二区精品在线观看| 久久久综合视频| 国产精品亚洲专一区二区三区| 久久免费午夜影院| 国产成人福利片| 亚洲国产精品ⅴa在线观看| 成人久久视频在线观看| 亚洲视频在线观看一区| 日本精品一级二级| 亚洲成人免费在线| 日韩美女一区二区三区| 国产在线国偷精品免费看| 久久一区二区视频| 成人午夜私人影院| 亚洲一区在线观看视频| 欧美日韩国产小视频| 免播放器亚洲一区| www国产成人免费观看视频 深夜成人网 | 国产女主播视频一区二区| av不卡一区二区三区| 亚洲一区二区视频| 日韩精品中午字幕| 成人在线视频首页| 一片黄亚洲嫩模| 日韩一区二区在线观看视频播放| 久草精品在线观看| **性色生活片久久毛片| 欧美色图片你懂的| 日本大胆欧美人术艺术动态| 久久亚洲春色中文字幕久久久| av电影一区二区| 丝袜诱惑亚洲看片| 国产欧美一区二区精品性| 99精品偷自拍| 麻豆91精品视频| 久久精品视频一区二区三区| 色8久久人人97超碰香蕉987| 美女脱光内衣内裤视频久久影院| 久久久久国产精品麻豆ai换脸| 日本韩国一区二区三区| 精品在线一区二区三区| 中文字幕一区二区5566日韩| 欧美疯狂性受xxxxx喷水图片| 国产精品性做久久久久久| 亚洲一区二区三区不卡国产欧美| 精品日韩一区二区三区| 91黄色免费看| 国产一区二区三区四区五区入口| 亚洲欧美福利一区二区| 2020国产精品自拍| 欧美色偷偷大香| 成人18视频日本| 韩国v欧美v亚洲v日本v| 亚洲一区二区三区视频在线播放| 久久精品亚洲国产奇米99 | 欧美激情综合五月色丁香| 欧美绝品在线观看成人午夜影视| 国产成人综合在线播放| 亚洲成av人片在线| 自拍偷在线精品自拍偷无码专区 | 色爱区综合激月婷婷| 国产精品456| 麻豆成人av在线| 亚洲已满18点击进入久久| 日本一区二区久久|