openocd: prevent jimtcl error message while testing commands
[fw/openocd] / src / target / register.h
index dc18e9a89935cf9038791303c1f14801c2eb9218..a7705f76e089bed004be1ce7c3a704d30b28a0c8 100644 (file)
 #ifndef OPENOCD_TARGET_REGISTER_H
 #define OPENOCD_TARGET_REGISTER_H
 
+#include "helper/replacements.h"
+#include "helper/types.h"
+
 struct target;
 
 enum reg_type {
+       REG_TYPE_BOOL,
        REG_TYPE_INT,
        REG_TYPE_INT8,
        REG_TYPE_INT16,
        REG_TYPE_INT32,
        REG_TYPE_INT64,
        REG_TYPE_INT128,
+       REG_TYPE_UINT,
        REG_TYPE_UINT8,
        REG_TYPE_UINT16,
        REG_TYPE_UINT32,
@@ -66,6 +71,7 @@ struct reg_data_type_union {
 struct reg_data_type_bitfield {
        uint32_t start;
        uint32_t end;
+       enum reg_type type;
 };
 
 struct reg_data_type_struct_field {
@@ -124,13 +130,15 @@ struct reg {
        bool caller_save;
        /* Pointer to place where the value is stored, in the format understood by
         * the binarybuffer.h functions. */
-       void *value;
+       uint8_t *value;
        /* The stored value needs to be written to the target. */
        bool dirty;
        /* When true, value is valid. */
        bool valid;
        /* When false, the register doesn't actually exist in the target. */
        bool exist;
+       /* Hide the register from gdb and omit it in 'reg' cmd output */
+       bool hidden;
        /* Size of the register in bits. */
        uint32_t size;
        /* Used for generating XML description of registers. Can be set to NULL for
@@ -156,6 +164,8 @@ struct reg_arch_type {
        int (*set)(struct reg *reg, uint8_t *buf);
 };
 
+struct reg *register_get_by_number(struct reg_cache *first,
+               uint32_t reg_num, bool search_all);
 struct reg *register_get_by_name(struct reg_cache *first,
                const char *name, bool search_all);
 struct reg_cache **register_get_last_cache_p(struct reg_cache **first);