diff options
| author | oharboe <oharboe@b42882b7-edfa-0310-969c-e2dbd0fdcd60> | 2008-10-30 07:49:13 +0000 | 
|---|---|---|
| committer | oharboe <oharboe@b42882b7-edfa-0310-969c-e2dbd0fdcd60> | 2008-10-30 07:49:13 +0000 | 
| commit | 069a04dca0badadb709c6f2f84ef668ad38ddc8a (patch) | |
| tree | 90a127a84e83b53e73b10daa9810fca948e84fb2 /src/target/arm7_9_common.c | |
| parent | b8f895deb66c72c64d1895a60615444ef7ab085a (diff) | |
| download | openocd_libswd-069a04dca0badadb709c6f2f84ef668ad38ddc8a.tar.gz openocd_libswd-069a04dca0badadb709c6f2f84ef668ad38ddc8a.tar.bz2 openocd_libswd-069a04dca0badadb709c6f2f84ef668ad38ddc8a.tar.xz openocd_libswd-069a04dca0badadb709c6f2f84ef668ad38ddc8a.zip | |
Hongtao Zheng single step fixes
git-svn-id: svn://svn.berlios.de/openocd/trunk@1113 b42882b7-edfa-0310-969c-e2dbd0fdcd60
Diffstat (limited to 'src/target/arm7_9_common.c')
| -rw-r--r-- | src/target/arm7_9_common.c | 42 | 
1 files changed, 29 insertions, 13 deletions
| diff --git a/src/target/arm7_9_common.c b/src/target/arm7_9_common.c index 9161aa67..d7684c5e 100644 --- a/src/target/arm7_9_common.c +++ b/src/target/arm7_9_common.c @@ -1553,6 +1553,9 @@ int arm7_9_resume(struct target_s *target, int current, u32 address, int handle_  	if (!current)  		buf_set_u32(armv4_5->core_cache->reg_list[15].value, 0, 32, address); +	u32 current_pc; +	current_pc = buf_get_u32(armv4_5->core_cache->reg_list[15].value, 0, 32); +  	/* the front-end may request us not to handle breakpoints */  	if (handle_breakpoints)  	{ @@ -1564,8 +1567,18 @@ int arm7_9_resume(struct target_s *target, int current, u32 address, int handle_  				return retval;  			} +			/* calculate PC of next instruction */ +			u32 next_pc; +			if ((retval = arm_simulate_step(target, &next_pc)) != ERROR_OK) +			{ +				u32 current_opcode; +				target_read_u32(target, current_pc, ¤t_opcode); +				LOG_ERROR("BUG: couldn't calculate PC of next instruction, current opcode was 0x%8.8x", current_opcode); +				return retval; +			} +  			LOG_DEBUG("enable single-step"); -			arm7_9->enable_single_step(target); +			arm7_9->enable_single_step(target, next_pc);  			target->debug_reason = DBG_REASON_SINGLESTEP; @@ -1675,23 +1688,13 @@ int arm7_9_resume(struct target_s *target, int current, u32 address, int handle_  	return ERROR_OK;  } -void arm7_9_enable_eice_step(target_t *target) +void arm7_9_enable_eice_step(target_t *target, u32 next_pc)  {  	armv4_5_common_t *armv4_5 = target->arch_info;  	arm7_9_common_t *arm7_9 = armv4_5->arch_info; -	int retval;  	u32 current_pc;  	current_pc = buf_get_u32(armv4_5->core_cache->reg_list[15].value, 0, 32); -	 -	u32 next_pc; -	if ((retval = arm_simulate_step(target, &next_pc)) != ERROR_OK) -	{ -		u32 current_opcode; -		target_read_u32(target, current_pc, ¤t_opcode); -		LOG_ERROR("BUG: couldn't calculate PC of next instruction, current opcode was 0x%8.8x", current_opcode); -		return; -	}  	if(next_pc != current_pc)  	{ @@ -1756,6 +1759,9 @@ int arm7_9_step(struct target_s *target, int current, u32 address, int handle_br  	if (!current)  		buf_set_u32(armv4_5->core_cache->reg_list[15].value, 0, 32, address); +	u32 current_pc; +	current_pc = buf_get_u32(armv4_5->core_cache->reg_list[15].value, 0, 32); +  	/* the front-end may request us not to handle breakpoints */  	if (handle_breakpoints)  		if ((breakpoint = breakpoint_find(target, buf_get_u32(armv4_5->core_cache->reg_list[15].value, 0, 32)))) @@ -1766,12 +1772,22 @@ int arm7_9_step(struct target_s *target, int current, u32 address, int handle_br  	target->debug_reason = DBG_REASON_SINGLESTEP; +	/* calculate PC of next instruction */ +	u32 next_pc; +	if ((retval = arm_simulate_step(target, &next_pc)) != ERROR_OK) +	{ +		u32 current_opcode; +		target_read_u32(target, current_pc, ¤t_opcode); +		LOG_ERROR("BUG: couldn't calculate PC of next instruction, current opcode was 0x%8.8x", current_opcode); +		return retval; +	} +  	if ((retval = arm7_9_restore_context(target)) != ERROR_OK)  	{  		return retval;  	} -	arm7_9->enable_single_step(target); +	arm7_9->enable_single_step(target, next_pc);  	if (armv4_5->core_state == ARMV4_5_STATE_ARM)  	{ | 
