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

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

?? arm7tdmi.c

?? JTAG控制源代碼.rar JTAG控制源代碼.rar
?? C
?? 第 1 頁 / 共 3 頁
字號:
		shift_in[1] = ARM7TDMI_DEBUG_SPEED;
		arm7tdmi_acs_sc1(shift_in, shift_out);

		//NOP 
		shift_in[0] = 0x1C001C00;					
		shift_in[1] = ARM7TDMI_DEBUG_SPEED;
		arm7tdmi_acs_sc1(shift_in, shift_out);

		//NOP 
		shift_in[0] = 0x1C001C00;					
		shift_in[1] = ARM7TDMI_DEBUG_SPEED;
		arm7tdmi_acs_sc1(shift_in, shift_out);

		//Step 4 - Move R0 to PC
		
		//MOV PC, R0 = 0x46874687
		shift_in[0] = 0x46874687;					
		shift_in[1] = ARM7TDMI_DEBUG_SPEED;
		arm7tdmi_acs_sc1(shift_in, shift_out);

		//NOP 
		shift_in[0] = 0x1C001C00;						//Instruct 1
		shift_in[1] = ARM7TDMI_DEBUG_SPEED;
		arm7tdmi_acs_sc1(shift_in, shift_out);

		//NOP 
		shift_in[0] = 0x1C001C00;						//Instruct 2
		shift_in[1] = ARM7TDMI_DEBUG_SPEED;
		arm7tdmi_acs_sc1(shift_in, shift_out);

		//Step 5 - Restore R0

		//MOV R0, #0 = 0x20002000
		shift_in[0] = 0x20002000;						//Instruct 3				
		shift_in[1] = ARM7TDMI_DEBUG_SPEED;
		arm7tdmi_acs_sc1(shift_in, shift_out);

		//NOP 
		shift_in[0] = 0x1C001C00;						//Instruct 4				
		shift_in[1] = ARM7TDMI_DEBUG_SPEED;
		arm7tdmi_acs_sc1(shift_in, shift_out);

		//NOP 
		shift_in[0] = 0x1C001C00;						//Instruct 5			
		shift_in[1] = ARM7TDMI_DEBUG_SPEED;
		arm7tdmi_acs_sc1(shift_in, shift_out);

		//LDR R0, [R0] = 0x68006800
		shift_in[0] = 0x68006800;						//Instruct 6			
		shift_in[1] = ARM7TDMI_DEBUG_SPEED;
		arm7tdmi_acs_sc1(shift_in, shift_out);

		//NOP 
		shift_in[0] = 0x1C001C00;						//Instruct 7				
		shift_in[1] = ARM7TDMI_DEBUG_SPEED;
		arm7tdmi_acs_sc1(shift_in, shift_out);

		//NOP 
		shift_in[0] = 0x1C001C00;						//Instruct 8					
		shift_in[1] = ARM7TDMI_DEBUG_SPEED;
		arm7tdmi_acs_sc1(shift_in, shift_out);

		//R1 - put the value of R0 to the data bus
		shift_in[0] = r0;									
		shift_in[1] = ARM7TDMI_DEBUG_SPEED;
		arm7tdmi_acs_sc1(shift_in, shift_out);

		//Write the value obtained from data bus to R0 
		shift_in[0] = 0x1C001C00;					
		shift_in[1] = ARM7TDMI_DEBUG_SPEED;
		arm7tdmi_acs_sc1(shift_in, shift_out);

		//Step 6 - Set SYSTEM speed flag

		//NOP 
		shift_in[0] = 0x1C001C00;						//Instruct 9
		shift_in[1] = ARM7TDMI_DEBUG_SPEED;
		arm7tdmi_acs_sc1(shift_in, shift_out);

		//NOP 
		shift_in[0] = 0x1C001C00;						//Instruct 10
		shift_in[1] = ARM7TDMI_SYSTEM_SPEED;
		arm7tdmi_acs_sc1(shift_in, shift_out);

		/*
		 * After move the new value to register PC, 10 instructions have been
		 * executed so far. To exit from DEBUG state and resume the normal 
		 * operation of the program under debug, 10 instructions backwards.
		 */

		//B -10 = 0xE7F6E7F6
		shift_in[0] = 0xE7F6E7F6;						//Final branch
		shift_in[1] = ARM7TDMI_DEBUG_SPEED;
		arm7tdmi_acs_sc1(shift_in, shift_out);
	}
	
	/*
	 * Last Step - Use RESTART to Exit DEBUG state and 
	 *			   return back to SYSTEM state
	 */
	status = tapctrl_acs_ireg(JTAG_BYPASS);
	status = tapctrl_acs_ireg(JTAG_RESTART);
	status = tapctrl_runtest();

	//Update the ARM7TDMI status
	arm7tdmi_status.state = ARM7TDMI_SYSTEM_STATE;
	arm7tdmi_status.by = -1;
	arm7tdmi_status.scanchain = -1;	 //For safe purpose
	
	return XJ_OK;
}


/* 
 * arm7tdmi_set_swbreakpt() -
 *		Used to set a software break point at a specific address.
 *
 *		ARM7TDMI supports two watchpoint units. Normally, WP0 for break point 
 *		and WP1 for watch point. If WP0 is used for hardware break point, then 
 *		no software break point can be supported. If WP0 is used for software 
 *		break point, it can support any number of software breakpoint.
 *
 *		@addr: address of software break point.
 */
static int arm7tdmi_set_swbreakpt(u32 addr)
{
	int status;
	u32 temp;
	u32 instruct;
	u32 bit_pattern = 0xDEEEDEEE;
	arm7tdmi_breakpt_list_t *breakpt_new;


	//In DEBUG state?
	if(arm7tdmi_status.state != ARM7TDMI_DEBUG_STATE)
		return XJERR_TARGET_RUNNING;
	
	status = arm7tdmi_connect_scanchain(2);
	if(status != XJ_OK)
		return status;

	/*
	 * Check the possibility.
	 * If watchpt-0 is already used as a hardware break point,
	 * return ERROR.
	 */
	if( (arm7tdmi_breakpt_head != NULL) && 
		arm7tdmi_breakpt_head->type == HARDWARE_BREAKPT)
		return XJERR_SET_BREAKPT_FAIL;


	//First disable WP0 
	arm7tdmi_ice_write(ARM7TDMI_WP0_CTRLVAL, 0x0);

	/*
	 * Try to set it as software break point by replacing the instruction
	 * at addr by a specific bit pattern
	 */
	status = arm7tdmi_connect_scanchain(1);

	arm7tdmi_mem_rd32(addr, &instruct, 1);		
	arm7tdmi_mem_wri32(addr, &bit_pattern, 1);
	arm7tdmi_mem_rd32(addr, &temp, 1);	

	status = arm7tdmi_connect_scanchain(2);

	//Fail, the target instruction can't be replaced
	if(temp != bit_pattern){		
		arm7tdmi_ice_write(ARM7TDMI_WP0_CTRLMSK, 0x0F7);
		arm7tdmi_ice_write(ARM7TDMI_WP0_CTRLVAL, 0x100);
		return XJERR_SET_BREAKPT_FAIL;
	}

	//Succesful
	breakpt_new = (arm7tdmi_breakpt_list_t*)malloc(sizeof(arm7tdmi_breakpt_list_t));
	if(breakpt_new == NULL){
		arm7tdmi_ice_write(ARM7TDMI_WP0_CTRLMSK, 0x0F7);
		arm7tdmi_ice_write(ARM7TDMI_WP0_CTRLVAL, 0x100);
		return XJ_ERROR;
	}

	breakpt_new->address = addr;
	breakpt_new->instruct = instruct;
	breakpt_new->type = SOFTWARE_BREAKPT;
	breakpt_new->next = NULL;
	
	breakpt_new->next = arm7tdmi_breakpt_head;
	arm7tdmi_breakpt_head = breakpt_new;

	//Configure WP0
	arm7tdmi_ice_write(ARM7TDMI_WP0_ADDRMSK, 0xFFFFFFFF);
	arm7tdmi_ice_write(ARM7TDMI_WP0_DATAVAL, bit_pattern);
	arm7tdmi_ice_write(ARM7TDMI_WP0_DATAMSK, 0x00000000);
	arm7tdmi_ice_write(ARM7TDMI_WP0_CTRLMSK, 0x0F7);
	arm7tdmi_ice_write(ARM7TDMI_WP0_CTRLVAL, 0x102);		//nOPC = 0, Enable WP0 b4 exit
	
	return XJ_OK;
} 


/* 
 * arm7tdmi_set_hwbreakpt() -
 *		Used to set a hardware break point at a specific address.
 *
 *		ARM7TDMI supports two watchpoint units. Normally, WP0 for break point 
 *		and WP1 for watch point. If WP0 is used for hardware break point, then 
 *		no software break point can be supported. If WP0 is used for software 
 *		break point, it can support any number of software breakpoint.
 *
 *		@addr: address of hardware break point.
 */
static int arm7tdmi_set_hwbreakpt(u32 addr)
{
	int status;	
	arm7tdmi_breakpt_list_t *breakpt_new;

	//In DEBUG state?
	if(arm7tdmi_status.state != ARM7TDMI_DEBUG_STATE)
		return XJERR_TARGET_RUNNING;
	
	status = arm7tdmi_connect_scanchain(2);
	if(status != XJ_OK)
		return status;

	/*
	 * Check the possibility.
	 * If watchpt-0 is already used as a hardware break point,
	 * return ERROR.
	 */
	if(arm7tdmi_breakpt_head != NULL)
		return XJERR_SET_BREAKPT_FAIL;

	//Add this hardware break point to the list of break point.
	breakpt_new = (arm7tdmi_breakpt_list_t*)malloc(sizeof(arm7tdmi_breakpt_list_t));
	if(breakpt_new == NULL)
		return XJ_ERROR;

	breakpt_new->address = addr;
	breakpt_new->instruct = 0;
	breakpt_new->type = HARDWARE_BREAKPT;
	breakpt_new->next = NULL;

	arm7tdmi_breakpt_head = breakpt_new;


	//Configure WP0
	arm7tdmi_ice_write(ARM7TDMI_WP0_CTRLVAL, 0x0);		//Disable WP0 during the setting
	arm7tdmi_ice_write(ARM7TDMI_WP0_ADDRVAL, addr);
	arm7tdmi_ice_write(ARM7TDMI_WP0_ADDRMSK, 0x0);
	arm7tdmi_ice_write(ARM7TDMI_WP0_DATAMSK, 0xFFFFFFFF);
	arm7tdmi_ice_write(ARM7TDMI_WP0_CTRLMSK, 0x0F7);
	arm7tdmi_ice_write(ARM7TDMI_WP0_CTRLVAL, 0x100);	//nOPC = 0, Enable WP0 b4 exit
	
	return XJ_OK;
}


/* 
 * arm7tdmi_set_breakpt() -
 *		Used to set a break point at a specific address.
 *		We prefer software break point. Everytime, we will try to
 *		set it as a software break point first. If fail, then try
 *		to set it as a hardware break point.		
 *
 *		@addr: address of break point.
 */
int arm7tdmi_set_breakpt(u32 addr)
{
	int status;
	
	status = arm7tdmi_set_swbreakpt(addr);

	if(status == XJ_OK)
		return XJ_OK;
	else
		status = arm7tdmi_set_hwbreakpt(addr);

	return status;
}


/*
 * arm7tdmi_clr_breakpt() -
 *		Used to clear a break point located at a specific address
 *
 *		@addr: address of the break point to be cleared.
 */
int arm7tdmi_clr_breakpt(u32 addr)
{
	int status;
	int type;
	u32 instruct;
	arm7tdmi_breakpt_list_t *breakpt_temp;
	arm7tdmi_breakpt_list_t *breakpt_prev;

	//In DEBUG state?
	if(arm7tdmi_status.state != ARM7TDMI_DEBUG_STATE)
		return XJERR_TARGET_RUNNING;
	
	status = arm7tdmi_connect_scanchain(2);
	if(status != XJ_OK)
		return status;

	//Find the target break point first
	breakpt_prev = NULL;
	for(breakpt_temp = arm7tdmi_breakpt_head; breakpt_temp != NULL; breakpt_temp = breakpt_temp->next){
		if(breakpt_temp->address == addr){
			if(breakpt_prev == NULL){
				arm7tdmi_breakpt_head = breakpt_temp->next;
			}else{
				breakpt_prev->next = breakpt_temp->next;
			}
			break;
		}
		breakpt_prev = breakpt_temp;
	}

	//Found??
	if(breakpt_temp == NULL)
		return XJERR_CLR_BREAKPT_FAIL;

	type = breakpt_temp->type;
	instruct = breakpt_temp->instruct;
	free(breakpt_temp);								//Delete breakpt_temp

	if(type == SOFTWARE_BREAKPT){					//Software break point
		status = arm7tdmi_connect_scanchain(1);
		arm7tdmi_mem_wri32(addr, &instruct, 1);
	}else{											//Hardware break point
		status = arm7tdmi_connect_scanchain(2);
		arm7tdmi_ice_write(ARM7TDMI_WP0_CTRLVAL, 0x0);
	}

	return XJ_OK;
} 


/* 
 * arm7tdmi_set_watchpt() -
 *		Used to set a watch point at a specific address.
 *
 *		ARM7TDMI supports two watchpoint units. Normally, WP0 for break point 
 *		and WP1 for watch point. 
 *
 *		@addr: address of watch point to be set.
 */
int arm7tdmi_set_watchpt(u32 addr)
{
	int status;

	//Is WP1 available?
	if(arm7tdmi_watchpt_status.busy == 1)
		return XJERR_SET_WATCHPT_FAIL;

	//In DEBUG state?
	if(arm7tdmi_status.state != ARM7TDMI_DEBUG_STATE)
		return XJERR_TARGET_RUNNING;
	
	status = arm7tdmi_connect_scanchain(2);
	if(status != XJ_OK)
		return status;

	//Configure WP1
	arm7tdmi_ice_write(ARM7TDMI_WP1_CTRLVAL, 0x0);		//Disable WP1 during the setting
	arm7tdmi_ice_write(ARM7TDMI_WP1_ADDRVAL, addr);
	arm7tdmi_ice_write(ARM7TDMI_WP1_ADDRMSK, 0x0);
	arm7tdmi_ice_write(ARM7TDMI_WP1_DATAMSK, 0xFFFFFFFF);
	arm7tdmi_ice_write(ARM7TDMI_WP1_CTRLMSK, 0x0F7);
	arm7tdmi_ice_write(ARM7TDMI_WP1_CTRLVAL, 0x108);	//nOPC = 1, Enable WP1 b4 exit

	//Update the status of WP1
	arm7tdmi_watchpt_status.busy = 1;
	arm7tdmi_watchpt_status.addr = addr;
	
	return XJ_OK;
}


/* 
 * arm7tdmi_clr_watchpt() -
 *		Used to clear a watch point at a specific address.
 *
 *		ARM7TDMI supports two watchpoint units. Normally, WP0 for break point 
 *		and WP1 for watch point. 
 *
 *		@addr: address of watch point to be cleared.
 */
int arm7tdmi_clr_watchpt(u32 addr)
{
	int status;

	//Match?
	if( (arm7tdmi_watchpt_status.busy == 0) || (arm7tdmi_watchpt_status.addr != addr) )
		return XJERR_SET_WATCHPT_FAIL;

	//In DEBUG state?
	if(arm7tdmi_status.state != ARM7TDMI_DEBUG_STATE)
		return XJERR_TARGET_RUNNING;
	
	status = arm7tdmi_connect_scanchain(2);
	if(status != XJ_OK)
		return status;

	//Disable WP1
	arm7tdmi_ice_write(ARM7TDMI_WP1_CTRLVAL, 0x0);		

	//Update the status of WP1
	arm7tdmi_watchpt_status.busy = 0;
	arm7tdmi_watchpt_status.addr = 0;	

	return XJ_OK;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕一区二区不卡| 国产九色精品成人porny| 国产美女精品在线| 欧美一区二区三区喷汁尤物| 中文字幕一区二区三区不卡在线 | 欧美激情艳妇裸体舞| 奇米影视一区二区三区| 欧美亚日韩国产aⅴ精品中极品| 中文字幕一区二区三区在线观看 | 色婷婷av久久久久久久| 国产精品视频一二三| 丁香另类激情小说| 国产精品久久久久精k8| 成人精品视频一区二区三区| 性久久久久久久| 91视频xxxx| 亚洲va欧美va天堂v国产综合| 在线视频你懂得一区| 亚洲v中文字幕| 精品久久国产老人久久综合| 国产中文字幕一区| 国产精品色在线观看| 色综合久久久久久久| 亚洲精品欧美激情| 亚洲欧美激情一区二区| 在线精品视频免费观看| 全部av―极品视觉盛宴亚洲| 久久夜色精品一区| 欧美人成免费网站| 国产精品一区免费在线观看| 一区二区三区加勒比av| 久久99精品久久久| 欧美激情一区二区三区四区| 欧美伦理影视网| 99在线精品观看| 日本成人在线电影网| 国产欧美日韩三区| 日韩三级精品电影久久久| 欧美伊人精品成人久久综合97| 国产日韩欧美亚洲| 国产麻豆午夜三级精品| 一区二区三区在线看| 六月丁香婷婷色狠狠久久| 国产精品美女视频| 精品国产3级a| 精品国产乱码久久久久久夜甘婷婷| 99久久精品一区| 高清国产一区二区| 国产精品一二三四| 国产91精品入口| 国产98色在线|日韩| 国产精品一级片在线观看| 国产一区二区影院| 国产激情一区二区三区四区| 日本不卡123| 国产在线一区二区综合免费视频| 日韩av一区二区三区四区| 日本美女一区二区三区| 美女一区二区三区| 久久精品国产免费| 狠狠网亚洲精品| 成人av网站大全| 在线观看av一区| 91精品蜜臀在线一区尤物| 欧美美女一区二区三区| 精品国内二区三区| 欧美国产成人在线| 午夜欧美视频在线观看| 老司机午夜精品| 成人看片黄a免费看在线| 色噜噜久久综合| 精品国产乱码久久久久久久| 欧美国产日韩a欧美在线观看| 中文字幕亚洲视频| 久久精品噜噜噜成人88aⅴ| 91影院在线免费观看| 在线观看日韩高清av| 欧美一区二区在线看| 国产精品乱人伦一区二区| 亚洲永久免费av| 韩日欧美一区二区三区| 色天天综合久久久久综合片| 精品乱码亚洲一区二区不卡| 亚洲三级免费电影| 国产精品伊人色| 欧美一区二区三区四区久久| 亚洲欧美在线观看| 老司机精品视频在线| 欧美日韩中文字幕精品| 国产亚洲综合在线| 狠狠久久亚洲欧美| 337p亚洲精品色噜噜狠狠| 伊人一区二区三区| 成人免费av网站| 国产精品天天看| 国产不卡在线播放| 久久影视一区二区| 国内偷窥港台综合视频在线播放| 7777精品伊人久久久大香线蕉完整版 | www国产精品av| 国产剧情在线观看一区二区| 日韩一区二区在线免费观看| 亚洲国产精品久久不卡毛片| 91免费版pro下载短视频| 国产精品综合在线视频| 精品日韩一区二区| 成人激情校园春色| 亚洲一区二区免费视频| 欧美影院精品一区| 亚洲最大的成人av| 欧美剧在线免费观看网站| 亚洲一区中文在线| 欧美一区二区在线免费观看| 亚洲国产精品一区二区久久恐怖片 | 欧美电影在线免费观看| 视频一区欧美精品| 久久婷婷久久一区二区三区| 成人精品国产一区二区4080| 亚洲人妖av一区二区| 欧美日韩不卡一区| 韩国中文字幕2020精品| 91在线免费播放| 日韩精品成人一区二区在线| 久久久久99精品一区| 欧美亚洲综合网| 久久99国产乱子伦精品免费| 中文字幕一区在线| 欧美一区二区日韩| 在线日韩av片| 国产69精品久久久久777| 亚洲精品国产成人久久av盗摄| 51久久夜色精品国产麻豆| 不卡的av中国片| 成人深夜视频在线观看| 激情综合网最新| 亚洲v中文字幕| 亚洲欧洲av一区二区三区久久| 91精品国模一区二区三区| 一本一道综合狠狠老| 国产成人高清在线| 狠狠色丁香久久婷婷综| 日日摸夜夜添夜夜添精品视频| 综合久久久久久| 精品久久久久久久久久久久久久久 | 日韩精品亚洲专区| 一区二区三区产品免费精品久久75| 久久只精品国产| 久久久影院官网| 欧美一级免费大片| 宅男在线国产精品| 91精品国产麻豆国产自产在线| 欧美影院一区二区三区| 欧美人牲a欧美精品| 欧美日本在线播放| 欧美一区二区视频在线观看| 欧美乱熟臀69xxxxxx| 91精品国产麻豆| 久久综合九色欧美综合狠狠| 久久久精品免费免费| 中文字幕永久在线不卡| 亚洲男人的天堂av| 亚洲成av人影院在线观看网| 高清av一区二区| 99re视频精品| 欧美日韩精品是欧美日韩精品| 欧美性猛交xxxx乱大交退制版| 7777精品伊人久久久大香线蕉| 欧美一区二区三区视频在线| 久久综合一区二区| 亚洲欧美经典视频| 美女视频免费一区| 99热国产精品| 91精品国产麻豆国产自产在线| 国产欧美综合色| 丝袜脚交一区二区| 国产aⅴ综合色| 日韩三级在线观看| 亚洲精品国产无天堂网2021| 看片的网站亚洲| 欧美性一区二区| 亚洲国产高清aⅴ视频| 三级一区在线视频先锋| av动漫一区二区| 国产亚洲一二三区| 美女视频免费一区| 91黄视频在线| 亚洲精品美腿丝袜| 成人动漫在线一区| 欧美精品一区二区三区视频| 亚洲国产日韩精品| 99麻豆久久久国产精品免费优播| 2020国产精品自拍| 日韩成人一区二区| 亚洲精品一区二区三区四区高清| 亚洲婷婷在线视频| 色综合欧美在线视频区| 国产精品福利一区二区三区| 国产盗摄视频一区二区三区| 精品成人免费观看| 国产专区欧美精品|