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

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

?? arm7tdmi.c

?? 自制JTAG調試代碼
?? 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一区二区三区免费野_久草精品视频
欧美人妖巨大在线| 国产一区二区三区黄视频| 久久伊人中文字幕| 色诱亚洲精品久久久久久| 亚洲成人在线网站| 欧美极品美女视频| 欧美一卡二卡在线| 色婷婷av一区二区三区gif| 国产一区二区三区在线观看精品| 一区二区三区成人在线视频| 久久香蕉国产线看观看99| 欧美日韩国产精品自在自线| 成人av在线影院| 国产一区二区三区在线观看免费视频| 亚洲成a人在线观看| 中文字幕一区二区三中文字幕| 日韩精品专区在线影院观看| 欧美性生活影院| 99国产精品国产精品久久| 国产成人a级片| 国产美女视频一区| 久久爱另类一区二区小说| 午夜免费久久看| 一区二区欧美精品| 亚洲欧美另类综合偷拍| 国产精品麻豆网站| 欧美国产精品劲爆| 久久久久99精品国产片| 欧美成人官网二区| 日韩欧美一区在线观看| 777色狠狠一区二区三区| 欧美色视频一区| 精品视频免费在线| 欧美老年两性高潮| 欧美日韩亚洲国产综合| 欧美午夜免费电影| 欧美猛男gaygay网站| 欧美日韩一卡二卡三卡| 欧美日韩一卡二卡| 欧美一卡在线观看| 欧美大胆一级视频| 欧美mv和日韩mv国产网站| 7777精品伊人久久久大香线蕉超级流畅 | 婷婷丁香激情综合| 亚洲国产精品一区二区尤物区| 亚洲人成精品久久久久久| 综合欧美亚洲日本| 亚洲人成网站影音先锋播放| 一区二区三区四区蜜桃| 亚洲一区二区欧美| 日韩在线观看一区二区| 美腿丝袜亚洲综合| 国内精品视频一区二区三区八戒| 国内精品第一页| 成人免费的视频| 91捆绑美女网站| 欧美色大人视频| 欧美一级黄色大片| 国产午夜精品一区二区| 亚洲三级免费观看| 国产精品情趣视频| 亚洲在线观看免费| 日韩av在线免费观看不卡| 久久99精品国产.久久久久久| 国产麻豆精品theporn| av一区二区三区四区| 欧美日韩久久不卡| 久久久久九九视频| 亚洲视频一区二区在线| 日韩精品视频网| 国产成人精品网址| 色婷婷国产精品| 日韩免费一区二区三区在线播放| 久久久久久久久久久久久女国产乱| 国产人成一区二区三区影院| 亚洲影视在线观看| 国内精品第一页| 色就色 综合激情| 欧美成人a在线| 亚洲色图欧美偷拍| 久久国产剧场电影| 97久久精品人人爽人人爽蜜臀| 欧美图片一区二区三区| 久久久亚洲精华液精华液精华液| 一二三区精品福利视频| 久久99国产精品免费网站| 成人午夜激情视频| 欧美日韩精品久久久| 欧美激情一区在线| 日韩精品视频网| 91亚洲国产成人精品一区二区三| 精品欧美一区二区久久| 一区二区三区中文在线观看| 国产主播一区二区三区| 欧美色涩在线第一页| 国产精品成人免费精品自在线观看 | 日本一区二区动态图| 人人狠狠综合久久亚洲| 91丨九色porny丨蝌蚪| 欧美xxxx在线观看| 亚洲国产欧美另类丝袜| 色悠悠久久综合| 2欧美一区二区三区在线观看视频| 欧美一级片在线| 成人爽a毛片一区二区免费| 99久久精品国产毛片| 日韩欧美国产一区在线观看| 国产精品久久三| 久久国产日韩欧美精品| 欧美日韩一级大片网址| 亚洲天堂精品在线观看| 国产精品资源网站| 日韩天堂在线观看| 三级欧美韩日大片在线看| 97精品电影院| 国产精品视频一二| 国产精品一级片在线观看| 日韩免费看的电影| 日本人妖一区二区| 欧美日韩国产天堂| 亚洲九九爱视频| av一区二区三区在线| 国产精品久久一卡二卡| 国产精品资源网| 国产亚洲一区二区三区在线观看| 人妖欧美一区二区| 欧美一二三四在线| 午夜免费欧美电影| 在线电影一区二区三区| 午夜在线成人av| 欧美色倩网站大全免费| 亚洲午夜电影在线| 欧美主播一区二区三区| 亚洲国产精品久久人人爱蜜臀| 91国偷自产一区二区开放时间| 亚洲天堂免费看| 欧美自拍丝袜亚洲| 午夜精品123| 欧美一卡二卡三卡| 精油按摩中文字幕久久| 久久蜜桃av一区二区天堂| 国产一区二区不卡在线| 国产亚洲污的网站| av不卡免费电影| 亚洲激情综合网| 欧美午夜视频网站| 日韩成人av影视| 精品理论电影在线| 国产福利一区在线| 国产精品久久久久7777按摩| 91久久线看在观草草青青| 亚洲一区二区三区激情| 欧美精品九九99久久| 久久疯狂做爰流白浆xx| 国产欧美一区在线| 91网页版在线| 亚洲国产欧美另类丝袜| 日韩欧美一区中文| 国产成人精品免费在线| 亚洲日本在线看| 精品视频一区 二区 三区| 精品一区二区影视| 中文字幕欧美激情| 91福利国产成人精品照片| 日韩电影在线一区二区| 久久久久久一二三区| 色综合视频在线观看| 日本中文字幕一区| 国产日韩精品一区二区三区 | 一区二区三区在线免费视频| 欧美日韩精品系列| 国产伦精品一区二区三区免费迷| 国产精品全国免费观看高清 | 国产成人精品一区二| 亚洲美女屁股眼交| 日韩欧美另类在线| 成人av免费在线| 日本不卡一二三| 国产精品欧美极品| 91精品免费观看| aaa亚洲精品一二三区| 欧美aⅴ一区二区三区视频| 国产欧美一区二区三区沐欲| 欧美精品 日韩| 成人精品国产福利| 免费成人深夜小野草| 中文字幕中文字幕一区| 日韩色视频在线观看| 91在线精品秘密一区二区| 蜜桃精品视频在线观看| 综合电影一区二区三区| 精品国产乱码久久久久久图片| 91在线观看高清| 国产一区二三区| 午夜精品久久久久久久| 中文字幕在线观看一区| 精品理论电影在线| 欧美日韩日日摸| 波多野结衣在线aⅴ中文字幕不卡| 日韩黄色免费网站|