/* * ---------------------------------------------------------------------------- * "THE BEER-WARE LICENSE" (Revision 42): * wrote this file. As long as you retain this notice you * can do whatever you want with this stuff. If we meet some day, and you think * this stuff is worth it, you can buy me a beer in return. Poul-Henning Kamp * ---------------------------------------------------------------------------- * * $Id$ * */ #include #include #include #include #include #include #define MAXBB 32768 struct bb { u_long zero_one; u_long filename; u_long counts; u_long ncounts; u_long next; u_long addr; u_long nwords; u_long func; u_long lineno; u_long file; }; struct nlist namelist[] = { { "bbset" }, { NULL } }; u_long lineno[MAXBB]; u_long counts[MAXBB]; u_long addr[MAXBB]; u_long func[MAXBB]; u_long file[MAXBB]; char *fn[MAXBB]; char *pn[MAXBB]; kvm_t *kv; main() { int i,j; u_long l1,l2,l3; struct bb bb; char buf[128]; kv = kvm_open(NULL,NULL,NULL,O_RDWR,"dnc"); if (!kv) {perror("kvm_open"); exit(1); } i = kvm_nlist(kv,namelist); if (i) {perror("kvm_nlist"); exit(1); } l1 = namelist[0].n_value; kvm_read(kv,l1,&l2,sizeof l2); while(l2--) { l1 += sizeof l1; kvm_read(kv,l1,&l3,sizeof l3); kvm_read(kv,l3,&bb,sizeof bb); if (!bb.ncounts) continue; if (bb.ncounts > MAXBB) { fprintf(stderr,"found %u counts above limit of %u\n", bb.ncounts, MAXBB); exit (1); } kvm_read(kv,bb.lineno,lineno, bb.ncounts * sizeof lineno[0]); kvm_read(kv,bb.counts,counts, bb.ncounts * sizeof counts[0]); kvm_read(kv,bb.addr, addr, bb.ncounts * sizeof addr[0]); kvm_read(kv,bb.file, file, bb.ncounts * sizeof file[0]); kvm_read(kv,bb.func, func, bb.ncounts * sizeof func[0]); for (i=0; i < bb.ncounts; i++) if (counts[i]) goto doit; continue; doit: for (i=0; i < bb.ncounts; i++) { if (!pn[i]) { kvm_read(kv,func[i], buf, sizeof buf); buf[sizeof buf -1] = 0; pn[i] = malloc(strlen(buf)+1); strcpy(pn[i],buf); for(j=i+1;j