target: cortex_a: fix segfault when SPSR is not properly handled

OpenOCD doesn't (yet) know how to handle HYP mode properly so spsr
register is not getting initialised when OpenOCD connects to a target
stopped in this mode.

Reported on IRC by thinkfat and nearffxx.

Change-Id: I4bda9ba0c582c8e9cacefe708cc4a3d947151f84
Signed-off-by: Paul Fertser <fercerpav@gmail.com>
Reviewed-on: http://openocd.zylin.com/3906
Tested-by: jenkins
Reviewed-by: Matthias Welwarsky <matthias@welwarsky.de>
Reviewed-by: Chengyu Zheng <chengyu.zheng@polimi.it>
This commit is contained in:
Paul Fertser 2016-12-12 11:50:17 +03:00
parent ee4f11dd68
commit d491b88dd9
1 changed files with 11 additions and 9 deletions

View File

@ -1241,16 +1241,18 @@ static int cortex_a_debug_entry(struct target *target)
reg->dirty = reg->valid; reg->dirty = reg->valid;
} }
/* read Saved PSR */ if (arm->spsr) {
retval = cortex_a_dap_read_coreregister_u32(target, &spsr, 17); /* read Saved PSR */
/* store current spsr */ retval = cortex_a_dap_read_coreregister_u32(target, &spsr, 17);
if (retval != ERROR_OK) /* store current spsr */
return retval; if (retval != ERROR_OK)
return retval;
reg = arm->spsr; reg = arm->spsr;
buf_set_u32(reg->value, 0, 32, spsr); buf_set_u32(reg->value, 0, 32, spsr);
reg->valid = 1; reg->valid = 1;
reg->dirty = 0; reg->dirty = 0;
}
#if 0 #if 0
/* TODO, Move this */ /* TODO, Move this */