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

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

?? ata.c

?? avr之IDE驅動程序
?? C
?? 第 1 頁 / 共 2 頁
字號:
	ataStatusWait(ATA_SR_DRQ, 0);

	// read data from drive
	ataReadDataBuffer(Buffer, 512*numsectors);

	// Return the error bit from the status register...
	temp = ataReadByte(ATA_REG_CMDSTATUS1);	// read status register

	return (temp & ATA_SR_ERR) ? 1:0;
}


unsigned char ataWriteSectorsCHS(unsigned char Drive, 
											unsigned char Head, 
											unsigned int Track,
											unsigned char Sector,
											unsigned int numsectors,
											unsigned char *Buffer)
{
  	unsigned char temp;

	// Wait for drive to be ready
	temp = ataStatusWait(ATA_SR_BSY, ATA_SR_BSY);

  	// Prepare parameters...
	ataWriteByte(ATA_REG_HDDEVSEL, 0xA0+(Drive ? 0x10:00)+Head); // CHS mode/Drive/Head
	ataWriteByte(ATA_REG_CYLHI, Track>>8);  		// MSB of track
	ataWriteByte(ATA_REG_CYLLO, Track);     		// LSB of track
  	ataWriteByte(ATA_REG_STARTSEC, Sector);    	// sector
	ataWriteByte(ATA_REG_SECCOUNT, numsectors);	// # of sectors

	// Issue write sector command
  	ataWriteByte(ATA_REG_CMDSTATUS1, 0x31);

	//delay(100);

	// Wait for drive to request data transfer
	ataStatusWait(ATA_SR_DRQ, 0);

	// write data to drive
	ataWriteDataBuffer(Buffer, 512*numsectors);
	
	// Wait for drive to finish write
	temp = ataStatusWait(ATA_SR_BSY, ATA_SR_BSY);

	// check for errors
	if (temp & ATA_SR_ERR)
	{
		rprintfProgStrM("WR ERR\r\n");
		return 1;
	}

	// Return the error bit from the status register...
	return (temp & ATA_SR_ERR) ? 1:0;
}

unsigned char ataReadSectorsLBA(	unsigned char Drive, 
											unsigned long lba,
											unsigned int numsectors,
                            		unsigned char *Buffer)
{
  	unsigned int cyl, head, sect;
  	unsigned char temp;

#ifdef DEBUG_ATA
	rprintfProgStrM("ATA LBA read ");
	rprintfu32(lba); rprintfProgStrM(" ");
	rprintfu16(numsectors); rprintfProgStrM(" ");
	rprintfu16((unsigned int)Buffer); 
	rprintfCRLF();
#endif

	sect = (int) ( lba & 0x000000ffL );
	lba = lba >> 8;
	cyl = (int) ( lba & 0x0000ffff );
	lba = lba >> 16;
	head = ( (int) ( lba & 0x0fL ) ) | ATA_HEAD_USE_LBA;

	temp = ataReadSectorsCHS( Drive, head, cyl, sect, numsectors, Buffer );

	if(temp)
		ataDiskErr();
	return temp;
}

unsigned char ataWriteSectorsLBA(	unsigned char Drive, 
												unsigned long lba,
												unsigned int numsectors,
                            			unsigned char *Buffer)
{
	unsigned int cyl, head, sect;
	unsigned char temp;

#ifdef DEBUG_ATA
	rprintfProgStrM("ATA LBA write ");
	rprintfu32(lba); rprintfProgStrM(" ");
	rprintfu16(numsectors); rprintfProgStrM(" ");
	rprintfu16((unsigned int)Buffer); 
	rprintfCRLF();
#endif

	sect = (int) ( lba & 0x000000ffL );
	lba = lba >> 8;
	cyl = (int) ( lba & 0x0000ffff );
	lba = lba >> 16;
	head = ( (int) ( lba & 0x0fL ) ) | ATA_HEAD_USE_LBA;

	temp = ataWriteSectorsCHS( Drive, head, cyl, sect, numsectors, Buffer );

	if(temp)
		ataDiskErr();
	return temp;
}                            		


unsigned char ataReadSectors(	unsigned char Drive, 
										unsigned long lba,
										unsigned int numsectors,
                            	unsigned char *Buffer)
{
  	unsigned int cyl, head, sect;
  	unsigned char temp;

	// check if drive supports native LBA mode
	if(ataDriveInfo.LBAsupport)
	{
		// drive supports using native LBA
		temp = ataReadSectorsLBA(Drive, lba, numsectors, Buffer);
	}
	else
	{
		// drive required CHS access
		#ifdef DEBUG_ATA
			// do this defore destroying lba
			rprintfProgStrM("ATA LBA for CHS read: ");
			rprintfProgStrM("LBA="); rprintfu32(lba); rprintfProgStrM(" ");
		#endif

		// convert LBA to pseudo CHS
		// remember to offset the sector count by one
		sect = (u08) (lba % ataDriveInfo.sectors)+1;
		lba = lba / ataDriveInfo.sectors;
		head = (u08) (lba % ataDriveInfo.heads);
		lba = lba / ataDriveInfo.heads;
		cyl = (u16) lba;

		#ifdef DEBUG_ATA
			rprintfProgStrM("C:H:S=");
			rprintfu16(cyl); rprintfProgStrM(":");
			rprintfu08(head); rprintfProgStrM(":");
			rprintfu08(sect); rprintfCRLF();
		#endif

		temp = ataReadSectorsCHS( Drive, head, cyl, sect, numsectors, Buffer );
	}

	if(temp)
		ataDiskErr();
	return temp;
}


unsigned char ataWriteSectors(unsigned char Drive, 
										unsigned long lba,
										unsigned int numsectors,
                            	unsigned char *Buffer)
{
  	unsigned int cyl, head, sect;
  	unsigned char temp;

	// check if drive supports native LBA mode
	if(ataDriveInfo.LBAsupport)
	{
		// drive supports using native LBA
		temp = ataWriteSectorsLBA(Drive, lba, numsectors, Buffer);
	}
	else
	{
		// drive required CHS access
		#ifdef DEBUG_ATA
			// do this defore destroying lba
			rprintfProgStrM("ATA LBA for CHS write: ");
			rprintfProgStrM("LBA="); rprintfu32(lba); rprintfProgStrM(" ");
		#endif

		// convert LBA to pseudo CHS
		// remember to offset the sector count by one
		sect = (u08) (lba % ataDriveInfo.sectors)+1;
		lba = lba / ataDriveInfo.sectors;
		head = (u08) (lba % ataDriveInfo.heads);
		lba = lba / ataDriveInfo.heads;
		cyl = (u16) lba;

		#ifdef DEBUG_ATA
			rprintfProgStrM("C:H:S=");
			rprintfu16(cyl); rprintfProgStrM(":");
			rprintfu08(head); rprintfProgStrM(":");
			rprintfu08(sect); rprintfCRLF();
		#endif

		temp = ataWriteSectorsCHS( Drive, head, cyl, sect, numsectors, Buffer );
	}

	if(temp)
		ataDiskErr();
	return temp;
}                            		

void ataDriveSelect(u08 DriveNo)
{
	ataWriteByte(ATA_REG_HDDEVSEL, 0xA0+(DriveNo ? 0x10:00)); // Drive selection
}
 
//----------------------------------------------------------------------------
// Set drive mode (STANDBY, IDLE)
//----------------------------------------------------------------------------
/*#define STANDBY 0
#define IDLE    1
#define SLEEP   2 
*/ 

/*
unsigned char SetMode(unsigned char DriveNo, unsigned char Mode, unsigned char PwrDown) 
{
  WriteBYTE(CMD, 6, 0xA0 + (DriveNo ? 0x10:0x00)); // Select drive
  WriteBYTE(CMD, 2, (PwrDown ? 0x01:0x00)); // Enable automatic power down
  switch (Mode) 
  {
    case STANDBY: WriteBYTE(CMD,7, 0xE2); break;
    case IDLE:    WriteBYTE(CMD,7, 0xE3); break;
    // NOTE: To recover from sleep, either issue a soft or hardware reset !
    // (But not on all drives, f.ex seagate ST3655A it's not nessecary to reset
    // but only to go in Idle mode, But on a Conner CFA170A it's nessecary with
    // a reset)
    case SLEEP:   WriteBYTE(CMD,7, 0xE6); break;
  }
  Timer10mSec=10000;
  while ((ReadBYTE(CMD,7) & 0xC0)!=0x40 && Timer10mSec); // Wait for DRDY & NOT BUSY 
  if (Timer10mSec==0) return 0xFF;                       //   or timeout
 
  // Return the error register...
  return ReadBYTE(CMD, 1);
}

*/

u08 ataReadByte(u08 reg)
{
	register u08 ret;
	//sbi(MCUCR, SRW);			// enable RAM waitstate
	ret = *((volatile unsigned char*) ATA_REG_BASE + reg);
	//cbi(MCUCR, SRW);			// disable RAM waitstate
	return ret;
}

void ataWriteByte(u08 reg, u08 data)
{
	//sbi(MCUCR, SRW);			// enable RAM waitstate
	*((volatile unsigned char*) ATA_REG_BASE + reg) = data;
	//cbi(MCUCR, SRW);			// disable RAM waitstate
}

 
void ataShowRegisters(unsigned char DriveNo) 
{ 
	ataWriteByte(ATA_REG_HDDEVSEL, 0xA0 + (DriveNo ? 0x10:0x00)); // Select drive
	
	rprintfProgStrM("R0: DATALOW  = 0x");	rprintfu08(ataReadByte(ATA_REG_DATAL	));		rprintfProgStrM(" \r\n");
	rprintfProgStrM("R1: ERROR    = 0x");	rprintfu08(ataReadByte(ATA_REG_ERROR	));		rprintfProgStrM(" \r\n");
	rprintfProgStrM("R2: SECT CNT = 0x");	rprintfu08(ataReadByte(ATA_REG_SECCOUNT));		rprintfProgStrM(" \r\n");
	rprintfProgStrM("R3: SECT NUM = 0x");	rprintfu08(ataReadByte(ATA_REG_STARTSEC));		rprintfProgStrM(" \r\n");
	rprintfProgStrM("R4: CYL LOW  = 0x");	rprintfu08(ataReadByte(ATA_REG_CYLLO	));		rprintfProgStrM(" \r\n");
	rprintfProgStrM("R5: CYL HIGH = 0x");	rprintfu08(ataReadByte(ATA_REG_CYLHI	));		rprintfProgStrM(" \r\n");
	rprintfProgStrM("R6: HEAD/DEV = 0x");	rprintfu08(ataReadByte(ATA_REG_HDDEVSEL));		rprintfProgStrM(" \r\n");
	rprintfProgStrM("R7: CMD/STA  = 0x");	rprintfu08(ataReadByte(ATA_REG_CMDSTATUS1));	rprintfProgStrM("\r\n");
} 

unsigned char ataSWReset(void)
{
	ataWriteByte(ATA_REG_HDDEVSEL, 0x06);	// SRST and nIEN bits
	delay(10);	// 10uS delay
	ataWriteByte(ATA_REG_HDDEVSEL, 0x02);	// nIEN bits
	delay(10);	// 10 uS delay
   
   while( (ataReadByte(ATA_REG_CMDSTATUS1) & 0xC0) != 0x40 ); // Wait for DRDY and not BSY
    
  	return ataReadByte(ATA_REG_CMDSTATUS1) + ataReadByte(ATA_REG_ERROR);
}

/*
unsigned char ATA_Idle(unsigned char Drive)
{

  WriteBYTE(CMD, 6, 0xA0 + (Drive ? 0x10:0x00)); // Select drive
  WriteBYTE(CMD,7, 0xE1);

  while ((ReadBYTE(CMD,7) & 0xC0)!=0x40); // Wait for DRDY & NOT BUSY 

  // Return the error register...
  return ReadBYTE(CMD, 1);
}
*/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕精品在线不卡| 亚洲综合无码一区二区| 成人午夜又粗又硬又大| 一区二区三区高清| youjizz久久| 捆绑调教一区二区三区| 综合色中文字幕| 成人av免费在线观看| 一区二区三区久久久| 国产欧美一区二区精品性| 91麻豆精品国产91久久久使用方法 | 成人欧美一区二区三区视频网页| 欧美日韩精品欧美日韩精品一| 国产精品一区二区视频| 天天操天天干天天综合网| 国产欧美日韩另类视频免费观看| 欧美性感一区二区三区| 国产一区三区三区| 亚洲自拍偷拍av| 亚洲免费观看高清完整版在线| 亚洲精品一区二区三区在线观看| 色综合网站在线| 波多野结衣亚洲一区| 精品一区二区免费看| 国产亚洲婷婷免费| 9191精品国产综合久久久久久 | 日韩精品一区二区三区中文不卡 | 国产露脸91国语对白| 天天影视色香欲综合网老头| 亚洲成人精品一区二区| 国产三级精品三级在线专区| 久久久久97国产精华液好用吗| 欧美一三区三区四区免费在线看| av中文字幕亚洲| 99在线精品免费| 成人国产精品免费| 午夜视频在线观看一区二区三区| 亚洲免费资源在线播放| 亚洲国产精品欧美一二99| 日韩一区二区免费在线电影| 精品久久久久久亚洲综合网| 亚洲精品在线三区| 久久久久久亚洲综合影院红桃| 日韩欧美国产一区二区三区| 国产成人av一区二区三区在线观看| 国产一区二区精品久久| 国产成人综合网| 一本色道a无线码一区v| 91国在线观看| 成人污污视频在线观看| 91麻豆6部合集magnet| 美脚の诱脚舐め脚责91| 国内精品久久久久影院色| 99精品在线观看视频| 色哟哟国产精品| 欧美一区二区大片| 中文字幕二三区不卡| 国产精品久久久久一区二区三区共| 亚洲欧洲精品一区二区三区| 一区二区三区91| 日本免费在线视频不卡一不卡二| 久久精品国产精品亚洲红杏| 麻豆精品一区二区三区| 国产美女在线观看一区| av一区二区久久| 日韩精品一区二区三区四区视频| 日本一区二区电影| 亚洲综合色自拍一区| 国产一区视频在线看| 在线视频综合导航| 久久麻豆一区二区| 日韩精品每日更新| 成人黄色在线网站| 中文字幕一区二区三区不卡 | 国产精品免费视频观看| 国产成人夜色高潮福利影视| 久久久久久9999| 激情亚洲综合在线| 久久久91精品国产一区二区三区| 国产麻豆午夜三级精品| 国产午夜亚洲精品理论片色戒| 国产裸体歌舞团一区二区| 久久久国产精品不卡| 成人久久18免费网站麻豆| 一区二区高清免费观看影视大全| 成人一区二区在线观看| 中文字幕亚洲不卡| 色吧成人激情小说| 日韩精品乱码av一区二区| 精品盗摄一区二区三区| 成人av网站在线观看| 亚洲视频一区在线观看| 欧美日韩国产精品成人| 日日夜夜免费精品| 久久亚洲一级片| 91网上在线视频| 日本人妖一区二区| 亚洲国产精品ⅴa在线观看| 99久久免费视频.com| 亚洲午夜影视影院在线观看| 日韩一卡二卡三卡| 成人免费福利片| 午夜精品成人在线| 国产日韩欧美精品在线| 色偷偷88欧美精品久久久| 日韩黄色免费电影| 中文字幕精品综合| 欧美福利电影网| 波多野结衣一区二区三区| 午夜久久久久久| 国产精品久久久久久一区二区三区| 日本韩国精品在线| 国产精品一品二品| 亚洲成人精品影院| 亚洲天堂中文字幕| 欧美不卡一区二区三区四区| www.亚洲国产| 国内精品久久久久影院色| 亚洲综合一区二区精品导航| 国产亚洲一本大道中文在线| 欧美亚洲综合一区| 国产不卡视频在线观看| 香蕉乱码成人久久天堂爱免费| 国产午夜亚洲精品不卡| 欧美群妇大交群中文字幕| 国产a级毛片一区| 老司机一区二区| 亚洲第四色夜色| 中文字幕中文字幕中文字幕亚洲无线| 欧美顶级少妇做爰| 91污在线观看| 国产黄色精品网站| 免费成人深夜小野草| 亚洲美女在线一区| 中文在线免费一区三区高中清不卡| 欧美区一区二区三区| 在线亚洲一区二区| 91理论电影在线观看| 成人小视频在线观看| 国产乱码精品一品二品| 久久99精品国产麻豆不卡| 午夜不卡在线视频| 午夜视频久久久久久| 亚洲一二三级电影| 亚洲午夜精品17c| 亚洲国产精品麻豆| 视频一区在线视频| 日韩国产在线一| 青草国产精品久久久久久| 午夜精品久久久久久久| 丝袜亚洲另类丝袜在线| 日韩和欧美一区二区三区| 日韩精品电影一区亚洲| 日韩—二三区免费观看av| 首页国产欧美日韩丝袜| 亚洲一区二区三区四区在线免费观看| 日韩美女视频一区二区 | 美女视频第一区二区三区免费观看网站| 亚洲人被黑人高潮完整版| 亚洲视频综合在线| 国产精品三级电影| 亚洲美女一区二区三区| 亚洲一区二区在线免费观看视频 | 男人的天堂亚洲一区| 久久精品国产在热久久| 激情偷乱视频一区二区三区| 国产一区二区三区久久悠悠色av| 国产麻豆精品视频| 99久久国产综合精品麻豆| 日本丰满少妇一区二区三区| 欧美二区三区91| 久久久久久久久久看片| 亚洲婷婷国产精品电影人久久| 亚洲国产精品麻豆| 激情六月婷婷综合| 91老师片黄在线观看| 欧美日韩在线亚洲一区蜜芽| 91精品欧美久久久久久动漫| 精品少妇一区二区三区免费观看| 久久综合av免费| 亚洲视频香蕉人妖| 日韩高清不卡一区二区| 韩国一区二区在线观看| 色综合欧美在线视频区| 日韩免费一区二区| 亚洲美女电影在线| 国内久久精品视频| 欧美性videosxxxxx| 久久看人人爽人人| 午夜免费欧美电影| 成人av资源网站| 欧美成人一级视频| 亚洲综合自拍偷拍| 成人中文字幕合集| 日韩一区二区电影在线| 一区二区三区不卡视频在线观看| 国产一区不卡在线| 欧美精品久久一区| 伊人婷婷欧美激情| 成人av影院在线|