⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 tlcs900offset.cpp

📁 免费的OS源代码 符合ITRON4.0规范 http://www.toppers.jp/official_release.html
💻 CPP
字号:
/* *  TOPPERS/JSP Kernel *      Toyohashi Open Platform for Embedded Real-Time Systems/ *      Just Standard Profile Kernel *  *  Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory *                              Toyohashi Univ. of Technology, JAPAN *  Copyright (C) 2003-2004 by Ryosuke Takeuchi *              Platform Development Center RIOCH COMPANY,LTD. JAPAN *  *  惧淡螟侯涪荚は·Free Software Foundation によって给山されている  *  GNU General Public License の Version 2 に淡揭されている掘凤か·笆 *  布の(1)×(4)の掘凤を塔たす眷圭に嘎り·塑ソフトウェア∈塑ソフトウェ *  アを猖恃したものを崔むˉ笆布票じ∷を蝗脱ˇ剩澜ˇ猖恃ˇ浩芹邵∈笆布· *  网脱と钙ぶ∷することを痰浸で钓满するˉ *  (1) 塑ソフトウェアをソ〖スコ〖ドの妨で网脱する眷圭には·惧淡の螟侯 *      涪山绩·この网脱掘凤および布淡の痰瘦沮惮年が·そのままの妨でソ〖 *      スコ〖ド面に崔まれていることˉ *  (2) 塑ソフトウェアを浩网脱材墙なバイナリコ〖ド∈リロケ〖タブルオブ *      ジェクトファイルやライブラリなど∷の妨で网脱する眷圭には·网脱 *      に燃うドキュメント∈网脱荚マニュアルなど∷に·惧淡の螟侯涪山绩· *      この网脱掘凤および布淡の痰瘦沮惮年を非很することˉ *  (3) 塑ソフトウェアを浩网脱稍材墙なバイナリコ〖ドの妨または怠达に寥 *      み哈んだ妨で网脱する眷圭には·肌のいずれかの掘凤を塔たすことˉ *    (a) 网脱に燃うドキュメント∈网脱荚マニュアルなど∷に·惧淡の螟侯 *        涪山绩·この网脱掘凤および布淡の痰瘦沮惮年を非很することˉ *    (b) 网脱の妨轮を·侍に年める数恕によって·惧淡螟侯涪荚に鼠桂する *        ことˉ *  (4) 塑ソフトウェアの网脱により木儡弄または粗儡弄に栏じるいかなる禄 *      巢からも·惧淡螟侯涪荚を倘勒することˉ *  *  塑ソフトウェアは·痰瘦沮で捏丁されているものであるˉ惧淡螟侯涪荚は· *  塑ソフトウェアに簇して·その努脱材墙拉も崔めて·いかなる瘦沮も乖わ *  ないˉまた·塑ソフトウェアの网脱により木儡弄または粗儡弄に栏じたい *  かなる禄巢に簇しても·その勒扦を砷わないˉ *  *  @(#) $Id: tlcs900offset.cpp,v 1.4 2007/04/17 05:08:07 honda Exp $ */// tlcs900offset.cpp : コンソ〖ル アプリケ〖ション脱のエントリ ポイントの年盗//#include <stdio.h>#include <stdlib.h>#include <string.h>#define	BUF_SIZE		512#define	STR_SIZE		128#define BIT_SIZE		6#define	NORMAL_STATE	0#define	TEXPTN_STATE	1#define	SP_STATE		2#define	PC_STATE		3#define	ENATEX_STATE	4static char const default_input_file[] = "makeoffset.asm";static char const default_output_file[] = "offset.inc";static char const lf[] = "\n";static char input_file[STR_SIZE];static char output_file[STR_SIZE];/*掐蜗ファイルがBEGIN, ENDの惰粗である眷圭はoffset_state = NORMAL_STATE;*/static int  offset_state = NORMAL_STATE;static bool test_string(char** s, char const * t);static bool skip_space(char** s);static bool skip_char(char** s, char const c);unsigned int atoh(char* s);void get_num(char* s);void get_num_undo(char* s);int main(int argc, char* argv[]){	FILE* pfo;	FILE* pfi;	int nCnt, address;	int shift_bit = 1;	int shift_cnt = 0;	char* s;	char  str[100];	char  buf[BUF_SIZE];	char  c;	strcpy(input_file, default_input_file);	strcpy(output_file, default_output_file);	//コマンドライン掐蜗を豺老	for(nCnt = 1 ; nCnt < argc ; nCnt++){		s = argv[nCnt];		if(*s++ == '-'){			c = *s;			while(*s != 0){				if(*s == ':')					break;				s++;			}			if(*s++ == ':'){				switch(c){				//output file name				case 'O':						case 'o':					strcpy(output_file, s);					break;				//input file name				case 'R':				case 'r':					strcpy(input_file, s);					break;				default:					printf("tlcs900offset -R:input_file -O:output_file\n");					break;				}			}		}	}	//input, outputファイル叹の筛洁叫蜗	printf("input file   = %s\n", input_file);	printf("output file  = %s\n", output_file);	if((pfi = fopen(input_file, "r")) == NULL){		fprintf(stderr, "can't open input file!");		exit(1);	}	if((pfo = fopen(output_file, "w")) == NULL){		fclose(pfi);		fprintf(stderr, "can't open output file!");		exit(1);	}	//inputファイルの艰り哈み	for(;;){		if((fgets(buf, BUF_SIZE, pfi)) == NULL)			break;		s = buf;		switch(offset_state){		//; BEGIN TCB_texptnの认跋の豺老		case TEXPTN_STATE:			if(test_string(&s, "; END")){				offset_state = NORMAL_STATE;				continue;			}			if(test_string(&s, "line") || test_string(&s, "call"))				continue;			if(skip_char(&s, 'x')){				continue;			}			get_num(s);			address = atoh(s);			printf("TCB_texptn\tequ\t%d\n",address);			fputs("TCB_texptn\t\tequ\t", pfo);			sprintf(str,"%d",address);			fputs(str, pfo);			fputs(lf, pfo);			break;		case SP_STATE:		//; BEGIN TCB_spの认跋の豺老			if(test_string(&s, "; END")){				offset_state = NORMAL_STATE;				continue;			}			if(test_string(&s, "line") || test_string(&s, "call") )				continue;			if(skip_space(&s))				continue;			if(skip_char(&s, '(')){				continue;			}			if(skip_char(&s, 'x')){				continue;			}			get_num(s);			address = atoh(s);			printf("TCB_sp\t\tequ\t%d\n",address);			fputs("TCB_sp\t\t\tequ\t", pfo);			sprintf(str,"%d",address);			fputs(str, pfo);			fputs(lf, pfo);			break;		case PC_STATE:		//; BEGIN TCB_pcの认跋の豺老			if(test_string(&s, "; END")){				offset_state = NORMAL_STATE;				continue;			}			if(test_string(&s, "line") || test_string(&s, "call"))				continue;			if(skip_char(&s, 'x')){				continue;			}			get_num(s);			address = atoh(s);			printf("TCB_pc\tequ\t%d\n",address);			fputs("TCB_pc\t\t\tequ\t", pfo);			sprintf(str,"%d",address);			fputs(str, pfo);			fputs(lf, pfo);			break;		case ENATEX_STATE:		//; BEGIN TCB_pcの认跋の豺老			if(test_string(&s, "; END")){				offset_state = NORMAL_STATE;				continue;			}			if(test_string(&s, "line") || test_string(&s, "call"))				continue;			if(skip_char(&s, 'x')){				continue;			}			get_num(s);			address = atoh(s);			printf("TCB_enatex\tequ\t%d\n",address);			fputs("TCB_enatex\t\tequ\t", pfo);			sprintf(str,"%d",address);			fputs(str, pfo);			fputs(lf, pfo);			get_num_undo(s);			if(skip_char(&s, ',')){				continue;			}			*(s + BIT_SIZE) = '\0';			printf("TCB_enatex_mask\tequ\t%s\n",s);			fputs("TCB_enatex_mask\tequ\t", pfo);			fputs(s, pfo);			fputs(lf, pfo);			if(skip_char(&s, 'x')){				continue;			}			address = atoh(s);			for(shift_cnt=0;shift_cnt<=16;shift_cnt++){				if(address == shift_bit){					printf("TCB_enatex_bit\tequ\t%d\n",shift_cnt);					fputs("TCB_enatex_bit\tequ\t", pfo);					sprintf(str,"%d",shift_cnt);					fputs(str, pfo);					fputs(lf, pfo);				}				shift_bit<<=1;			}			break;		default:			if(test_string(&s, "; BEGIN TCB_texptn")){				offset_state = TEXPTN_STATE;				continue;			}else if(test_string(&s, "; BEGIN TCB_sp")){				offset_state = SP_STATE;				continue;			}else if(test_string(&s, "; BEGIN TCB_pc")){				offset_state = PC_STATE;				continue;			}else if(test_string(&s, "; BEGIN TCB_enatex")){				offset_state = ENATEX_STATE;				continue;			}			break;		}	}	return 0;}/* * 16渴矢机误をint房に恃垂 */unsigned int atoh(char* s){	int nCnt = 0;	for(;;){		if(*s >= '0' && *s <= '9')			nCnt = (nCnt * 16) + (*s - '0');		else if(*s >= 'A' && *s <= 'F')			nCnt = (nCnt * 16) + (*s - 'A' + 10);		else if(*s >= 'a' && *s <= 'f')			nCnt = (nCnt * 16) + (*s - 'a' + 10);		else			break;		s++;	}	return nCnt;}/* * アドレス婶尸を藐叫 */void get_num(char* s){	int nCnt;	for(nCnt = 0 ; nCnt < 4 ; nCnt++){		if(*(s+nCnt) == ')'){			*(s+nCnt) = '\0';		}	}}/* * get_numで今き垂えた婶尸を傅に提す */void get_num_undo(char* s){	int nCnt;	for(nCnt = 0 ; nCnt < 4 ; nCnt++){		if(*(s+nCnt) == '\0'){			*(s+nCnt) = ')';		}	}}/* * 矢机误を孺秤して票办ならばTURE */static bool test_string(char** s, char const *t){	char*  p;	char   c;	p = *s;	while(*p <= ' '){		if(*p == 0)			return false;		p++;	}	while((c = *p++) != 0){		if(c != *t++)			break;		if(*t == 0){			*s = p;			return true;		}	}	return false;}/* * 回年のキャラクタまでスキップ */static bool skip_char(char** s, char const c){	char* p;	p = *s;	while(*p != c){		if(*p == 0)			break;		p++;	}	if(*p){		p++;		*s = p;		return false;	}	else{		*s = p;		return true;	}}/* * スペ〖スまたはタブをスキップする */static bool skip_space(char** s){	char* p;	p = *s;	while(*p <= ' '){		if(*p == 0)			break;		p++;	}	*s = p;	if(*p)		return false;	else		return true;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -