ref: f65f1bb7adbcd97e8738d15c37903338d8885570
dir: /sv.c/
#include <u.h> #include <libc.h> #include <thread.h> #include <draw.h> #include "dat.h" #include "fns.h" extern QLock drawlock; vlong tc; int pause; static int tdiv; static void step(vlong tics) { Msg *m; qlock(&drawlock); while((m = readnet()) != nil){ parsemsg(m); clearmsg(m); } while(!pause && tics-- > 0) stepsim(); qunlock(&drawlock); } static void simproc(void *sys) { vlong t, t0, dt, Δtc; initnet(sys); initsim(); Δtc = 1; t0 = nsec(); for(;;){ step(Δtc); tc += 1; t = nsec(); Δtc = (t - t0) / tdiv; if(Δtc <= 0) Δtc = 1; t0 += Δtc * tdiv; dt = (t0 - t) / Te6; if(dt > 0) sleep(dt); } } void initsv(int tv, char *sys) { tdiv = Te9 / (tv * 3); if(proccreate(simproc, sys, 16*1024) < 0) sysfatal("proccreate: %r"); }