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

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

?? zlg_fs.c

?? 周立功MagicArm2410上的SD卡驅動
?? C
?? 第 1 頁 / 共 2 頁
字號:
/****************************************Copyright (c)****************************************************                               Guangzou ZLG-MCU Development Co.,LTD.**                                     graduate school**                                 http://www.zlgmcu.com****--------------File Info-------------------------------------------------------------------------------** File name:			zlg_fs.c** Last modified Date:  2005-05-25** Last Version:		1.0** Descriptions:		This is a Kernel module for uClinux 2.4.x .**                      This module let uClinux 2.4.x can use ZLG/FS . **------------------------------------------------------------------------------------------------------** Created by:			Chenmingji** Created date:		2005-05-25** Version:				1.0** Descriptions:		The original version****------------------------------------------------------------------------------------------------------** Modified by:			Chenmingji** Modified date:		2005-05-25** Version:				1.01** Descriptions:		Modified zlg_fs_cleanup()**********************************************************************************************************/#define IN_ZLG_FS#include "config.h"/********************************************************************************************************              function announce********************************************************************************************************/static int zlg_fs_open(struct inode *inode, struct file *filp);static int zlg_fs_release(struct inode *inode, struct file *filp); static int zlg_fs_ioctl(struct inode *inode, struct file *filp, unsigned int cmd,		    unsigned long param);static int check_zlg_fs_change(kdev_t dev);static int zlg_fs_revalidate(kdev_t dev);int  zlg_fs_init(void);void zlg_fs_cleanup(void);/********************************************************************************************************              function announce********************************************************************************************************/#define MAJOR_NR major                      /* force definitions on in blk.h    */#define DEVICE_NO_RANDOM                    /* no entropy to contribute         */#define DEVICE_OFF(d)                       /* do-nothing */MODULE_PARM(major, "i");module_init(zlg_fs_init);module_exit(zlg_fs_cleanup);#define DEVICE_NR(device) (MINOR(device) >> ZLG_FS_SHIFT)MODULE_LICENSE("Proprietary");MODULE_DESCRIPTION("Guangzou ZLG-MCU Development Co.,LTD.\ngraduate school\nhttp://www.zlgmcu.com");MODULE_SUPPORTED_DEVICE("uClinux2.4.x LPC2200 ZLG/FS");MODULE_AUTHOR("chenmingji");/***********************************************************************************************************                  "全局和靜態變量在這里定義"         **        global variables and static variables define here********************************************************************************************************/static int major = ZLG_FS_MAJOR_NR;             /* must be declared before including blk.h */#include <linux/blk.h>static int ZLG_FS_blocksizes[MAX_DISKS << ZLG_FS_SHIFT]; /* bytes per device         */static int ZLG_FS_sizes[MAX_DISKS << ZLG_FS_SHIFT];      /* bytes per device's block */                                                                /* must be (1 << n)         */static unsigned int ZLG_FS_usage[MAX_DISKS];                   /* device using count */fs_drivers *DiskInfo[MAX_DISKS];static struct hd_struct part[MAX_DISKS << ZLG_FS_SHIFT];struct gendisk zlg_fs_gendisk;/********************************************************************************************************/static struct block_device_operations zlg_fs_fops =        /* driver info  */{    owner:              THIS_MODULE,    open:               zlg_fs_open,    release:            zlg_fs_release,    ioctl:              zlg_fs_ioctl,    check_media_change: check_zlg_fs_change,    revalidate:         zlg_fs_revalidate,};/*********************************************************************************************************** Function name: zlg_fs_add_driver** Descriptions: add driver.** Input:info:   driver info** Output 0:     OK**        other: not OK** Created by:   Chenmingji** Created Date: 2005-05-25**-------------------------------------------------------------------------------------------------------** Modified by:** Modified Date: **------------------------------------------------------------------------------------------------------********************************************************************************************************/        int zlg_fs_add_driver(fs_drivers *info){    int i;        for (i = 0; i < MAX_DISKS; i++)    {        if (DiskInfo[i] == NULL)        {            DiskInfo[i] = info;            return 0;        }    }    return -1;    }/*********************************************************************************************************** Function name: zlg_fs_remove_driver** Descriptions: replace  __make_request() in this module.** Descriptions: remove driver** Input:info:   driver info** Output 0:     OK**        other: not OK** Created by:   Chenmingji** Created Date: 2005-05-25**-------------------------------------------------------------------------------------------------------** Modified by:** Modified Date: **------------------------------------------------------------------------------------------------------********************************************************************************************************/        int zlg_fs_remove_driver(fs_drivers *info){    int i;        for (i = 0; i < MAX_DISKS; i++)    {        if (DiskInfo[i] == info)        {            DiskInfo[i] = NULL;            return 0;        }    }    return -1;}/*********************************************************************************************************** Function name: zlg_fs_make_request** Descriptions: replace  __make_request() in this module.** Input:queue:  request queue**       rw:    command(read or write)**       bh:     information of block** Output 0:     OK**        other: not OK** Created by:   Chenmingji** Created Date: 2005-05-25**-------------------------------------------------------------------------------------------------------** Modified by:** Modified Date: **------------------------------------------------------------------------------------------------------********************************************************************************************************/        static int zlg_fs_make_request(request_queue_t *queue, int rw, struct buffer_head *bh){    u32 temp, SecSize;    u32 size;    int part, num, nr;    Disk_RW_Parameter dp;    fs_drivers *fs;    num = DEVICE_NR(bh->b_rdev);    nr = MINOR(bh->b_rdev);    if (num >= MAX_DISKS)     {        static int count = 0;        if (count++ < 5)        {            printk(KERN_WARNING DEVICE_NAME ": request past end of device\n");        }        bh->b_end_io(bh, 0);        return 0;    }    fs = DiskInfo[num];    /* Figure out what we are doing */    dp.RsvdForLow = fs->RsvdForLow;    SecSize = fs->BytesPerSec;    dp.SectorIndex = bh->b_rsector + zlg_fs_gendisk.part[nr].start_sect;    dp.Buf = bh->b_data;    size = bh->b_size;    if (bh->b_rsector + size / SecSize >= zlg_fs_gendisk.part[nr].nr_sects)    {        bh->b_end_io(bh, 0);        return 0;    }    /* Do the transfer */    switch(rw)    {        case READ:        case READA:  /* Readahead */            while (size >= SecSize)            {                DiskInfo[num]->DiakCommand(DISK_READ_SECTOR, &dp);                size = size - SecSize;                dp.SectorIndex++;                dp.Buf += SecSize;            }            bh->b_end_io(bh, 1);            break;        case WRITE:            refile_buffer(bh);            while (size >= SecSize)            {                DiskInfo[num]->DiakCommand(DISK_WRITE_SECTOR, &dp);                size = size - SecSize;                dp.SectorIndex++;                dp.Buf += SecSize;            }            mark_buffer_uptodate(bh, 1);            bh->b_end_io(bh, 1);            break;        default:            /* can't happen */            bh->b_end_io(bh, 0);            break;    }    /* Nonzero return means we're done */    return 0;    }/*********************************************************************************************************** Function name: zlg_fs_queue** Descriptions: queue device** Input:q:      queue** Output 0:     OK**        other: not OK** Created by:   Chenmingji** Created Date: 2005-05-25**-------------------------------------------------------------------------------------------------------** Modified by:** Modified Date: **------------------------------------------------------------------------------------------------------********************************************************************************************************/#if 0        static int  zlg_fs_queue(request_queue_t *q){    return 0; } #endif/*********************************************************************************************************** Function name: zlg_fs_open** Descriptions: open device** Input:inode:  information of device**       filp:   pointer of file** Output 0:     OK**        other: not OK** Created by:   Chenmingji** Created Date: 2005-05-25**-------------------------------------------------------------------------------------------------------** Modified by:** Modified Date: **------------------------------------------------------------------------------------------------------********************************************************************************************************/        static int  zlg_fs_open(struct inode *inode, struct file *filp){    int num;    unsigned long flag;    Disk_RW_Parameter dp;    num = DEVICE_NR(inode->i_rdev);    if (num >= MAX_DISKS)    {        return -ENODEV;    }    if (DiskInfo[num] == NULL)    {        return -ENODEV;    }    //local_irq_save(flag);    ZLG_FS_usage[num]++;    if (ZLG_FS_usage[num] == 1)    {        dp.RsvdForLow = DiskInfo[num]->RsvdForLow;        DiskInfo[num]->DiakCommand(DISK_INIT, &dp);        if (DiskInfo[num]->open != NULL)        {            DiskInfo[num]->open(inode, filp);        }        zlg_fs_revalidate(inode->i_rdev);    }    //local_irq_restore(flag);        MOD_INC_USE_COUNT;    return 0;          /* success */} /*********************************************************************************************************** Function name: zlg_fs_release** Descriptions: release device** Input:inode:  information of device**       filp:   pointer of file** Output 0:     OK**        other: not OK** Created by:   Chenmingji** Created Date: 2005-05-25**-------------------------------------------------------------------------------------------------------** Modified by:** Modified Date: **------------------------------------------------------------------------------------------------------********************************************************************************************************/        static int  zlg_fs_release(struct inode *inode, struct file *filp) {    int num;    Disk_RW_Parameter dp;    unsigned long flag;    int part1, npart, i;    num = DEVICE_NR(inode->i_rdev);    if (num >= MAX_DISKS)    {        return -ENODEV;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区二区三区不卡国产欧美| 香蕉成人啪国产精品视频综合网| 欧洲av一区二区嗯嗯嗯啊| 日本伊人午夜精品| 亚洲欧美日韩一区| 精品国产乱码久久久久久1区2区| 在线观看亚洲成人| 成人av电影免费在线播放| 免费精品视频最新在线| 亚洲午夜免费视频| 亚洲色图欧洲色图婷婷| 久久久www免费人成精品| 7777精品伊人久久久大香线蕉完整版 | 99久久久久免费精品国产| 亚洲成人7777| 亚洲三级在线看| 国产色综合久久| 欧美xxx久久| 538prom精品视频线放| 色菇凉天天综合网| 99久久99久久精品国产片果冻| 久久成人18免费观看| 天天操天天干天天综合网| 亚洲人成网站色在线观看| 国产精品日产欧美久久久久| 久久美女艺术照精彩视频福利播放| 欧美另类变人与禽xxxxx| 91电影在线观看| 91美女精品福利| www.综合网.com| 国产a视频精品免费观看| 国产一区在线不卡| 国产露脸91国语对白| 国产一区在线看| 国产精品影视网| 国产999精品久久| 国产成人免费视频网站| 国产乱子伦视频一区二区三区 | 欧洲av在线精品| 欧美视频一区二区在线观看| 91高清在线观看| 欧美这里有精品| 欧美伦理视频网站| 欧美一区二区三区播放老司机| 91精品国产综合久久久蜜臀图片| 欧美精品第1页| 欧美一区二区三区视频在线| 日韩一区二区三区三四区视频在线观看| 欧美精品在线观看一区二区| 91精品国产黑色紧身裤美女| 日韩一区二区三区电影在线观看| 日韩欧美国产一区在线观看| 精品国内片67194| 久久精品视频在线免费观看| 国产精品丝袜一区| 亚洲免费观看高清完整版在线观看| 一区二区三区日韩在线观看| 亚洲成av人综合在线观看| 青青草91视频| 国产精品一区二区三区乱码| 成人免费av资源| 日本韩国欧美在线| 欧美一区二区视频在线观看2022| 337p粉嫩大胆噜噜噜噜噜91av| 久久精品一区八戒影视| 国产精品美女久久久久久| 亚洲一区二区三区国产| 麻豆成人久久精品二区三区红| 国产高清久久久久| 亚洲欧洲色图综合| 亚洲五月六月丁香激情| 全国精品久久少妇| www.久久精品| 欧美日韩一区二区不卡| 久久免费的精品国产v∧| 日韩理论片在线| 奇米影视一区二区三区| 成人激情免费电影网址| 欧美日韩激情一区二区三区| 久久久久成人黄色影片| 亚洲激情图片小说视频| 精品一区精品二区高清| 色素色在线综合| 欧美不卡123| 一区二区三区在线播| 韩国精品主播一区二区在线观看 | 亚洲精品乱码久久久久久日本蜜臀| 午夜欧美电影在线观看| 国产精品一区二区三区网站| 欧美三级中文字幕在线观看| 久久久青草青青国产亚洲免观| 一区二区欧美精品| 国产老妇另类xxxxx| 欧美猛男男办公室激情| 国产精品久久久久aaaa樱花| 日本一不卡视频| 91麻豆视频网站| 国产夜色精品一区二区av| 午夜不卡av在线| 91丨porny丨蝌蚪视频| 久久综合九色综合97_久久久| 亚洲综合在线视频| 高清在线不卡av| 欧美va天堂va视频va在线| 亚洲国产美国国产综合一区二区| 福利一区二区在线| 欧美成人免费网站| 婷婷综合另类小说色区| 色素色在线综合| 中文字幕一区二区三区四区不卡 | 国产精品一二三四区| 91精品在线麻豆| 亚洲精品国产一区二区三区四区在线| 国产成人av自拍| 欧美精品一区二区精品网| 五月天精品一区二区三区| 91蝌蚪porny| 综合自拍亚洲综合图不卡区| 国产成人啪午夜精品网站男同| 日韩一级大片在线| 石原莉奈在线亚洲三区| 色国产综合视频| 伊人性伊人情综合网| 99久久99久久免费精品蜜臀| 国产精品午夜久久| 国产成人av资源| 国产精品三级电影| 国产成人av一区二区三区在线观看| 日韩女优av电影| 久久er精品视频| 五月婷婷久久综合| 欧美日韩激情一区| 一区二区三区日本| 在线观看国产精品网站| 亚洲精品日日夜夜| 在线观看亚洲专区| 亚洲成在人线免费| 欧美日韩三级在线| 日韩中文字幕av电影| 欧美一区二区福利在线| 日韩av在线免费观看不卡| 欧美一卡在线观看| 久久精品国产网站| 久久婷婷成人综合色| 国产寡妇亲子伦一区二区| 国产精品拍天天在线| 97久久超碰精品国产| 亚洲激情五月婷婷| 91麻豆精品久久久久蜜臀 | 日本视频一区二区三区| 日韩欧美久久久| 国产精品1024| 亚洲欧洲精品一区二区精品久久久 | 久久婷婷久久一区二区三区| 国产精品一线二线三线精华| 日本一区二区三区四区| 成人不卡免费av| 一区二区三区四区av| 欧美丰满美乳xxx高潮www| 久久国产人妖系列| 亚洲国产高清在线观看视频| 91小宝寻花一区二区三区| 亚洲综合色成人| 日韩欧美不卡一区| 成人国产在线观看| 亚洲国产美国国产综合一区二区| 91精品国产色综合久久不卡电影| 国产资源精品在线观看| 国产精品超碰97尤物18| 欧美丰满少妇xxxbbb| 国产高清在线观看免费不卡| 一区二区三区高清在线| 欧美va亚洲va香蕉在线| 91啪亚洲精品| 蜜桃视频在线观看一区| 欧美国产日韩在线观看| 欧美日韩亚洲国产综合| 国产电影一区二区三区| 夜夜夜精品看看| 久久美女艺术照精彩视频福利播放 | 自拍偷自拍亚洲精品播放| 欧美高清一级片在线| 成人一区二区三区中文字幕| 亚洲福利视频导航| 26uuu成人网一区二区三区| 色婷婷综合久久久| 激情欧美一区二区三区在线观看| 亚洲欧美电影一区二区| 精品免费国产一区二区三区四区| 95精品视频在线| 精品一二三四区| 亚洲国产乱码最新视频| 国产三级欧美三级日产三级99| 欧美伊人精品成人久久综合97| 国产福利一区二区三区视频| 亚洲一区二区三区国产| 国产精品卡一卡二| 久久日韩精品一区二区五区| 在线观看精品一区| 成人av网址在线|