target: add -ctibase config option in addition to -dbgbase
Some vendors don't fully populate the ROM table, e.g. BCM2357 (used in Raspberry Pi 3) doesn't list CTI, however it is mandatory for halting an ARMv8 core and therefore it's always present (and required), regardless of the ROM table listing it or not. Change-Id: Ia18a4f1b5b931ccd19805b188ebf737c837c6b54 Signed-off-by: Matthias Welwarsky <matthias.welwarsky@sysgo.com>
This commit is contained in:
parent
f2a271e264
commit
df32af234c
|
@ -4445,6 +4445,7 @@ enum target_cfg_param {
|
||||||
TCFG_COREID,
|
TCFG_COREID,
|
||||||
TCFG_CHAIN_POSITION,
|
TCFG_CHAIN_POSITION,
|
||||||
TCFG_DBGBASE,
|
TCFG_DBGBASE,
|
||||||
|
TCFG_CTIBASE,
|
||||||
TCFG_RTOS,
|
TCFG_RTOS,
|
||||||
TCFG_DEFER_EXAMINE,
|
TCFG_DEFER_EXAMINE,
|
||||||
};
|
};
|
||||||
|
@ -4460,6 +4461,7 @@ static Jim_Nvp nvp_config_opts[] = {
|
||||||
{ .name = "-coreid", .value = TCFG_COREID },
|
{ .name = "-coreid", .value = TCFG_COREID },
|
||||||
{ .name = "-chain-position", .value = TCFG_CHAIN_POSITION },
|
{ .name = "-chain-position", .value = TCFG_CHAIN_POSITION },
|
||||||
{ .name = "-dbgbase", .value = TCFG_DBGBASE },
|
{ .name = "-dbgbase", .value = TCFG_DBGBASE },
|
||||||
|
{ .name = "-ctibase", .value = TCFG_CTIBASE },
|
||||||
{ .name = "-rtos", .value = TCFG_RTOS },
|
{ .name = "-rtos", .value = TCFG_RTOS },
|
||||||
{ .name = "-defer-examine", .value = TCFG_DEFER_EXAMINE },
|
{ .name = "-defer-examine", .value = TCFG_DEFER_EXAMINE },
|
||||||
{ .name = NULL, .value = -1 }
|
{ .name = NULL, .value = -1 }
|
||||||
|
@ -4726,7 +4728,20 @@ no_params:
|
||||||
Jim_SetResult(goi->interp, Jim_NewIntObj(goi->interp, target->dbgbase));
|
Jim_SetResult(goi->interp, Jim_NewIntObj(goi->interp, target->dbgbase));
|
||||||
/* loop for more */
|
/* loop for more */
|
||||||
break;
|
break;
|
||||||
|
case TCFG_CTIBASE:
|
||||||
|
if (goi->isconfigure) {
|
||||||
|
e = Jim_GetOpt_Wide(goi, &w);
|
||||||
|
if (e != JIM_OK)
|
||||||
|
return e;
|
||||||
|
target->ctibase = (uint32_t)w;
|
||||||
|
target->ctibase_set = true;
|
||||||
|
} else {
|
||||||
|
if (goi->argc != 0)
|
||||||
|
goto no_params;
|
||||||
|
}
|
||||||
|
Jim_SetResult(goi->interp, Jim_NewIntObj(goi->interp, target->ctibase));
|
||||||
|
/* loop for more */
|
||||||
|
break;
|
||||||
case TCFG_RTOS:
|
case TCFG_RTOS:
|
||||||
/* RTOS */
|
/* RTOS */
|
||||||
{
|
{
|
||||||
|
|
|
@ -185,6 +185,11 @@ struct target {
|
||||||
uint32_t dbgbase; /* Really a Cortex-A specific option, but there is no
|
uint32_t dbgbase; /* Really a Cortex-A specific option, but there is no
|
||||||
* system in place to support target specific options
|
* system in place to support target specific options
|
||||||
* currently. */
|
* currently. */
|
||||||
|
|
||||||
|
bool ctibase_set; /* By default the debug base is not set */
|
||||||
|
uint32_t ctibase; /* Really a Cortex-A specific option, but there is no
|
||||||
|
* system in place to support target specific options
|
||||||
|
* currently. */
|
||||||
struct rtos *rtos; /* Instance of Real Time Operating System support */
|
struct rtos *rtos; /* Instance of Real Time Operating System support */
|
||||||
bool rtos_auto_detect; /* A flag that indicates that the RTOS has been specified as "auto"
|
bool rtos_auto_detect; /* A flag that indicates that the RTOS has been specified as "auto"
|
||||||
* and must be detected when symbols are offered */
|
* and must be detected when symbols are offered */
|
||||||
|
|
Loading…
Reference in New Issue