44 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,
ARMV4_5_CPSR,
100 .name =
"Supervisor",
118 .name =
"Undefined instruction",
134 .name =
"Secure Monitor",
140 .name =
"Secure Monitor ARM1176JZF-S",
153 .name =
"Thread (User)",
163 .name =
"Hypervisor",
177 LOG_ERROR(
"unrecognized psr mode: %#02x", psr_mode);
178 return "UNRECOGNIZED";
264 static const struct {
287 [0] = { .name =
"r0", .cookie = 0, .mode =
ARM_MODE_ANY, .gdb_index = 0, },
288 [1] = { .name =
"r1", .cookie = 1, .mode =
ARM_MODE_ANY, .gdb_index = 1, },
289 [2] = { .name =
"r2", .cookie = 2, .mode =
ARM_MODE_ANY, .gdb_index = 2, },
290 [3] = { .name =
"r3", .cookie = 3, .mode =
ARM_MODE_ANY, .gdb_index = 3, },
291 [4] = { .name =
"r4", .cookie = 4, .mode =
ARM_MODE_ANY, .gdb_index = 4, },
292 [5] = { .name =
"r5", .cookie = 5, .mode =
ARM_MODE_ANY, .gdb_index = 5, },
293 [6] = { .name =
"r6", .cookie = 6, .mode =
ARM_MODE_ANY, .gdb_index = 6, },
294 [7] = { .name =
"r7", .cookie = 7, .mode =
ARM_MODE_ANY, .gdb_index = 7, },
300 [8] = { .name =
"r8", .cookie = 8, .mode =
ARM_MODE_ANY, .gdb_index = 8, },
301 [9] = { .name =
"r9", .cookie = 9, .mode =
ARM_MODE_ANY, .gdb_index = 9, },
302 [10] = { .name =
"r10", .cookie = 10, .mode =
ARM_MODE_ANY, .gdb_index = 10, },
303 [11] = { .name =
"r11", .cookie = 11, .mode =
ARM_MODE_ANY, .gdb_index = 11, },
304 [12] = { .name =
"r12", .cookie = 12, .mode =
ARM_MODE_ANY, .gdb_index = 12, },
313 [13] = { .name =
"sp_usr", .cookie = 13, .mode =
ARM_MODE_USR, .gdb_index = 26, },
314 [14] = { .name =
"lr_usr", .cookie = 14, .mode =
ARM_MODE_USR, .gdb_index = 27, },
317 [15] = { .name =
"pc", .cookie = 15, .mode =
ARM_MODE_ANY, .gdb_index = 15, },
318 [16] = { .name =
"r8_fiq", .cookie = 8, .mode =
ARM_MODE_FIQ, .gdb_index = 28, },
319 [17] = { .name =
"r9_fiq", .cookie = 9, .mode =
ARM_MODE_FIQ, .gdb_index = 29, },
320 [18] = { .name =
"r10_fiq", .cookie = 10, .mode =
ARM_MODE_FIQ, .gdb_index = 30, },
321 [19] = { .name =
"r11_fiq", .cookie = 11, .mode =
ARM_MODE_FIQ, .gdb_index = 31, },
322 [20] = { .name =
"r12_fiq", .cookie = 12, .mode =
ARM_MODE_FIQ, .gdb_index = 32, },
324 [21] = { .name =
"sp_fiq", .cookie = 13, .mode =
ARM_MODE_FIQ, .gdb_index = 33, },
325 [22] = { .name =
"lr_fiq", .cookie = 14, .mode =
ARM_MODE_FIQ, .gdb_index = 34, },
327 [23] = { .name =
"sp_irq", .cookie = 13, .mode =
ARM_MODE_IRQ, .gdb_index = 35, },
328 [24] = { .name =
"lr_irq", .cookie = 14, .mode =
ARM_MODE_IRQ, .gdb_index = 36, },
330 [25] = { .name =
"sp_svc", .cookie = 13, .mode =
ARM_MODE_SVC, .gdb_index = 37, },
331 [26] = { .name =
"lr_svc", .cookie = 14, .mode =
ARM_MODE_SVC, .gdb_index = 38, },
333 [27] = { .name =
"sp_abt", .cookie = 13, .mode =
ARM_MODE_ABT, .gdb_index = 39, },
334 [28] = { .name =
"lr_abt", .cookie = 14, .mode =
ARM_MODE_ABT, .gdb_index = 40, },
336 [29] = { .name =
"sp_und", .cookie = 13, .mode =
ARM_MODE_UND, .gdb_index = 41, },
337 [30] = { .name =
"lr_und", .cookie = 14, .mode =
ARM_MODE_UND, .gdb_index = 42, },
339 [31] = { .name =
"cpsr", .cookie = 16, .mode =
ARM_MODE_ANY, .gdb_index = 25, },
340 [32] = { .name =
"spsr_fiq", .cookie = 16, .mode =
ARM_MODE_FIQ, .gdb_index = 43, },
341 [33] = { .name =
"spsr_irq", .cookie = 16, .mode =
ARM_MODE_IRQ, .gdb_index = 44, },
342 [34] = { .name =
"spsr_svc", .cookie = 16, .mode =
ARM_MODE_SVC, .gdb_index = 45, },
343 [35] = { .name =
"spsr_abt", .cookie = 16, .mode =
ARM_MODE_ABT, .gdb_index = 46, },
344 [36] = { .name =
"spsr_und", .cookie = 16, .mode =
ARM_MODE_UND, .gdb_index = 47, },
347 [37] = { .name =
"sp", .cookie = 13, .mode =
ARM_MODE_ANY, .gdb_index = 13, },
348 [38] = { .name =
"lr", .cookie = 14, .mode =
ARM_MODE_ANY, .gdb_index = 14, },
351 [39] = { .name =
"sp_mon", .cookie = 13, .mode =
ARM_MODE_MON, .gdb_index = 48, },
352 [40] = { .name =
"lr_mon", .cookie = 14, .mode =
ARM_MODE_MON, .gdb_index = 49, },
353 [41] = { .name =
"spsr_mon", .cookie = 16, .mode =
ARM_MODE_MON, .gdb_index = 50, },
356 [42] = { .name =
"sp_hyp", .cookie = 13, .mode =
ARM_MODE_HYP, .gdb_index = 51, },
357 [43] = { .name =
"spsr_hyp", .cookie = 16, .mode =
ARM_MODE_HYP, .gdb_index = 52, },
360 static const struct {
409 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 31
412 0, 1, 2, 3, 4, 5, 6, 7, 16, 17, 18, 19, 20, 21, 22, 15, 32
415 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 23, 24, 15, 33
418 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 25, 26, 15, 34
421 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 27, 28, 15, 35
424 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 29, 30, 15, 36
427 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 31
430 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 39, 40, 15, 41,
433 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 42, 14, 15, 43,
440 LOG_ERROR(
"core_state exceeds table size");
484 if (cpsr & (1 << 5)) {
485 if (cpsr & (1 << 24)) {
491 if (cpsr & (1 << 24)) {
492 LOG_ERROR(
"Jazelle state handling is BROKEN!");
499 LOG_DEBUG(
"set CPSR %#8.8" PRIx32
": %s mode, %s state", cpsr,
524 LOG_ERROR(
"Register map is not available yet, the target is not fully initialised");
543 .
name =
"net.sourceforge.openocd.fake_fpa"
553 .
name =
"GDB dummy FPA register",
570 .
name =
"GDB dummy FPA status register",
600 reg_arch_info->
num, reg_arch_info->
mode);
624 if (
reg == armv4_5_target->
cpsr) {
634 LOG_DEBUG(
"changing ARM core mode to '%s'",
636 value &= ~((1 << 24) | (1 << 5));
668 struct reg *reg_list = calloc(num_regs,
sizeof(
struct reg));
669 struct arm_reg *reg_arch_info = calloc(num_regs,
sizeof(
struct arm_reg));
672 if (!cache || !reg_list || !reg_arch_info) {
679 cache->
name =
"ARM registers";
684 for (i = 0; i < num_core_regs; i++) {
699 reg_arch_info[i].
arm =
arm;
703 reg_list[i].
size = 32;
706 reg_list[i].
arch_info = ®_arch_info[i];
707 reg_list[i].
exist =
true;
729 if (reg_list[i].
number <= 15 || reg_list[i].
number == 25) {
730 reg_list[i].
feature->
name =
"org.gnu.gdb.arm.core";
731 reg_list[i].
group =
"general";
733 reg_list[i].
feature->
name =
"net.sourceforge.openocd.banked";
734 reg_list[i].
group =
"banked";
741 for (i = num_core_regs, j = 0; i < num_regs; i++, j++) {
745 reg_arch_info[i].
arm =
arm;
752 reg_list[i].
arch_info = ®_arch_info[i];
753 reg_list[i].
exist =
true;
768 arm->
pc = reg_list + 15;
782 for (
unsigned int i = 0; i < cache->
num_regs; i++) {
801 LOG_ERROR(
"BUG: called for a non-ARM target");
809 LOG_USER(
"target halted in %s state due to %s, current mode: %s\n"
810 "cpsr: 0x%8.8" PRIx32
" pc: 0x%8.8" PRIx32
"%s%s",
840 "Microcontroller Profile not supported - use standard reg cmd");
845 LOG_ERROR(
"not a valid arm core mode - communication failure?");
870 name =
"System and User";
896 for (
unsigned int j = 0; j < 4; j++, i++) {
910 output_len += snprintf(
output + output_len,
911 sizeof(
output) - output_len,
912 "%8s: %8.8" PRIx32
" ",
934 if (strcmp(
CMD_ARGV[0],
"arm") == 0) {
942 if (strcmp(
CMD_ARGV[0],
"thumb") == 0)
963 unsigned int count = 1;
978 if (strcmp(
CMD_ARGV[2],
"thumb") != 0)
987 if (address & 0x01) {
1008 bool is_mcr =
false;
1009 unsigned int arg_cnt = 5;
1093 int retval =
arm->
mcr(
target, cpnum, op1, op2, crn, crm, value);
1100 int retval =
arm->
mrc(
target, cpnum, op1, op2, crn, crm, &value);
1112 bool is_mcrr =
false;
1113 unsigned int arg_cnt = 3;
1201 .handler = handle_armv4_5_reg_command,
1203 .help =
"display ARM core registers",
1209 .handler = handle_armv4_5_mcrmrc,
1210 .help =
"write coprocessor register",
1211 .usage =
"cpnum op1 CRn CRm op2 value",
1216 .handler = handle_armv4_5_mcrmrc,
1217 .help =
"read coprocessor register",
1218 .usage =
"cpnum op1 CRn CRm op2",
1223 .handler = handle_armv4_5_mcrrmrrc,
1224 .help =
"write coprocessor 64-bit register",
1225 .usage =
"cpnum op1 CRm value",
1230 .handler = handle_armv4_5_mcrrmrrc,
1231 .help =
"read coprocessor 64-bit register",
1232 .usage =
"cpnum op1 CRm",
1242 .
name =
"core_state",
1243 .handler = handle_arm_core_state_command,
1245 .usage =
"['arm'|'thumb']",
1246 .help =
"display/change ARM core state",
1249 .name =
"disassemble",
1250 .handler = handle_arm_disassemble_command,
1252 .usage =
"address [count ['thumb']]",
1253 .help =
"disassemble instructions",
1265 .help =
"ARM command group",
1287 struct reg **reg_list[],
int *reg_list_size,
1294 LOG_ERROR(
"not a valid arm core mode - communication failure?");
1298 switch (reg_class) {
1300 *reg_list_size = 26;
1301 *reg_list = malloc(
sizeof(
struct reg *) * (*reg_list_size));
1303 for (i = 0; i < 16; i++)
1307 for (i = 16; i < 24; i++)
1318 *reg_list_size = 51;
1321 *reg_list_size = 53;
1324 *reg_list_size = 48;
1326 unsigned int list_size_core = *reg_list_size;
1328 *reg_list_size += 33;
1330 *reg_list = malloc(
sizeof(
struct reg *) * (*reg_list_size));
1332 for (i = 0; i < 16; i++)
1349 for (i = 16; i < 24; i++) {
1351 (*reg_list)[i]->
size = 0;
1354 (*reg_list)[24]->
size = 0;
1358 for (i = 0; i < 33; i++)
1365 LOG_ERROR(
"not a valid register class type in query.");
1372 uint32_t exit_point,
1373 unsigned int timeout_ms,
1395 "target reentered debug state, but not at the desired exit point: 0x%4.4" PRIx32
"",
1404 int num_mem_params,
struct mem_param *mem_params,
1405 int num_reg_params,
struct reg_param *reg_params,
1406 uint32_t entry_point, uint32_t exit_point,
1407 unsigned int timeout_ms,
void *
arch_info,
1408 int (*run_it)(
struct target *
target, uint32_t exit_point,
1409 unsigned int timeout_ms,
void *
arch_info))
1414 uint32_t context[17];
1416 int exit_breakpoint_size = 0;
1423 LOG_ERROR(
"current target isn't an ARMV4/5 target");
1433 LOG_ERROR(
"not a valid arm core mode - communication failure?");
1439 LOG_ERROR(
"ARMv4 target needs HW breakpoint location");
1446 for (i = 0; i <= 16; i++) {
1458 for (i = 0; i < num_mem_params; i++) {
1462 mem_params[i].
value);
1467 for (i = 0; i < num_reg_params; i++) {
1473 LOG_ERROR(
"BUG: register '%s' not found", reg_params[i].reg_name);
1478 LOG_ERROR(
"BUG: register '%s' size doesn't match reg_params[i].size",
1479 reg_params[i].reg_name);
1490 exit_breakpoint_size = 4;
1492 exit_breakpoint_size = 2;
1494 LOG_ERROR(
"BUG: can't execute algorithms when not in ARM or Thumb state");
1512 LOG_ERROR(
"can't add HW breakpoint to terminate algorithm");
1528 for (i = 0; i < num_mem_params; i++) {
1532 mem_params[i].
value);
1534 retval = retvaltemp;
1538 for (i = 0; i < num_reg_params; i++) {
1545 LOG_ERROR(
"BUG: register '%s' not found", reg_params[i].reg_name);
1552 "BUG: register '%s' size doesn't match reg_params[i].size",
1553 reg_params[i].reg_name);
1563 for (i = 0; i <= 16; i++) {
1566 arm_algorithm_info->
core_mode, i).value, 0, 32);
1567 if (regvalue != context[i]) {
1568 LOG_DEBUG(
"restoring register %s with value 0x%8.8" PRIx32
"",
1570 arm_algorithm_info->
core_mode, i).name, context[i]);
1572 arm_algorithm_info->
core_mode, i).value, 0, 32, context[i]);
1595 unsigned int timeout_ms,
1603 (uint32_t)entry_point,
1604 (uint32_t)exit_point,
1623 uint32_t exit_var = 0;
1625 static const uint8_t arm_crc_code_le[] = {
1626 #include "../../contrib/loaders/checksum/armv4_5_crc.inc"
1629 assert(
sizeof(arm_crc_code_le) % 4 == 0);
1632 sizeof(arm_crc_code_le), &crc_algorithm);
1637 for (i = 0; i <
ARRAY_SIZE(arm_crc_code_le) / 4; i++) {
1639 crc_algorithm->
address + i *
sizeof(uint32_t),
1656 unsigned int timeout = 20000 * (1 + (
count / (1024 * 1024)));
1660 exit_var = crc_algorithm->
address +
sizeof(arm_crc_code_le) - 8;
1670 LOG_ERROR(
"error executing ARM crc algorithm");
1696 uint32_t exit_var = 0;
1698 static const uint8_t check_code_le[] = {
1699 #include "../../contrib/loaders/erase_check/armv4_5_erase_check.inc"
1702 assert(
sizeof(check_code_le) % 4 == 0);
1704 if (erased_value != 0xff) {
1705 LOG_ERROR(
"Erase value 0x%02" PRIx8
" not yet supported for ARMv4/v5 targets",
1712 sizeof(check_code_le), &check_algorithm);
1717 for (i = 0; i <
ARRAY_SIZE(check_code_le) / 4; i++) {
1720 + i *
sizeof(uint32_t),
1731 buf_set_u32(reg_params[0].value, 0, 32, blocks[0].address);
1737 buf_set_u32(reg_params[2].value, 0, 32, erased_value);
1741 exit_var = check_algorithm->
address +
sizeof(check_code_le) - 4;
1771 for (; num_regs && retval ==
ERROR_OK; num_regs--,
reg++) {
1780 uint32_t op1, uint32_t op2,
1781 uint32_t crn, uint32_t crm,
1789 uint32_t
op, uint32_t crm,
1797 uint32_t op1, uint32_t op2,
1798 uint32_t crn, uint32_t crm,
1806 uint32_t
op, uint32_t crm,
void init_reg_param(struct reg_param *param, char *reg_name, uint32_t size, enum param_direction direction)
void destroy_reg_param(struct reg_param *param)
Holds the interface to ARM cores.
static bool is_arm(struct arm *arm)
arm_mode
Represent state of an ARM core.
static struct arm * target_to_arm(const struct target *target)
Convert target handle to generic ARM target state handle.
arm_state
The PSR "T" and "J" bits define the mode of "classic ARM" cores.
@ ARM_CORE_TYPE_M_PROFILE
int arm_blank_check_memory(struct target *target, struct target_memory_check_block *blocks, int num_blocks, uint8_t erased_value)
Runs ARM code in the target to check whether a memory block holds all ones.
static const struct reg_arch_type arm_reg_type
static int armv4_5_set_core_reg(struct reg *reg, uint8_t *buf)
static const uint8_t arm_svc_indices[3]
static const uint8_t arm_gdb_dummy_fp_value[12]
static const uint8_t arm_irq_indices[3]
const struct command_registration arm_all_profiles_command_handlers[]
struct reg * arm_reg_current(struct arm *arm, unsigned int regnum)
Returns handle to the register currently mapped to a given number.
int armv4_5_run_algorithm_inner(struct target *target, int num_mem_params, struct mem_param *mem_params, int num_reg_params, struct reg_param *reg_params, uint32_t entry_point, uint32_t exit_point, unsigned int timeout_ms, void *arch_info, int(*run_it)(struct target *target, uint32_t exit_point, unsigned int timeout_ms, void *arch_info))
int arm_arch_state(struct target *target)
static const char * arm_core_state_string(struct arm *arm)
static const struct @71 arm_mode_data[]
bool is_arm_mode(unsigned int psr_mode)
Return true iff the parameter denotes a valid ARM processor mode.
int arm_checksum_memory(struct target *target, target_addr_t address, uint32_t count, uint32_t *checksum)
Runs ARM code in the target to calculate a CRC32 checksum.
int arm_mode_to_number(enum arm_mode mode)
Map PSR mode bits to linear number indexing armv4_5_core_reg_map.
static int arm_default_mcrr(struct target *target, int cpnum, uint32_t op, uint32_t crm, uint64_t value)
static int arm_default_mrrc(struct target *target, int cpnum, uint32_t op, uint32_t crm, uint64_t *value)
static struct reg arm_gdb_dummy_fp_reg
Dummy FPA registers are required to support GDB on ARM.
static const char * arm_state_strings[]
COMMAND_HANDLER(handle_armv4_5_reg_command)
static int arm_full_context(struct target *target)
static const uint8_t arm_abt_indices[3]
struct reg_cache * arm_build_reg_cache(struct target *target, struct arm *arm)
const char * arm_get_gdb_arch(const struct target *target)
static const uint8_t arm_hyp_indices[2]
int arm_get_gdb_reg_list(struct target *target, struct reg **reg_list[], int *reg_list_size, enum target_register_class reg_class)
const int armv4_5_core_reg_map[9][17]
static struct reg arm_gdb_dummy_fps_reg
Dummy FPA status registers are required to support GDB on ARM.
static const uint8_t arm_fiq_indices[8]
static int arm_default_mrc(struct target *target, int cpnum, uint32_t op1, uint32_t op2, uint32_t crn, uint32_t crm, uint32_t *value)
static int armv4_5_get_core_reg(struct reg *reg)
void arm_free_reg_cache(struct arm *arm)
static const uint8_t arm_usr_indices[17]
static const struct @72 arm_core_regs[]
static struct reg_feature arm_gdb_dummy_fp_features
static const uint8_t arm_mon_indices[3]
static const uint8_t arm_und_indices[3]
static const struct command_registration arm_exec_command_handlers[]
const struct command_registration arm_command_handlers[]
static void arm_gdb_dummy_init(void)
enum arm_mode armv4_5_number_to_mode(int number)
Map linear number indexing armv4_5_core_reg_map to PSR mode bits.
static const struct @73 arm_vfp_v3_regs[]
int arm_init_arch_info(struct target *target, struct arm *arm)
const char * arm_mode_name(unsigned int psr_mode)
Map PSR mode bits to the name of an ARM processor operating mode.
void arm_set_cpsr(struct arm *arm, uint32_t cpsr)
Configures host-side ARM records to reflect the specified CPSR.
int armv4_5_run_algorithm(struct target *target, int num_mem_params, struct mem_param *mem_params, int num_reg_params, struct reg_param *reg_params, target_addr_t entry_point, target_addr_t exit_point, unsigned int timeout_ms, void *arch_info)
static int armv4_5_run_algorithm_completion(struct target *target, uint32_t exit_point, unsigned int timeout_ms, void *arch_info)
static int arm_default_mcr(struct target *target, int cpnum, uint32_t op1, uint32_t op2, uint32_t crn, uint32_t crm, uint32_t value)
static const uint8_t arm_gdb_dummy_fps_value[4]
#define ARMV4_5_CORE_REG_MODE(cache, mode, num)
Support functions to access arbitrary bits in a byte array.
static uint32_t buf_get_u32(const uint8_t *_buffer, unsigned int first, unsigned int num)
Retrieves num bits from _buffer, starting at the first bit, returning the bits in a 32-bit word.
static void buf_set_u32(uint8_t *_buffer, unsigned int first, unsigned int num, uint32_t value)
Sets num bits in _buffer, starting at the first bit, using the bits in value.
int breakpoint_remove(struct target *target, target_addr_t address)
int breakpoint_add(struct target *target, target_addr_t address, unsigned int length, enum breakpoint_type type)
void command_print(struct command_invocation *cmd, const char *format,...)
#define CMD
Use this macro to access the command being handled, rather than accessing the variable directly.
#define CMD_NAME
Use this macro to access the name of the command being handled, rather than accessing the variable di...
#define CMD_ARGV
Use this macro to access the arguments for the command being handled, rather than accessing the varia...
#define COMMAND_PARSE_ADDRESS(in, out)
#define ERROR_COMMAND_SYNTAX_ERROR
#define CMD_ARGC
Use this macro to access the number of arguments for the command being handled, rather than accessing...
#define COMMAND_PARSE_NUMBER(type, in, out)
parses the string in into out as a type, or prints a command error and passes the error code to the c...
#define CMD_CTX
Use this macro to access the context of the command being handled, rather than accessing the variable...
#define COMMAND_REGISTRATION_DONE
Use this as the last entry in an array of command_registration records.
#define ERROR_COMMAND_ARGUMENT_INVALID
enum esirisc_reg_num number
static uint16_t direction
static const struct @109 regs[]
#define LOG_USER(expr ...)
#define LOG_WARNING(expr ...)
#define LOG_TARGET_ERROR(target, fmt_str,...)
#define LOG_ERROR(expr ...)
#define LOG_DEBUG(expr ...)
struct qn908x_flash_bank __attribute__
void register_init_dummy(struct reg *reg)
struct reg * register_get_by_name(struct reg_cache *first, const char *name, bool search_all)
size_t size
Size of the control block search area.
const struct command_registration semihosting_common_handlers[]
unsigned int common_magic
enum arm_state core_state
Represents a generic ARM core, with standard application registers.
int(* full_context)(struct target *target)
Retrieve all core registers, for display.
enum arm_arch arch
ARM architecture version.
int(* mrrc)(struct target *target, int cpnum, uint32_t op, uint32_t crm, uint64_t *value)
Read coprocessor to two registers.
enum arm_core_type core_type
Indicates what registers are in the ARM state core register set.
int(* mrc)(struct target *target, int cpnum, uint32_t op1, uint32_t op2, uint32_t crn, uint32_t crm, uint32_t *value)
Read coprocessor register.
enum arm_mode core_mode
Record the current core mode: SVC, USR, or some other mode.
struct reg * cpsr
Handle to the CPSR/xPSR; valid in all core modes.
struct reg * pc
Handle to the PC; valid in all core modes.
int(* write_core_reg)(struct target *target, struct reg *reg, int num, enum arm_mode mode, uint8_t *value)
const int * map
Support for arm_reg_current()
int(* mcrr)(struct target *target, int cpnum, uint32_t op, uint32_t crm, uint64_t value)
Write coprocessor from two registers.
int(* read_core_reg)(struct target *target, struct reg *reg, int num, enum arm_mode mode)
Retrieve a single core register.
struct reg_cache * core_cache
int(* mcr)(struct target *target, int cpnum, uint32_t op1, uint32_t op2, uint32_t crn, uint32_t crm, uint32_t value)
Write coprocessor register.
struct reg * spsr
Handle to the SPSR; valid only in core modes with an SPSR.
unsigned int common_magic
int arm_vfp_version
Floating point or VFP version, 0 if disabled.
struct target * target
Backpointer to the target.
enum arm_state core_state
Record the current core state: ARM, Thumb, or otherwise.
int(* get)(struct reg *reg)
struct reg_feature * feature
struct reg_data_type * reg_data_type
const struct reg_arch_type * type
bool hit_fileio
A flag reporting whether semihosting fileio operation is active.
bool is_fileio
A flag reporting whether semihosting fileio is active.
bool is_active
A flag reporting whether semihosting is active.
struct semihosting * semihosting
int target_halt(struct target *target)
int target_write_buffer(struct target *target, target_addr_t address, uint32_t size, const uint8_t *buffer)
int target_read_buffer(struct target *target, target_addr_t address, uint32_t size, uint8_t *buffer)
int target_run_algorithm(struct target *target, int num_mem_params, struct mem_param *mem_params, int num_reg_params, struct reg_param *reg_param, target_addr_t entry_point, target_addr_t exit_point, unsigned int timeout_ms, void *arch_info)
Downloads a target-specific native code algorithm to the target, and executes it.
int target_alloc_working_area(struct target *target, uint32_t size, struct working_area **area)
int target_write_u32(struct target *target, target_addr_t address, uint32_t value)
int target_free_working_area(struct target *target, struct working_area *area)
Free a working area.
const char * debug_reason_name(const struct target *t)
int target_wait_state(struct target *target, enum target_state state, unsigned int ms)
struct target * get_current_target(struct command_context *cmd_ctx)
const char * target_type_name(const struct target *target)
Get the target type name.
int target_resume(struct target *target, int current, target_addr_t address, int handle_breakpoints, int debug_execution)
Make the target (re)start executing using its saved execution context (possibly with some modificatio...
#define ERROR_TARGET_NOT_HALTED
static bool target_was_examined(const struct target *target)
#define ERROR_TARGET_INVALID
static const char * target_name(const struct target *target)
Returns the instance-specific name of the specified target.
#define ERROR_TARGET_NOT_EXAMINED
#define ERROR_TARGET_TIMEOUT
#define ERROR_TARGET_FAILURE
#define ARRAY_SIZE(x)
Compute the number of elements of a variable length array.
static uint32_t le_to_h_u32(const uint8_t *buf)