- /*
- * Reschedule every 1/10 sec.
- */
- if (lbolt % (hz/10) == 0) {
- runrun++;
- aston();
- }
-
- /*
- * Run network slow and fast timeouts.
- */
- if (protofast <= 0) {
- protofast = hz / PR_FASTHZ;
- pffasttimo();
- }
- if (protoslow <= 0) {
- protoslow = hz / PR_SLOWHZ;
- pfslowtimo();
- }
- if (ifnetslow <= 0) {
- ifnetslow = hz / IFNET_SLOWHZ;
- if_slowtimo();
- }
-
- /*
- * Lightning bolt every second:
- * sleep timeouts
- * process priority recomputation
- * process %cpu averaging
- * virtual memory metering
- * kick swapper if processes want in
- */
- if (lbolt >= hz) {
- /*
- * This doesn't mean much on VAX since we run at
- * software interrupt time... if hardclock()
- * calls softclock() directly, it prevents
- * this code from running when the priority
- * was raised when the clock interrupt occurred.
- */
- if (BASEPRI(ps))
- return;
-
- /*
- * If we didn't run a few times because of
- * long blockage at high ipl, we don't
- * really want to run this code several times,
- * so squish out all multiples of hz here.
- */
- s = spl6();
- time += lbolt / hz; lbolt %= hz;
- splx(s);
-
- /*
- * Wakeup lightning bolt sleepers.
- * Processes sleep on lbolt to wait
- * for short amounts of time (e.g. 1 second).
- */
- wakeup((caddr_t)&lbolt);
-
- /*
- * Recompute process priority and process
- * sleep() system calls as well as internal
- * sleeps with timeouts (tsleep() kernel routine).
- */
- for (pp = proc; pp < procNPROC; pp++)
- if (pp->p_stat && pp->p_stat!=SZOMB) {
-#ifdef MUSH
- /*
- * Charge process for memory in use
- */
- if (pp->p_quota->q_uid)
- pp->p_quota->q_cost +=
- shconsts.sc_click * pp->p_rssize;
-#endif
- /*
- * Increase resident time, to max of 127 seconds
- * (it is kept in a character.) For
- * loaded processes this is time in core; for
- * swapped processes, this is time on drum.
- */
- if (pp->p_time != 127)
- pp->p_time++;
- /*
- * If process has clock counting down, and it
- * expires, set it running (if this is a tsleep()),
- * or give it an SIGALRM (if the user process
- * is using alarm signals.
- */
- if (pp->p_clktim && --pp->p_clktim == 0)
- if (pp->p_flag & STIMO) {
- s = spl6();
- switch (pp->p_stat) {
-
- case SSLEEP:
- setrun(pp);
- break;
-
- case SSTOP:
- unsleep(pp);
- break;
- }
- pp->p_flag &= ~STIMO;
- splx(s);
- } else
- psignal(pp, SIGALRM);
- /*
- * If process is blocked, increment computed
- * time blocked. This is used in swap scheduling.
- */
- if (pp->p_stat==SSLEEP || pp->p_stat==SSTOP)
- if (pp->p_slptime != 127)
- pp->p_slptime++;
- /*
- * Update digital filter estimation of process
- * cpu utilization for loaded processes.
- */
- if (pp->p_flag&SLOAD)
- pp->p_pctcpu = ccpu * pp->p_pctcpu +
- (1.0 - ccpu) * (pp->p_cpticks/(float)hz);
- /*
- * Recompute process priority. The number p_cpu
- * is a weighted estimate of cpu time consumed.
- * A process which consumes cpu time has this
- * increase regularly. We here decrease it by
- * a fraction based on load average giving a digital
- * decay filter which damps out in about 5 seconds
- * when seconds are measured in time expanded by the
- * load average.
- *
- * If a process is niced, then the nice directly
- * affects the new priority. The final priority
- * is in the range 0 to 255, to fit in a character.
- */
- pp->p_cpticks = 0;
-#ifdef MUSH
- a = ave((pp->p_cpu & 0377), avenrun[0]*nrscale) +
- pp->p_nice - NZERO + pp->p_quota->q_nice;
-#else
- a = ave((pp->p_cpu & 0377), avenrun[0]*nrscale) +
- pp->p_nice - NZERO;
-#endif
- if (a < 0)
- a = 0;
- if (a > 255)
- a = 255;
- pp->p_cpu = a;
- (void) setpri(pp);
- /*
- * Now have computed new process priority
- * in p->p_usrpri. Carefully change p->p_pri.
- * A process is on a run queue associated with
- * this priority, so we must block out process
- * state changes during the transition.
- */
- s = spl6();
- if (pp->p_pri >= PUSER) {
- if ((pp != u.u_procp || noproc) &&
- pp->p_stat == SRUN &&
- (pp->p_flag & SLOAD) &&
- pp->p_pri != pp->p_usrpri) {
- remrq(pp);
- pp->p_pri = pp->p_usrpri;
- setrq(pp);
- } else
- pp->p_pri = pp->p_usrpri;
- }