标签:30天自制操作系统 operating system 定时器 中断处理程序
定时器的中断处理程序要保证高效率,需要进行一些优化,这里介绍优化的方法。对于一个操作系统来说,会有多个定时器,假设该操作系统维护了500个定时器,当每一次定时中断发生时(这里我们设定1秒发生100次中断),调用中断处理程序,中断处理程序会对这500个定时器进行if判断,看哪些正在被使用,这样1秒内,就会有500X100=10000次if判断,而中断处理程序最讲究节省时间。实际上,我们不必每发生一次定时中断就去对这500个定时器进行判断。因为假设我们使用了500个定时器中的10个,而10个定时器中最小的超时时间是10s,即10s后才触发第一个定时器,而在这10s内,会进行10000X10=10万次无用的if判断,如果能省去这10万次if判断会是对性能的一次了不起的提升。这里采取的优化策略是:我们维护一个next链,即10个正在被使用的定时器按照超时时间由小到大形成next链,一开始next表示最小的超时时间(本例中为10s),这样每一次调用中断处理程序,先将当前时间count和next进行比较,如果count < next, 则说明此时没有定时间超时,就不必再对500个定时器进行判断,如果count == next,说明当前正在被使用而且都没有超时的定时器中超时时间最小的定时器到了超时时间,接下来就让这个定时器超时,并选出下一个next,即剩下的正在被使用而且没有超时的定时器中超时时间最小的定时器的超时时间。这样,随着时间的推移,每一次中断,count便加1, count会遇到next链中的各个超时时间,一旦遇到就意味着有定时器要超时了,没有遇到就说明此时没有定时器会超时,就省去了大量的无用的if判断。下面是经过优化的定时中断处理程序:
// when IRQ0(timer interrupt) happens, invoke the interrupt handler: inthandler20 void inthandler20(int *esp) { io_out8(PIC0_OCW2, 0x60); // Inform PIC the information that IRQ0-00 has been received. timerctl.count++; // each second it adds 100 if (timerctl.next > timerctl.count) { return; // the next time has not arrived, so finish } timerctl.next = 0xffffffff; int i; for (i = 0; i < MAX_TIMER; i++) { if (timerctl.timer[i].flags == TIMER_FLAGS_USING) { if (timerctl.timer[i].timeout <= timerctl.count) { // timeout timerctl.timer[i].flags = TIMER_FLAGS_ALLOC; fifo8_put(timerctl.timer[i].fifo, timerctl.timer[i].data); } else { // not timeout if (timerctl.next > timerctl.timer[i].timeout) { timerctl.next = timerctl.timer[i].timeout; // elect the next time of timeout } } } } return; }
// when IRQ0(timer interrupt) happens, invoke the interrupt handler: inthandler20 void inthandler20(int *esp) { int i, j; io_out8(PIC0_OCW2, 0x60); // Inform PIC the information that IRQ0-00 has been received. timerctl.count++; // each second it adds 100 if (timerctl.next > timerctl.count) { return; // the next time has not arrived, so finish } // checking in all of the timers which are being used, which timer time out. // now we do not have to do MAX_TIMER times of 'if' for (i = 0; i < timerctl.using; i++) { if (timerctl.timers[i]->timeout > timerctl.count) { break; } // timeout timerctl.timers[i]->flags = TIMER_FLAGS_ALLOC; fifo8_put(timerctl.timers[i]->fifo, timerctl.timers[i]->data); } // a timer has timed out, we need shift the rest using timer timerctl.using -= i; for (j = 0; j < timerctl.using; j++) { timerctl.timers[j] = timerctl.timers[i + j]; } if (timerctl.using > 0) { timerctl.next = timerctl.timers[0]->timeout; } else { timerctl.next = 0xffffffff; } return; }
30天自制操作系统之第12天 定时器,布布扣,bubuko.com
标签:30天自制操作系统 operating system 定时器 中断处理程序
原文地址:http://blog.csdn.net/bluecloudmatrix/article/details/38460555