Re: [thisops uV3 15/18] Xen: Use this_cpu_ops

From: Jeremy Fitzhardinge
Date: Tue Nov 30 2010 - 15:54:01 EST


On 11/30/2010 11:07 AM, Christoph Lameter wrote:
> static irqreturn_t xen_timer_interrupt(int irq, void *dev_id)
> {
> - struct clock_event_device *evt = &__get_cpu_var(xen_clock_events);
> irqreturn_t ret;
>
> ret = IRQ_NONE;
> - if (evt->event_handler) {
> - evt->event_handler(evt);
> + if (__this_cpu_read(xen_clock_events.event_handler)) {
> + __this_cpu_read(xen_clock_events.event_handler)(evt);

Really? What code does this generate? If this is generating two
segment-prefixed reads rather than getting the address and doing normal
reads on it, then I don't think it is an improvement.

The rest looks OK, I guess. How does it change the generated code?

J
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/