X-Git-Url: https://review.openocd.org/gitweb?a=blobdiff_plain;f=src%2Ftarget%2Fregister.h;h=4b45fd3c455791ac3b7d4c47653d1cc0925050b5;hb=033d1053ae42b913ff7100221628c0376e596d71;hp=bc40d1fa61d177b6ee0d5adc658391a7886a5339;hpb=de3fb2f3bce2de5be44223204ce368216ed85b0f;p=openocd.git diff --git a/src/target/register.h b/src/target/register.h index bc40d1fa61..4b45fd3c45 100644 --- a/src/target/register.h +++ b/src/target/register.h @@ -23,53 +23,38 @@ #ifndef REGISTER_H #define REGISTER_H -#include "types.h" +struct target; -struct target_s; - -struct bitfield_desc -{ - char *name; - int num_bits; -}; - -typedef struct reg_s +struct reg { - char *name; + const char *name; void *value; - int dirty; - int valid; + bool dirty; + bool valid; uint32_t size; - struct bitfield_desc *bitfield_desc; - int num_bitfields; void *arch_info; - int arch_type; -} reg_t; + const struct reg_arch_type *type; +}; -typedef struct reg_cache_s +struct reg_cache { - char *name; - struct reg_cache_s *next; - reg_t *reg_list; - int num_regs; -} reg_cache_t; + const char *name; + struct reg_cache *next; + struct reg *reg_list; + unsigned num_regs; +}; -typedef struct reg_arch_type_s +struct reg_arch_type { - int id; - int (*get)(reg_t *reg); - int (*set)(reg_t *reg, uint8_t *buf); - struct reg_arch_type_s *next; -} reg_arch_type_t; + int (*get)(struct reg *reg); + int (*set)(struct reg *reg, uint8_t *buf); +}; -reg_t* register_get_by_name(reg_cache_t *first, +struct reg* register_get_by_name(struct reg_cache *first, const char *name, bool search_all); -reg_cache_t** register_get_last_cache_p(reg_cache_t **first); - -int register_reg_arch_type(int (*get)(reg_t *reg), - int (*set)(reg_t *reg, uint8_t *buf)); -reg_arch_type_t* register_get_arch_type(int id); +struct reg_cache** register_get_last_cache_p(struct reg_cache **first); +void register_cache_invalidate(struct reg_cache *cache); -void register_init_dummy(reg_t *reg); +void register_init_dummy(struct reg *reg); #endif /* REGISTER_H */