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

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

?? rwdisk.c

?? 本程序是在ucos ii 下的一個讀寫硬盤的C源程序。可供在他人開發嵌入式系統的讀寫硬盤時參考。
?? C
字號:
/***************************************************************************
                          rwdisk.c  -  description
                             -------------------
    copyright            : (C) 2003
    
 ***************************************************************************/
 
#include "ata.h"
#include "disk.h"


#define SECTOR_SIZE 512

unsigned char intFlag = 1;
//////////////////////////////////////////////////////////////////
void init_chip_param()
{
	// set transfer parameters
	T2_INIT_REG = 0x44;           // set chip PIO transfer mode 
	T2i_INIT_REG = 0x44;
}

/////////////////////////////////////////
void wait_device_int()
{
	unsigned char ch;

	ch = INTR_REG;
	while(!(ch & 0x01)){
		ch = read_ata_reg(Adr_AS);
		if(ch & 0x01) break;
		ch = PIO_FSM;
		ch = INTR_REG;
	}
	read_ata_reg(Adr_ST);
	ch = CHIP_STATUS;
}

/////////////////////////////////////////////////////////////
void ata_select_dev()
{
	//unsigned int data i;

	while(read_ata_reg(Adr_ST) & 0x88);
	write_ata_reg(Adr_DH,0x00);
	//for(;i<5;i++);		//delay
	while(read_ata_reg(Adr_ST) & 0x88);
}
////////////////////////////////////////////////////////

unsigned char read_ata_reg(unsigned char addr)
{
	unsigned char ch;
        
        PIO_CTRL_REG |= 0x80;	//PIO read enable
        ATA_ADDR_REG = addr;
        PIO_CTRL_REG &= 0x00;

	while (!(INTR_REG & 0x02));	//wait pio ready;

	ATA_ADDR_REG = 0x00;
	ch = PIOFIFOL_R;
	return ch;
}
//////////////////////////////////////////////////////////
/* host write atapi device's register(8 bits) */
void write_ata_reg(unsigned char addr,unsigned char ch)
{
        PIO_CTRL_REG |= 0x81;		//PIO write enable
        ATA_ADDR_REG = addr; 
        PIO_CTRL_REG &= 0x01;

	while(!(INTR_REG & 0x02));	//wait pio ready;
	
        PIOFIFOL_W = ch;
	ATA_ADDR_REG = 0x00;
}

////////////////////////////////////////////////////////////
void wait_pio_ready()
{
	unsigned char ch;

	ch = CHIP_STATUS;
	while (!(ch & 0x01)) 
		ch = INTR_REG;
}

/////////////////////////////////////////////////////////////////
void set_pio_write(void)
{
	PIO_CTRL_REG = 0x01;
}

////////////////////////////////////////////////////////////////

void set_pio_read(void)
{
	PIO_CTRL_REG = 0x00;
}

/////////////////////////////////////////////////////////////////////////
/*
    Non-data command flow, this protocol include: SET FEARTURE,READ NATIVE MAX ADDRESS,
	                            SET MAX ADDRESS, etc.
*/

int non_data_com(device_reg_set_t *device_reg_set)
{
	unsigned char ch;
   
	ata_select_dev();

	write_ata_reg(Adr_FR,device_reg_set->feature);
	write_ata_reg(Adr_SC,device_reg_set->sector_count);
	write_ata_reg(Adr_SN,device_reg_set->sector_number);
	write_ata_reg(Adr_CH,device_reg_set->cylinder_high);
	write_ata_reg(Adr_CL,device_reg_set->cylinder_low);
	write_ata_reg(Adr_DH,device_reg_set->device_head);
	write_ata_reg(Adr_CM,device_reg_set->command);

	ch = read_ata_reg(Adr_AS);
	while(ch & 0x80)
		ch = read_ata_reg(Adr_AS);

	if(ch & 0x01) {                            //some error occured
		ch = read_ata_reg(Adr_ER);
		if(intFlag) {
			wait_device_int();
			read_ata_reg(Adr_ST);
			return -1;
		}
		else {
			read_ata_reg(Adr_ST);
			return -1;
		}
	}

	if(intFlag) {                              // normal exit
		wait_device_int();
		read_ata_reg(Adr_ST);
		return 0;
	}
	else {
		read_ata_reg(Adr_ST);
		return 0;
	}
}


/////////////////////////////////////////////////////////////////////////
/* 
    PIO DATA in flow, this protocol include: identify device,indentify packet device,
                     read buffer,read multiple, read sectors  
        
*/

int ata_pio_in(device_reg_set_t *p_device_reg_set)
{
	unsigned char ch;
//	unsigned int i;
	unsigned long byte_num = 0;

	write_ata_reg(Adr_FR,p_device_reg_set->feature);
	write_ata_reg(Adr_SC,p_device_reg_set->sector_count);
	write_ata_reg(Adr_SN,p_device_reg_set->sector_number);
	write_ata_reg(Adr_CH,p_device_reg_set->cylinder_high);
	write_ata_reg(Adr_CL,p_device_reg_set->cylinder_low);
	write_ata_reg(Adr_DH,p_device_reg_set->device_head);
	write_ata_reg(Adr_CM,p_device_reg_set->command);

	do{
		ch = read_ata_reg(Adr_AS);
		if(ch & 0x01){
			ch = read_ata_reg(Adr_ER);
			if(intFlag){
				wait_device_int();
				read_ata_reg(Adr_ST);
			}
			else read_ata_reg(Adr_ST);
			return -1;
		}
		if(intFlag){
			wait_device_int();
			read_ata_reg(Adr_ST);
		}
		else {
			read_ata_reg(Adr_AS);
			ch = read_ata_reg(Adr_ST);
			while(!((!(ch & 0x80))&&(ch & 0x08)))
				ch = read_ata_reg(Adr_ST);
		}
		PIO_CTRL_REG = PIO_READ;                        //set pio read;
		for(; byte_num < SECTOR_SIZE; byte_num += 2) {
			ATA_ADDR_REG = Adr_DA;		//Adr_DA:PIO data register;
			while(!(INTR_REG & 0x02));	//wait pio ready;
			ATA_ADDR_REG = 0x00;

			ch = PIOFIFOH_R;
			ch = PIOFIFOL_R;
		}
		byte_num += SECTOR_SIZE;
		ch = read_ata_reg(Adr_AS);
	}while(((ch & 0x80)&&(!(ch & 0x08))) || ((!(ch & 0x80)) && (ch & 0x08)));

	read_ata_reg(Adr_AS);
	read_ata_reg(Adr_ST);
	return 0;
}


/////////////////////////////////////////////////////////////////////////
/*
    PIO DATA out flow, this protocol include: security disable password,security erase unit,
                     security set password, security unlock, write buffer, write multiple,
                     write sector  
*/

int ata_pio_out(device_reg_set_t *device_reg_set,unsigned int length)
{
	unsigned char ch;
	unsigned int i,byte_num;
	unsigned int num = 1;     //the number of sectors that be writed to disc
        
	write_ata_reg(Adr_FR,device_reg_set->feature);
	write_ata_reg(Adr_SC,device_reg_set->sector_count);
	write_ata_reg(Adr_SN,device_reg_set->sector_number);
	write_ata_reg(Adr_CH,device_reg_set->cylinder_high);
	write_ata_reg(Adr_CL,device_reg_set->cylinder_low);
	write_ata_reg(Adr_DH,device_reg_set->device_head);
	write_ata_reg(Adr_CM,device_reg_set->command);

	ch = read_ata_reg(Adr_AS);
	if(ch & 0x01) {
		ch = read_ata_reg(Adr_ER);
		if(intFlag) {
			wait_device_int();
			read_ata_reg(Adr_ST);
			return -1;
		}
		else {
			read_ata_reg(Adr_ST);
			return -1;
		}
	}

	while(!(!(ch & 0x80)&&(ch & 0x08)))
		ch = read_ata_reg(Adr_AS);

	do {
		byte_num = num*512;
		if(byte_num>length)  //error: data number beyond the length of array
			return -1;
		for(i=(num-1)*512;i<byte_num;i+=2) {
			set_pio_write();
			ATA_ADDR_REG = Adr_DA;//Adr_DA:PIO data register;
			wait_pio_ready();
			PIOFIFOH_W = (unsigned char)(i >> 8);
			PIOFIFOL_W = (unsigned char)(i);
			ATA_ADDR_REG = 0x00;
		}
		num++;

		ch = read_ata_reg(Adr_AS);
		if(ch & 0x01) {                    //error
			ch = read_ata_reg(Adr_ER);
			if(intFlag) {
				wait_device_int();
				read_ata_reg(Adr_ST);
				return -1;
			}
			else {
				read_ata_reg(Adr_ST);
				return -1;
			}
		}
		if(!(!(ch & 0x80)&&(ch & 0x08))||((ch & 0x80)&&(!(ch & 0x08)))) {
			if(intFlag) {
				wait_device_int();
				read_ata_reg(Adr_ST);
				return 0;
			}
			else {
				read_ata_reg(Adr_ST);
				return 0;
			}
		}
		else {
			if(intFlag) {
				wait_device_int();
				read_ata_reg(Adr_ST);
			}
			else {
				ch = read_ata_reg(Adr_ST);
				while(!(!(ch & 0x80)&&(ch & 0x08)))
					ch = read_ata_reg(Adr_ST);
			}
		}
	} while(1);
}

/////////////////////////////////////////////////////////////////////////
int pio_block_out(volatile device_reg_set_t *p_device_reg_set)
{
	unsigned char ch;
 	unsigned int j=0,k=0;
        
	write_ata_reg(Adr_FR,p_device_reg_set->feature);
	write_ata_reg(Adr_SC,p_device_reg_set->sector_count);
	write_ata_reg(Adr_SN,p_device_reg_set->sector_number);
	write_ata_reg(Adr_CH,p_device_reg_set->cylinder_high);
	write_ata_reg(Adr_CL,p_device_reg_set->cylinder_low);
	write_ata_reg(Adr_DH,p_device_reg_set->device_head);
	write_ata_reg(Adr_CM,p_device_reg_set->command);

	//for(i=0;i<1000;i++);      //delay
	ch = read_ata_reg(Adr_AS);
	ch = read_ata_reg(Adr_ST);	   
	if(ch == 0x51) {
		ch = read_ata_reg(Adr_ER);
		if(intFlag) {
			wait_device_int();
			return -1;
		}
		else {
			read_ata_reg(Adr_ST);
			return -1;
		}
	}

	while(!(!(ch & 0x80)&&(ch & 0x08)&&(ch & 0x40)))
		ch = read_ata_reg(Adr_AS);

	do {
		PIO_CTRL_REG = 0x80;
		ATA_ADDR_REG = Adr_DA;   	//Adr_DA:PIO data register;
		PIO_CTRL_REG = 0x07;  
 
		ch = INTR_REG;
		while(!(ch&0x04))
			ch = INTR_REG;      	// wait pio block finish interrupt
		PIO_CTRL_REG = 0x80;  
		ATA_ADDR_REG = 0x00;

		if(intFlag) {
			wait_device_int();
			ch = read_ata_reg(Adr_ST);
		}
		else {
			//tmp = CHIP_STATUS;
			read_ata_reg(Adr_AS);
			ch = read_ata_reg(Adr_ST);
		}            
		if(ch & 0x01) {
			if(intFlag) {
				wait_device_int();
				read_ata_reg(Adr_ST);
				return read_ata_reg(Adr_ER);
			}
			else {
				//tmp = CHIP_STATUS;
				read_ata_reg(Adr_ST);
				return read_ata_reg(Adr_ER);
			}
		}
		if(!(!(ch & 0x80)&&(ch & 0x08))||((ch & 0x80)&&(!(ch & 0x08)))) {
			ch = read_ata_reg(Adr_ST);
			return 0;
		}
		else {
			while(!(!(ch & 0x80)&&(ch & 0x08)&&(ch & 0x40)))
			ch = read_ata_reg(Adr_AS);
		}
	}while(1);
}

//////////////////////////////////////////////////////////////////////////////////////
int pio_block_in(device_reg_set_t *p_device_reg_set)
{
	unsigned char ch;

	write_ata_reg(Adr_FR,p_device_reg_set->feature);
	write_ata_reg(Adr_SC,p_device_reg_set->sector_count);
	write_ata_reg(Adr_SN,p_device_reg_set->sector_number);
	write_ata_reg(Adr_CH,p_device_reg_set->cylinder_high);
	write_ata_reg(Adr_CL,p_device_reg_set->cylinder_low);
	write_ata_reg(Adr_DH,p_device_reg_set->device_head);
	write_ata_reg(Adr_CM,p_device_reg_set->command);
	
	ch = read_ata_reg(Adr_AS);
	do{
		if(ch & 0x01){
			ch = read_ata_reg(Adr_ER);
			if(intFlag){
				wait_device_int();
				read_ata_reg(Adr_ST);
			}
			else read_ata_reg(Adr_ST);
			return -1;
		}
		if(intFlag){
			wait_device_int();
		}
		else {
			read_ata_reg(Adr_AS);
			ch = read_ata_reg(Adr_ST);
			while(!((!(ch & 0x80))&&(ch & 0x08)))
				ch = read_ata_reg(Adr_ST);
		}

		PIO_CTRL_REG = 0x80;
		ATA_ADDR_REG = Adr_DA;   	//Adr_DA:PIO data register;
		PIO_CTRL_REG = 0x06;    

		ch = INTR_REG;
		while(!(ch&0x04))
			ch = INTR_REG;      	// wait pio block finish interrupt

		ATA_ADDR_REG = 0x00;  
		ch = CHIP_STATUS;
		ch = read_ata_reg(Adr_ST);
	}while(((ch & 0x80)&&(!(ch & 0x08))) || ((!(ch & 0x80)) && (ch & 0x08)));

	ch = read_ata_reg(Adr_AS);
	ch = read_ata_reg(Adr_ST);
	return 0;
}







?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产夜色精品一区二区av| 欧美日韩精品综合在线| 免费在线看成人av| 首页欧美精品中文字幕| 亚洲成a天堂v人片| 日韩精品亚洲专区| 久久国产精品第一页| 免费高清视频精品| 精品一区二区三区在线观看国产| 国产最新精品免费| 豆国产96在线|亚洲| 成人久久视频在线观看| 91免费精品国自产拍在线不卡| 91色porny在线视频| 色综合天天综合狠狠| 欧美性生交片4| 91精品欧美综合在线观看最新| 日韩欧美在线综合网| 国产亚洲人成网站| 亚洲女与黑人做爰| 日本免费在线视频不卡一不卡二| 六月丁香综合在线视频| 国产精品一区二区久激情瑜伽| 粉嫩aⅴ一区二区三区四区 | 7777精品伊人久久久大香线蕉的 | 国产精品久久久久久久久快鸭 | 国产精品小仙女| 91啪在线观看| 7777女厕盗摄久久久| 国产色91在线| 一区二区三区波多野结衣在线观看 | 日韩亚洲欧美综合| 国产精品人成在线观看免费 | 男女激情视频一区| 成人激情开心网| 欧美一级日韩免费不卡| 亚洲欧洲在线观看av| 奇米精品一区二区三区在线观看| 懂色av中文字幕一区二区三区| 色8久久精品久久久久久蜜 | 国产日韩亚洲欧美综合| 亚洲午夜影视影院在线观看| 国产一区视频在线看| 欧美性色综合网| 亚洲精品欧美激情| 国产一区二区三区av电影| 欧洲一区二区三区在线| 国产日韩欧美精品在线| 日韩精品电影一区亚洲| av一二三不卡影片| 欧美精品一区二区高清在线观看| 一区二区三区精密机械公司| 国产精品综合在线视频| 欧美一区二区三区的| 亚洲精品一二三| 成人激情小说乱人伦| 精品剧情v国产在线观看在线| 一区二区三区在线观看国产| 国产成人免费网站| 精品国产自在久精品国产| 亚洲综合图片区| 色系网站成人免费| 国产欧美精品一区二区三区四区| 免费成人av在线播放| 欧美日韩在线三级| 亚洲激情图片小说视频| 99国产精品国产精品毛片| 国产视频一区在线观看| 激情亚洲综合在线| 日韩美女天天操| 蜜臀99久久精品久久久久久软件| 欧美日韩一级大片网址| 亚洲一区二区三区三| 色丁香久综合在线久综合在线观看| 国产偷国产偷亚洲高清人白洁| 精品一区二区免费在线观看| 欧美一区二区黄| 蜜臀a∨国产成人精品| 欧美一区二区久久| 麻豆精品久久久| 久久综合九色综合欧美98| 国产一区二区三区电影在线观看| 精品对白一区国产伦| 狠狠色狠狠色综合| 国产视频一区在线观看| voyeur盗摄精品| 亚洲精品免费在线观看| 欧美精品九九99久久| 日韩电影在线观看网站| 精品国产乱码久久久久久牛牛 | 99国内精品久久| 亚洲精品国产无套在线观| 欧美三级电影在线观看| 香蕉av福利精品导航| 日韩欧美精品在线| 成人综合在线网站| 亚洲免费视频中文字幕| 欧美精品乱人伦久久久久久| 麻豆一区二区三区| 国产精品美女久久久久久久久 | av中文字幕亚洲| 亚洲线精品一区二区三区| 欧美一级午夜免费电影| 成人亚洲精品久久久久软件| 亚洲老妇xxxxxx| 日韩情涩欧美日韩视频| av成人老司机| 视频一区欧美日韩| 欧美经典一区二区三区| 欧美性大战xxxxx久久久| 免费视频最近日韩| 中文字幕在线免费不卡| 欧美精选午夜久久久乱码6080| 国产一区二区三区在线看麻豆| 亚洲日本成人在线观看| 日韩免费视频一区| 色猫猫国产区一区二在线视频| 蜜臀久久99精品久久久久久9| 国产精品国产自产拍高清av王其| 欧美高清hd18日本| 成人av中文字幕| 久久9热精品视频| 一区二区三区精品视频在线| 国产日产欧美一区二区视频| 欧美夫妻性生活| 97se亚洲国产综合自在线观| 精品一区二区在线播放| 午夜视频一区在线观看| 中文字幕日韩一区二区| 精品国产乱码久久久久久闺蜜| 欧美自拍偷拍一区| www.欧美亚洲| 国产美女视频91| 久久国产生活片100| 亚洲电影在线免费观看| 亚洲男人天堂一区| 国产精品麻豆欧美日韩ww| 精品日产卡一卡二卡麻豆| 欧美麻豆精品久久久久久| 一本大道综合伊人精品热热 | 亚洲国产高清不卡| 久久久影视传媒| 日韩欧美中文字幕一区| 欧美日韩国产一级片| 欧美亚洲动漫另类| 91久久精品日日躁夜夜躁欧美| 99国产精品国产精品久久| 国产精品1024| 成人一级片网址| 处破女av一区二区| 99re热视频精品| 不卡影院免费观看| 99re成人在线| 在线亚洲一区观看| 欧美日韩三级在线| 欧美高清hd18日本| 欧美成人女星排行榜| 日韩精品一区二区三区三区免费| 91精品国模一区二区三区| 666欧美在线视频| 日韩一级高清毛片| 久久亚洲免费视频| 中文字幕精品在线不卡| 国产精品嫩草久久久久| 一区二区三区在线免费| 国产成人亚洲综合色影视| 国产91露脸合集magnet | 日韩专区在线视频| 美女脱光内衣内裤视频久久网站 | 91久久精品国产91性色tv| 91国产成人在线| 日韩一区二区影院| 国产亚洲一区二区三区四区| 国产精品麻豆视频| 亚洲国产美女搞黄色| 日本vs亚洲vs韩国一区三区| 国产真实乱偷精品视频免| 成人97人人超碰人人99| 在线观看网站黄不卡| 这里只有精品电影| 久久久久久亚洲综合影院红桃| 专区另类欧美日韩| 三级欧美韩日大片在线看| 国产精品系列在线观看| 色香蕉久久蜜桃| 精品国产免费视频| 一区二区三区高清在线| 蜜臂av日日欢夜夜爽一区| 不卡视频一二三| 4438亚洲最大| 亚洲欧美自拍偷拍色图| 日日夜夜免费精品| 粉嫩欧美一区二区三区高清影视| 欧美视频中文字幕| 国产欧美日韩在线| 日本aⅴ亚洲精品中文乱码| 9久草视频在线视频精品| 91精品久久久久久久99蜜桃 | 精品三级av在线| 亚洲美女在线一区|