This patch implements a series of apigetuint* call back functions which are used to access data from the dump image. Eppic uses these call back functions to fetch the actual value of the global variables. This patch also adds other call back functions as a place holder which will be implemented in later patches. This is mainly to avoid compilation error while registering the call back functions using eppic_apiset() function. Signed-off-by: Aravinda Prasad <aravinda at linux.vnet.ibm.com> --- extension_eppic.c | 128 +++++++++++++++++++++++++++++++++++++++++++++++++++++ extension_eppic.h | 50 ++++++++++++++++++++- 2 files changed, 176 insertions(+), 2 deletions(-) diff --git a/extension_eppic.c b/extension_eppic.c index fc47b1f..26c945f 100644 --- a/extension_eppic.c +++ b/extension_eppic.c @@ -20,6 +20,7 @@ #include <sys/types.h> #include <fcntl.h> +#include "makedumpfile.h" #include "extension_eppic.h" /* @@ -64,6 +65,131 @@ reg_callback(char *name, int load) return; } +/* + * Call back functions for eppic to query the dump image + */ + +static int +apigetmem(ull iaddr, void *p, int nbytes) +{ + return readmem(VADDR, iaddr, p, nbytes); +} + +static int +apiputmem(ull iaddr, void *p, int nbytes) +{ + return 1; +} + +static char * +apimember(char *mname, ull pidx, type_t *tm, + member_t *m, ull *lidx) +{ + return 0; +} + +static int +apigetctype(int ctype, char *name, type_t *tout) +{ + return 0; +} + +static char * +apigetrtype(ull idx, type_t *t) +{ + return ""; +} + +static int +apialignment(ull idx) +{ + return 0; +} + +int +apigetval(char *name, ull *val, VALUE_S *value) +{ + ull ptr = 0; + + ptr = get_symbol_addr(name); + if (!ptr) + return 0; + + *val = ptr; + return 1; +} + +static enum_t * +apigetenum(char *name) +{ + return 0; +} + +static def_t * +apigetdefs(void) +{ + return 0; +} + +static uint8_t +apigetuint8(void *ptr) +{ + uint8_t val; + if (!readmem(VADDR, (unsigned long)ptr, (char *)&val, sizeof(val))) + return (uint8_t) -1; + return val; +} + +static uint16_t +apigetuint16(void *ptr) +{ + uint16_t val; + if (!readmem(VADDR, (unsigned long)ptr, (char *)&val, sizeof(val))) + return (uint16_t) -1; + return val; +} + +static uint32_t +apigetuint32(void *ptr) +{ + uint32_t val; + if (!readmem(VADDR, (unsigned long)ptr, (char *)&val, sizeof(val))) + return (uint32_t) -1; + return val; +} + +static uint64_t +apigetuint64(void *ptr) +{ + uint64_t val; + if (!readmem(VADDR, (unsigned long)ptr, (char *)&val, sizeof(val))) + return (uint64_t) -1; + return val; +} + +static char * +apifindsym(char *p) +{ + return NULL; +} + +apiops icops = { + apigetmem, + apiputmem, + apimember, + apigetctype, + apigetrtype, + apialignment, + apigetval, + apigetenum, + apigetdefs, + apigetuint8, + apigetuint16, + apigetuint32, + apigetuint64, + apifindsym +}; + /* Initialize eppic */ int @@ -72,7 +198,7 @@ eppic_init() if (eppic_open() >= 0) { /* Register call back functions */ - eppic_apiset(NULL, 3, sizeof(long), 0); + eppic_apiset(&icops, 3, sizeof(long), 0); /* set the new function callback */ eppic_setcallback(reg_callback); diff --git a/extension_eppic.h b/extension_eppic.h index 67efd11..100ef5b 100644 --- a/extension_eppic.h +++ b/extension_eppic.h @@ -22,5 +22,53 @@ int eppic_init(void); /* Eppic initialize */ -#endif /* _EXTENSION_EPPIC_H */ +/* + * MEMBER_S, ENUM_S, DEF_S and TYPE_S are extracts from eppic header + * file eppic.h. The reason for not including the eppic.h header file + * in this file is because, lot of things in eppic.h are not required + * for makedumpfile extension. + */ + +/* member information */ +typedef MEMBER_S { + + char *name; + int offset; /* offset from top of structure */ + int size; /* size in bytes of the member or of the bit array */ + int fbit; /* fist bit (-1) is not a bit field */ + int nbits; /* number of bits for this member */ + int value; /* for a enum member, the corresponding value_t */ + +} member_t; + +/* list to hold enum constant information */ +typedef ENUM_S { + struct enum_s *next; + char *name; + int value; + +} enum_t; + +/* list of macro symbols and there corresponding value_ts */ +typedef DEF_S { + struct def_s *next; + char *name; + char *val; + +} def_t; + + +typedef TYPE_S { + int type; /* type_t of type_t */ + ull idx; /* index to basetype_t or ctype_t */ + int size; /* size of this item */ + /* ... next fields are use internally */ + int typattr; /* base type_t qualifiers */ + int ref; /* level of reference */ + int fct; /* 1 if function pointer */ + int *idxlst; /* points to list of indexes if array */ + ull rtype; /* type_t a reference refers too */ +} type_t; + +#endif /* _EXTENSION_EPPIC_H */