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

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

?? xmodem.c

?? ucos-II+移植到arm+s3c2410的全套代碼
?? C
字號:
/*----------------------------------------------------------------------------------
作者 孫愷
2003 6 11
Xmodem協議文件傳送

說明
	通過串口按照Xmodem協議接受發送文件。
	帶CRC校驗,包128字節,接受有錯誤處理。

todo:	
	添加發送過程中的包報發送失敗處理。
-----------------------------------------------------------------------------------*/

#include "../inc/command/xmodem.h"
#include "../inc/sys/lib.h"
#include <string.h>
#include <stdio.h>

#define Debug_Printf	printfNULL

int calcrc(unsigned char *ptr, int count)
{
    int crc, i;
	crc = 0;
    while(--count >= 0) {
	crc = crc ^ (int)*ptr++ << 8;
	for(i = 0; i < 8; ++i)
	    if(crc & 0x8000)
		crc = crc << 1 ^ 0x1021;
	    else
		crc = crc << 1;
	}
    return (crc & 0xFFFF);
}


int XReceiveFile(char * filename,int filetype)
{
	static unsigned char data[133];
	int i,j,crc,crcr;
	int error=FALSE,errornum=0;
	char paknum=1;
	int packagecon=1;

	FILE *file1;

	file1=fopen(filename, "w");
	if(file1==NULL) {
		return FAIL;
	}
	
	Debug_Printf("Wait to begin receice FILE.\n");
	for(i=0;;i++) {
		putchar(0x43);
		data[0]=0;
		getchartimeout(data, 1, 10000);
		if(data[0]==XMODEM_SOH) {
			Debug_Printf("Begin receice FILE.\n");
			break;
		}
		else {
			Debug_Printf("Try %d times.\n",i);
		}
		if(i==100) {
			Debug_Printf("Reach Max TRY Number!\n");
			fclose(file1);
			return FAIL;
		}
	}
	getchartimeout(data+1,132,1000);
	for(i=0;;i++) {
		switch(data[0]) {
			case XMODEM_SOH:
				crc=calcrc(data+3,128);
				crcr=data[131];
				crcr=crcr<<8;
				crcr=crcr|data[132];
				if(data[1]!=paknum) {
					if(data[1]==(paknum-1)) {
						Debug_Printf("'blk' error:%d!=%d(should),\n",data[1],paknum);
						Debug_Printf("Perhaps master not receive lastv XMODEM_ACK!!\n");
						Debug_Printf("Goon!!!\n");
						hudelay(2);
						error=FALSE;
						paknum--;
						putchar(XMODEM_ACK);
					}
					else {
						Debug_Printf("'blk' error:%d!=%d(should)\n",data[1],paknum);
						error=TRUE;
					}
				}
				else if(data[2]!=0xff-data[1]) 	{
					Debug_Printf("'255-blk' error\n");
					error=TRUE;		
				}
				else if(crc!=crcr) {
					Debug_Printf("crc error.:%x!=%x(should).\n",crcr,crc);
					error=TRUE;
				}
				else {
					Debug_Printf("Receive package:%d\n",packagecon);
					error=FALSE;
					if(filetype==XMODEM_DAT) {
						fwrite(data+3,128, 1, file1);
					}
					else if(filetype==XMODEM_TXT) {
						if(data[130]==0x1a) {
							for(j=0;j<128;j++) {
								if(data[j+3]==0x1a)
									break;
							}
							fwrite(data+3,j, 1, file1);
						}
						else
							fwrite(data+3, 128, 1, file1);
					}
					putchar(XMODEM_ACK);
					data[131]=0;
					paknum++;
					packagecon++;
				}
				break;
			case XMODEM_EOT:
				Debug_Printf("Receive finished.\n");
				putchar(XMODEM_ACK);
				fclose(file1);
				return TRUE;
				break;
			default:
				Debug_Printf("Unknowen Command!\n");
				error=TRUE;
				break;
		}
		if(error==TRUE) {
			errornum++;
			if(errornum==100) {
				Debug_Printf("Reach Max Receive ERROR Number!\n");
				fclose(file1);
				return FALSE;
			}
			else {
				Debug_Printf("Error:NO.%d,PackNum:%d,blk=%d,crc=%x\n",errornum,packagecon,data[1],crcr);
				mdelay(1);
				//OSFlushUart0();
				putchar(XMODEM_NAK);
			}
		}
		data[0]=0;
		data[1]=0;
		data[2]=0;
		getchartimeout(data,133,1000);
	}
	
}

int XTransmitFile(char * filename,int filetype)
{
	static unsigned char data[133];
	int i,j,crc;
	int errornum=0;
	unsigned int paknum=1,fullpacknum;
	FILE *file1;
	int b128;
	int finish;

	char fillchar=0;

	//get file size
	file_stat s;
	lstat(filename, &s);


	finish=FALSE;
	
	file1=fopen(filename, "r");
	if(file1==NULL) {
		return FALSE;
	}

	if(filetype==XMODEM_DAT)
		fillchar=0x1a;
	else if(filetype==XMODEM_TXT)
		fillchar=' ';
	fullpacknum=s.st_size/128;
	if((s.st_size%128)==0) {
		b128=TRUE;
	}
	else {
		b128=FALSE;
	}

	Debug_Printf("File Size %d.\n",s.st_size);
	Debug_Printf("Total %d Package.\n",fullpacknum);
 	hudelay(25);
	Debug_Printf("Wait to Begin transmit FILE.\n");
	for(i=0;;i++) {
		data[0]=0;
		getchartimeout(data,1,1000);
		if(data[0]==0x43) {
			Debug_Printf("Begin transmit FILE.\n");
			break;
		}
		else {
			Debug_Printf("\nWait %d times.",i);
		}
		if(i==600) {
			Debug_Printf("Reach Max Wait Number!\n");
			fclose(file1);
			return FALSE;
		}
	}
	data[0]=XMODEM_ACK;

	for(i=0;;i++) {
		if(data[0]==XMODEM_ACK) {
			if(paknum<=fullpacknum) {
				data[0]=XMODEM_SOH;
				data[1]=paknum;
				data[2]=0xff-paknum;
				fread(data+3,128, 1, file1);
				crc=calcrc(data+3,128);
				data[131]=crc>>8;
				data[132]=crc;
				for(j=0;j<133;j++)
					putchar(data[j]);
				paknum++;
				Debug_Printf("Transmit %d package.\n",paknum);
			}
			else if((paknum==fullpacknum+1)&&(b128==FALSE)) {
				data[0]=XMODEM_SOH;
				data[1]=paknum;
				data[2]=0xff-paknum;
				if((s.st_size%128)==0) {
					fread(data+3, 128, 1, file1);
				}
				else {
					fread(data+3,s.st_size%128, 1, file1);
					for(j=s.st_size%128;j<131;j++) {
						data[3+j]=fillchar;
					}
				}
				crc=calcrc(data+3,128);
				data[131]=crc>>8;
				data[132]=crc;
				for(j=0;j<133;j++)
					putchar(data[j]);
				Debug_Printf("Transmit %d package, last one, filled.\n",paknum);
				paknum++;
			}
			else {
				if (finish==FALSE) {
					data[0]=XMODEM_EOT;
					putchar(data[0]);
					finish=TRUE;
				}
				else {
					Debug_Printf("Transmit Finished.\n");
					Debug_Printf("File Size %d.\n",s.st_size);
					Debug_Printf("Total %d Package + %d Package.\n",fullpacknum,(b128==FALSE));
					//OSFlushUart0();
					fclose(file1);
					return TRUE;
				}
			}
		}
		else if(data[0]==XMODEM_CAN) {
			Debug_Printf("Transmit canceled.\n");
			//OSFlushUart0();
			fclose(file1);
			return FALSE;
		}
		else if(data[0]==XMODEM_NAK) {
			errornum++;
			if(errornum==100) {
				Debug_Printf("Reach Max Transmit ERROR Number!\n");
				//OSFlushUart0();
				fclose(file1);
				return FALSE;
			}
			else {
				Debug_Printf("'XMODEM_NAK' found!,NO.%d\n",errornum);
				if (finish==FALSE) {
					for(j=0;j<133;j++)
						putchar(data[j]);
				}
				else {
					data[0]=XMODEM_EOT;
					putchar(data[0]);
				}
			}
		}
		getchartimeout(data,1,1000);
	}

	/*
	for(i=0;;i++)
	{
		Debug_Printf("\nReceive Command:0x%x",data[0]);
		if(data[0]==XMODEM_ACK)
		{
			Debug_Printf("\nTransmit NO.%d package.",paknum-1);
			if(paknum<fullpacknum)
			{
				data[0]=XMODEM_SOH;
				data[1]=paknum;
				data[2]=0xff-paknum;
				//memcpy(data+3,&(file1->Buffer[(paknum-1)*128]),128);
				ReadOSFile(file1,(U8 *)(data+3),128);
				crc=calcrc(data+3,128);
				data[131]=crc>>8;
				data[132]=crc;

				////
				if(20==paknum)
					data[3]=~data[3];
				////
				
				for(j=0;j<133;j++)
					putchar(data[j]);
				paknum++;
				
			}
			else if(paknum==fullpacknum)
			{
				data[0]=XMODEM_SOH;
				data[1]=paknum;
				data[2]=0xff-paknum;
				//memcpy(data+3,&(file1->Buffer[(paknum-1)*128]),file1->filesize%128);
				
				if((file1->filesize%128)==0)
				{
					ReadOSFile(file1,(U8 *)(data+3),128);
				}
				else
				{
					ReadOSFile(file1,(U8 *)(data+3),file1->filesize%128);
					for(j=file1->filesize%128;j<131;j++)
					{
						if(filetype==XMODEM_DAT)
							data[3+j]=0x1a;
						else if(filetype==XMODEM_TXT)
							data[3+j]=' ';
					}
				}
				crc=calcrc(data+3,128);
				data[131]=crc>>8;
				data[132]=crc;
				for(j=0;j<133;j++)
					putchar(data[j]);
				Debug_Printf("\nTransmit %d package.",paknum);
				paknum++;
			}
			else
			{
				//if (data[0]!=XMODEM_EOT)
				{
					data[0]=XMODEM_EOT;
					putchar(data[0]);
				}
				//else
				{
					Debug_Printf("\nTransmit Finished.");
					CloseOSFile(file1);
					OSReadUart0(data,1,1000);
					return TRUE;
				}
			}
		}
		else if(data[0]==XMODEM_NAK)
		{

			errornum++;
			if(errornum==10)
			{
				Debug_Printf("\nReach Max Transmit ERROR Number!");
				CloseOSFile(file1);
				return FALSE;
			}
			else
			{
				Debug_Printf("\n'XMODEM_NAK' found!,NO.%d",errornum);
				Debug_Printf("\nReTransmit:Package=%d",data[1]);
				udelay(1000);
				OSFlushUart0();
				for(j=0;j<133;j++)
					putchar(data[j]);
			}
		
		}
		else if(data[0]==XMODEM_CAN)
		{
			Debug_Printf("\nTransmit Canceled by Receiver!");
			CloseOSFile(file1);
			return FALSE;
		}
		else
		{	
			errornum++;
			if(errornum==10)
			{
				Debug_Printf("\nReach Max Transmit ERROR Number!");
				CloseOSFile(file1);
				return FALSE;
			}
			Debug_Printf("\nUnknowen Command!");
			udelay(30000);
		
		}
		data[0]=0;
		OSReadUart0(data,1,1000);
	}
	*/

}

int XReceive2Mem(unsigned char *pbuffer, unsigned int* n)
{
	static unsigned char data[133];
	int i,crc,crcr;
	int error=FALSE,errornum=0;
	char paknum=1;
	int packagecon=1;

	Debug_Printf("Wait to begin receice FILE.\n");
	for(i=0;;i++) {
		putchar(0x43);
		data[0]=0;
		getchartimeout(data, 1, 1000);
		if(data[0]==XMODEM_SOH) {
			Debug_Printf("Begin receice FILE.\n");
			break;
		}
		else {
			Debug_Printf("Try %d times.\n",i);
		}
		if(i==60) {
			Debug_Printf("Reach Max TRY Number!\n");
			return FAIL;
		}
	}
	getchartimeout(data+1,132,1000);
	for(i=0;;i++) {
		switch(data[0]) {
			case XMODEM_SOH:
				crc=calcrc(data+3,128);
				crcr=data[131];
				crcr=crcr<<8;
				crcr=crcr|data[132];
				if(data[1]!=paknum) {
					if(data[1]==(paknum-1)) {
						Debug_Printf("'blk' error:%d!=%d(should),\n",data[1],paknum);
						Debug_Printf("Perhaps master not receive lastv XMODEM_ACK!!\n");
						Debug_Printf("Goon!!!\n");
						hudelay(2);
						error=FALSE;
						paknum--;
						putchar(XMODEM_ACK);
					}
					else {
						Debug_Printf("'blk' error:%d!=%d(should)\n",data[1],paknum);
						error=TRUE;
					}
				}
				else if(data[2]!=0xff-data[1]) 	{
					Debug_Printf("'255-blk' error\n");
					error=TRUE;		
				}
				else if(crc!=crcr) {
					Debug_Printf("crc error.:%x!=%x(should).\n",crcr,crc);
					error=TRUE;
				}
				else {
					Debug_Printf("Receive package:%d\n",packagecon);
					error=FALSE;

					memcpy(pbuffer,(data+3),128);
					*n+=128;
					pbuffer+=128;

					putchar(XMODEM_ACK);
					data[131]=0;
					paknum++;
					packagecon++;
				}
				break;
			case XMODEM_EOT:
				Debug_Printf("Receive finished.\n");
				putchar(XMODEM_ACK);
				return TRUE;
				break;
			default:
				Debug_Printf("Unknowen Command!\n");
				error=TRUE;
				break;
		}
		if(error==TRUE) {
			errornum++;
			if(errornum==100) {
				Debug_Printf("Reach Max Receive ERROR Number!\n");
				return FALSE;
			}
			else {
				Debug_Printf("Error:NO.%d,PackNum:%d,blk=%d,crc=%x\n",errornum,packagecon,data[1],crcr);
				mdelay(1);
				//OSFlushUart0();
				putchar(XMODEM_NAK);
			}
		}
		data[0]=0;
		data[1]=0;
		data[2]=0;
		getchartimeout(data,133,1000);
	}
	
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲黄网站在线观看| 日韩一区精品视频| 在线不卡免费av| 国产91丝袜在线播放九色| 日韩精品成人一区二区在线| 国产精品美女久久久久久2018| 51精品视频一区二区三区| av不卡在线观看| 国产在线精品一区二区不卡了| 亚洲福利国产精品| ...av二区三区久久精品| 2020国产精品自拍| 欧美精品精品一区| 欧美综合在线视频| 成人动漫av在线| 国产一区二区三区在线观看精品| 天天综合网 天天综合色| 亚洲女厕所小便bbb| 亚洲国产高清aⅴ视频| 久久综合色婷婷| 欧美一级日韩不卡播放免费| 欧美亚洲综合色| 91碰在线视频| 99精品视频在线观看免费| 国产一区二区三区高清播放| 美腿丝袜在线亚洲一区| 亚洲成a人片在线不卡一二三区| 亚洲色图19p| 日韩伦理电影网| 中文字幕日韩欧美一区二区三区| 国产午夜精品在线观看| 久久久久久久电影| 欧美电影免费观看完整版| 欧美精品欧美精品系列| 欧美日韩在线播放三区| 欧美性猛交xxxx乱大交退制版 | 欧美自拍偷拍午夜视频| 4438成人网| 国产精品1区2区| 久久电影网站中文字幕| 麻豆成人久久精品二区三区小说| 视频一区视频二区中文| 亚洲成人一二三| 亚洲影视在线播放| 亚洲mv在线观看| 日韩国产精品久久久久久亚洲| 日韩精品91亚洲二区在线观看 | 欧美日韩一区二区三区在线看| 色婷婷综合久久久中文一区二区| www..com久久爱| 色综合天天天天做夜夜夜夜做| 成人精品在线视频观看| 一本大道久久精品懂色aⅴ| 色老汉av一区二区三区| 欧美色欧美亚洲另类二区| 欧美精三区欧美精三区| 日韩一区二区三区在线视频| 26uuu成人网一区二区三区| 日本一区二区三区在线不卡| 亚洲欧洲av另类| 亚洲国产综合人成综合网站| 视频一区二区欧美| 国内精品写真在线观看| 成人av综合在线| 欧美亚洲国产怡红院影院| 欧美日韩电影一区| 欧美精品一区男女天堂| 国产精品白丝在线| 亚洲123区在线观看| 麻豆精品一区二区三区| 国产高清在线观看免费不卡| 91视频国产资源| 欧美一级xxx| 国产精品久久久久久久久免费丝袜| 亚洲欧美一区二区久久| 美女网站一区二区| 成人精品电影在线观看| 欧美日韩日日骚| 久久久欧美精品sm网站| 亚洲精品国产无套在线观| 欧美aa在线视频| www.欧美.com| 日韩精品一区二区三区视频| 亚洲欧洲av在线| 久久精品久久99精品久久| 成人国产在线观看| 欧美精品tushy高清| 亚洲国产成人一区二区三区| 五月天一区二区| 成人av免费在线播放| 欧美一区二区三区在线视频| 国产精品毛片大码女人| 美女诱惑一区二区| 日本韩国欧美在线| 久久久亚洲精品一区二区三区| 亚洲一区二区欧美激情| 丁香天五香天堂综合| 欧美一区三区四区| 亚洲欧美另类久久久精品| 国产在线视视频有精品| 欧美吻胸吃奶大尺度电影| 欧美激情资源网| 美女视频黄a大片欧美| 一本久道中文字幕精品亚洲嫩| 久久新电视剧免费观看| 日日噜噜夜夜狠狠视频欧美人| 99久久伊人精品| 久久久综合九色合综国产精品| 丝袜亚洲另类欧美| 色悠悠久久综合| 国产精品人人做人人爽人人添| 美腿丝袜亚洲色图| 欧美高清视频在线高清观看mv色露露十八 | 中文字幕视频一区| 国产麻豆视频精品| 91精品国产美女浴室洗澡无遮挡| 亚洲柠檬福利资源导航| 成人福利视频在线| 国产欧美一区二区精品性色超碰| 久久草av在线| 91精品国产一区二区三区香蕉| 亚洲一区国产视频| 色婷婷综合久久| 亚洲人xxxx| 一本大道久久精品懂色aⅴ| 国产精品国产三级国产有无不卡| 国产成人久久精品77777最新版本| 日韩精品在线网站| 蜜臀91精品一区二区三区| 在线播放视频一区| 丝袜美腿一区二区三区| 欧美伦理视频网站| 视频一区欧美精品| 日韩一区二区三区三四区视频在线观看 | 亚洲免费av高清| 色综合色综合色综合| 亚洲婷婷在线视频| 色婷婷综合久久久中文一区二区| 亚洲日本韩国一区| 欧美专区亚洲专区| 亚洲不卡一区二区三区| 欧美高清一级片在线| 美女视频黄 久久| 337p日本欧洲亚洲大胆色噜噜| 激情综合色播激情啊| 国产丝袜欧美中文另类| 成人激情小说网站| 亚洲三级在线播放| 欧美午夜精品久久久久久超碰| 亚洲国产欧美在线人成| 欧美一区二区三区在| 久久成人免费日本黄色| 久久久国产一区二区三区四区小说| 国产mv日韩mv欧美| 亚洲欧美偷拍卡通变态| 欧美少妇一区二区| 捆绑调教一区二区三区| 国产亚洲午夜高清国产拍精品| 成人黄动漫网站免费app| 亚洲精品成人悠悠色影视| 欧美日韩国产一二三| 久久精品国产一区二区| 欧美激情在线观看视频免费| 99精品国产视频| 午夜精品成人在线视频| 精品国产乱码久久久久久久| 成人avav影音| 视频一区二区三区中文字幕| 久久久高清一区二区三区| 色综合天天做天天爱| 日韩电影在线观看网站| 国产欧美日韩三区| 欧美三级乱人伦电影| 狠狠色狠狠色合久久伊人| 亚洲欧美经典视频| 日韩精品一区二区三区在线观看 | 在线成人小视频| 国产美女视频91| 亚洲一区二区三区四区不卡| 精品三级在线观看| 91福利区一区二区三区| 奇米777欧美一区二区| 一区视频在线播放| 日韩欧美国产三级电影视频| 成人黄色电影在线| 免费在线观看一区二区三区| 国产精品久久久久一区二区三区 | 色噜噜狠狠色综合欧洲selulu| 日本vs亚洲vs韩国一区三区二区| 国产日本欧美一区二区| 欧美老肥妇做.爰bbww视频| 国产成人免费视频网站 | 成人欧美一区二区三区小说| 欧美一区二区三区日韩视频| 91免费在线视频观看| 国产一区二区成人久久免费影院| 亚洲国产综合91精品麻豆| 国产精品久久久久一区| 精品成人免费观看| 欧美日韩精品福利|