/* * Copyright (c) 1982, 1986 Regents of the University of California. * All rights reserved. The Berkeley software License Agreement * specifies the terms and conditions for redistribution. * * @(#)kgclock.c 7.1 (Berkeley) 6/5/86 */ #include "kg.h" #if NKG > 0 /* * KL-11 as profiling clock */ #include "../machine/pte.h" #include "../machine/psl.h" #include "param.h" #include "map.h" #include "buf.h" #include "time.h" #include "kernel.h" #include "ubavar.h" int kgprobe(), kgattach(); struct uba_device *kginfo[1]; u_short kgstd[] = { 0177560, 0 }; struct uba_driver kgdriver = { kgprobe, 0, kgattach, 0, kgstd, "kg", kginfo }; struct klregs { u_short fill[2]; u_short tcsr; u_short tbuf; }; #define KLSTRT 0300 /* intr enbl + done */ struct klregs *klbase; int usekgclock = 1; /* if zero, kgclock is disabled */ kgprobe(reg) caddr_t reg; { register int br, cvec; /* value-result */ register struct klregs *klp = (struct klregs *)reg; klp->tcsr = KLSTRT; DELAY(100000); klp->tcsr = 0; return (sizeof(struct klregs)); } kgattach(ui) struct uba_device *ui; { klbase = (struct klregs *)ui->ui_addr; } /* * start the sampling clock */ startkgclock() { if (klbase && usekgclock && phz == 0) klbase->tcsr = KLSTRT; /* enable interrupts */ } /* ARGSUSED */ kgclock(dev, r0, r1, r2, r3, r4 ,r5, pc, ps) caddr_t pc; int ps; { register int k; static long otime; static long calibrate; if (usekgclock == 0) { phz = 0; otime = 0; return; } klbase->tbuf = 0377; /* reprime clock (scope sync too) */ if (phz == 0) { if (otime == 0) { otime = time.tv_sec + 1; calibrate = 0; } if (time.tv_sec >= otime) calibrate++; if (time.tv_sec >= otime + 4) { phz = calibrate / 4; otime = 0; } return; } gatherstats(pc, ps); /* this routine lives in kern_clock.c */ } #endif