From: Richard Purdie <rpurdie@linux.intel.com>
To: Matthew Garrett <mjg59@srcf.ucam.org>
Cc: Andrew Morton <akpm@linux-foundation.org>,
linux-kernel@vger.kernel.org, nouveau@lists.freedesktop.org,
dri-devel@lists.freedesktop.org, intel-gfx@lists.freedesktop.org,
linux-acpi@vger.kernel.org, lenb@kernel.org
Subject: Re: [PATCH 1/5] Backlight: Add backlight type
Date: Mon, 22 Nov 2010 10:17:00 +0000 [thread overview]
Message-ID: <1290421020.1272.16707.camel@rex> (raw)
In-Reply-To: <20101119202558.GA10898@srcf.ucam.org>
On Fri, 2010-11-19 at 20:25 +0000, Matthew Garrett wrote:
> On Fri, Nov 19, 2010 at 12:05:23PM -0800, Andrew Morton wrote:
> > On Fri, 19 Nov 2010 10:53:52 -0500
> > Matthew Garrett <mjg@redhat.com> wrote:
> >
> > > There may be multiple ways of controlling the backlight on a given machine.
> > > Allow drivers to expose the type of interface they are providing, making
> > > it possible for userspace to make appropriate policy decisions.
> > >
> > > ...
> > >
> > > 60 files changed, 102 insertions(+), 0 deletions(-)
> >
> > This patch has a pretty short half-life.
>
> Well, ideally it would have landed in the backlight tree when I sent it
> months ago. Then we'd have the opportunity to ensure that everything was
> fixed up before it went in in the merge window.
>
> > > @@ -62,6 +68,8 @@ struct backlight_properties {
> > > /* FB Blanking active? (values as for power) */
> > > /* Due to be removed, please use (state & BL_CORE_FBBLANK) */
> > > int fb_blank;
> > > + /* Backlight type */
> > > + enum backlight_type type;
> > > /* Flags used to signal drivers of state changes */
> > > /* Upper 4 bits are reserved for driver internal use */
> > > unsigned int state;
> >
> > And if/when the half-life expires, we'll have drivers in-tree which
> > forget to set backlight_properties.type. I haven't checked, but if
> > we're lucky they will default to "0".
>
> Depends entirely on whether they kzalloc the structure or not before
> calling backlight_device_register().
>
> > What will be the runtime effects upon such unconverted drivers?
> > Ideally we'd like them to continue to work OK, and to emit a runtime
> > warning. In which case you'll need BACKLIGHT_RAW=1 so the unconverted
> > driver can be detected, warned about and fixed up by the core code.
>
> The worst case I can think of is that we walk off the array - I guess
> there's an argument for sanity checking that in backlight_show_type().
I think adding a BACKLIGHT_TYPEUNKNOWN as the first item in the enum,
sanity checking the array bounds and printing a warning if type is not
one of the defined values would be good.
I also want to make sure you think this patch is going to scale with
multiple GPU output machines? Thats the main reason I've held off any
patch like this as it doesn't help solve that problem as far as I can
tell. Yes, we have the device parent information and I see later in the
patch series you ensure the backlight is registered against the
connector which is good. If you have an ACPI "firmware" control that you
say should always be preferred, how do we know which connector device
that corresponds to in the multiple output case? From that point of view
this model falls apart?
What I really want to avoid is a new interface which just papers over
cracks, only to have everything crumble anyway.
Cheers,
Richard
next prev parent reply other threads:[~2010-11-22 10:20 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-11-19 15:53 [PATCH 1/5] Backlight: Add backlight type Matthew Garrett
2010-11-19 15:53 ` [PATCH 2/5] i915: Add native backlight control Matthew Garrett
2010-11-19 15:53 ` [PATCH 3/5] radeon: Expose backlight class device for legacy LVDS encoder Matthew Garrett
2010-11-19 15:53 ` [PATCH 4/5] nouveau: Change the backlight parent device to the connector, not the PCI dev Matthew Garrett
2010-11-19 15:53 ` [PATCH 5/5] ACPI: Tie ACPI backlight devices to PCI devices if possible Matthew Garrett
2010-11-19 20:05 ` [PATCH 1/5] Backlight: Add backlight type Andrew Morton
2010-11-19 20:25 ` Matthew Garrett
2010-11-19 20:35 ` Andrew Morton
2010-11-22 10:17 ` Richard Purdie [this message]
2010-11-22 12:30 ` Matthew Garrett
2010-11-22 13:35 ` Richard Purdie
2010-11-22 13:40 ` Matthew Garrett
-- strict thread matches above, loose matches on Subject: below --
2011-01-14 19:24 Matthew Garrett
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=1290421020.1272.16707.camel@rex \
--to=rpurdie@linux.intel.com \
--cc=akpm@linux-foundation.org \
--cc=dri-devel@lists.freedesktop.org \
--cc=intel-gfx@lists.freedesktop.org \
--cc=lenb@kernel.org \
--cc=linux-acpi@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=mjg59@srcf.ucam.org \
--cc=nouveau@lists.freedesktop.org \
/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;
as well as URLs for NNTP newsgroup(s).