ref: c3cfd06564ab868d1e78bf5fe8fe6fac07202de9
dir: /sys/src/9/mtx/clock.c/
#include	"u.h"
#include	"../port/lib.h"
#include	"mem.h"
#include	"dat.h"
#include	"fns.h"
#include	"io.h"
#include	"ureg.h"
static	ulong	clkreload;
void
delayloopinit(void)
{
	ulong v;
	uvlong x;
	m->loopconst = 5000;
	v = getdec();
	delay(1000);
	v -= getdec();
	x = m->loopconst;
	x *= m->dechz;
	x /= v;
	m->loopconst = x;
}
void
clockinit(void)
{
	/* XXX this should not be hard coded! */
	m->cpuhz = 300000000;
	m->bushz = 66666666;
	m->dechz = m->bushz/4;			/* true for all 604e */
	m->tbhz = m->dechz;				/* conjecture; manual doesn't say */
	delayloopinit();
	clkreload = m->dechz/HZ-1;
	putdec(clkreload);
}
void
clockintr(Ureg *ureg)
{
	long v;
	v = -getdec();
	if(v > clkreload/2){
		if(v > clkreload)
			m->ticks += v/clkreload;
		v = 0;
	}
	putdec(clkreload-v);
	timerintr(ureg, 0);
}
void
timerset(Tval)
{
}
void
delay(int l)
{
	ulong i, j;
	j = m->loopconst;
	while(l-- > 0)
		for(i=0; i < j; i++)
			;
}
void
microdelay(int l)
{
	ulong i;
	l *= m->loopconst;
	l += 500;
	l /= 1000;
	if(l <= 0)
		l = 1;
	for(i = 0; i < l; i++)
		;
}
uvlong
fastticks(uvlong *hz)
{
	if(hz)
		*hz = HZ;
	return m->ticks;
}
ulong
µs(void)
{
	return fastticks2us(m->ticks);
}
/*  
 *  performance measurement ticks.  must be low overhead.
 *  doesn't have to count over a second.
 */
ulong
perfticks(void)
{
	return m->ticks;
}