X-Git-Url: https://review.openocd.org/gitweb?p=openocd.git;a=blobdiff_plain;f=src%2Ftarget%2Fregister.h;h=0cd0ddfe467d91ce8406021204d4e1ecae434ef3;hp=456ab5901c443ea227dc95dfec6dedccc673a9b3;hb=c4992c6d863d0ead91d84d19bbfe1643d720b205;hpb=a582e9a8d183c56d1aa8ae18afc1c11e2cbd6d2d diff --git a/src/target/register.h b/src/target/register.h index 456ab5901c..0cd0ddfe46 100644 --- a/src/target/register.h +++ b/src/target/register.h @@ -2,6 +2,9 @@ * Copyright (C) 2005 by Dominic Rath * * Dominic.Rath@gmx.de * * * + * Copyright (C) 2007,2008 Øyvind Harboe * + * oyvind.harboe@zylin.com * + * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation; either version 2 of the License, or * @@ -20,50 +23,38 @@ #ifndef REGISTER_H #define REGISTER_H -#include "types.h" -#include "target.h" - -struct target_s; +struct target; -typedef struct bitfield_desc_s +struct reg { char *name; - int num_bits; -} bitfield_desc_t; - -typedef struct reg_s -{ - char *name; - u8 *value; - int dirty; - int valid; - int size; - bitfield_desc_t *bitfield_desc; - int num_bitfields; + void *value; + bool dirty; + bool valid; + uint32_t size; 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; + 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, u8 *buf); - struct reg_arch_type_s *next; -} reg_arch_type_t; + int (*get)(struct reg *reg); + int (*set)(struct reg *reg, uint8_t *buf); +}; -extern reg_t* register_get_by_name(reg_cache_t *first, char *name, int search_all); -extern reg_cache_t** register_get_last_cache_p(reg_cache_t **first); -extern int register_reg_arch_type(int (*get)(reg_t *reg), int (*set)(reg_t *reg, u8 *buf)); -extern reg_arch_type_t* register_get_arch_type(int id); +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); -#endif /* REGISTER_H */ +void register_init_dummy(struct reg *reg); +#endif /* REGISTER_H */