* Christoph Lameter ([email protected]) wrote:
> On Tue, 20 Nov 2007, Mathieu Desnoyers wrote:
>
> > > Index: linux-2.6/fs/nfs/iostat.h
> > > ===================================================================
> > > --- linux-2.6.orig/fs/nfs/iostat.h 2007-11-15 21:17:24.391404458 -0800
> > > +++ linux-2.6/fs/nfs/iostat.h 2007-11-15 21:25:33.167654066 -0800
> > > @@ -123,7 +123,7 @@ static inline void nfs_inc_server_stats(
> > > int cpu;
> > >
> > > cpu = get_cpu();
> > > - iostats = per_cpu_ptr(server->io_stats, cpu);
> > > + iostats = CPU_PTR(server->io_stats, cpu);
> > > iostats->events[stat] ++;
> >
> > Is there a way to change this into a CPU_ADD ?
>
> Yes I must have missed that.
>
> Could be
>
> CPU_INC(server->io_stats->events[stat]);
>
> >
> > > put_cpu_no_resched();
> >
> > Why put_cpu_no_resched here ?
>
> We do not want to reschedule here? We may have already disabled interrupts
> or some such thing.
Well, if interrupts are disabled, then the preempt check will see it and
won't trigger the reschedule. On the other hand, if this code is called
when preemption is enabled, we can add important scheduler latencies by
not checking if a resched must be done at the end of this region.
So if we are so sure that interrupts are always disbled or that
preemption is already disabled when this function is called, why do we
disable preemption here at all ?
(this is not introduced by your patch, it just happens to be how the
code was before)
--
Mathieu Desnoyers
Computer Engineering Ph.D. Student, Ecole Polytechnique de Montreal
OpenPGP key fingerprint: 8CD5 52C3 8E3C 4140 715F BA06 3F25 A8FE 3BAE 9A68
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
[Index of Archives]
[Kernel Newbies]
[Netfilter]
[Bugtraq]
[Photo]
[Stuff]
[Gimp]
[Yosemite News]
[MIPS Linux]
[ARM Linux]
[Linux Security]
[Linux RAID]
[Video 4 Linux]
[Linux for the blind]
[Linux Resources]