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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? mmc_disk.c

?? LINUXSD驅(qū)動(dòng)使用實(shí)驗(yàn)
?? C
字號(hào):
/* * drivers/mmc/mmc_disk.c * * Block Device Driver for MMC * * Copyright (C) 2001-2003 MIZI Research, Inc. * * Author: Yong-iL Joh <tolkien@mizi.com> * $Id: mmc_disk.c,v 1.2 2004/01/26 08:29:56 laputa Exp $ * * Revision History: * * 2001-XX-XX Yong-iL Joh <tolkien@mizi.com> * - initial release * * 2002-07-25 Chan Gyun Jeong <cgjeong@mizi.com> * - code cleanup and restructuring *  * 2003-01-13 Chan Gyun Jeong <cgjeong@mizi.com> * - remove task_schedule() * * * 2004-01-06 kwang hyun La <nala.la@samsung.com> * - removed a delay fn for a performance  */#include <linux/config.h>#include <linux/module.h>#include <linux/kernel.h>#include <linux/init.h>#include <linux/errno.h>#include <linux/devfs_fs_kernel.h>#include <linux/blkpg.h>#include <linux/hdreg.h>#include <linux/genhd.h>#include <linux/sched.h>#include <linux/delay.h>#include <asm/uaccess.h>#include <asm/hardware.h>#include "mmc.h"#define MMC_SHIFT      2  /* max 4 partition */#define MMC_NRDEV      (1 << MMC_SHIFT)#define MMC_NDISK      (MAX_MMC_SLOTS << MMC_SHIFT)#define MAJOR_NR          60#define DEVICE_NAME       "mmc"#define DEVICE_REQUEST    do_mmc_request#define DEVICE_NR(device) (MINOR(device) >> MMC_SHIFT)#define DEVICE_ON(device)#define DEVICE_OFF(device)#define DEVICE_NO_RANDOM#include <linux/blk.h>static int mmc_sizes[MMC_NDISK];static int mmc_blksizes[MMC_NDISK];static struct hd_struct mmc_part[MMC_NDISK];static char mmc_gendisk_flags[MAX_MMC_SLOTS];static struct gendisk mmc_gendisk = {	major:              MAJOR_NR,	major_name:         DEVICE_NAME,	minor_shift:        MMC_SHIFT,	max_p:              MMC_NRDEV,	part:               mmc_part,	sizes:              mmc_sizes,	flags:              mmc_gendisk_flags,};static struct mmc_disk {	int use_cnt;	struct mmc_slot *slot;} mmc_disk[MAX_MMC_SLOTS];#define SD_PRIV(x)	((struct mmc_disk *)(mmc_disk) + (x))#define SD_SLOT(x)	(SD_PRIV(x)->slot)#define IS_EMPTY(x)	(SD_SLOT(x) == NULL)static int do_mmc_rw(struct request *req, int rd){	int ret = 0;	int dev = DEVICE_NR(req->rq_dev);	unsigned int sect_first, sect_last;	unsigned long blksize, from;	char *buffer;	/* read_len must be 512 bytes */	blksize = SD_SLOT(dev)->read_len;	buffer = req->buffer;	sect_first = req->sector + mmc_part[MINOR(req->rq_dev)].start_sect;	sect_last = sect_first + req->current_nr_sectors;	from = sect_first * blksize;	while (sect_first < sect_last) {		ret = SD_SLOT(dev)->transfer1b(SD_SLOT(dev), rd, from, buffer);		if (ret) {			if (ret == -EBUSY) {				DEBUG2(3, "[%s] MMC busy\n", __FUNCTION__);				schedule_timeout(HZ/20); /* prevent busy waiting */				continue;			} else {				DEBUG2(1, "[%s] error: %d\n", 				       __FUNCTION__, ret);				break;			}		}		sect_first++;		from += blksize;		buffer += blksize;	}	return ret;}static void do_mmc_request(request_queue_t * q){	int dev, ret, res;	struct request *req;	int rd;	while (1) {		INIT_REQUEST;	/* blk.h */		req = CURRENT;		/* We can do this because the generic code knows not to		   touch the request at the head of the queue */		spin_unlock_irq(&io_request_lock);		/* check if the device is valid */		dev = DEVICE_NR(req->rq_dev);		if (dev >= MAX_MMC_SLOTS || IS_EMPTY(dev) || 		    mmc_sizes[MINOR(req->rq_dev)] == 0) {			res = 0;			goto endreq;		}		if (req->sector + req->current_nr_sectors > 		    mmc_part[MINOR(req->rq_dev)].nr_sects) {			/* request past end of device */			res = 0;			goto endreq;		}		if (req->cmd == READ) {			rd = 1;		} else if (req->cmd == WRITE) {			rd = 0;		} else {			/* invalid request command */			res = 0;			goto endreq;		}		ret = do_mmc_rw(req, rd);		if (ret) {			res = 0;			goto endreq;		}		res = 1;	endreq:		spin_lock_irq(&io_request_lock);		end_request(res);	}}static int mmc_ioctl(struct inode *inode, struct file *filp,		       unsigned int cmd, unsigned long arg){	int dev = DEVICE_NR(inode->i_rdev);	int minor = MINOR(inode->i_rdev);		switch (cmd) {	case BLKGETSIZE:		return put_user(mmc_gendisk.part[minor].nr_sects, 				(long *) arg);#ifdef BLKGETSIZE64	case BLKGETSIZE64:		return put_user((u64)mmc_gendisk.part[minor].nr_sects,				(u64 *)arg);#endif	case BLKFLSBUF:		if (!capable(CAP_SYS_ADMIN)) return -EACCES;		invalidate_device(inode->i_rdev, 1);		return 0;	case HDIO_GETGEO: {		struct hd_geometry geo;		geo.cylinders = 1;		geo.heads = 1;		geo.sectors = mmc_gendisk.part[minor].nr_sects;		geo.start = mmc_gendisk.part[minor].start_sect;		return copy_to_user((void *)arg, &geo, sizeof(geo)) ? 			-EFAULT : 0;	}	case BLKRRPART: {		int i;		if (!capable(CAP_SYS_ADMIN)) return -EACCES;		if (SD_PRIV(dev)->use_cnt > 1) return -EBUSY;		for (i = mmc_gendisk.max_p - 1; i >= 0; i--) {			if (mmc_gendisk.part[i].nr_sects) {				kdev_t devid = MKDEV(MAJOR(inode->i_rdev), 						     minor + i);				invalidate_device(devid, 1);				mmc_gendisk.part[minor + i].start_sect = 0;				mmc_gendisk.part[minor + i].nr_sects = 0;			}		}		grok_partitions(&mmc_gendisk, dev, mmc_gendisk.max_p, 				SD_SLOT(dev)->size / SD_SLOT(dev)->read_len);		return 0;	}	case BLKROSET:	case BLKROGET:	case BLKSSZGET:		return blk_ioctl(inode->i_rdev, cmd, arg);	default: 		return -EINVAL;	}}static int mmc_open(struct inode *inode, struct file *filp){	int dev = DEVICE_NR(inode->i_rdev);	if (dev >= MAX_MMC_SLOTS) return -ENODEV;	if (IS_EMPTY(dev)) return -ENODEV;	if ((filp->f_mode & FMODE_WRITE) && SD_SLOT(dev)->readonly) {		DEBUG2(2, "[%s] it's readonly", __FUNCTION__); 		return -EROFS;	}	SD_PRIV(dev)->use_cnt++;	MOD_INC_USE_COUNT;	return 0;}static int mmc_release(struct inode * inode, struct file * filp){	int dev = DEVICE_NR(inode->i_rdev);	invalidate_device(inode->i_rdev, 1);		SD_PRIV(dev)->use_cnt--;	if (!mmc_sizes[MINOR(inode->i_rdev)]) {		SD_SLOT(dev) = NULL;	}	MOD_DEC_USE_COUNT;	return 0;}static struct block_device_operations mmc_fops = {	owner:			THIS_MODULE,	open:			mmc_open,	release:		mmc_release,	ioctl:			mmc_ioctl,};static void mmc_notify_add(struct mmc_slot *slot){	int i, dev, minor;	for (i = 0, dev = -1; i < MAX_MMC_SLOTS; i++) {		if (IS_EMPTY(i)) {			if (dev == -1) dev = i;		} else if (SD_SLOT(i)->id == slot->id) {			/* already mounted */			dev = i;			break;		}	}	if (dev == -1) return;	SD_SLOT(dev) = slot;	minor = dev << mmc_gendisk.minor_shift;	mmc_gendisk.part[minor].start_sect = 0;	mmc_gendisk.nr_real++;	register_disk(&mmc_gendisk, MKDEV(MAJOR_NR, minor), 		      mmc_gendisk.max_p, mmc_gendisk.fops, 		      SD_SLOT(dev)->size / SD_SLOT(dev)->read_len);#ifdef CONFIG_MIZI	event_notify(EXT_DEV_INSERT);#endif	DEBUG2(1, "Register %s: %ldMB\n", 	       "MultiMediaCard",	       SD_SLOT(dev)->size/(1024 * 1024));}static void mmc_notify_remove(struct mmc_slot *slot){	int dev, minor;	for (dev = 0; dev < MAX_MMC_SLOTS; dev++) {		if (SD_SLOT(dev) == slot) {			break;		}	}	if (dev >= MAX_MMC_SLOTS) return;	minor = dev << mmc_gendisk.minor_shift;	/* Unregister the related device files at the /dev/mmc directory, 	   grok_partitions(*, *, *, 0) does not work here */	devfs_register_partitions (&mmc_gendisk, minor, 1);	mmc_gendisk.nr_real--;	if (!(SD_PRIV(dev)->use_cnt)) {		SD_SLOT(dev) = NULL;	}	for (; minor < (dev + 1) << mmc_gendisk.minor_shift; minor++) {		if (mmc_sizes[minor]) {			mmc_sizes[minor] = 0;		}	}#ifdef CONFIG_MIZI	event_notify(EXT_DEV_REMOVE);#endif	DEBUG2(1, "Unregister %s: remain %s\n",	       "MultiMediaCard",	       IS_EMPTY(dev) ? "unmounted":"mounted");}static struct mmc_notifier disk_notifier = {	add:    mmc_notify_add,	remove: mmc_notify_remove,};static int __init init_mmc_disk(void){	if (devfs_register_blkdev(MAJOR_NR, DEVICE_NAME, &mmc_fops)) {		printk("MMC Disk: failed to register major %d\n", MAJOR_NR);		return -EBUSY;	}	mmc_gendisk.fops = &mmc_fops;	memset(mmc_gendisk.flags, GENHD_FL_REMOVABLE, MAX_MMC_SLOTS);	blksize_size[MAJOR_NR] = mmc_blksizes;	blk_size[MAJOR_NR] = mmc_sizes;	blk_init_queue(BLK_DEFAULT_QUEUE(MAJOR_NR), DEVICE_REQUEST);	add_gendisk(&mmc_gendisk);	register_mmc_user(&disk_notifier);	return 0;}static void __exit exit_mmc_disk(void){	unregister_mmc_user(&disk_notifier);	devfs_unregister_blkdev(MAJOR_NR, DEVICE_NAME);	blk_cleanup_queue(BLK_DEFAULT_QUEUE(MAJOR_NR));	del_gendisk(&mmc_gendisk);	blk_size[MAJOR_NR] = NULL;	blksize_size[MAJOR_NR] = NULL;}module_init(init_mmc_disk);module_exit(exit_mmc_disk);MODULE_AUTHOR("Yong-iL Joh <tolkien@mizi.com>");MODULE_LICENSE("Not GPL, Proprietary License");MODULE_DESCRIPTION("MMC Memory Card block device driver");

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
午夜欧美视频在线观看 | 国产精一区二区三区| 亚洲午夜一二三区视频| 日韩精品成人一区二区三区| www.久久久久久久久| 日本一区二区视频在线观看| 日韩理论在线观看| 狠狠色综合色综合网络| xf在线a精品一区二区视频网站| 精品影视av免费| 国产精品国产三级国产普通话三级| 色综合欧美在线视频区| 美女视频黄久久| 国产精品成人网| 日韩一区二区麻豆国产| 国产精品一级黄| 亚洲超碰精品一区二区| 日韩欧美中文字幕一区| jizzjizzjizz欧美| 亚洲超碰97人人做人人爱| 国产视频不卡一区| 色视频成人在线观看免| 国产在线精品免费| 亚洲一区二区三区自拍| 日韩精品一区二区三区swag| 色综合久久久久网| 久久精品72免费观看| 亚洲综合在线第一页| 国产精品初高中害羞小美女文| 精品日韩欧美一区二区| 一本到三区不卡视频| 91论坛在线播放| 国产麻豆视频一区二区| 午夜激情久久久| 一区二区三区精品在线观看| 日本一区二区视频在线观看| 欧美成人高清电影在线| 777xxx欧美| 在线免费一区三区| av资源站一区| 99久久国产综合精品麻豆| 国产精品香蕉一区二区三区| 亚洲一区二区不卡免费| 亚洲影院在线观看| 中文字幕日韩一区二区| 久久精品亚洲精品国产欧美| 久久久久久电影| 日韩欧美一二三四区| 欧美日韩国产另类一区| 日韩视频在线观看一区二区| 欧美精品在欧美一区二区少妇| 色又黄又爽网站www久久| 色哟哟日韩精品| 日本韩国一区二区| 91美女在线看| 欧美婷婷六月丁香综合色| 色欧美日韩亚洲| 国产高清在线精品| 91在线精品一区二区| 99在线精品观看| 成人综合婷婷国产精品久久 | 午夜久久电影网| 亚洲黄一区二区三区| 天天综合日日夜夜精品| 日韩成人精品在线| 一区二区在线观看免费| 日本三级韩国三级欧美三级| 日本亚洲天堂网| 日韩福利视频导航| 国产河南妇女毛片精品久久久| 成人午夜av电影| 国产suv精品一区二区三区| 播五月开心婷婷综合| 成人动漫精品一区二区| 粉嫩嫩av羞羞动漫久久久 | 高清av一区二区| 国产白丝精品91爽爽久久| 奇米四色…亚洲| 国产福利一区二区三区视频| 大胆欧美人体老妇| 国产福利一区二区| 91国产成人在线| 日韩一区二区三区视频在线| 久久综合一区二区| 日韩毛片在线免费观看| 天天免费综合色| 国产成人在线视频播放| 99久久精品免费看国产免费软件| 26uuu亚洲| 一区二区三区电影在线播| 丝袜亚洲精品中文字幕一区| 精品一区二区三区av| 色综合久久99| 欧美日韩国产一区| 精品国产伦一区二区三区观看体验| 最新热久久免费视频| 亚洲成a人片在线不卡一二三区| 免费看日韩a级影片| 91视频xxxx| 678五月天丁香亚洲综合网| 国产欧美日韩激情| 亚洲va国产天堂va久久en| 韩国女主播成人在线| 色婷婷久久久久swag精品| 91成人免费电影| 精品理论电影在线观看| 亚洲乱码精品一二三四区日韩在线 | 久久综合网色—综合色88| 亚洲天天做日日做天天谢日日欢| 久久99在线观看| 日本电影欧美片| 精品国产制服丝袜高跟| 亚洲一区在线观看免费观看电影高清 | 日韩欧美不卡在线观看视频| 国产精品久久久久精k8| 日韩和的一区二区| 在线观看日韩av先锋影音电影院| 亚洲精品一区二区在线观看| 亚洲精品成人少妇| 成人精品视频一区二区三区尤物| 制服丝袜在线91| 亚洲免费伊人电影| 波波电影院一区二区三区| 欧美伦理电影网| 一区在线播放视频| 风间由美一区二区三区在线观看| 欧美日韩免费观看一区二区三区| 国产欧美一区二区精品秋霞影院| 亚洲资源中文字幕| 成人va在线观看| 欧美va在线播放| 免费在线观看日韩欧美| 欧美亚洲综合另类| 综合婷婷亚洲小说| 成人av在线影院| 国产日韩精品一区二区三区在线| 蜜臀av亚洲一区中文字幕| 日韩一区二区精品葵司在线| 亚洲国产日韩av| 91在线视频播放| 一区二区三区资源| 一本大道久久a久久综合| 国产精品美女久久久久高潮| 成人动漫精品一区二区| 欧美经典一区二区三区| 国产一区二区视频在线播放| 欧美伦理影视网| 美女久久久精品| 欧美一级日韩一级| 亚洲制服欧美中文字幕中文字幕| 色乱码一区二区三区88| 一区二区在线观看av| 成人精品鲁一区一区二区| 中文字幕一区二区三区不卡在线| 成人天堂资源www在线| 欧美日本乱大交xxxxx| 青青草国产成人99久久| 日韩一区二区三区免费看| 亚洲国产综合视频在线观看| 在线观看91av| 日本中文字幕一区二区视频| 欧美三级日韩三级| 久久成人麻豆午夜电影| 日韩精品资源二区在线| 狠狠色丁香婷婷综合| 久久久久久久久岛国免费| 风间由美一区二区三区在线观看 | 一区二区成人在线视频| 日本精品一级二级| 亚洲国产欧美在线人成| 北条麻妃国产九九精品视频| 亚洲精品精品亚洲| 欧美视频日韩视频在线观看| 亚洲高清三级视频| 久久综合九色综合欧美98 | 国产精品一区二区x88av| 国产欧美一区二区精品久导航| 成人av手机在线观看| 一区二区理论电影在线观看| 91精品国产色综合久久ai换脸| 国产精品一区二区免费不卡| 最新不卡av在线| 欧美久久久久久蜜桃| 国产一区二区在线观看视频| 夜夜精品视频一区二区| 久久久不卡网国产精品二区| 91性感美女视频| 精品无人区卡一卡二卡三乱码免费卡 | 亚洲天堂网中文字| 日韩美女一区二区三区| 91香蕉视频mp4| 理论电影国产精品| 亚洲一区二区三区小说| 亚洲国产成人自拍| 欧美一区二区三区在线| 一本一道久久a久久精品综合蜜臀| 久久97超碰色| 亚洲成人tv网| 亚洲欧美综合色| 久久色中文字幕|