 9fab85c2de
			
		
	
	
		9fab85c2de
		
	
	
	
	
		
			
			* Renamed struct timer to struct minix_timer * Renamed timer_t to minix_timer_t * Ensured all the code uses the minix_timer_t typedef * Removed ifdef around _BSD_TIMER_T * Removed include/timers.h and merged it into include/minix/timers.h * Resolved prototype conflict by renaming kernel's (re)set_timer to (re)set_kernel_timer. Change-Id: I56f0f30dfed96e1a0575d92492294cf9a06468a5
		
			
				
	
	
		
			90 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			90 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* Watchdog timer management. These functions in this file provide a
 | |
|  * convenient interface to the timers library that manages a list of
 | |
|  * watchdog timers. All details of scheduling an alarm at the CLOCK task
 | |
|  * are hidden behind this interface.
 | |
|  *
 | |
|  * The entry points into this file are:
 | |
|  *   init_timer:     initialize a timer structure
 | |
|  *   set_timer:      reset and existing or set a new watchdog timer
 | |
|  *   cancel_timer:   remove a timer from the list of timers
 | |
|  *   expire_timers:  check for expired timers and run watchdog functions
 | |
|  *
 | |
|  */
 | |
| 
 | |
| #include "syslib.h"
 | |
| #include <minix/timers.h>
 | |
| #include <minix/sysutil.h>
 | |
| 
 | |
| static minix_timer_t *timers = NULL;
 | |
| static int expiring = 0;
 | |
| 
 | |
| /*===========================================================================*
 | |
|  *                              init_timer                                   *
 | |
|  *===========================================================================*/
 | |
| void init_timer(minix_timer_t *tp)
 | |
| {
 | |
|         tmr_inittimer(tp);
 | |
| }
 | |
| 
 | |
| /*===========================================================================*
 | |
|  *                              set_timer                                    *
 | |
|  *===========================================================================*/
 | |
| void set_timer(minix_timer_t *tp, int ticks, tmr_func_t watchdog, int arg)
 | |
| {
 | |
|         int r;
 | |
|         clock_t now, prev_time = 0, next_time;
 | |
| 
 | |
|         if ((r = getticks(&now)) != OK)
 | |
|                 panic("set_timer: couldn't get uptime");
 | |
| 
 | |
|         /* Set timer argument and add timer to the list. */
 | |
|         tmr_arg(tp)->ta_int = arg;
 | |
|         prev_time = tmrs_settimer(&timers, tp, now+ticks, watchdog, &next_time);
 | |
| 
 | |
|         /* Reschedule our synchronous alarm if necessary. */
 | |
|         if (expiring == 0 && (! prev_time || prev_time > next_time)) {
 | |
|                 if (sys_setalarm(next_time, 1) != OK)
 | |
|                         panic("set_timer: couldn't set alarm");
 | |
|         }
 | |
| }
 | |
| 
 | |
| /*===========================================================================*
 | |
|  *                              cancel_timer                                 *
 | |
|  *===========================================================================*/
 | |
| void cancel_timer(minix_timer_t *tp)
 | |
| {
 | |
|         clock_t next_time, prev_time;
 | |
|         prev_time = tmrs_clrtimer(&timers, tp, &next_time);
 | |
| 
 | |
|         /* If the earliest timer has been removed, we have to set the alarm to
 | |
|          * the next timer, or cancel the alarm altogether if the last timer
 | |
|          * has been cancelled (next_time will be 0 then).
 | |
|          */
 | |
|         if (expiring == 0 && (prev_time < next_time || ! next_time)) {
 | |
|                 if (sys_setalarm(next_time, 1) != OK)
 | |
|                         panic("cancel_timer: couldn't set alarm");
 | |
|         }
 | |
| }
 | |
| 
 | |
| /*===========================================================================*
 | |
|  *                              expire_timers                                *
 | |
|  *===========================================================================*/
 | |
| void expire_timers(clock_t now)
 | |
| {
 | |
|         clock_t next_time;
 | |
| 
 | |
|         /* Check for expired timers. Use a global variable to indicate that
 | |
|          * watchdog functions are called, so that sys_setalarm() isn't called
 | |
|          * more often than necessary when set_timer or cancel_timer are called
 | |
|          * from these watchdog functions. */
 | |
|         expiring = 1;
 | |
|         tmrs_exptimers(&timers, now, &next_time);
 | |
|         expiring = 0;
 | |
| 
 | |
|         /* Reschedule an alarm if necessary. */
 | |
|         if (next_time > 0) {
 | |
|                 if (sys_setalarm(next_time, 1) != OK)
 | |
|                         panic("expire_timers: couldn't set alarm");
 | |
|         }
 | |
| }
 |