Changes in kernel/arch/sparc64/src/drivers/tick.c [965dc18:d46f5cc] in mainline
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
kernel/arch/sparc64/src/drivers/tick.c
r965dc18 rd46f5cc 27 27 */ 28 28 29 /** @addtogroup sparc64 29 /** @addtogroup sparc64 30 30 * @{ 31 31 */ … … 54 54 interrupt_register(14, "tick_int", tick_interrupt); 55 55 compare.int_dis = false; 56 compare.tick_cmpr = CPU->arch.clock_frequency / HZ; 56 compare.tick_cmpr = tick_counter_read() + 57 CPU->arch.clock_frequency / HZ; 57 58 CPU->arch.next_tick_cmpr = compare.tick_cmpr; 58 59 tick_compare_write(compare.value); 59 tick_write(0);60 60 61 #if defined (US3) 61 #if defined (US3) || defined (SUN4V) 62 62 /* disable STICK interrupts and clear any pending ones */ 63 63 tick_compare_reg_t stick_compare; … … 77 77 /** Process tick interrupt. 78 78 * 79 * @param n Interrupt Level, 14, (can be ignored)79 * @param n Interrupt Level (14, can be ignored) 80 80 * @param istate Interrupted state. 81 * 81 82 */ 82 void tick_interrupt( int n, istate_t *istate)83 void tick_interrupt(unsigned int n, istate_t *istate) 83 84 { 84 85 softint_reg_t softint, clear; … … 111 112 * overflow only in 146 years. 112 113 */ 113 drift = tick_ read() - CPU->arch.next_tick_cmpr;114 drift = tick_counter_read() - CPU->arch.next_tick_cmpr; 114 115 while (drift > CPU->arch.clock_frequency / HZ) { 115 116 drift -= CPU->arch.clock_frequency / HZ; 116 117 CPU->missed_clock_ticks++; 117 118 } 118 CPU->arch.next_tick_cmpr = tick_ read() +119 CPU->arch.next_tick_cmpr = tick_counter_read() + 119 120 (CPU->arch.clock_frequency / HZ) - drift; 120 121 tick_compare_write(CPU->arch.next_tick_cmpr);
Note:
See TracChangeset
for help on using the changeset viewer.