[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20131127140143.GB24403@gmail.com>
Date: Wed, 27 Nov 2013 15:01:43 +0100
From: Ingo Molnar <mingo@...nel.org>
To: Peter Zijlstra <peterz@...radead.org>
Cc: Juri Lelli <juri.lelli@...il.com>, tglx@...utronix.de,
mingo@...hat.com, rostedt@...dmis.org, oleg@...hat.com,
fweisbec@...il.com, darren@...art.com, johan.eker@...csson.com,
p.faure@...tech.ch, linux-kernel@...r.kernel.org,
claudio@...dence.eu.com, michael@...rulasolutions.com,
fchecconi@...il.com, tommaso.cucinotta@...up.it,
nicola.manica@...i.unitn.it, luca.abeni@...tn.it,
dhaval.giani@...il.com, hgu1972@...il.com,
paulmck@...ux.vnet.ibm.com, raistlin@...ux.it,
insop.song@...il.com, liming.wang@...driver.com, jkacur@...hat.com,
harald.gustafsson@...csson.com, vincent.guittot@...aro.org,
bruce.ashfield@...driver.com,
Andrew Morton <akpm@...ux-foundation.org>,
Linus Torvalds <torvalds@...ux-foundation.org>
Subject: Re: [PATCH 02/14] sched: add extended scheduling interface. (new ABI)
* Peter Zijlstra <peterz@...radead.org> wrote:
> On Wed, Nov 27, 2013 at 02:23:54PM +0100, Ingo Molnar wrote:
> > There are 3 main compatibility cases:
> >
> > - the kernel's 'sizeof sched_attr' is equal to sched_attr:size: the
> > kernel version and user-space version matches, it's a straight ABI
> > in this case with full functionality.
> >
> > - the kernel's 'sizeof sched_attr' is larger than sched_attr::size
> > [the kernel is newer than what user-space was built for], in this
> > case the kernel assumes that all remaining values are zero and acts
> > accordingly.
>
> It also needs to fail sched_getparam() when any of the fields that do
> not fit in the smaller struct provided are !0.
>
> > - the kernel's 'sizeof sched_attr' is smaller than sched_attr::size
> > [the kernel is older than what user-space was built for]. In
> > this case the kernel should return -ENOSYS if any of the
> > additional fields are nonzero. If those are all zero then it
> > will work as if a smaller structure was passed in.
>
> So the problem I see with this one is that because you're allowed to
> call sched_setparam() or whatever it will be called next on another
> task; a task can very easily fail its sched_getparam() call.
>
> Suppose the application is 'old' and only supports a subset of the
> fields; but its wants to get, modify and set its params. This will
> work as long nothing will set anything it doesn't know about.
>
> As soon as some external entity -- say a sysad using schedtool --
> sets a param field it doesn't support the get, modify, set routing
> completely fails.
There are two approaches to this that I can see:
1)
allow partial information to be returned to user-space, for existing
input parameters. The new fields won't be displayed, but the tool
doesn't know about them anyway so it's OK. The tool can still display
all the other existing parameters.
2)
Return -ENOSYS if the 'extra' fields are nonzero. In this case the
usual case of old tooling + new kernel will still work just fine,
because old tooling won't set the new fields to any non-default
(nonzero) values. In the 'mixed' case old tooling will not be able to
change/display those fields.
I tend to lean towards #1. What do you think?
Thanks,
Ingo
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists