Annotation of coherent/b/kernel/coh.386/clocked.c, revision 1.1

1.1     ! root        1: /*
        !             2:  * clocked.c - support routines for alternate clock rate
        !             3:  *
        !             4:  *  altclk_in(hz, fn) - install routine with specified rate
        !             5:  *                      "hz" should be a multiple of system rate of 100 Hz
        !             6:  *                     return 0 if completed ok, -1 otherwise
        !             7:  *
        !             8:  *  altclk_out()      - uninstall alternate clock routine and restore system rate
        !             9:  *                     return old value of "altclk"
        !            10:  *
        !            11:  *  altclk_rate(hz)   - set clock interrupt rate
        !            12:  *                     new rate must be an even multiple of system rate "HZ"
        !            13:  *                     return 0 if completed ok, -1 otherwise
        !            14:  *
        !            15:  *  History:
        !            16:  *    90/08/08 hws     initial version, works with hs.c modified for com[1-4]
        !            17:  *    90/08/14 hws     make it more like a Unix system call
        !            18:  */
        !            19: 
        !            20: #include       <sys/coherent.h>                /* altclk */
        !            21: 
        !            22: #ifdef _I386
        !            23: #include       <sys/param.h>           /* HZ */
        !            24: #else
        !            25: #include       <sys/const.h>           /* HZ */
        !            26: #endif
        !            27: 
        !            28: #define        PIT     0x40            /* 8253 port */
        !            29: #define        TMR0_M3 0x36            /* timer 0, mode 3 */
        !            30: #define        SYS_HZ  1193200L        /* rate of input clock to timer 0 */
        !            31: 
        !            32: typedef int (*PFI)();          /* pointer to function returning int */
        !            33: 
        !            34: altclk_rate(hz)
        !            35: unsigned int hz;
        !            36: {
        !            37:        int s;                  /* to save CPU irpt flag */
        !            38:        unsigned int interval;  /* period for hz, in units of 1.19 MHz ticks */
        !            39:        int ret;
        !            40: 
        !            41:        if (hz >= HZ && hz % HZ == 0) {         /* can't go slower than HZ! */
        !            42:                interval = SYS_HZ/hz;
        !            43:                s = sphi();                     /* disable irpts */
        !            44:                outb(PIT+3, TMR0_M3);
        !            45:                outb(PIT, interval & 0xff);
        !            46:                outb(PIT, interval >> 8);       /* unsigned shift */
        !            47:                spl(s);                         /* restore previous irpt state */
        !            48:                ret = 0;
        !            49:        } else {
        !            50:                ret = -1;
        !            51:        }
        !            52:        return ret;
        !            53: }
        !            54: 
        !            55: int altclk_in(hz, fn)
        !            56: int hz;
        !            57: PFI fn;
        !            58: {
        !            59:        int ret;
        !            60: 
        !            61:        if ((ret = altclk_rate(hz)) == 0)
        !            62:                altclk = fn;
        !            63:        return ret;
        !            64: }
        !            65: 
        !            66: PFI altclk_out()
        !            67: {
        !            68:        PFI ret;
        !            69: 
        !            70:        ret = altclk;
        !            71:        if (ret) {
        !            72:                altclk_rate(HZ);
        !            73:                altclk = 0;
        !            74:        }
        !            75:        return ret;
        !            76: }

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.