2005-10-20 22:28:54 +02:00
|
|
|
#include "inc.h"
|
|
|
|
#include "../ds/store.h"
|
|
|
|
|
2010-01-19 22:00:20 +01:00
|
|
|
#define LINES 22
|
|
|
|
|
2010-01-14 16:24:16 +01:00
|
|
|
PRIVATE struct data_store ds_store[NR_DS_KEYS];
|
2005-10-20 22:28:54 +02:00
|
|
|
|
|
|
|
PUBLIC void data_store_dmp()
|
|
|
|
{
|
2010-01-14 16:24:16 +01:00
|
|
|
struct data_store *p;
|
|
|
|
static int prev_i = 0;
|
|
|
|
int r, i, n = 0;
|
2005-10-20 22:28:54 +02:00
|
|
|
|
2010-01-14 16:24:16 +01:00
|
|
|
if((r=getsysinfo(DS_PROC_NR, SI_DATA_STORE, ds_store)) != OK) {
|
|
|
|
printf("Couldn't talk to DS: %d.\n", r);
|
2006-07-13 16:50:23 +02:00
|
|
|
return;
|
|
|
|
}
|
2005-10-20 22:28:54 +02:00
|
|
|
|
2010-01-14 16:24:16 +01:00
|
|
|
printf("Data store contents:\n");
|
|
|
|
printf("-slot- ------key------ -----owner----- ---type--- ----value---\n");
|
2010-01-19 22:00:20 +01:00
|
|
|
for(i = prev_i; i < NR_DS_KEYS && n < LINES; i++) {
|
2010-01-14 16:24:16 +01:00
|
|
|
p = &ds_store[i];
|
|
|
|
if(!(p->flags & DSF_IN_USE))
|
|
|
|
continue;
|
|
|
|
|
|
|
|
printf("%6d %-15s %-15s ", i, p->key, p->owner);
|
|
|
|
switch(p->flags & DSF_MASK_TYPE) {
|
|
|
|
case DSF_TYPE_U32:
|
|
|
|
printf("%-10s %12u\n", "U32", p->u.u32);
|
|
|
|
break;
|
|
|
|
case DSF_TYPE_STR:
|
|
|
|
printf("%-10s %12s\n", "STR", p->u.string);
|
|
|
|
break;
|
|
|
|
case DSF_TYPE_MEM:
|
|
|
|
printf("%-10s %12u\n", "MEM", p->u.mem.length);
|
|
|
|
break;
|
|
|
|
case DSF_TYPE_MAP:
|
|
|
|
printf("%-10s %9u/%3u\n", "MAP", p->u.map.length,
|
|
|
|
p->u.map.sindex);
|
|
|
|
break;
|
|
|
|
case DSF_TYPE_LABEL:
|
|
|
|
printf("%-10s %12u\n", "LABEL", p->u.u32);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
return;
|
2006-07-13 16:50:23 +02:00
|
|
|
}
|
2010-01-14 16:24:16 +01:00
|
|
|
|
2010-01-19 22:00:20 +01:00
|
|
|
n++;
|
2005-10-20 22:28:54 +02:00
|
|
|
}
|
2010-01-14 16:24:16 +01:00
|
|
|
|
2005-10-20 22:28:54 +02:00
|
|
|
if (i >= NR_DS_KEYS) i = 0;
|
|
|
|
else printf("--more--\r");
|
|
|
|
prev_i = i;
|
|
|
|
}
|
|
|
|
|