X-Git-Url: https://git.gag.com/?a=blobdiff_plain;f=src%2Ftarget%2Fregister.h;h=cf08e4ae31a0f517ed9bff04598c9fa63818bbf6;hb=2aab7d3ce2b53200ed01eeedb8348fa4b977bed3;hp=e7904e5805f4d728b4b0e947457d1e464231113e;hpb=3885ab5a5af7ece410ce3eeb1059da3ea950436a;p=fw%2Fopenocd diff --git a/src/target/register.h b/src/target/register.h index e7904e580..cf08e4ae3 100644 --- a/src/target/register.h +++ b/src/target/register.h @@ -20,55 +20,39 @@ * Free Software Foundation, Inc., * * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * ***************************************************************************/ + #ifndef REGISTER_H #define REGISTER_H -#include "types.h" - -struct target_s; +struct target; -typedef struct bitfield_desc_s -{ - char *name; - int num_bits; -} bitfield_desc_t; - -typedef struct reg_s -{ - char *name; +struct reg { + const char *name; void *value; - int dirty; - int valid; + bool dirty; + bool valid; uint32_t size; - bitfield_desc_t *bitfield_desc; - int num_bitfields; void *arch_info; - int arch_type; -} reg_t; - -typedef struct reg_cache_s -{ - char *name; - struct reg_cache_s *next; - reg_t *reg_list; - int num_regs; -} reg_cache_t; - -typedef struct reg_arch_type_s -{ - 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; - -reg_t* register_get_by_name(reg_cache_t *first, char *name, int 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); - -void register_init_dummy(reg_t *reg); + const struct reg_arch_type *type; +}; + +struct reg_cache { + const char *name; + struct reg_cache *next; + struct reg *reg_list; + unsigned num_regs; +}; + +struct reg_arch_type { + int (*get)(struct reg *reg); + int (*set)(struct reg *reg, uint8_t *buf); +}; + +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); +void register_cache_invalidate(struct reg_cache *cache); + +void register_init_dummy(struct reg *reg); #endif /* REGISTER_H */