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

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

?? zlg_fs.c

?? atmel de booloader 內有源代碼 用blb編譯
?? 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网站大全| 国产精品天美传媒| 日韩一级欧美一级| 久久婷婷国产综合精品青草| 国产亚洲精品久| 日韩毛片一二三区| 日本在线不卡视频| jlzzjlzz国产精品久久| 欧美精品日日鲁夜夜添| 亚洲国产精品国自产拍av| 一区二区三区精品视频在线| 久久国产福利国产秒拍| 99久久国产综合精品色伊 | 欧美精品一区二区三区在线播放| 国产日韩欧美一区二区三区乱码 | 精品国产青草久久久久福利| 亚洲视频一区在线| 久久er精品视频| 在线免费不卡电影| 中文幕一区二区三区久久蜜桃| 亚洲成人精品在线观看| 大陆成人av片| 日韩精品中文字幕在线一区| 亚洲在线一区二区三区| 国产盗摄一区二区三区| 欧美一级精品大片| 亚洲女与黑人做爰| 国产成人精品三级| 精品久久久久香蕉网| 偷拍与自拍一区| 国产酒店精品激情| 欧美精品一卡二卡| 亚洲精品国产成人久久av盗摄| 精品亚洲成a人在线观看| 欧美日韩国产免费一区二区| 国产精品免费丝袜| 国产老肥熟一区二区三区| 中文字幕不卡在线播放| 久久精品国产秦先生| 欧美怡红院视频| 一区二区成人在线观看| 91原创在线视频| 国产精品国产三级国产aⅴ原创 | 国产乱人伦精品一区二区在线观看 | 国产成人免费高清| 国产乱码字幕精品高清av| 日韩精品在线看片z| 日韩国产成人精品| 欧美日韩成人一区二区| 亚洲一级在线观看| 69堂亚洲精品首页| 热久久一区二区| 日韩视频在线你懂得| 日韩黄色片在线观看| 欧美一区二区视频在线观看2020| 亚洲mv在线观看| 欧美情侣在线播放| 久久精品免费观看| 久久这里只精品最新地址| 国产一区不卡视频| 欧美韩国日本综合| 99re这里只有精品视频首页| 亚洲精品五月天| 在线视频国内自拍亚洲视频| 亚洲综合男人的天堂| 欧美日韩高清不卡| 日韩va亚洲va欧美va久久| 91精品国产综合久久精品性色| 亚洲欧美一区二区久久| 一本色道久久综合亚洲精品按摩| 亚洲一二三四在线观看| 欧美zozozo| 99久久精品久久久久久清纯| 亚洲激情自拍偷拍| 欧美男女性生活在线直播观看| 久久福利资源站| 中文字幕国产精品一区二区| 在线观看国产精品网站| 六月丁香婷婷色狠狠久久| 中文乱码免费一区二区| 欧美日韩一本到| 久久精品国产亚洲高清剧情介绍| 国产欧美日韩一区二区三区在线观看| 99精品视频在线观看| 五月天一区二区| 亚洲国产电影在线观看| 欧美日本一区二区三区| 欧美三级日韩三级国产三级| 国产精品一线二线三线| 亚洲你懂的在线视频| 日韩欧美亚洲另类制服综合在线| 韩国在线一区二区| 日韩中文字幕一区二区三区| 国产日韩欧美一区二区三区乱码 | 日韩精品免费视频人成| 国产女主播一区| 欧美日韩国产成人在线91 | 国产精品乱码一区二三区小蝌蚪| 欧美亚洲国产怡红院影院| 久久91精品久久久久久秒播| 亚洲女同一区二区| 2021国产精品久久精品| 欧美日韩欧美一区二区| 成人精品一区二区三区四区 | 精品久久久三级丝袜| 一本到不卡免费一区二区| 久久99久久久久| 亚洲国产欧美在线人成| 国产精品久久三| 精品国产99国产精品| 91福利在线导航| 成人av资源站| 国产精品99久久久久| 久草中文综合在线| 蜜桃视频第一区免费观看| 亚洲一区在线免费观看| 亚洲精品欧美在线| 久久精品欧美一区二区三区不卡| 欧洲精品中文字幕| 91麻豆免费在线观看| 成人av在线电影| 美女性感视频久久| 亚洲成人手机在线| 亚洲九九爱视频| 国产精品入口麻豆原神| 久久天堂av综合合色蜜桃网| 欧美日韩国产高清一区| 99国产精品久| 成人精品视频一区二区三区尤物| 日韩有码一区二区三区| 亚洲444eee在线观看| 亚洲国产日韩a在线播放性色| 亚洲精品久久7777| 亚洲男同性恋视频| 一区二区三区在线观看视频| 亚洲欧洲成人精品av97| 亚洲丝袜美腿综合| 亚洲愉拍自拍另类高清精品| 亚洲精品欧美综合四区| 亚洲在线成人精品| 亚洲三级久久久| 亚洲色图欧美在线| |精品福利一区二区三区| 一区二区三区蜜桃网| 国产精品伦理一区二区| 一区二区三区四区在线播放| 亚洲午夜在线观看视频在线| 日韩不卡手机在线v区| 久草热8精品视频在线观看| 国产精品一二三四五| 成人h动漫精品一区二| 91蜜桃传媒精品久久久一区二区| 色av综合在线| 日韩一区二区免费在线观看| 欧美精品一区二区三| 国产蜜臀av在线一区二区三区| 最新成人av在线| 午夜欧美电影在线观看| 久久精品久久久精品美女| 国产精品一二三四| 91老司机福利 在线| 91精品国产色综合久久| 久久精品一区二区三区不卡牛牛| 国产精品你懂的| 五月激情丁香一区二区三区| 国产精品18久久久久久久网站| 成人毛片老司机大片| 91久久香蕉国产日韩欧美9色| 欧美另类一区二区三区| 亚洲国产精品精华液ab| 亚洲丰满少妇videoshd| 国产剧情av麻豆香蕉精品| 色www精品视频在线观看| 精品国产亚洲在线| 亚洲综合一区二区| 国产乱子伦一区二区三区国色天香| av在线综合网| 欧美成人bangbros| 一区二区三区日韩精品视频| 蜜桃在线一区二区三区| 色婷婷久久久亚洲一区二区三区| 日韩欧美一级片| 亚洲欧美日韩综合aⅴ视频| 另类成人小视频在线| 91网站视频在线观看| 在线播放亚洲一区| 精品国产区一区| 欧美极品美女视频| 蜜臀av一区二区在线观看| 精东粉嫩av免费一区二区三区| 91在线观看高清| 久久影院午夜论| 亚洲国产日韩在线一区模特 | 三级一区在线视频先锋| 99re这里只有精品视频首页| 精品成人在线观看| 一区二区三区日韩欧美精品| 国产在线麻豆精品观看| 欧美另类z0zxhd电影| 中文字幕va一区二区三区|