X-Git-Url: https://review.openocd.org/gitweb?p=openocd.git;a=blobdiff_plain;f=src%2Ftarget%2Fregister.h;h=0f8f2f4e0b1c8f09102c7fbf9ea30d95ed2774d6;hp=ca8866b1e2cece5253ec393eda5adf557a085318;hb=71cde5e359f273585880ea8986709b950ba85b08;hpb=d0dee7ccafcf87259fadf6c5de43df8583b0e885 diff --git a/src/target/register.h b/src/target/register.h index ca8866b1e2..0f8f2f4e0b 100644 --- a/src/target/register.h +++ b/src/target/register.h @@ -23,15 +23,7 @@ #ifndef REGISTER_H #define REGISTER_H -#include "types.h" - -struct target_s; - -struct bitfield_desc -{ - char *name; - int num_bits; -}; +struct target; struct reg { @@ -40,10 +32,8 @@ struct reg int dirty; int valid; uint32_t size; - struct bitfield_desc *bitfield_desc; - int num_bitfields; void *arch_info; - int arch_type; + const struct reg_arch_type *type; }; struct reg_cache @@ -51,24 +41,19 @@ struct reg_cache char *name; struct reg_cache *next; struct reg *reg_list; - int num_regs; + unsigned num_regs; }; struct reg_arch_type { - int id; int (*get)(struct reg *reg); int (*set)(struct reg *reg, uint8_t *buf); - struct reg_arch_type *next; }; 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); - -int register_reg_arch_type(int (*get)(struct reg *reg), - int (*set)(struct reg *reg, uint8_t *buf)); -struct reg_arch_type* register_get_arch_type(int id); +void register_cache_invalidate(struct reg_cache *cache); void register_init_dummy(struct reg *reg);