1: /*
   2:  * Copyright (c) 1980 Regents of the University of California.
   3:  * All rights reserved.  The Berkeley software License Agreement
   4:  * specifies the terms and conditions for redistribution.
   5:  */
   6: 
   7: #if defined(LIBC_SCCS) && !defined(lint)
   8: static char sccsid[] = "@(#)mon.c	5.3 (Berkeley) 3/9/86";
   9: #endif LIBC_SCCS and not lint
  10: 
  11: #define ARCDENSITY  5   /* density of routines */
  12: #define MINARCS     50  /* minimum number of counters */
  13: #define HISTFRACTION    2   /* fraction of text space for histograms */
  14: 
  15: 
  16: struct phdr {
  17:     int *lpc;
  18:     int *hpc;
  19:     int ncnt;
  20: };
  21: 
  22: struct cnt {
  23:     int *pc;
  24:     long ncall;
  25: } *countbase;
  26: 
  27: static int cntrs = 0;
  28: static int profiling = 3;
  29: static char *s_sbuf;
  30: static int s_bufsiz;
  31: static int s_scale;
  32: static char *s_lowpc;
  33: 
  34: int numctrs;
  35: 
  36: #define MSG "No space for monitor buffer(s)\n"
  37: 
  38: monstartup(lowpc, highpc)
  39:     char *lowpc;
  40:     char *highpc;
  41: {
  42:     int monsize;
  43:     char *buffer;
  44:     int cntsiz;
  45:     extern char *sbrk();
  46:     extern char *minbrk;
  47: 
  48: 
  49:     cntsiz = (highpc - lowpc) * ARCDENSITY / 100;
  50:     if (cntsiz < MINARCS)
  51:         cntsiz = MINARCS;
  52:     monsize = (highpc - lowpc + HISTFRACTION - 1) / HISTFRACTION
  53:         + sizeof(struct phdr) + cntsiz * sizeof(struct cnt);
  54:     monsize = (monsize + 1) & ~1;
  55:     buffer = sbrk(monsize);
  56:     if (buffer == (char *)-1) {
  57:         write(2, MSG, sizeof(MSG));
  58:         return;
  59:     }
  60:     minbrk = sbrk(0);
  61:     monitor(lowpc, highpc, buffer, monsize, cntsiz);
  62: }
  63: 
  64: /*
  65:  *	This routine is massaged so that it may be jsb'ed to
  66:  */
  67: asm(".text");
  68: asm("#the beginning of mcount()");
  69: asm(".data");
  70: mcount()
  71: {
  72:     register int *selfpc;   /* r11 */
  73:     register long **cntp;   /* r10 */
  74: 
  75:     /*
  76: 	 * find the return address for mcount,
  77: 	 * and address of counter pointer
  78: 	 */
  79:     asm("	movl	(sp),r11");  /* selfpc = ... (jsb frame) */
  80:     asm("	movl	r0,r10");    /* address of count local */
  81:     /*
  82: 	 * check that we aren't recursively invoked.
  83: 	 */
  84:     if (profiling)
  85:         goto out;
  86:     profiling++;
  87:     /*
  88: 	 * check that counter is allocated
  89: 	 */
  90:     if (*cntp == 0) {
  91:         /*
  92: 		 * check that a counter is available
  93: 		 */
  94:         if (cntrs++ == numctrs)
  95:             goto overflow;
  96:         countbase->pc = selfpc;
  97:         *cntp = &countbase->ncall;
  98:         countbase++;
  99:     }
 100:     (**cntp)++;
 101:     profiling--;
 102: out:
 103:     asm( "	rsb" );
 104: 
 105: overflow:
 106: #   define  TOLIMIT "mcount: counter overflow\n"
 107:     write( 2 , TOLIMIT , sizeof( TOLIMIT ) );
 108:     goto out;
 109: }
 110: asm(".text");
 111: asm("#the end of mcount()");
 112: asm(".data");
 113: 
 114: monitor(lowpc, highpc, buf, bufsiz, cntsiz)
 115:     char *lowpc, *highpc;
 116:     char *buf;
 117:     int bufsiz, cntsiz;
 118: {
 119:     register int o;
 120:     struct phdr *php;
 121:     static int ssiz;
 122:     static char *sbuf;
 123: 
 124:     if (lowpc == 0) {
 125:         moncontrol(0);
 126:         o = creat("mon.out", 0666);
 127:         write(o, sbuf, ssiz);
 128:         close(o);
 129:         return;
 130:     }
 131:     sbuf = buf;
 132:     ssiz = bufsiz;
 133:     php = (struct phdr *)&buf[0];
 134:     php->lpc = (int *)lowpc;
 135:     php->hpc = (int *)highpc;
 136:     php->ncnt = cntsiz;
 137:     numctrs = cntsiz;
 138:     countbase = (struct cnt *)(buf + sizeof(struct phdr));
 139:     o = sizeof(struct phdr) + cntsiz * sizeof(struct cnt);
 140:     buf += o;
 141:     bufsiz -= o;
 142:     if (bufsiz <= 0)
 143:         return;
 144:     o = (highpc - lowpc);
 145:     if(bufsiz < o)
 146:         o = ((float) bufsiz / o) * 65536;
 147:     else
 148:         o = 65536;
 149:     s_scale = o;
 150:     s_sbuf = buf;
 151:     s_bufsiz = bufsiz;
 152:     s_lowpc = lowpc;
 153:     moncontrol(1);
 154: }
 155: 
 156: /*
 157:  * Control profiling
 158:  *	profiling is what mcount checks to see if
 159:  *	all the data structures are ready.
 160:  */
 161: moncontrol(mode)
 162:     int mode;
 163: {
 164:     if (mode) {
 165:     /* start */
 166:     profil(s_sbuf, s_bufsiz, s_lowpc, s_scale);
 167:     profiling = 0;
 168:     } else {
 169:     /* stop */
 170:     profil((char *)0, 0, 0, 0);
 171:     profiling = 3;
 172:     }
 173: }

Defined functions

mcount defined in line 70; never used
moncontrol defined in line 161; used 2 times
monitor defined in line 114; used 1 times
  • in line 61
monstartup defined in line 38; never used

Defined variables

cntrs defined in line 27; used 1 times
  • in line 94
countbase defined in line 25; used 4 times
numctrs defined in line 34; used 2 times
profiling defined in line 28; used 5 times
s_bufsiz defined in line 30; used 2 times
s_lowpc defined in line 32; used 2 times
s_sbuf defined in line 29; used 2 times
s_scale defined in line 31; used 2 times
sccsid defined in line 8; never used

Defined struct's

cnt defined in line 22; used 6 times
phdr defined in line 16; used 10 times

Defined macros

ARCDENSITY defined in line 11; used 1 times
  • in line 49
HISTFRACTION defined in line 13; used 2 times
  • in line 52(2)
MINARCS defined in line 12; used 2 times
MSG defined in line 36; used 2 times
  • in line 57(2)
TOLIMIT defined in line 106; used 2 times
  • in line 107(2)
Last modified: 1986-03-10
Generated: 2016-12-26
Generated by src2html V0.67
page hit count: 741
Valid CSS Valid XHTML 1.0 Strict