From: Russell King - ARM Linux <linux@arm.linux.org.uk>
To: "Måns Rullgård" <mans@mansr.com>
Cc: linux-arm-kernel@lists.infradead.org,
linux-kernel@vger.kernel.org, linux-omap@vger.kernel.org,
linux-cris-kernel@axis.com, linux-mips@linux-mips.org,
linux-xtensa@linux-xtensa.org, kernel@stlinux.com,
linux-rpi-kernel@lists.infradead.org,
linux-samsung-soc@vger.kernel.org, linux-tegra@vger.kernel.org
Subject: Re: [PATCH] sched_clock: add data pointer argument to read callback
Date: Sat, 10 Oct 2015 00:54:41 +0100 [thread overview]
Message-ID: <20151009235441.GD32536@n2100.arm.linux.org.uk> (raw)
In-Reply-To: <yw1x4mhzioxl.fsf@unicorn.mansr.com>
On Sat, Oct 10, 2015 at 12:48:22AM +0100, Måns Rullgård wrote:
> Russell King - ARM Linux <linux@arm.linux.org.uk> writes:
>
> > On Fri, Oct 09, 2015 at 10:57:35PM +0100, Mans Rullgard wrote:
> >> This passes a data pointer specified in the sched_clock_register()
> >> call to the read callback allowing simpler implementations thereof.
> >>
> >> In this patch, existing uses of this interface are simply updated
> >> with a null pointer.
> >
> > This is a bad description. It tells us what the patch is doing,
> > (which we can see by reading the patch) but not _why_. Please include
> > information on why the change is necessary - describe what you are
> > trying to achieve.
>
> Currently most of the callbacks use a global variable to store the
> address of a counter register. This has several downsides:
>
> - Loading the address of a global variable can be more expensive than
> keeping a pointer next to the function pointer.
>
> - It makes it impossible to have multiple instances of a driver call
> sched_clock_register() since the caller can't know which clock will
> win in the end.
>
> - Many of the existing callbacks are practically identical and could be
> replaced with a common generic function if it had a pointer argument.
>
> If I've missed something that makes this a stupid idea, please tell.
So my next question is whether you intend to pass an iomem pointer
through this, or a some kind of structure, or both. It matters,
because iomem pointers have a __iomem attribute to keep sparse
happy. Having to force that attribute on and off pointers is frowned
upon, as it defeats the purpose of the sparse static checker.
--
FTTC broadband for 0.8mile line: currently at 9.6Mbps down 400kbps up
according to speedtest.net.
next prev parent reply other threads:[~2015-10-09 23:54 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <1444427858-576-1-git-send-email-mans@mansr.com>
2015-10-09 23:20 ` [PATCH] sched_clock: add data pointer argument to read callback Russell King - ARM Linux
2015-10-09 23:48 ` Måns Rullgård
2015-10-09 23:54 ` Russell King - ARM Linux [this message]
2015-10-10 0:42 ` Måns Rullgård
2015-10-10 15:33 ` Russell King - ARM Linux
2015-10-11 20:40 ` Thomas Gleixner
2015-10-12 13:02 ` Gregory CLEMENT
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20151009235441.GD32536@n2100.arm.linux.org.uk \
--to=linux@arm.linux.org.uk \
--cc=kernel@stlinux.com \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-cris-kernel@axis.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mips@linux-mips.org \
--cc=linux-omap@vger.kernel.org \
--cc=linux-rpi-kernel@lists.infradead.org \
--cc=linux-samsung-soc@vger.kernel.org \
--cc=linux-tegra@vger.kernel.org \
--cc=linux-xtensa@linux-xtensa.org \
--cc=mans@mansr.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox