]> Zhao Yanbai Git Server - minix.git/commitdiff
Replaced flagalrm() timers with another technique to check for timeouts.
authorJorrit Herder <jnherder@minix3.org>
Tue, 31 May 2005 14:43:04 +0000 (14:43 +0000)
committerJorrit Herder <jnherder@minix3.org>
Tue, 31 May 2005 14:43:04 +0000 (14:43 +0000)
This allowed removing the p_flagarlm timer from the kernel's process table.
Furthermore, I merged p_syncalrm and p_signalrm into p_alarm_timer to save
even more space. Note that processes can no longer have both a signal and
synchronous alarm timer outstanding as of now.

15 files changed:
drivers/at_wini/at_wini.c
drivers/floppy/floppy.c
drivers/fxp/fxp.c
drivers/rtl8139/rtl8139.c
drivers/tty/console.c
include/minix/config.h
include/minix/type.h
include/minix/utils.h
kernel/const.h
kernel/proc.h
kernel/system.c
kernel/system/clock.c
kernel/type.h
lib/utils/Makefile
servers/fs/cmostime.c

index 86f36695283fcd88485b959d6f681a65fc43234f..efb054ca9a2cfb980b98e970271728335057c6ed 100644 (file)
@@ -8,7 +8,6 @@
  * Changes:
  *   Nov 18, 2004   moved AT disk driver to user-space  (Jorrit N. Herder)
  *   Aug 20, 2004   watchdogs replaced by sync alarms  (Jorrit N. Herder)
- *   May 02, 2004   sys_flagalrm() replaces micro_elapsed()  (Jorrit N. Herder)
  *   Mar 23, 2000   added ATAPI CDROM support  (Michael Temari)
  *   May 14, 2000   d-d/i rewrite  (Kees J. Bot)
  *   Apr 13, 1992   device dependent/independent split  (Kees J. Bot)
@@ -883,17 +882,18 @@ int value;                        /* required status */
  * ticks. Disabling the alarm is not needed, because a static flag is used
  * and a leftover timeout cannot do any harm.
  */
-  static int timeout_flag;     /* must be static, not cancelled */             
+  clock_t t0, t1;
   int s;
-  timeout_flag = 0;
-  sys_flagalrm(TIMEOUT_TICKS, &timeout_flag);
+  getuptime(&t0);
   do {
        if ((s=sys_inb(w_wn->base + REG_STATUS, &w_status)) != OK)
                server_panic(w_name(),"Couldn't read register",s);
        if ((w_status & mask) == value) {
                return 1;
        }
-  } while (! timeout_flag);
+  } while ((s=getuptime(&t1)) == OK && (t1-t0) < TIMEOUT_TICKS );
+  if (OK != s) printf("AT_WINI: warning, get_uptime failed: %d\n",s);
+
   w_need_reset();                      /* controller gone deaf */
   return(0);
 }
index 1719ff0aaeabba680da7bdb2eca13ca393f0012f..ce9b3f05b7b78273afdd3f3d75c5234f8411c76a 100644 (file)
@@ -8,7 +8,6 @@
  * Changes:
  *   Dec 01, 2004   floppy driver moved to user-space (Jorrit N. Herder)
  *   Sep 15, 2004   sync alarms/ local timer management  (Jorrit N. Herder)
- *   May 02, 2004   sys_flagalrm() replaces micro_elapsed()  (Jorrit N. Herder)
  *   Aug 12, 2003   null seek no interrupt fix  (Mike Haertel)
  *   May 14, 2000   d-d/i rewrite  (Kees J. Bot)
  *   Apr 04, 1992   device dependent/independent split  (Kees J. Bot)
@@ -689,7 +688,7 @@ PRIVATE void start_motor()
   f_set_timer(&f_tmr_timeout, f_dp->start, f_timeout);
   f_busy = BSY_IO;
   do {
-       receive(HARDWARE, &mess); 
+       receive(ANY, &mess); 
        if (mess.m_type == SYN_ALARM) { 
                f_expire_tmrs(NULL);
        } else {
@@ -771,10 +770,7 @@ PRIVATE int seek()
        f_set_timer(&f_tmr_timeout, HZ/30, f_timeout);
        f_busy = BSY_IO;
        do {
-               /* printf("Wait for message from HARDWARE 0\n"); */
-               receive(HARDWARE, &mess); 
-               /* printf("Floppy: got message, type %d (HARD_INT %d)\n",
-               mess.m_type, (mess.m_type == HARD_INT)); */
+               receive(ANY, &mess); 
                if (mess.m_type == SYN_ALARM) { 
                        f_expire_tmrs(NULL);
                } else {
@@ -872,15 +868,14 @@ PRIVATE int fdc_results()
  */
 
   int s, result_nr, status;
-  static int timeout;          /* must be static if not cancelled */
+  clock_t t0,t1;
 
   /* Extract bytes from FDC until it says it has no more.  The loop is
    * really an outer loop on result_nr and an inner loop on status. 
    * A timeout flag alarm is set.
    */
   result_nr = 0;
-  timeout = 0;
-  sys_flagalrm(TIMEOUT_TICKS, &timeout);       
+  getuptime(&t0);
   do {
        /* Reading one byte is almost a mirror of fdc_out() - the DIRECTION
         * bit must be set instead of clear, but the CTL_BUSY bit destroys
@@ -900,14 +895,10 @@ PRIVATE int fdc_results()
                if ((s=sys_irqenable(&irq_hook_id)) != OK)
                        server_panic("FLOPPY", "Couldn't enable IRQs", s);
 
-               /* Disabling the alarm is not needed, because a static flag
-                * is used and a leftover timeout cannot do any harm. It is
-                * done for correctness. This can safely be removed, though. 
-                */
-               sys_flagalrm(0, &timeout);      /* for correctness */   
                return(OK);                     /* only good exit */
        }
-  } while (! timeout);
+  } while ( (s=getuptime(&t1))==OK && (t1-t0) < TIMEOUT_TICKS );
+  if (OK!=s) printf("FLOPPY: warning, getuptime failed: %d\n", s); 
   need_reset = TRUE;           /* controller chip must be reset */
 
   if ((s=sys_irqenable(&irq_hook_id)) != OK)
@@ -952,19 +943,16 @@ int val;          /* write this byte to floppy disk controller */
  * can only write to it when it is listening, and it decides when to listen.
  * If the controller refuses to listen, the FDC chip is given a hard reset.
  */
-
-  static int timeout;          /* must be static if not cancelled */ 
+  clock_t t0, t1;
   int s, status;
 
   if (need_reset) return;      /* if controller is not listening, return */
 
-  /* It may take several tries to get the FDC to accept a command. 
-   * A timeout flag alarm is set. 
-   */
-  timeout = 0;
-  sys_flagalrm(TIMEOUT_TICKS, &timeout);       
+  /* It may take several tries to get the FDC to accept a command.  */
+  getuptime(&t0);
   do {
-       if (timeout) {                  /* controller is not listening */
+       if ( (s=getuptime(&t1))==OK && (t1-t0) > TIMEOUT_TICKS ) {
+               if (OK!=s) printf("FLOPPY: warning, getuptime failed: %d\n", s); 
                need_reset = TRUE;      /* hit it over the head */
                return;
        }
@@ -973,11 +961,6 @@ int val;           /* write this byte to floppy disk controller */
   }
   while ((status & (MASTER | DIRECTION)) != (MASTER | 0)); 
   
-  /* Disabling the alarm is not needed, because a static flag is used and a
-   * leftover timeout cannot do any harm. It is done for correctness. This
-   * can safely be removed, though. 
-   */
-  sys_flagalrm(0, &timeout);   /* for correctness */   
   if ((s=sys_outb(FDC_DATA, val)) != OK)
        server_panic("FLOPPY","Sys_outb in fdc_out() failed", s);
 }
@@ -1062,7 +1045,7 @@ PRIVATE void f_reset()
    * SYN_ALARM message on a timeout.
    */
   do {
-       receive(HARDWARE, &mess); 
+       receive(ANY, &mess); 
        if (mess.m_type == SYN_ALARM) { 
                f_expire_tmrs(NULL);
        } else {                        /* expect HARD_INT */
@@ -1108,10 +1091,7 @@ PRIVATE int f_intr_wait()
    * occurs, report an error.
    */
   do {
-       /* printf("Wait for message from HARDWARE 2\n"); */
-       receive(HARDWARE, &mess); 
-       /* printf("Floppy: got message, type %d (HARD_INT %d) ",
-               mess.m_type, (mess.m_type == HARD_INT)); */
+       receive(ANY, &mess); 
        if (mess.m_type == SYN_ALARM) {
                f_expire_tmrs(NULL);
        } else { 
index e3748d56d2ba93f53cb3c9164edc50a425c714ea..296c1f5927b12c16089a89ac19b31a454c7e3e7d 100644 (file)
@@ -904,8 +904,7 @@ fxp_t *fp;
 {
        static char eakey[]= FXP_ENVVAR "#_EA";
        static char eafmt[]= "x:x:x:x:x:x";
-       static int timeout_flag;        /* must be static */
-
+       clock_t t0,t1;
        int i, r;
        port_t port;
        u32_t bus_addr;
@@ -959,13 +958,12 @@ fxp_t *fp;
 
        fxp_cu_ptr_cmd(fp, SC_CU_START, bus_addr, TRUE /* check idle */);
 
-       timeout_flag= 0;
-       sys_flagalrm(MICROS_TO_TICKS(1000), &timeout_flag);
+       getuptime(&t0);
        do {
                /* Wait for CU command to complete */
                if (ias.ias_status & CBL_F_C)
                        break;
-       } while (!timeout_flag);
+       } while (getuptime(&t1)==OK && (t1-t0) < MICROS_TO_TICKS(1000));
 
        if (!(ias.ias_status & CBL_F_C))
                panic("fxp_confaddr: CU command failed to complete", NO_NUM);
@@ -1361,11 +1359,10 @@ suspend:
 static void fxp_do_conf(fp)
 fxp_t *fp;
 {
-       static int timeout_flag;        /* must be static */
-
        int r;
        u32_t bus_addr;
        struct cbl_conf cc;
+       clock_t t0,t1;
 
        /* Configure device */
        cc.cc_status= 0;
@@ -1380,13 +1377,12 @@ fxp_t *fp;
 
        fxp_cu_ptr_cmd(fp, SC_CU_START, bus_addr, TRUE /* check idle */);
 
-       timeout_flag= 0;
-       sys_flagalrm(MICROS_TO_TICKS(100000), &timeout_flag);
+       getuptime(&t0);
        do {
                /* Wait for CU command to complete */
                if (cc.cc_status & CBL_F_C)
                        break;
-       } while (!timeout_flag);
+       } while (getuptime(&t1)==OK && (t1-t0) < MICROS_TO_TICKS(100000));
 
        if (!(cc.cc_status & CBL_F_C))
                panic("fxp_do_conf: CU command failed to complete", NO_NUM);
@@ -1405,8 +1401,7 @@ int cmd;
 phys_bytes bus_addr;
 int check_idle;
 {
-       static int timeout_flag;        /* must be static */
-
+       clock_t t0,t1;
        port_t port;
        u8_t scb_cmd;
 
@@ -1425,14 +1420,13 @@ int check_idle;
        /* What is a reasonable time-out? There is nothing in the
         * documentation. 1 ms should be enough.
         */
-       timeout_flag= 0;
-       sys_flagalrm(MICROS_TO_TICKS(1000), &timeout_flag);
+       getuptime(&t0);
        do {
                /* Wait for CU command to be accepted */
                scb_cmd= fxp_inb(port, SCB_CMD);
                if ((scb_cmd & SC_CUC_MASK) == SC_CU_NOP)
                        break;
-       } while (!timeout_flag);
+       } while (getuptime(&t1)==OK && (t1-t0) < MICROS_TO_TICKS(1000));
 
        if ((scb_cmd & SC_CUC_MASK) != SC_CU_NOP)
                panic("fxp_cu_ptr_cmd: CU does not accept command", NO_NUM);
@@ -1448,8 +1442,7 @@ int cmd;
 phys_bytes bus_addr;
 int check_idle;
 {
-       static int timeout_flag;        /* must be static */
-
+       clock_t t0,t1;
        port_t port;
        u8_t scb_cmd;
 
@@ -1465,14 +1458,13 @@ int check_idle;
        fxp_outl(port, SCB_POINTER, bus_addr);
        fxp_outb(port, SCB_CMD, cmd);
 
-       timeout_flag= 0;
-       sys_flagalrm(MICROS_TO_TICKS(1000), &timeout_flag);
+       getuptime(&t0);
        do {
                /* Wait for RU command to be accepted */
                scb_cmd= fxp_inb(port, SCB_CMD);
                if ((scb_cmd & SC_RUC_MASK) == SC_RU_NOP)
                        break;
-       } while (!timeout_flag);
+       } while (getuptime(&t1)==OK && (t1-t0) < MICROS_TO_TICKS(1000));
 
        if ((scb_cmd & SC_RUC_MASK) != SC_RU_NOP)
                panic("fxp_ru_ptr_cmd: RU does not accept command", NO_NUM);
@@ -1519,8 +1511,7 @@ fxp_t *fp;
 static void fxp_getstat(mp)
 message *mp;
 {
-       static int timeout_flag;        /* Must be static */
-
+       clock_t t0,t1;
        int dl_port;
        port_t port;
        fxp_t *fp;
@@ -1546,13 +1537,12 @@ message *mp;
         */
        fxp_cu_ptr_cmd(fp, SC_CU_DUMP_SC, 0, FALSE /* do not check idle */);
 
-       timeout_flag= 0;
-       sys_flagalrm(MICROS_TO_TICKS(1000), &timeout_flag);
+       getuptime(&t0);
        do {
                /* Wait for CU command to complete */
                if (*p != 0)
                        break;
-       } while (!timeout_flag);
+       } while (getuptime(&t1)==OK && (t1-t0) < MICROS_TO_TICKS(1000));
 
        if (*p == 0)
                panic("fxp_getstat: CU command failed to complete", NO_NUM);
@@ -2331,8 +2321,7 @@ PRIVATE u16_t mii_read(fp, reg)
 fxp_t *fp;
 int reg;
 {
-       static int timeout_flag;        /* must be static */
-
+       clock_t t0,t1;
        port_t port;
        u32_t v;
 
@@ -2346,13 +2335,12 @@ int reg;
        fxp_outl(port, CSR_MDI_CTL, CM_READ | (1 << CM_PHYADDR_SHIFT) |
                (reg << CM_REG_SHIFT));
 
-       timeout_flag= 0;
-       sys_flagalrm(MICROS_TO_TICKS(1000), &timeout_flag);
+       getuptime(&t0);
        do {
                v= fxp_inl(port, CSR_MDI_CTL);
                if (v & CM_READY)
                        break;
-       } while (!timeout_flag);
+       } while (getuptime(&t1)==OK && (t1-t0) < MICROS_TO_TICKS(1000));
 
        if (!(v & CM_READY))
                panic("mii_read: MDI not ready after command", NO_NUM);
index 75ad303d105e0420b1a2bf16812694328ccff2ec..e938ec5db157b73d402c47fcb8d36bbcba6ee2d4 100755 (executable)
@@ -836,33 +836,29 @@ re_t *rep;
        u32_t t;
        phys_bytes bus_buf;
        int i;
-       static int timeout;             /* must be static if not cancelled */
+       clock_t t0,t1;
 
        port= rep->re_base_port;
 
 #if 0
        /* Reset the PHY */
        rl_outb(port, RL_BMCR, MII_CTRL_RST);
-       timeout=0;
-       sys_flagalrm(HZ, &timeout);     
+       getuptime(&t0);
        do {
                if (!(rl_inb(port, RL_BMCR) & MII_CTRL_RST))
                        break;
-       } while (! timeout);
-       sys_flagalrm(0, &timeout);      /* for correctness */   
+       } while (getuptime(&t1)==OK && (t1-t0) < HZ);
        if (rl_inb(port, RL_BMCR) & MII_CTRL_RST)
                server_panic("rtl8139","reset PHY failed to complete", NO_NUM);
 #endif
 
        /* Reset the device */
        rl_outb(port, RL_CR, RL_CR_RST);
-       timeout=0;
-       sys_flagalrm(HZ, &timeout);     
+       getuptime(&t0);
        do {
                if (!(rl_inb(port, RL_CR) & RL_CR_RST))
                        break;
-       } while (! timeout);
-       sys_flagalrm(0, &timeout);      /* for correctness */   
+       } while (getuptime(&t1)==OK && (t1-t0) < HZ);
        if (rl_inb(port, RL_CR) & RL_CR_RST)
                server_panic("rtl8139","reset failed to complete", NO_NUM);
 
@@ -1789,7 +1785,7 @@ re_t *rep;
        port_t port;
        u8_t cr;
        int i;
-       static int timeout;             /* must be static if not cancelled */   
+       clock_t t0,t1;
 
        rep->re_clear_rx= FALSE;
        port= rep->re_base_port;
@@ -1798,13 +1794,11 @@ re_t *rep;
        cr= rl_inb(port, RL_CR);
        cr &= ~RL_CR_RE;
        rl_outb(port, RL_CR, cr);
-       timeout=0;
-       sys_flagalrm(HZ, &timeout);     
+       getuptime(&t0);
        do {
                if (!(rl_inb(port, RL_CR) & RL_CR_RE))
                        break;
-       } while (! timeout);
-       sys_flagalrm(0, &timeout);      /* for correctness */   
+       } while (getuptime(&t1)==OK && (t1-t0) < HZ);
        if (rl_inb(port, RL_CR) & RL_CR_RE)
                server_panic("rtl8139","cannot disable receiver", NO_NUM);
 
@@ -2063,8 +2057,7 @@ re_t *rep;
 #if 0
        u8_t cr;
 #endif
-       static int timeout;             /* must be static if not cancelled */   
-
+       clock_t t0,t1;
        int_event_check = FALSE;        /* disable check by default */
 
        RAND_UPDATE
@@ -2160,13 +2153,11 @@ re_t *rep;
                        cr= rl_inb(port, RL_CR);
                        cr &= ~RL_CR_TE;
                        rl_outb(port, RL_CR, cr);
-                       timeout=0;
-                       sys_flagalrm(HZ, &timeout);     
+                       getuptime(&t0);
                        do {
                                if (!(rl_inb(port, RL_CR) & RL_CR_TE))
                                        break;
-                       } while (! timeout);
-                       sys_flagalrm(0, &timeout);      /* for correctness */   
+                       } while (getuptime(&t1)==OK && (t1-t0) < HZ);
                        if (rl_inb(port, RL_CR) & RL_CR_TE)
                        {
                          server_panic("rtl8139","cannot disable transmitter",
@@ -2575,7 +2566,7 @@ int a;
 u16_t w;
 {
        int b, i, cmd;
-       static int timeout;             /* must be static if not cancelled */   
+       clock_t t0, t1;
 
        outb_reg3(dep, 1, 0x80 | 0x8);          /* Set CS */
 
@@ -2602,13 +2593,11 @@ u16_t w;
        outb_reg3(dep, 1, 0x80);        /* Drop CS */
        /* micro_delay(1); */                   /* Is this required? */
        outb_reg3(dep, 1, 0x80 | 0x8);          /* Set CS */
-       timeout = 0;
-       sys_flagalrm(1, &timeout);
+       getuptime(&t0);
        do {
                if (inb_reg3(dep, 1) & 1)
                        break;
-       } while (! timeout);
-       sys_flagalrm(0, &timeout);      /* for correctness */
+       } while (getuptime(&t1) == OK && (t1 == t0));
        if (!(inb_reg3(dep, 1) & 1))
                server_panic("set_ee_word","device remains busy", NO_NUM);
 }
index 7cb74157db68e8cbcc3f6c37b2323d63cedfc839..d38a22deb2c4f7574112b05e598cb10fdb41663d 100644 (file)
@@ -22,6 +22,9 @@
 #include <minix/com.h>
 #include "tty.h"
 
+#include "../../kernel/const.h"
+#include "../../kernel/type.h"
+
 /* Definitions used by the console driver. */
 #define MONO_BASE    0xB0000L  /* base of mono video memory */
 #define COLOR_BASE   0xB8000L  /* base of color video memory */
index 90d5b21c74937841c83b73b16a88fb9a2b574de1..6d8ccb4f3708d9ab69bf485811a0b5f241053c1b 100755 (executable)
 #define NR_BUF_HASH     512    /* size of buf hash table; MUST BE POWER OF 2*/
 #endif
 
-/* Defines for kernel configuration. */
+/* Defines for driver and kernel configuration. */
 #define AUTO_BIOS          0   /* xt_wini.c - use Western's autoconfig BIOS */
 #define LINEWRAP           1   /* console.c - wrap lines at column 80 */
 #define ALLOW_GAP_MESSAGES 1   /* proc.c - allow messages in the gap between
                                 * the end of bss and lowest stack address */
-#define KMESS_BUF_SIZE   512           /* size in bytes for kernel messages */
 
 /* Number of controller tasks (/dev/cN device classes). */
 #define NR_CTRLRS          2
index ecde3aa746b30993f33d54b29b8eafab37207206..1869c3011d1189461df08460f8168d0e385dd517 100755 (executable)
@@ -119,14 +119,4 @@ struct machine {
   int vdu_vga;
 };
 
-/* The kernel outputs messages in a local buffer, which can be requested and
- * printed by the TTY driver. The buffer structure is defined here. 
- */
-struct kmessages {
-  int km_next;                         /* next index to write */
-  int km_size;                         /* current size in buffer */
-  char km_buf[KMESS_BUF_SIZE];         /* buffer for messages */
-};
-
-
 #endif /* _TYPE_H */
index 1cfe1e35d8a957be06defd16e618876b456ca16f..7e7d9dacbb2857ecbf734556d6f4ad0b0f82c125 100644 (file)
@@ -43,9 +43,9 @@ _PROTOTYPE(int fkey_ctl, (int fkey_code, int enable_disable)          );
 _PROTOTYPE(void server_report, (char *who, char *mess, int num)                );
 _PROTOTYPE(void server_panic, (char *who, char *mess, int num)         );
 
-#define get_own_proc_nr(where) get_proc_nr((where), NULL)
 _PROTOTYPE(int get_proc_nr, (int *proc_nr, char *proc_name) );
 
+_PROTOTYPE(int getuptime, (clock_t *ticks));
 _PROTOTYPE(int tick_delay, (clock_t ticks));
 
 #endif /* _EXTRALIB_H */
index 65ebf77f4772bbb0de51411efb948301af2540b7..ae89e4f14d14669a9d795aa28d844d16bfca40c6 100755 (executable)
@@ -4,8 +4,6 @@
 #include <ibm/ports.h>         /* port addresses and magic numbers */
 #include <ibm/bios.h>          /* BIOS addresses, sizes and magic numbers */
 
-#if (CHIP == INTEL)
-
 /* To translate an address in kernel space to a physical address.  This is
  * the same as umap_local(proc_ptr, D, vir, sizeof(*vir)), but less costly.
  */
@@ -27,6 +25,9 @@
 /* How long should the process names be in the kernel? */
 #define P_NAME_LEN     8
 
+/* How many bytes should the circular buffer for kernel diagnostics. */
+#define KMESS_BUF_SIZE   256           
+
 /* How many bytes for (port,value)-pairs vector to copy in. */
 #define VDEVIO_BUF_SIZE  128
 
@@ -48,6 +49,9 @@
 #define SET_BIT(map,bit) ( MAP_CHUNK(map,bit) |= (1 << CHUNK_OFFSET(bit) )
 #define UNSET_BIT(map,bit) ( MAP_CHUNK(map,bit) &= ~(1 << CHUNK_OFFSET(bit) )
 
+
+#if (CHIP == INTEL)
+
 /* Program stack words and masks. */
 #define INIT_PSW      0x0200   /* initial psw */
 #define INIT_TASK_PSW 0x1200   /* initial psw for tasks (with IOPL 1) */
@@ -67,7 +71,6 @@
  */
 #define NR_MEMS            8   /* number of chunks of memory */
 
-
 #endif /* (CHIP == INTEL) */
 
 #if (CHIP == M68000)
index 567e690913e7dcca0d06557d609e84457eb49eb2..570d8deccaeeb58ce629429dcc584d07efa1ba2f 100755 (executable)
@@ -45,19 +45,16 @@ struct proc {
   clock_t p_user_time;         /* user time in ticks */
   clock_t p_sys_time;          /* sys time in ticks */
 
-  timer_t p_signalrm;          /* signal alarm timer */ 
-  timer_t p_flagalrm;          /* flag alarm timer */ 
-  timer_t p_syncalrm;          /* synchronous alarm timer */ 
-
   struct proc *p_nextready;    /* pointer to next ready process */
   struct notification *p_ntf_q;        /* queue of pending notifications */
   struct proc *p_caller_q;     /* head of list of procs wishing to send */
   struct proc *p_q_link;       /* link to next proc wishing to send */
-  message *p_messbuf;          /* pointer to message buffer */
+  message *p_messbuf;          /* pointer to passed message buffer */
   proc_nr_t p_getfrom;         /* from whom does process want to receive? */
   proc_nr_t p_sendto;          /* to whom does process want to send? */
 
-  sigset_t p_pending;          /* bit map for pending signals */
+  timer_t p_alarm_timer;       /* timer shared by different alarm types */ 
+  sigset_t p_pending;          /* bit map for pending kernel signals */
   unsigned p_pendcount;                /* count of pending and unfinished signals */
 
   char p_name[P_NAME_LEN];     /* name of the process, including \0 */
index d736f2c23f70ccd9928fdde907827c958b734fa3..a60bf4e0f94903a9eeccd130c2132429cece3e05 100755 (executable)
@@ -114,9 +114,7 @@ PRIVATE void initialize(void)
 
   /* Initialize all alarm timers for all processes. */
   for (rp=BEG_PROC_ADDR; rp < END_PROC_ADDR; rp++) {
-    tmr_inittimer(&(rp->p_signalrm));
-    tmr_inittimer(&(rp->p_syncalrm));
-    tmr_inittimer(&(rp->p_flagalrm));
+    tmr_inittimer(&(rp->p_alarm_timer));
   }
 
   /* Initialize the call vector to a safe default handler. Some system calls 
@@ -146,7 +144,6 @@ PRIVATE void initialize(void)
   map(SYS_TIMES, do_times);            /* get uptime and process times */
   map(SYS_SIGNALRM, do_signalrm);      /* causes an alarm signal */
   map(SYS_SYNCALRM, do_syncalrm);      /* send a notification message */
-  map(SYS_FLAGALRM, do_flagalrm);      /* set a timeout flag to 1 */
 
   /* Device I/O. */
   map(SYS_IRQCTL, do_irqctl);                  /* interrupt control operations */ 
@@ -192,9 +189,7 @@ int proc_nr;                                /* slot of process to clean up */
   rc = proc_addr(proc_nr);
 
   /* Turn off any alarm timers at the clock. */   
-  reset_timer(&rc->p_signalrm);
-  reset_timer(&rc->p_flagalrm);
-  reset_timer(&rc->p_syncalrm);
+  reset_timer(&rc->p_alarm_timer);
 
   /* Make sure the exiting process is no longer scheduled. */
   if (rc->p_flags == 0) lock_unready(rc);
index 7e31d0d3f67792fb88a81b55161c0015a1bcf7e8..d096229ab516d2088575d773974f1f1d9cfccd5e 100644 (file)
@@ -39,22 +39,19 @@ register message *m_ptr;    /* pointer to request message */
 
 
 /* The system call implemented in this file:
- *   m_type:   SYS_SIGNALRM, SYS_SYNCALRM, SYS_FLAGALRM
+ *   m_type:   SYS_SIGNALRM, SYS_SYNCALRM 
  *
  * The parameters for this system call are:
  *    m2_i1:   ALRM_PROC_NR            (set alarm for this process)    
  *    m2_l1:   ALRM_EXP_TIME           (alarm's expiration time)
  *    m2_i2:   ALRM_ABS_TIME           (expiration time is absolute?)
  *    m2_l1:   ALRM_SEC_LEFT           (return seconds left of previous)
- *    m2_p1:   ALRM_FLAG_PTR           (virtual addr of alarm flag)    
  *
  * Changes:
- *    Aug 25, 2004   fully rewritten to unite all alarms  (Jorrit N. Herder)  
- *    May 02, 2004   added new timeout flag alarm  (Jorrit N. Herder)
+ *    Aug 25, 2004   fully rewritten to clean up code  (Jorrit N. Herder)  
  */
 
 FORWARD _PROTOTYPE( void cause_syncalrm, (timer_t *tp) );
-FORWARD _PROTOTYPE( void cause_flagalrm, (timer_t *tp) );
 FORWARD _PROTOTYPE( void cause_signalrm, (timer_t *tp) );
 
 /*===========================================================================*
@@ -64,7 +61,7 @@ PUBLIC int do_setalarm(m_ptr)
 message *m_ptr;                        /* pointer to request message */
 {
 /* A process requests an alarm, or wants to cancel its alarm. This function
- * is shared used for all of SYS_SIGNALRM, SYS_SYNCALRM, and SYS_FLAGALRM.
+ * is shared used for both the SYS_SIGNALRM and SYS_SYNCALRM.
  */
   int proc_nr;                 /* which process wants the alarm */
   long exp_time;               /* expiration time for this alarm */
@@ -80,26 +77,12 @@ message *m_ptr;                     /* pointer to request message */
   use_abs_time = m_ptr->ALRM_ABS_TIME; /* flag for absolute time */
 
   /* Get the timer structure and set the parameters for this alarm. */
+  tp = &(proc_addr(proc_nr)->p_alarm_timer);   
+  tmr_arg(tp)->ta_int = proc_nr;       
   switch (m_ptr->m_type) {
-    case SYS_SYNCALRM:                 /* notify with SYN_ALARM message */
-       tp = &(proc_addr(proc_nr)->p_syncalrm); 
-       tmr_arg(tp)->ta_int = proc_nr;  
-        tp->tmr_func = cause_syncalrm;
-        break;
-    case SYS_SIGNALRM:                 /* send process a SIGALRM signal */
-       tp = &(proc_addr(proc_nr)->p_signalrm); 
-       tmr_arg(tp)->ta_int = proc_nr;
-        tp->tmr_func = cause_signalrm;
-        break;
-    case SYS_FLAGALRM:                 /* set caller's timeout flag to 1 */    
-       tp = &(proc_addr(proc_nr)->p_flagalrm); 
-        tmr_arg(tp)->ta_long =                 
-            numap_local(proc_nr,(vir_bytes) m_ptr->ALRM_FLAG_PTR,sizeof(int));
-        if (! tmr_arg(tp)->ta_long) return(EFAULT);
-       tp->tmr_func = cause_flagalrm;  
-        break;
-    default:                           /* invalid alarm type */
-        return(EINVAL);
+  case SYS_SYNCALRM:   tp->tmr_func = cause_syncalrm;          break;
+  case SYS_SIGNALRM:   tp->tmr_func = cause_signalrm;          break;
+  default:             return(EINVAL);         /* invalid alarm type */
   }
 
   /* Return the ticks left on the previous alarm. */
@@ -134,21 +117,6 @@ timer_t *tp;
   cause_sig(tmr_arg(tp)->ta_int, SIGALRM);
 }
 
-/*===========================================================================*
- *                             cause_flagalrm                               *
- *===========================================================================*/
-PRIVATE void cause_flagalrm(tp)
-timer_t *tp;
-{
-/* Routine called if a timer goes off for a process that requested a timeout 
- * flag to be set when the alarm expires. The timer argument 'ta_long' gives
- * the physical address of the timeout flag. No validity check was done when 
- * setting the alarm, so check for 0 here. 
- */
-  int timeout = 1;
-  phys_bytes timeout_flag = (phys_bytes) tmr_arg(tp)->ta_long;
-  phys_copy(vir2phys(&timeout), tmr_arg(tp)->ta_long, sizeof(int));
-}
 
 /*===========================================================================*
  *                             cause_syncalrm                               *
index 5fe929287740efad6b5487f92748268548191bf9..42832bc0567a432b486ccb80bc353b6b7d131b1a 100755 (executable)
@@ -45,6 +45,14 @@ struct notification {
   struct notification* n_next;         /* pointer to next notification */
 };
 
+/* The kernel outputs diagnostic messages in a circular buffer. */
+struct kmessages {
+  int km_next;                         /* next index to write */
+  int km_size;                         /* current size in buffer */
+  char km_buf[KMESS_BUF_SIZE];         /* buffer for messages */
+};
+
+
 #if (CHIP == INTEL)
 typedef unsigned reg_t;                /* machine register */
 
index ff9dfeef4f5076530bea1a2665e42020c5e3e681..c829e27cd7014b09c09119c47828fbf820300ca1 100644 (file)
@@ -8,6 +8,7 @@ all:    $(LIBUTILS)
 
 OBJECTS        = \
        $(LIBUTILS)(tick_delay.o) \
+       $(LIBUTILS)(get_upt.o) \
        $(LIBUTILS)(get_mon_prm.o) \
        $(LIBUTILS)(env_parse.o) \
        $(LIBUTILS)(env_panic.o) \
@@ -24,6 +25,9 @@ $(LIBUTILS):  $(OBJECTS)
        aal cr $@ *.o
        rm *.o
 
+$(LIBUTILS)(get_upt.o):        get_upt.c
+       $(CC1) get_upt.c
+
 $(LIBUTILS)(tick_delay.o):     tick_delay.c
        $(CC1) tick_delay.c
 
index 514c42d439ce3016bc1bf77969815d2467de21d8..cce3cb587194e2eb0e87c1d8575d0457afe0746d 100644 (file)
@@ -1,6 +1,7 @@
 #include "fs.h"
 #include <minix/com.h>
 #include <minix/callnr.h>
+#include <minix/utils.h>
 #include <time.h>
 #include <ibm/cmos.h>
 #include <ibm/bios.h>
@@ -75,16 +76,16 @@ PRIVATE int get_cmostime(struct tm *t, int y2kflag)
  */
   int osec, n;
   unsigned long i;
-  static int timeout_flag;
+  clock_t t0,t1;
 
   /* Start a timer to keep us from getting stuck on a dead clock. */
-  timeout_flag = 0;
-  sys_flagalrm(5*HZ, &timeout_flag);
+  getuptime(&t0);
   do {
        osec = -1;
        n = 0;
        do {
-               if (timeout_flag) {
+               getuptime(&t1); 
+               if (t1-t0 > 5*HZ) {
                        printf("readclock: CMOS clock appears dead\n");
                        return(1);
                }
@@ -117,7 +118,6 @@ PRIVATE int get_cmostime(struct tm *t, int y2kflag)
        || read_register(RTC_MDAY) != t->tm_mday
        || read_register(RTC_MONTH) != t->tm_mon
        || read_register(RTC_YEAR) != t->tm_year);
-  sys_flagalrm(0, &timeout_flag); /* not strictly necessarily; flag is static */
 
   if ((read_register(RTC_REG_B) & RTC_B_DM_BCD) == 0) {
        /* Convert BCD to binary (default RTC mode). */