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

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

?? mmap.c

?? linux device driver源碼
?? C
字號:
/*  -*- C -*- * mmap.c -- memory mapping for the scullv char module * * Copyright (C) 2001 Alessandro Rubini and Jonathan Corbet * Copyright (C) 2001 O'Reilly & Associates * * The source code in this file can be freely used, adapted, * and redistributed in source or binary form, so long as an * acknowledgment appears in derived source files.  The citation * should list that the code comes from the book "Linux Device * Drivers" by Alessandro Rubini and Jonathan Corbet, published * by O'Reilly & Associates.   No warranty is attached; * we cannot take responsibility for errors or fitness for use. * * $Id: _mmap.c.in,v 1.21 2001/07/18 22:28:18 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一区二区三区免费野_久草精品视频
丁香婷婷综合激情五月色| 欧美在线你懂的| 在线看国产一区二区| 精品美女一区二区| 一区二区三区在线观看国产| 国模少妇一区二区三区| 欧美日韩高清一区二区三区| 中文字幕av不卡| 精品一区二区在线免费观看| 欧美亚日韩国产aⅴ精品中极品| 国产农村妇女毛片精品久久麻豆| 免费精品视频最新在线| 欧美亚一区二区| 亚洲精品国产第一综合99久久| 国产伦精品一区二区三区在线观看| 欧美日韩中文另类| 一区二区三区自拍| av午夜精品一区二区三区| 久久综合色播五月| 久久se这里有精品| 日韩精品最新网址| 轻轻草成人在线| 日韩午夜小视频| 日韩av一区二| 日韩一区二区电影| 精品影视av免费| 337p日本欧洲亚洲大胆精品| 久久福利资源站| 日韩欧美你懂的| 狠狠色综合播放一区二区| 日韩欧美一级精品久久| 九九精品视频在线看| 久久女同精品一区二区| 国产精品一区久久久久| 久久久99久久| 99九九99九九九视频精品| 亚洲日本丝袜连裤袜办公室| 色综合久久中文综合久久97| 亚洲免费av网站| 色噜噜狠狠色综合中国 | 色婷婷av一区二区三区大白胸| 亚洲欧美综合网| 欧美曰成人黄网| 日本一区中文字幕| 久久久高清一区二区三区| www.欧美.com| 亚洲午夜免费电影| 欧美一级免费观看| 国产精品一区二区你懂的| 国产精品久久久久久久久免费桃花| 99精品国产一区二区三区不卡 | 国产亚洲1区2区3区| 99视频一区二区| 亚洲bt欧美bt精品| 久久精品一级爱片| 色系网站成人免费| 精品一区二区三区视频| 国产精品妹子av| 欧美欧美午夜aⅴ在线观看| 久久99精品国产.久久久久| 中文字幕免费观看一区| 欧美日韩日本视频| 高清在线观看日韩| 亚洲3atv精品一区二区三区| 久久久亚洲欧洲日产国码αv| 97精品久久久久中文字幕| 琪琪久久久久日韩精品| 国产精品短视频| 欧美一级在线观看| www.亚洲在线| 蜜桃av噜噜一区| 亚洲美女在线国产| 久久久久成人黄色影片| 欧美午夜电影一区| 成人免费毛片嘿嘿连载视频| 午夜精品久久久久久| 国产精品久久久久永久免费观看 | 欧美日韩一区二区欧美激情| 精品在线你懂的| 亚洲成人在线免费| 亚洲欧洲成人自拍| 国产欧美日韩在线视频| 欧美日韩在线电影| 99在线热播精品免费| 狠狠色伊人亚洲综合成人| 亚洲国产综合色| 中文字幕在线观看不卡视频| 欧美不卡123| 欧美老肥妇做.爰bbww| 99久精品国产| 成人免费看片app下载| 精品一二线国产| 日韩av一区二区三区四区| 亚洲在线视频免费观看| 国产精品久久久久毛片软件| 久久老女人爱爱| 日韩精品自拍偷拍| 日韩一区二区三区电影在线观看| 欧美色图在线观看| 91久久精品午夜一区二区| a亚洲天堂av| av中文字幕亚洲| 成人午夜大片免费观看| 国产精品亚洲一区二区三区在线| 精东粉嫩av免费一区二区三区| 日韩中文字幕1| 日韩二区三区四区| 天天做天天摸天天爽国产一区| 亚洲图片自拍偷拍| 日韩在线一区二区三区| 男女性色大片免费观看一区二区 | 成人黄色a**站在线观看| 国产精品1区2区3区| 国产毛片一区二区| 国产1区2区3区精品美女| 成人综合在线观看| 成人国产一区二区三区精品| 91色porny蝌蚪| 91国在线观看| 欧美日韩电影在线播放| 56国语精品自产拍在线观看| 日韩三级视频在线观看| 欧美大片免费久久精品三p| 亚洲精品一区二区在线观看| 久久久综合网站| 国产精品久久三| 亚洲mv在线观看| 激情小说欧美图片| 成人在线视频一区| 一本色道a无线码一区v| 欧美裸体一区二区三区| 91精品国产综合久久香蕉麻豆| 精品剧情在线观看| 国产精品视频你懂的| 樱桃视频在线观看一区| 日本午夜一本久久久综合| 国产精品91xxx| 91玉足脚交白嫩脚丫在线播放| 欧美剧情电影在线观看完整版免费励志电影 | 夜夜嗨av一区二区三区四季av| 亚洲综合激情小说| 精品一区免费av| 色综合天天天天做夜夜夜夜做| 欧美色网站导航| 国产三级三级三级精品8ⅰ区| 亚洲色图欧洲色图婷婷| 日韩高清一区二区| 不卡av在线网| 欧美肥妇bbw| 亚洲国产高清aⅴ视频| 日韩国产高清影视| 成人国产在线观看| 欧美一级理论片| 亚洲欧美日韩在线不卡| 久久精品99国产国产精| 91老师片黄在线观看| 欧美电影免费观看完整版| 亚洲丝袜自拍清纯另类| 久久99精品国产麻豆不卡| 日本福利一区二区| 国产女人18毛片水真多成人如厕| 亚洲成av人片观看| 99久久久国产精品| 久久久www免费人成精品| 亚洲午夜羞羞片| 91亚洲精品乱码久久久久久蜜桃 | 国产精品99精品久久免费| 欧美日韩中文一区| 亚洲欧美另类在线| 国产黄色精品视频| 91精品在线观看入口| 亚洲男人天堂av| 成人av午夜电影| 国产亚洲欧美一级| 久久99精品视频| 69堂成人精品免费视频| 亚洲人成网站精品片在线观看| 国产精品99久久久久久似苏梦涵| 91麻豆精品国产91久久久久久| 一区二区三区色| 一本大道久久a久久精二百| 国产精品麻豆一区二区| 国产美女在线观看一区| 精品三级在线观看| 久久99国产精品久久| 91精品婷婷国产综合久久性色| 一区二区在线免费观看| 色综合久久中文综合久久牛| 成人欧美一区二区三区白人 | 中文字幕亚洲欧美在线不卡| 狠狠色狠狠色合久久伊人| 日韩免费在线观看| 美腿丝袜亚洲综合| 精品日韩成人av| 精品一区二区三区日韩| 日韩精品一区二区三区蜜臀| 日本不卡一二三| 欧美一区二区观看视频| 蜜桃视频在线观看一区二区| 精品日韩在线一区|