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

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

?? mmap.c

?? ldd1的源代碼
?? C
字號:
/*  -*- C -*- * mmap.c -- memory mapping for the scullv char module * * $Id: _mmap.c.in,v 1.9 2000/10/22 16:06:12 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;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->vm_pgoff << PAGE_SHIFT);    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 */    lpage = VMALLOC_VMADDR(pageptr);    pgd = pgd_offset(&init_mm, lpage);    pmd = pmd_offset(pgd, lpage);    pte = pte_offset(pmd, lpage);    page = pte_page(*pte);        /* 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;}#endifstruct vm_operations_struct scullv_vm_ops = {    open:     scullv_vma_open,    close:  scullv_vma_close,#ifdef LINUX_24    nopage:   scullv_vma_nopage,#else    nopage:   scullv_vma_nopage_old,#endif};#ifndef LINUX_20int scullv_mmap(struct file *filp, struct vm_area_struct *vma){    struct inode *inode = INODE_FROM_F(filp);#ifdef LINUX_22					    if (vma->vm_offset & (PAGE_SIZE-1))		        return -ENXIO; /* need aligned offsets */	#endif						    /* don't do anything here: "nopage" will fill the holes */    vma->vm_ops = &scullv_vm_ops;#ifdef LINUX_24					    vma->vm_private_data = scullv_devices + MINOR(inode->i_rdev);#endif						    vma->vm_file = filp;    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->vm_offset & (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| 午夜精品爽啪视频| 欧美精品一区二区三| 国产成人亚洲精品青草天美 | 欧美日韩国产片| 极品少妇一区二区三区精品视频| 亚洲卡通欧美制服中文| 久久久久久**毛片大全| 91影院在线观看| av在线不卡电影| av亚洲精华国产精华| 香蕉影视欧美成人| 奇米精品一区二区三区四区 | 欧美日韩mp4| 91影院在线免费观看| 九九国产精品视频| 国产91综合网| 精品一区二区三区久久| 国产一区二区三区日韩| 国产揄拍国内精品对白| 石原莉奈一区二区三区在线观看| 亚洲精品视频自拍| 麻豆成人久久精品二区三区红| 国产精品对白交换视频| 亚洲大片一区二区三区| 日韩欧美精品在线| 亚洲另类在线制服丝袜| 亚洲另类春色校园小说| 日韩高清一区二区| 视频一区视频二区中文| 国产在线精品一区二区夜色| 麻豆精品一区二区综合av| 亚洲日本青草视频在线怡红院| 日韩一区二区三区免费看| 国产午夜三级一区二区三| 亚洲精品一区二区精华| 成人欧美一区二区三区视频网页| 一区二区视频在线看| 欧美aaaaaa午夜精品| 国产在线视频不卡二| 色综合中文综合网| 国产欧美一区二区精品秋霞影院| 欧美国产日韩a欧美在线观看| 亚洲主播在线观看| 日本不卡高清视频| 精品一区二区三区的国产在线播放| 国产成人欧美日韩在线电影| 日韩欧美一区中文| 国产精品久久久久7777按摩 | 91精品国产福利在线观看| 91精品国产品国语在线不卡| 一级特黄大欧美久久久| 国产一区二区三区免费| 91福利资源站| 亚洲国产高清不卡| 视频一区在线播放| a4yy欧美一区二区三区| 在线观看亚洲成人| 精品国产凹凸成av人网站| 亚洲一区二区三区四区在线观看 | 91麻豆精品国产91久久久| 中文字幕+乱码+中文字幕一区| 一区二区日韩电影| 大胆亚洲人体视频| 国产精品久久久久永久免费观看| 成人av网站在线观看| 一区二区三区丝袜| 国产成人精品三级| 亚洲永久免费av| 91精品婷婷国产综合久久性色| 日本伊人午夜精品| 欧美巨大另类极品videosbest| 亚洲一区二区av在线| 国产suv精品一区二区6| 精品国产乱码91久久久久久网站| 日韩国产在线一| 欧美日韩一区二区三区视频| 午夜视频在线观看一区二区三区 | 国产三级精品在线| 国产福利一区二区三区视频在线| 91成人在线精品| 青青草97国产精品免费观看| 久久久久久麻豆| 国产精品资源站在线| 亚洲欧洲制服丝袜| www国产成人| 国产精品影音先锋| 国产精品女同互慰在线看| 91精品黄色片免费大全| 国产高清成人在线| 一区二区三区高清| 在线观看成人小视频| 午夜精品福利一区二区三区蜜桃| 日韩女同互慰一区二区| 在线区一区二视频| 婷婷综合五月天| 欧美一区中文字幕| 成人免费看片app下载| 亚洲国产视频直播| 伊人开心综合网| 国产精品久久毛片a| 日韩欧美一区在线| 国产成人久久精品77777最新版本| 亚洲免费伊人电影| 91精品国产91热久久久做人人| 色菇凉天天综合网| 国产精品99久久久久久久vr| 久久激情五月婷婷| 黑人精品欧美一区二区蜜桃 | 亚洲成人av电影| 国产精品久久久久久久久久久免费看| 综合激情网...| 欧美mv日韩mv| 顶级嫩模精品视频在线看| 国产精品99久久久久久似苏梦涵 | 日本一区二区在线不卡| 91精品国产综合久久福利| 欧美理论在线播放| 色综合久久综合网欧美综合网| 裸体健美xxxx欧美裸体表演| 精品一区二区三区免费毛片爱| 亚洲一区二区综合| 1024成人网色www| 亚洲精品成人精品456| 亚洲精品视频在线| 一区二区三区产品免费精品久久75| 91精品国模一区二区三区| 日韩午夜电影在线观看| 精品欧美乱码久久久久久1区2区| 91精品免费在线| 日韩精品中文字幕在线一区| 欧美精品一区二区三区蜜桃| 精品久久久久久久久久久久包黑料| 欧美大片在线观看一区二区| 欧美白人最猛性xxxxx69交| 日韩欧美黄色影院| 久久九九国产精品| 亚洲妇熟xx妇色黄| 另类小说综合欧美亚洲| 波多野结衣亚洲一区| 91色婷婷久久久久合中文| 欧美在线综合视频| 久久亚洲二区三区| 蜜臀av性久久久久av蜜臀妖精| bt欧美亚洲午夜电影天堂| 日韩丝袜情趣美女图片| 亚洲精品久久7777| 久久国产欧美日韩精品| 91精品国产高清一区二区三区 | 国产麻豆欧美日韩一区| 精品视频在线免费看| 精品国产一区二区三区不卡| 一区二区三区四区五区视频在线观看| 亚洲超丰满肉感bbw| 在线视频国产一区| 国产精品乱码一区二区三区软件 | 欧美日韩中字一区| 欧美一区二区女人| 亚洲国产精品嫩草影院| 欧洲在线/亚洲| 国产精品欧美一区喷水| 成人免费视频播放| 久久精品日产第一区二区三区高清版| 中文字幕的久久| 亚洲国产精品久久一线不卡| 这里只有精品视频在线观看| 国产精品久久久久久久久免费相片| 日本不卡一区二区三区| 91精品福利视频| 亚洲国产日韩一区二区| 在线观看中文字幕不卡| 国产欧美在线观看一区| 粉嫩av一区二区三区在线播放| 中文字幕一区二区不卡| 东方欧美亚洲色图在线| 国产精品国产三级国产三级人妇| 久久99国产精品久久| 欧美激情自拍偷拍| 91亚洲男人天堂| 免费观看日韩av| 日韩一级黄色大片| 国产suv精品一区二区6| 欧美激情中文字幕| 欧美在线制服丝袜| 日本女人一区二区三区| 日韩三级免费观看| 丁香婷婷综合色啪| 亚洲三级在线看| 91精品国产黑色紧身裤美女| 蜜桃视频在线一区| 久久综合99re88久久爱| 国产一本一道久久香蕉| 亚洲欧美日本在线| 欧美日韩免费视频| 蜜桃传媒麻豆第一区在线观看| 中文字幕制服丝袜成人av| 欧美老女人第四色| 国产成人精品一区二区三区网站观看| 午夜不卡在线视频|