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

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

?? ata.c

?? avr之IDE驅(qū)動(dòng)程序
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):
/*! \file ata.c \brief IDE-ATA hard disk interface driver. */
//*****************************************************************************
//
// File Name	: 'ata.c'
// Title		: IDE-ATA interface driver for hard disks
// Author		: Pascal Stang
// Date			: 11/22/2000
// Revised		: 4/19/2003
// Version		: 0.3
// Target MCU	: Atmel AVR Series
// Editor Tabs	: 4
//
// NOTE: This code is currently below version 1.0, and therefore is considered
// to be lacking in some functionality or documentation, or may not be fully
// tested.  Nonetheless, you can expect most functions to work.
//
// This code is distributed under the GNU Public License
//		which can be found at http://www.gnu.org/licenses/gpl.txt
//
//*****************************************************************************

#ifndef WIN32
	#include <avr/io.h>
	#include <avr/interrupt.h>
	#include <avr/signal.h>
	#include <avr/pgmspace.h>
//	#include <stdio.h>
#endif
#include "global.h"
#include "timer.h"
#include "rprintf.h"

#include "ata.h"

//#define DEBUG_ATA	1

// global variables

// drive information
typeDriveInfo ataDriveInfo;


void ataInit(void)
{

}

void ataDriveInit(void)
{
	u08 i;
	unsigned char* buffer = (unsigned char*) SECTOR_BUFFER_ADDR;

	// read drive identity
	rprintfProgStrM("\r\nScanning IDE interface...\r\n");
	// Wait for drive to be ready
	ataStatusWait(ATA_SR_BSY, ATA_SR_BSY);
	// issue identify command
	ataWriteByte(ATA_REG_CMDSTATUS1, 0xEC);
	// wait for drive to request data transfer
	ataStatusWait(ATA_SR_DRQ, ATA_SR_DRQ);
	timerPause(200);
	// read in the data
	ataReadDataBuffer(buffer, 512);

	// set local drive info parameters
	ataDriveInfo.cylinders =		*( ((unsigned int*) buffer) + ATA_IDENT_CYLINDERS );
	ataDriveInfo.heads =			*( ((unsigned int*) buffer) + ATA_IDENT_HEADS );
	ataDriveInfo.sectors =			*( ((unsigned int*) buffer) + ATA_IDENT_SECTORS );
	ataDriveInfo.LBAsupport =		*( ((unsigned int*) buffer) + ATA_IDENT_FIELDVALID );
	ataDriveInfo.sizeinsectors =	*( (unsigned long*) (buffer + ATA_IDENT_LBASECTORS*2) );
	// copy model string
	for(i=0; i<40; i+=2)
	{
		// correct for byte order
		ataDriveInfo.model[i  ] = buffer[(ATA_IDENT_MODEL*2) + i + 1];
		ataDriveInfo.model[i+1] = buffer[(ATA_IDENT_MODEL*2) + i    ];
	}
	// terminate string
	ataDriveInfo.model[40] = 0;

	// process and print info
	if(ataDriveInfo.LBAsupport)
	{
		// LBA support
		rprintf("Drive 0: %dMB ", ataDriveInfo.sizeinsectors/(1000000/512) );
		rprintf("LBA mode -- MODEL: ");
	}
	else
	{
		// CHS, no LBA support
		// calculate drive size
		ataDriveInfo.sizeinsectors = (unsigned long) ataDriveInfo.cylinders*
												ataDriveInfo.heads*ataDriveInfo.sectors;
		rprintf("Drive 0: %dMB ", ataDriveInfo.sizeinsectors/(1000000/512) );
		rprintf("CHS mode C=%d H=%d S=%d -- MODEL: ", ataDriveInfo.cylinders, ataDriveInfo.heads, ataDriveInfo.sectors );
	}
	// print model information	
	rprintfStr(ataDriveInfo.model); rprintfCRLF();

	// initialize local disk parameters
	//ataDriveInfo.cylinders = ATA_DISKPARM_CLYS;
	//ataDriveInfo.heads = ATA_DISKPARM_HEADS;
	//ataDriveInfo.sectors = ATA_DISKPARM_SECTORS;

}

void ataDiskErr(void)
{
	unsigned char b;

	b = ataReadByte(ATA_REG_ERROR);	
	rprintfProgStrM("ATA Error: "); 
	rprintfu08(b); 
	rprintfCRLF();
}

void ataSetDrivePowerMode(u08 DriveNo, u08 mode, u08 timeout)
{
	// select drive
	ataDriveSelect(DriveNo);
	// Wait for drive to be ready
	ataStatusWait(ATA_SR_BSY, ATA_SR_BSY);

	// set mode
	switch(mode)
	{
	case ATA_DISKMODE_SPINDOWN:		ataWriteByte(ATA_REG_CMDSTATUS1, ATA_CMD_SPINDOWN); break;
	case ATA_DISKMODE_SPINUP:		ataWriteByte(ATA_REG_CMDSTATUS1, ATA_CMD_SPINUP); break;
	case ATA_DISKMODE_SETTIMEOUT:
		ataWriteByte(ATA_REG_SECCOUNT, timeout);
		ataWriteByte(ATA_REG_CMDSTATUS1, ATA_CMD_IDLE_5SU);
		break;
	case ATA_DISKMODE_SLEEP:		ataWriteByte(ATA_REG_CMDSTATUS1, ATA_CMD_SLEEP); break;
	default:
		break;
	}
}

void ataPrintSector( u08 *Buffer)
{
	u08 i;
	u16 j;
	u08 *buf;
	u08 s;

	buf = Buffer;
	
	// print the low order address indicies
	rprintfProgStrM("     00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F  0123456789ABCDEF\r\n");
	rprintfProgStrM("     -----------------------------------------------  ---- ASCII -----\r\n");
	
	// print the data
	for(j=0; j<0x20; j++)
	{
		// print the high order address index for this line
		rprintfu16(j<<4);
		rprintfProgStrM(" ");

		// print the hex data
		for(i=0; i<0x10; i++)
		{
			rprintfu08(buf[(j<<4)+i]);
			rprintfProgStrM(" ");
		}
		
		// leave some space
		rprintfProgStrM(" ");

		// print the ascii data
		for(i=0; i<0x10; i++)
		{
			s = buf[(j<<4)+i]; 
			// make sure character is printable
			if(s >= 0x20)
			{
				rprintfChar(s);
			}
			else
			{
				rprintfChar(0x20);
			}

		}
		rprintfCRLF();
	}
}

void ataReadDataBuffer(u08 *Buffer, u16 numBytes)
{
	unsigned int i;

	//sbi(MCUCR, SRW);			// enable RAM waitstate

	// read data from drive
	for (i=0; i<(numBytes/16); i++)
	{
		// optimize by reading 16 bytes in-line before looping
		*Buffer++ = *((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAL);
		*Buffer++ = *((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAH);
		*Buffer++ = *((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAL);
		*Buffer++ = *((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAH);
		*Buffer++ = *((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAL);
		*Buffer++ = *((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAH);
		*Buffer++ = *((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAL);
		*Buffer++ = *((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAH);
		*Buffer++ = *((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAL);
		*Buffer++ = *((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAH);
		*Buffer++ = *((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAL);
		*Buffer++ = *((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAH);
		*Buffer++ = *((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAL);
		*Buffer++ = *((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAH);
		*Buffer++ = *((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAL);
		*Buffer++ = *((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAH);
	}
	//cbi(MCUCR, SRW);			// disable RAM waitstate
	
}

void ataWriteDataBuffer(u08 *Buffer, u16 numBytes)
{
	register unsigned char temp;
	unsigned int i;

	//sbi(MCUCR, SRW);			// enable RAM waitstate

	// write data to drive
	for (i=0; i<(numBytes/16); i++) 	
	{
		// optimize by writing 16 bytes in-line before looping
		// keep byte order correct by using temp register
		temp = *Buffer++;
		*((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAH) = *Buffer++;
		*((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAL) = temp;
		temp = *Buffer++;
		*((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAH) = *Buffer++;
		*((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAL) = temp;
		temp = *Buffer++;
		*((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAH) = *Buffer++;
		*((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAL) = temp;
		temp = *Buffer++;
		*((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAH) = *Buffer++;
		*((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAL) = temp;
		temp = *Buffer++;
		*((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAH) = *Buffer++;
		*((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAL) = temp;
		temp = *Buffer++;
		*((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAH) = *Buffer++;
		*((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAL) = temp;
		temp = *Buffer++;
		*((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAH) = *Buffer++;
		*((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAL) = temp;
		temp = *Buffer++;
		*((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAH) = *Buffer++;
		*((volatile unsigned char*) ATA_REG_BASE + ATA_REG_DATAL) = temp;
	}
	//cbi(MCUCR, SRW);			// disable RAM waitstate

}

u08 ataStatusWait(u08 mask, u08 waitStatus)
{
	register u08 status;

	delay(100);

	// wait for desired status
	while( ((status = ataReadByte(ATA_REG_CMDSTATUS1)) & mask) == waitStatus );

	return status;
}


unsigned char ataReadSectorsCHS(	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 read sector command...
  	ataWriteByte(ATA_REG_CMDSTATUS1, 0x21);

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

	if (temp & ATA_SR_ERR)
	{
		rprintfProgStrM("RD ERR\r\n");
		return 1;
	}

	// Wait for drive to request data transfer

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲gay无套男同| 国产激情一区二区三区| 亚洲天堂a在线| 中文字幕欧美激情一区| 久久精品亚洲乱码伦伦中文| 亚洲精品一区二区三区影院| 日韩免费电影一区| 日韩女优av电影| 欧美变态tickling挠脚心| 91精品国产色综合久久不卡电影 | 日日夜夜免费精品| 亚洲国产成人精品视频| 午夜私人影院久久久久| 日韩高清不卡在线| 蜜芽一区二区三区| 久国产精品韩国三级视频| 久久99久久久久久久久久久| 国产毛片一区二区| 懂色av噜噜一区二区三区av| 成人网在线播放| 91在线视频官网| 欧美日韩在线三区| 欧美一激情一区二区三区| 欧美成人精品福利| 欧美国产综合一区二区| 亚洲欧美区自拍先锋| 亚洲最大成人网4388xx| 日韩制服丝袜先锋影音| 国内精品国产成人国产三级粉色| 国产91精品一区二区麻豆亚洲| 91一区一区三区| 91精品国产综合久久福利软件 | 国产欧美一区二区精品忘忧草| 国产精品免费看片| 一区二区三区国产精品| 麻豆一区二区99久久久久| 丰满白嫩尤物一区二区| 91黄色在线观看| 精品国产免费一区二区三区四区| 国产精品午夜在线观看| 一区二区三国产精华液| 蜜桃av噜噜一区二区三区小说| 国产91精品精华液一区二区三区 | 久久综合99re88久久爱| 国产精品国产三级国产专播品爱网| 一区二区三区在线视频播放| 麻豆视频观看网址久久| 高清日韩电视剧大全免费| 欧美主播一区二区三区美女| 欧美大胆一级视频| 最新国产成人在线观看| 日本不卡一二三区黄网| 成人黄色一级视频| 日韩一级精品视频在线观看| 亚洲欧洲av一区二区三区久久| 亚洲r级在线视频| 成人久久视频在线观看| 欧美电影在哪看比较好| 中文字幕在线观看一区| 免费高清在线视频一区·| 99re这里都是精品| 精品国产伦一区二区三区观看方式| 日韩伦理电影网| 精品一区二区三区久久| 欧美色图一区二区三区| 国产网站一区二区| 奇米精品一区二区三区四区| 99久久精品国产导航| 欧美精品一区二区三区久久久| 亚洲综合图片区| 不卡一区中文字幕| 久久久亚洲国产美女国产盗摄 | 激情图片小说一区| 欧美日韩在线精品一区二区三区激情| 国产欧美日韩一区二区三区在线观看 | 国产精品福利影院| 国精产品一区一区三区mba桃花| 欧美性videosxxxxx| 国产精品美女一区二区| 国内一区二区视频| 日韩欧美亚洲一区二区| 亚洲午夜久久久| 97se亚洲国产综合在线| 久久女同精品一区二区| 久久精品久久综合| 777色狠狠一区二区三区| 国产综合色在线| 欧美www视频| 日韩精品一二三四| 欧美日韩一区高清| 亚洲一区二区中文在线| 91麻豆福利精品推荐| 国产精品女主播av| 国产不卡一区视频| 久久久久国产精品麻豆ai换脸 | 99久久精品国产麻豆演员表| 欧美极品xxx| 国产成人精品免费在线| www久久精品| 国产在线不卡视频| 337p日本欧洲亚洲大胆色噜噜| 男人的j进女人的j一区| 69久久夜色精品国产69蝌蚪网| 亚洲v中文字幕| 欧美日韩亚洲不卡| 视频一区视频二区在线观看| 欧美人与z0zoxxxx视频| 视频一区在线播放| 欧美一级理论片| 日韩电影在线观看网站| 91精品一区二区三区在线观看| 秋霞国产午夜精品免费视频| 欧美成人精品高清在线播放| 国产一区二区美女诱惑| 国产午夜精品理论片a级大结局| 丁香一区二区三区| 亚洲欧美怡红院| 在线亚洲免费视频| 婷婷六月综合亚洲| 欧美电影免费观看高清完整版在| 蓝色福利精品导航| 久久久久9999亚洲精品| 99久久99久久精品国产片果冻 | 成人精品视频一区二区三区尤物| 国产精品你懂的| 色噜噜狠狠一区二区三区果冻| 亚洲国产精品视频| 欧美tickle裸体挠脚心vk| 国产九色sp调教91| 中文字幕一区二区三区蜜月| 日本高清不卡视频| 欧美a一区二区| 日本一区二区三区电影| 一本到不卡免费一区二区| 午夜影视日本亚洲欧洲精品| 日韩免费高清av| 99久久亚洲一区二区三区青草| 亚洲一区二区三区影院| 日韩一级黄色片| 成人久久视频在线观看| 五月天国产精品| 久久在线观看免费| 91美女片黄在线观看91美女| 日韩制服丝袜先锋影音| 国产三级久久久| 在线精品亚洲一区二区不卡| 麻豆精品视频在线| 国产精品福利一区| 欧美精品三级日韩久久| 国产精品18久久久| 亚洲国产精品久久一线不卡| 2020国产成人综合网| 色综合久久综合网97色综合| 秋霞成人午夜伦在线观看| 国产精品国产三级国产三级人妇 | 日韩精品一区二区三区中文不卡 | 精品久久一区二区| 91麻豆123| 精品在线播放免费| 亚洲黄一区二区三区| 欧美精品一区二区三区四区| 在线观看91精品国产入口| 国产精品夜夜爽| 肉色丝袜一区二区| 亚洲激情一二三区| 中文字幕精品三区| 日韩欧美电影在线| 欧美在线视频全部完| 国产精品一区二区久久不卡| 亚洲超丰满肉感bbw| 国产精品成人午夜| 26uuu亚洲| 制服丝袜日韩国产| 91国偷自产一区二区使用方法| 国产精品自拍三区| 欧美aaaaa成人免费观看视频| 亚洲靠逼com| 国产精品美女久久久久久久网站| 欧美电影免费观看高清完整版在线| 欧美中文字幕一区二区三区亚洲 | 日韩亚洲欧美综合| 欧美三级中文字幕| 色综合天天综合色综合av| 高潮精品一区videoshd| 久久国产麻豆精品| 亚洲sss视频在线视频| 亚洲狠狠丁香婷婷综合久久久| 国产日韩欧美a| 欧美成人一区二区三区| 欧美精品日日鲁夜夜添| 91激情五月电影| 色综合久久九月婷婷色综合| 欧美一区二区女人| 5566中文字幕一区二区电影| 色综合久久九月婷婷色综合| 99久久综合狠狠综合久久| 国产东北露脸精品视频| 美国精品在线观看| 美女视频网站黄色亚洲| 婷婷国产v国产偷v亚洲高清|