Compile fix for fslib (BITS_PER_BLOCK was renamed to FS_BITS_PER_BLOCK).
Added extra arg to various timer functions.
{
int nr_blocks;
- nr_blocks = (int) (nr_bits / BITS_PER_BLOCK(block_size));
- if (((bit_t) nr_blocks * BITS_PER_BLOCK(block_size)) < nr_bits) ++nr_blocks;
+ nr_blocks = (int) (nr_bits / FS_BITS_PER_BLOCK(block_size));
+ if (((bit_t) nr_blocks * FS_BITS_PER_BLOCK(block_size)) < nr_bits) ++nr_blocks;
return(nr_blocks);
}
readlink.c
*/
-#define readlink _readlink
-
#include <unistd.h>
#include <errno.h>
/*===========================================================================*
* tmrs_clrtimer *
*===========================================================================*/
-void tmrs_clrtimer(tmrs, tp)
+clock_t tmrs_clrtimer(tmrs, tp, new_head)
timer_t **tmrs; /* pointer to timers queue */
timer_t *tp; /* timer to be removed */
+clock_t *new_head;
{
/* Deactivate a timer and remove it from the timers queue.
*/
timer_t **atp;
struct proc *p;
+ clock_t old_head = 0;
+
+ if(*tmrs)
+ old_head = (*tmrs)->tmr_exp_time;
+ else
+ old_head = 0;
tp->tmr_exp_time = TMR_NEVER;
for (atp = tmrs; *atp != NULL; atp = &(*atp)->tmr_next) {
if (*atp == tp) {
*atp = tp->tmr_next;
- return;
+ break;
}
}
+
+ if(new_head) {
+ if(*tmrs)
+ *new_head = (*tmrs)->tmr_exp_time;
+ else
+ *new_head = 0;
+ }
+
+ return old_head;
}
/*===========================================================================*
* tmrs_exptimers *
*===========================================================================*/
-void tmrs_exptimers(tmrs, now)
+void tmrs_exptimers(tmrs, now, new_head)
timer_t **tmrs; /* pointer to timers queue */
clock_t now; /* current time */
+clock_t *new_head;
{
/* Use the current time to check the timers queue list for expired timers.
* Run the watchdog functions for all expired timers and deactivate them.
tp->tmr_exp_time = TMR_NEVER;
(*tp->tmr_func)(tp);
}
+
+ if(new_head) {
+ if(*tmrs)
+ *new_head = (*tmrs)->tmr_exp_time;
+ else
+ *new_head = 0;
+ }
}
/*===========================================================================*
* tmrs_settimer *
*===========================================================================*/
-void tmrs_settimer(tmrs, tp, exp_time, watchdog)
+clock_t tmrs_settimer(tmrs, tp, exp_time, watchdog, new_head)
timer_t **tmrs; /* pointer to timers queue */
timer_t *tp; /* the timer to be added */
clock_t exp_time; /* its expiration time */
tmr_func_t watchdog; /* watchdog function to be run */
+clock_t *new_head; /* new earliest timer, if non NULL */
{
/* Activate a timer to run function 'fp' at time 'exp_time'. If the timer is
* already in use it is first removed from the timers queue. Then, it is put
* The caller responsible for scheduling a new alarm for the timer if needed.
*/
timer_t **atp;
+ clock_t old_head = 0;
+
+ if(*tmrs)
+ old_head = (*tmrs)->tmr_exp_time;
/* Possibly remove an old timer. Then set the timer's variables. */
if (tp->tmr_exp_time != TMR_NEVER)
- (void) tmrs_clrtimer(tmrs,tp);
+ (void) tmrs_clrtimer(tmrs, tp, NULL);
tp->tmr_exp_time = exp_time;
tp->tmr_func = watchdog;
}
tp->tmr_next = *atp;
*atp = tp;
+ if(new_head)
+ (*new_head) = (*tmrs)->tmr_exp_time;
+ return old_head;
}