Hello. Tony Breeds wrote:
> Signed-off-by: Tony Breeds <[EMAIL PROTECTED]> I don't see my own signoff or at least a reference to my prior work in this patch or even at -rt patch -- despite this code ha clearly borrowed from it. And I'm not sure why this crippled version (lacking 40x/ Book E specific clockevents implementation) is preferred over mine, unless this implementation was only aimed at PPC64 machines... > Index: working/arch/powerpc/Kconfig > =================================================================== > --- working.orig/arch/powerpc/Kconfig > +++ working/arch/powerpc/Kconfig > @@ -30,6 +30,9 @@ config GENERIC_TIME > config GENERIC_TIME_VSYSCALL > def_bool y > > +config GENERIC_CLOCKEVENTS > + def_bool y > + > config GENERIC_HARDIRQS > bool > default y Also, have the deterministic CPU accounting incompatibility with clockevents been dealt with? > Index: working/arch/powerpc/kernel/time.c > =================================================================== > --- working.orig/arch/powerpc/kernel/time.c > +++ working/arch/powerpc/kernel/time.c [...] > @@ -519,10 +541,12 @@ void __init iSeries_time_init_early(void > void timer_interrupt(struct pt_regs * regs) > { > struct pt_regs *old_regs; > - int next_dec; > int cpu = smp_processor_id(); > - unsigned long ticks; > - u64 tb_next_jiffy; > + struct clock_event_device *evt = &per_cpu(decrementers, cpu); > + > + /* Ensure a positive value is written to the decrementer, or else > + * some CPUs will continuue to take decrementer exceptions */ > + set_dec(DECREMENTER_MAX); BookE and 40x CPUs don't need this. > #ifdef CONFIG_PPC32 > if (atomic_read(&ppc_n_lost_interrupts) != 0) > @@ -532,7 +556,6 @@ void timer_interrupt(struct pt_regs * re > old_regs = set_irq_regs(regs); > irq_enter(); > > - profile_tick(CPU_PROFILING); > calculate_steal_time(); > > #ifdef CONFIG_PPC_ISERIES > @@ -540,44 +563,20 @@ void timer_interrupt(struct pt_regs * re > get_lppaca()->int_dword.fields.decr_int = 0; > #endif > > - while ((ticks = tb_ticks_since(per_cpu(last_jiffy, cpu))) > - >= tb_ticks_per_jiffy) { > - /* Update last_jiffy */ > - per_cpu(last_jiffy, cpu) += tb_ticks_per_jiffy; > - /* Handle RTCL overflow on 601 */ > - if (__USE_RTC() && per_cpu(last_jiffy, cpu) >= 1000000000) > - per_cpu(last_jiffy, cpu) -= 1000000000; I don't see where the patch removes those variables themselves... [...] > - write_seqlock(&xtime_lock); > - tb_next_jiffy = tb_last_jiffy + tb_ticks_per_jiffy; > - if (__USE_RTC() && tb_next_jiffy >= 1000000000) > - tb_next_jiffy -= 1000000000; > - if (per_cpu(last_jiffy, cpu) >= tb_next_jiffy) { > - tb_last_jiffy = tb_next_jiffy; > - do_timer(1); > - } > - write_sequnlock(&xtime_lock); > - } Again, where those variables are removed? > - > - next_dec = tb_ticks_per_jiffy - ticks; > - set_dec(next_dec); > + if (evt->event_handler) > + evt->event_handler(evt); > + else > + evt->set_next_event(DECREMENTER_MAX, evt); We have already set it to DECREMENTER_MAX at the start of the function. Please remove the 'else' part... > @@ -797,6 +796,53 @@ void __init clocksource_init(void) > clock->name, clock->mult, clock->shift); > } > > +static int decrementer_set_next_event(unsigned long evt, > + struct clock_event_device *dev) > +{ > + set_dec(evt); I'd use (evt - 1) since the interrupt gets generated at 0xffffffff count, not 0 (on classic CPUs). With you removing of the code that compensated for the errors, they will accumulate. And no, this wouldn't be enough anyway, since on 40x and Book E you'll need to set it for evt anyway, since the interrupt happens at 0 count... NAK the patch. And I really don't understand why you're throwing alway already tested/working code... > + return 0; > +} > + > +static void decrementer_set_mode(enum clock_event_mode mode, > + struct clock_event_device *dev) > +{ > + if (mode != CLOCK_EVT_MODE_ONESHOT) > + decrementer_set_next_event(DECREMENTER_MAX, dev); > +} > + > +static void register_decrementer_clockevent(int cpu) > +{ > + struct clock_event_device *dec = &per_cpu(decrementers, cpu); > + > + *dec = decrementer_clockevent; > + dec->cpumask = cpumask_of_cpu(cpu); > + > + printk(KERN_ERR "clockevent: %s mult[%lx] shift[%d] cpu[%d]\n", This is a mistake indeed. :-P WBR, Sergei _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@ozlabs.org https://ozlabs.org/mailman/listinfo/linuxppc-dev