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

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

?? cfc.c

?? thenewofTiny-FatFs
?? C
字號:
/*-----------------------------------------------------------------------*/
/* CompactFlash control module                            (C)ChaN, 2007  */
/*-----------------------------------------------------------------------*/


#include <avr/io.h>
#include <avr/interrupt.h>
#include <string.h>
#include "diskio.h"


/* ATA command */
#define CMD_RESET		0x08	/* DEVICE RESET */
#define CMD_READ		0x20	/* READ SECTOR(S) */
#define CMD_WRITE		0x30	/* WRITE SECTOR(S) */
#define CMD_IDENTIFY	0xEC	/* DEVICE IDENTIFY */
#define CMD_SETFEATURES	0xEF	/* SET FEATURES */

/* ATA register bit definitions */
#define	LBA				0xE0
#define	BSY				0x80
#define	DRDY			0x40
#define	DF				0x20
#define	DRQ				0x08
#define	ERR				0x01
#define	SRST			0x40
#define	nIEN			0x20

/* Contorl Ports */
#define	CTRL_PORT		PORTA
#define	CTRL_DDR		DDRA
#define	SOCK_PORT		PORTC
#define	SOCK_DDR		DDRC
#define	SOCK_PIN		PINC
#define	DAT0_PORT		PORTD
#define	DAT0_DDR		DDRD
#define	DAT0_PIN		PIND
#define	SOCKINS			0x03
#define	SOCKPWR			0x04

/* Bit definitions for Control Port */
#define	CTL_READ		0x20
#define	CTL_WRITE		0x40
#define	CTL_RESET		0x80
#define	REG_DATA		0xF0
#define	REG_ERROR		0xF1
#define	REG_FEATURES	0xF1
#define	REG_COUNT		0xF2
#define	REG_SECTOR		0xF3
#define	REG_CYLL		0xF4
#define	REG_CYLH		0xF5
#define	REG_DEV			0xF6
#define	REG_COMMAND		0xF7
#define	REG_STATUS		0xF7
#define	REG_DEVCTRL		0xEE
#define	REG_ALTSTAT		0xEE




/*--------------------------------------------------------------------------

   Module Private Functions

---------------------------------------------------------------------------*/

static volatile
DSTATUS Stat = STA_NOINIT;	/* Disk status */

static volatile
BYTE Timer;			/* 100Hz decrement timer */



/*-----------------------------------------------------------------------*/
/* Read an ATA register                                                  */
/*-----------------------------------------------------------------------*/

static
BYTE read_ata (
	BYTE reg			/* Register to be read */
)
{
	BYTE rd;


	CTRL_PORT = reg;
	CTRL_PORT &= ~CTL_READ;
	CTRL_PORT &= ~CTL_READ;
	CTRL_PORT &= ~CTL_READ;
	rd = DAT0_PIN;
	CTRL_PORT |= CTL_READ;
	return rd;
}



/*-----------------------------------------------------------------------*/
/* Write a byte to an ATA register                                       */
/*-----------------------------------------------------------------------*/

static
void write_ata (
	BYTE reg,		/* Register to be written */
	BYTE dat		/* Data to be written */
)
{
	CTRL_PORT = reg;
	DAT0_PORT = dat;
	DAT0_DDR = 0xFF;
	CTRL_PORT &= ~CTL_WRITE;
	CTRL_PORT &= ~CTL_WRITE;
	CTRL_PORT |= CTL_WRITE;
	DAT0_PORT = 0xFF;
	DAT0_DDR = 0;
}



/*-----------------------------------------------------------------------*/
/* Read a part of data block                                             */
/*-----------------------------------------------------------------------*/

static
void read_part (
	BYTE *buff, 	/* Data buffer to store read data */
	BYTE ofs,		/* Offset of the part of data in unit of word */
	BYTE count		/* Number of word to pick up */
)
{
	BYTE c = 0, dl, dh;


	CTRL_PORT = REG_DATA;		/* Select Data register */
	do {
		CTRL_PORT &= ~CTL_READ;		/* IORD = L */
		CTRL_PORT &= ~CTL_READ;		/* delay */
		dl = DAT0_PIN;				/* Read Even data */
		CTRL_PORT |= CTL_READ;		/* IORD = H */
		CTRL_PORT &= ~CTL_READ;		/* IORD = L */
		CTRL_PORT &= ~CTL_READ;		/* delay */
		dh = DAT0_PIN;				/* Read Odd data */
		CTRL_PORT |= CTL_READ;		/* IORD = H */
		if (count && (c >= ofs)) {	/* Pick up a part of block */
			*buff++ = dl;
			*buff++ = dh;
			count--;
		}
	} while (++c);
	read_ata(REG_ALTSTAT);
	read_ata(REG_STATUS);
}



/*-----------------------------------------------------------------------*/
/* Wait for Data Ready                                                   */
/*-----------------------------------------------------------------------*/

static
BOOL wait_data (void)
{
	BYTE s;


	Timer = 100;	/* Time out = 1 sec */
	do {
		if (!Timer) return FALSE;		/* Abort when timeout occured */
		s = read_ata(REG_STATUS);		/* Get status */
	} while ((s & (BSY|DRQ)) != DRQ);	/* Wait for BSY goes low and DRQ goes high */

	read_ata(REG_ALTSTAT);
	return TRUE;
}




/*--------------------------------------------------------------------------

   Public Functions

---------------------------------------------------------------------------*/


/*-----------------------------------------------------------------------*/
/* Initialize Disk Drive                                                 */
/*-----------------------------------------------------------------------*/

DSTATUS disk_initialize (
	BYTE drv		/* Physical drive nmuber (0) */
)
{
	if (drv) return STA_NOINIT;		/* Supports only single drive */

	Stat |= STA_NOINIT;

	SOCK_PORT = 0xFF;						/* Power OFF */
	SOCK_DDR = SOCKPWR;
	DAT0_PORT = 0;
	CTRL_DDR = 0;

	for (Timer = 5; Timer; );				/* 50ms */
	if (Stat & STA_NODISK) return Stat;

	/* Initialize CFC control port */
	SOCK_PORT &= ~SOCKPWR;					/* Power ON */
	CTRL_PORT = CTL_READ | CTL_WRITE;
	for (Timer = 1; Timer; );				/* 10ms */
	CTRL_DDR = 0xFF;

	DAT0_PORT = 0xFF;						/* Pull-up D0-D7 */
	for (Timer = 5; Timer; );				/* 50ms */
	CTRL_PORT |= CTL_RESET;					/* Deassert RESET */
	for (Timer = 2; Timer; );				/* 20ms */
	write_ata(REG_DEV, 0);					/* Select Device 0 */
	Timer = 100;
	do {
		if (!Timer) return Stat;
	} while (!(read_ata(REG_STATUS) & (BSY | DRQ)));

	write_ata(REG_DEVCTRL, SRST | nIEN);	/* Software reset */
	for (Timer = 2; Timer; );
	write_ata(REG_DEVCTRL, nIEN);
	for (Timer = 2; Timer; );
	Timer = 100;
	do {
		if (!Timer) return Stat;
	} while ((read_ata(REG_STATUS) & (DRDY|BSY)) != DRDY);

	write_ata(REG_FEATURES, 0x01);			/* Select 8-bit PIO transfer mode */
	write_ata(REG_COMMAND, CMD_SETFEATURES);
	Timer = 100;
	do {
		if (!Timer) return Stat;
	} while (read_ata(REG_STATUS) & BSY);

	Stat &= ~STA_NOINIT;		/* When device goes ready, clear STA_NOINIT */

	return Stat;
}



/*-----------------------------------------------------------------------*/
/* Return Disk Status                                                    */
/*-----------------------------------------------------------------------*/

DSTATUS disk_status (
	BYTE drv		/* Physical drive nmuber (0) */
)
{
	if (drv) return STA_NOINIT;		/* Supports only single drive */
	return Stat;
}



/*-----------------------------------------------------------------------*/
/* Read Sector(s)                                                        */
/*-----------------------------------------------------------------------*/

DRESULT disk_read (
	BYTE drv,		/* Physical drive nmuber (0) */
	BYTE *buff,		/* Data buffer to store read data */
	DWORD sector,	/* Sector number (LBA) */
	BYTE count		/* Sector count (1..255) */
)
{
	BYTE c, iord_l, iord_h;


	if (drv || !count) return RES_PARERR;
	if (Stat & STA_NOINIT) return RES_NOTRDY;

	/* Issue Read Setor(s) command */
	write_ata(REG_COUNT, count);
	write_ata(REG_SECTOR, (BYTE)sector);
	write_ata(REG_CYLL, (BYTE)(sector >> 8));
	write_ata(REG_CYLH, (BYTE)(sector >> 16));
	write_ata(REG_DEV, ((BYTE)(sector >> 24) & 0x0F) | LBA);
	write_ata(REG_COMMAND, CMD_READ);

	do {
		if (!wait_data()) return RES_ERROR;	/* Wait data ready */
		CTRL_PORT = REG_DATA;
		iord_h = REG_DATA;
		iord_l = REG_DATA & ~CTL_READ;
		c = 0;
		do {
			CTRL_PORT = iord_l;		/* IORD = L */
			CTRL_PORT = iord_l;		/* delay */
			CTRL_PORT = iord_l;		/* delay */
			*buff++ = DAT0_PIN;		/* Get even data */
			CTRL_PORT = iord_h;		/* IORD = H */
			CTRL_PORT = iord_h;		/* delay */
			CTRL_PORT = iord_l;		/* IORD = L */
			CTRL_PORT = iord_l;		/* delay */
			CTRL_PORT = iord_l;		/* delay */
			*buff++ = DAT0_PIN;		/* Get Odd data */
			CTRL_PORT = iord_h;		/* IORD = H */
		} while (--c);
	} while (--count);

	read_ata(REG_ALTSTAT);
	read_ata(REG_STATUS);

	return RES_OK;
}



/*-----------------------------------------------------------------------*/
/* Write Sector(s)                                                       */
/*-----------------------------------------------------------------------*/

#if _READONLY == 0
DRESULT disk_write (
	BYTE drv,			/* Physical drive nmuber (0) */
	const BYTE *buff,	/* Data to be written */
	DWORD sector,		/* Sector number (LBA) */
	BYTE count			/* Sector count (1..255) */
)
{
	BYTE s, c, iowr_l, iowr_h;


	if (drv || !count) return RES_PARERR;
	if (Stat & STA_NOINIT) return RES_NOTRDY;

	/* Issue Write Setor(s) command */
	write_ata(REG_COUNT, count);
	write_ata(REG_SECTOR, (BYTE)sector);
	write_ata(REG_CYLL, (BYTE)(sector >> 8));
	write_ata(REG_CYLH, (BYTE)(sector >> 16));
	write_ata(REG_DEV, ((BYTE)(sector >> 24) & 0x0F) | LBA);
	write_ata(REG_COMMAND, CMD_WRITE);

	do {
		if (!wait_data()) return RES_ERROR;
		CTRL_PORT = REG_DATA;
		iowr_h = REG_DATA;
		iowr_l = REG_DATA & ~CTL_WRITE;
		DAT0_DDR = 0xFF;		/* Set D0-D7 as output */
		c = 0;
		do {
			DAT0_PORT = *buff++;	/* Set even data */
			CTRL_PORT = iowr_l;		/* IOWR = L */
			CTRL_PORT = iowr_h;		/* IOWR = H */
			DAT0_PORT = *buff++;	/* Set odd data */
			CTRL_PORT = iowr_l;		/* IOWR = L */
			CTRL_PORT = iowr_h;		/* IOWR = H */
		} while (--c);
		DAT0_PORT = 0xFF;		/* Set D0-D7 as input */
		DAT0_DDR = 0;
	} while (--count);

	Timer = 100;
	do {
		if (!Timer) return RES_ERROR;
		s = read_ata(REG_STATUS);
	} while (s & BSY);
	if (s & ERR) return RES_ERROR;

	read_ata(REG_ALTSTAT);
	read_ata(REG_STATUS);

	return RES_OK;
}
#endif /* _READONLY */



/*-----------------------------------------------------------------------*/
/* Miscellaneous Functions                                               */
/*-----------------------------------------------------------------------*/

DRESULT disk_ioctl (
	BYTE drv,		/* Physical drive nmuber (0) */
	BYTE ctrl,		/* Control code */
	void *buff		/* Buffer to send/receive data block */
)
{
	BYTE n, w, ofs, dl, dh, *ptr = buff;


	if (drv) return RES_PARERR;
	if (Stat & STA_NOINIT) return RES_NOTRDY;

	switch (ctrl) {
		case GET_SECTOR_COUNT :	/* Get number of sectors on the disk (DWORD) */
			ofs = 60; w = 2; n = 0;
			break;

		case GET_SECTOR_SIZE :	/* Get sectors on the disk (WORD) */
			*(WORD*)buff = 512;
			return RES_OK;

		case CTRL_SYNC :	/* Nothing to do */
			return RES_OK;

		case ATA_GET_REV :	/* Get firmware revision (8 chars) */
			ofs = 23; w = 4; n = 4;
			break;

		case ATA_GET_MODEL :	/* Get model name (40 chars) */
			ofs = 27; w = 20; n = 20;
			break;

		case ATA_GET_SN :	/* Get serial number (20 chars) */
			ofs = 10; w = 10; n = 10;
			break;

		default:
			return RES_PARERR;
	}

	write_ata(REG_COMMAND, CMD_IDENTIFY);
	if (!wait_data()) return RES_ERROR;
	read_part(ptr, ofs, w);
	while (n--) {
		dl = *ptr; dh = *(ptr+1);
		*ptr++ = dh; *ptr++ = dl; 
	}

	return RES_OK;
}



/*-----------------------------------------------------------------------*/
/* Device timer interrupt procedure                                      */
/*-----------------------------------------------------------------------*/
/* This function must be called in period of 10ms */


void disk_timerproc (void)
{
	static BYTE pv;
	BYTE n;


	n = Timer;					/* 100Hz decrement timer */
	if (n) Timer = --n;

	n = pv;
	pv = SOCK_PIN & SOCKINS;	/* Sapmle socket switch */

	if (n == pv) {					/* Have contacts stabled? */
		if (pv & SOCKINS) {			/* CD1 or CD2 is high (Socket empty) */
			Stat |= (STA_NODISK | STA_NOINIT);
			DAT0_DDR = 0; DAT0_PORT = 0;			/* Float D0-D7 */
			CTRL_DDR = CTL_RESET; CTRL_PORT = 0;	/* Assert RESET# */
			SOCK_PORT |= SOCKPWR;					/* Power OFF */
		} else {					/* CD1 and CD2 are low (Card inserted) */
			Stat &= ~STA_NODISK;
		}
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲自拍偷拍九九九| 精品一区二区免费看| 日日夜夜精品视频天天综合网| 欧美aaaaaa午夜精品| 成人黄色小视频| 91精品国产综合久久精品app | 日韩av网站在线观看| 国产激情一区二区三区| 欧美另类z0zxhd电影| 中文字幕第一区二区| 奇米色一区二区| 欧美三区在线观看| 综合色中文字幕| 成人美女视频在线看| 精品日韩一区二区三区 | 久久久亚洲综合| 亚洲chinese男男1069| 成人高清视频在线观看| 欧美电视剧在线观看完整版| 一区二区三区在线观看国产 | 视频一区二区三区中文字幕| 色综合天天综合狠狠| 中文字幕精品—区二区四季| 久久97超碰国产精品超碰| 欧美日本视频在线| 一区二区三区在线不卡| av激情成人网| 国产精品国产a级| 高潮精品一区videoshd| 精品电影一区二区| 久久99国产精品久久| 欧美一级xxx| 日韩精品免费专区| 日韩一级高清毛片| 精品综合免费视频观看| 精品久久久久香蕉网| 久久成人18免费观看| 欧美mv日韩mv| 精品一区二区三区在线视频| 精品区一区二区| 国产精品一二三区| 国产精品免费aⅴ片在线观看| 国产福利视频一区二区三区| 国产精品网曝门| 99re热这里只有精品视频| 17c精品麻豆一区二区免费| jlzzjlzz亚洲日本少妇| 亚洲视频在线一区观看| 欧美日韩一区精品| 蜜桃av噜噜一区| 久久亚洲捆绑美女| www.日本不卡| 亚洲观看高清完整版在线观看 | 成人高清免费在线播放| 亚洲欧美日韩一区二区 | 极品少妇xxxx精品少妇偷拍| 精品久久国产老人久久综合| 国产精品自拍一区| 最新成人av在线| 欧美日韩中文字幕一区二区| 亚洲 欧美综合在线网络| 日韩色在线观看| 粉嫩av一区二区三区粉嫩| 亚洲欧美另类久久久精品2019| 精品视频色一区| 国内精品写真在线观看| 亚洲欧美综合色| 欧美乱熟臀69xxxxxx| 国产激情精品久久久第一区二区| 1区2区3区精品视频| 69堂精品视频| 成人久久视频在线观看| 午夜在线成人av| 国产亚洲欧美日韩日本| 欧美日韩在线精品一区二区三区激情| 美国十次了思思久久精品导航| 国产精品拍天天在线| 欧美性一区二区| 国产99久久久精品| 午夜av电影一区| 国产精品丝袜91| 欧美无人高清视频在线观看| 国产在线播放一区二区三区| 亚洲国产wwwccc36天堂| 国产精品久久久久久久第一福利| 日韩视频免费直播| 欧美日韩亚洲丝袜制服| 粉嫩蜜臀av国产精品网站| 蜜臀精品久久久久久蜜臀| 亚洲精品菠萝久久久久久久| 国产色产综合色产在线视频| 26uuuu精品一区二区| 色先锋aa成人| 丰满亚洲少妇av| 蜜臀a∨国产成人精品| 亚洲一区中文日韩| 国产精品麻豆一区二区| 久久女同性恋中文字幕| 日韩精品影音先锋| 欧美精品一卡两卡| 欧美在线观看18| 91浏览器打开| 成人a区在线观看| 国产尤物一区二区| 精品亚洲成av人在线观看| 日韩和欧美一区二区三区| 一卡二卡三卡日韩欧美| 亚洲欧美日韩久久| 国产精品久久久久久久午夜片| 国产亚洲欧美激情| 国产欧美一区二区在线| 久久人人爽人人爽| 2020国产精品自拍| 久久亚洲欧美国产精品乐播| 2014亚洲片线观看视频免费| 91精品国产综合久久精品麻豆| 欧美三级电影网| 欧美日韩dvd在线观看| 欧美午夜宅男影院| 欧美日韩视频不卡| 这里只有精品电影| 欧美一级二级三级蜜桃| 精品国产一区二区三区久久久蜜月| 日韩欧美综合在线| 久久久青草青青国产亚洲免观| 久久天堂av综合合色蜜桃网 | 91免费观看视频| 92精品国产成人观看免费| 91一区二区在线观看| 欧美亚洲综合久久| 91精品在线免费观看| 精品久久久久久久人人人人传媒| 久久一日本道色综合| 中文av字幕一区| 亚洲精品大片www| 热久久免费视频| 国产麻豆精品视频| 99国产精品久久久久| 欧美视频你懂的| 日韩视频免费观看高清完整版 | 久久99这里只有精品| 国产一区二区在线看| 国产很黄免费观看久久| jiyouzz国产精品久久| 欧美日韩精品一区二区天天拍小说 | 亚洲卡通动漫在线| 日本在线观看不卡视频| 国产伦精品一区二区三区免费| 成人午夜在线视频| 欧美日韩国产成人在线免费| 久久精品日韩一区二区三区| 亚洲精品一二三| 麻豆专区一区二区三区四区五区| 成人午夜又粗又硬又大| 欧美三级视频在线播放| 久久久久久久久免费| 亚洲精品ww久久久久久p站| 精品中文字幕一区二区| 色婷婷av久久久久久久| 精品电影一区二区三区| 亚洲自拍偷拍九九九| 国产成人午夜高潮毛片| 欧美日韩一级黄| 欧美高清一级片在线观看| 午夜精品久久久久久久| 99热在这里有精品免费| 欧美成人精品3d动漫h| 亚洲影视在线播放| 国产夫妻精品视频| 日韩欧美区一区二| 亚洲综合色成人| 国产一区二区看久久| 88在线观看91蜜桃国自产| 亚洲图片另类小说| 国产美女在线精品| 欧美一区二区三区婷婷月色| 一区二区三区视频在线观看| 国产精品一级二级三级| 欧美精品一二三四| 一区二区在线观看不卡| 丁香激情综合五月| 精品精品欲导航| 日本女优在线视频一区二区| 欧美亚洲动漫制服丝袜| 亚洲图片你懂的| 岛国av在线一区| 久久久久久久久久久电影| 久久精品国内一区二区三区| 欧美日韩在线观看一区二区 | 日本高清不卡在线观看| 国产精品少妇自拍| 国产精品系列在线播放| 精品欧美一区二区在线观看| 午夜久久久久久久久| 欧美三级乱人伦电影| 亚洲成人激情综合网| 一本色道久久综合亚洲精品按摩| 国产精品日韩成人| 成人免费视频视频在线观看免费| 久久亚洲精华国产精华液|