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

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

?? ata.c

?? thenewofTiny-FatFs
?? C
字號:
/*-----------------------------------------------------------------------*/
/* ATA 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				0x40
#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	DAT1_PORT		PORTC
#define	DAT1_DDR		DDRC
#define	DAT1_PIN		PINC
#define	DAT0_PORT		PORTD
#define	DAT0_DDR		DDRD
#define	DAT0_PIN		PIND

/* 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
WORD 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 */
		dh = DAT1_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)
{
	WORD w;
	BYTE s;


	cli(); Timer = 1000; sei();	/* Time out = 10 sec */
	do {
		cli(); w = Timer; sei();
		if (!w) 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) */
)
{
	WORD w;


	if (drv) return STA_NOINIT;		/* Supports only single drive */
	Stat |= STA_NOINIT;

	/* Initialize the ATA control port */
	DAT0_PORT = 0xFF;
	DAT1_PORT = 0xFF;
	DAT0_DDR = 0;
	DAT1_DDR = 0;
	CTRL_PORT = CTL_READ | CTL_WRITE;		/* Assert RESET */
	CTRL_DDR = 0xFF;

	for (Timer = 2; Timer; );				/* 20ms */
	CTRL_PORT |= CTL_RESET;					/* Deassert RESET */
	for (Timer = 1; Timer; );				/* 10ms */
	write_ata(REG_DEV, 0);					/* Select Device 0 */

	cli(); Timer = 1000; sei();
	do {
		cli(); w = Timer; sei();
		if (!w) 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; );

	cli(); Timer = 1000; sei();
	do {
		cli(); w = Timer; sei();
		if (!w) return Stat;
	} while ((read_ata(REG_STATUS) & (DRDY|BSY)) != DRDY);

	write_ata(REG_FEATURES, 3);				/* Select PIO default mode without IORDY */
	write_ata(REG_COUNT, 1);
	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 = 128;
		do {
			CTRL_PORT = iord_l;		/* IORD = L */
			CTRL_PORT = iord_l;		/* delay */
			*buff++ = DAT0_PIN;		/* Get even data */
			*buff++ = DAT1_PIN;		/* Get odd data */
			CTRL_PORT = iord_h;		/* IORD = H */
			CTRL_PORT = iord_l;		/* IORD = L */
			CTRL_PORT = iord_l;		/* delay */
			*buff++ = DAT0_PIN;		/* Get even data */
			*buff++ = DAT1_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-D15 as output */
		DAT1_DDR = 0xFF;
		c = 128;
		do {
			DAT0_PORT = *buff++;	/* Set even data */
			DAT1_PORT = *buff++;	/* Set odd data */
			CTRL_PORT = iowr_l;		/* IOWR = L */
			CTRL_PORT = iowr_h;		/* IOWR = H */
			DAT0_PORT = *buff++;	/* Set even data */
			DAT1_PORT = *buff++;	/* Set odd data */
			CTRL_PORT = iowr_l;		/* IOWR = L */
			CTRL_PORT = iowr_h;		/* IOWR = H */
		} while (--c);
		DAT0_PORT = 0xFF;	/* Set D0-D15 as input */
		DAT1_PORT = 0xFF;
		DAT0_DDR = 0;
		DAT1_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, dl, dh, ofs, w, *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)
{
	WORD n;


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

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产98色在线|日韩| 久久色在线观看| 欧美亚洲图片小说| 色一情一乱一乱一91av| 在线观看成人免费视频| 色综合久久综合中文综合网| 色视频成人在线观看免| 色94色欧美sute亚洲线路一久| 色美美综合视频| 欧美日韩五月天| 制服丝袜成人动漫| 日韩欧美久久一区| 精品剧情v国产在线观看在线| 精品少妇一区二区三区日产乱码| 欧美成人伊人久久综合网| 精品久久久影院| 欧美激情一区三区| 亚洲欧美激情小说另类| 一区二区久久久| 日韩国产高清影视| 九九精品视频在线看| 成人一区在线观看| 91免费版在线看| 欧美三级日韩三级| 日韩免费福利电影在线观看| 久久久久久久久一| 亚洲精选免费视频| 日韩成人精品在线| 国产福利一区在线| 色婷婷精品大视频在线蜜桃视频| 欧美日韩一区二区三区四区| 日韩免费电影网站| 成人欧美一区二区三区黑人麻豆| 亚洲午夜电影网| 国产综合久久久久久鬼色| 99久久久国产精品免费蜜臀| 欧美精品tushy高清| 久久精品亚洲一区二区三区浴池| 亚洲欧美国产三级| 免费一级欧美片在线观看| 国产91清纯白嫩初高中在线观看 | 成人h动漫精品一区二区| 在线视频国内自拍亚洲视频| 欧美一级搡bbbb搡bbbb| 国产精品免费网站在线观看| 亚洲444eee在线观看| 国产iv一区二区三区| 欧美日韩另类一区| 国产亚洲一区字幕| 日精品一区二区| 97成人超碰视| 2022国产精品视频| 亚洲丰满少妇videoshd| 成人午夜看片网址| 日韩欧美国产三级电影视频| 亚洲免费观看高清完整版在线观看| 日本不卡一区二区三区| 91香蕉国产在线观看软件| 欧美xxxxxxxxx| 一区二区三区免费| 国产高清视频一区| 日韩三级视频在线观看| 亚洲精品成人悠悠色影视| 国产夫妻精品视频| 日韩一区二区三区在线视频| 亚洲日本丝袜连裤袜办公室| 国产乱淫av一区二区三区| 91精品黄色片免费大全| 亚洲一区在线视频观看| gogogo免费视频观看亚洲一| 久久夜色精品国产欧美乱极品| 亚洲国产aⅴ天堂久久| 91在线码无精品| 久久精品一区二区三区av| 美国毛片一区二区三区| 欧美性大战久久久久久久| 中文字幕一区二区三区色视频| 国产一区二区看久久| 欧美一区二区三区在线视频| 一区二区三区四区亚洲| 99精品视频一区二区三区| 国产亚洲制服色| 国产资源精品在线观看| 日韩精品中文字幕在线一区| 日本午夜精品视频在线观看| 欧美亚洲国产怡红院影院| 亚洲私人影院在线观看| 成人福利视频网站| 亚洲国产激情av| 国产精品影音先锋| 久久久夜色精品亚洲| 国产一区高清在线| 精品国产1区2区3区| 久久精品国产在热久久| 精品日产卡一卡二卡麻豆| 日本中文字幕一区| 日韩美女视频在线| 精品在线播放免费| 久久综合九色综合97婷婷| 激情综合色播激情啊| 精品国产乱码久久久久久久| 久久国产三级精品| 日韩免费看的电影| 极品尤物av久久免费看| 久久午夜电影网| 国产成人精品免费| 国产精品久久久久久久久晋中| 97精品久久久午夜一区二区三区| 自拍偷拍欧美精品| 欧美三级在线看| 免费观看在线色综合| 精品国产乱码久久久久久闺蜜| 国产乱码一区二区三区| 国产精品久久影院| 欧美图片一区二区三区| 天堂va蜜桃一区二区三区漫画版| 欧美一区二区三区免费视频 | 欧美日韩黄色一区二区| 日本亚洲一区二区| 久久久久久久久伊人| 99久久伊人网影院| 亚洲人吸女人奶水| 欧美日韩不卡一区| 国产中文一区二区三区| 国产精品久久久久久福利一牛影视| 色婷婷亚洲综合| 日日摸夜夜添夜夜添国产精品| 精品国产伦理网| 99视频有精品| 无码av免费一区二区三区试看| 日韩精品一区国产麻豆| 风流少妇一区二区| 亚洲一区二区欧美激情| 日韩久久久精品| a亚洲天堂av| 日韩二区三区四区| 亚洲国产成人午夜在线一区| 在线观看成人免费视频| 狠狠色狠狠色综合系列| 亚洲精品水蜜桃| 欧美一级一区二区| 91在线观看视频| 美女脱光内衣内裤视频久久影院| 国产日韩三级在线| 色成人在线视频| 精品一二三四在线| 亚洲制服丝袜在线| 久久五月婷婷丁香社区| 色猫猫国产区一区二在线视频| 久久国产精品露脸对白| 亚洲美女屁股眼交| 精品国产乱码久久| 欧洲色大大久久| 国产精品一区二区三区99| 亚洲高清免费视频| 国产精品久久久久久久久免费桃花 | 久久久久国产精品厨房| 欧美日韩在线不卡| 高潮精品一区videoshd| 三级成人在线视频| 亚洲人成网站在线| 久久精品这里都是精品| 欧美一区二区免费视频| 91偷拍与自偷拍精品| 国精产品一区一区三区mba桃花| 亚洲一区二区三区四区不卡| 国产欧美日韩综合精品一区二区| 欧美高清视频一二三区 | 欧美午夜一区二区| 粉嫩av亚洲一区二区图片| 蜜臀av一区二区在线观看| 亚洲精品乱码久久久久久日本蜜臀| 久久色.com| 精品久久久久久无| 69堂成人精品免费视频| 欧美中文字幕一区二区三区| av不卡一区二区三区| 国产激情偷乱视频一区二区三区| 蜜臀av国产精品久久久久| 亚洲午夜一二三区视频| 亚洲欧美经典视频| 亚洲欧美中日韩| 国产农村妇女毛片精品久久麻豆| 精品国产乱码久久久久久闺蜜| 7777精品久久久大香线蕉| 欧美在线短视频| 色综合久久久久久久久久久| 丁香亚洲综合激情啪啪综合| 激情综合网最新| 免费欧美在线视频| 日本一道高清亚洲日美韩| 丝袜诱惑亚洲看片| 天天影视色香欲综合网老头| 亚洲图片欧美综合| 一区二区三区av电影| 一区二区在线电影| 一区二区三区四区在线免费观看| 亚洲美女屁股眼交3| 一区二区三区鲁丝不卡| 夜夜精品浪潮av一区二区三区|