Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp2485454ybl; Mon, 19 Aug 2019 02:51:57 -0700 (PDT) X-Google-Smtp-Source: APXvYqx8gwstU+9O/3xLCij6X4WRqBEAbrrT2RszmKrSA4JikS39CHFhx7srwH4Dp5OdryLk7ZZY X-Received: by 2002:a17:902:830c:: with SMTP id bd12mr22012301plb.237.1566208317373; Mon, 19 Aug 2019 02:51:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1566208317; cv=none; d=google.com; s=arc-20160816; b=YSWwmcEC6iIyK/4BQqf0S6XLtQIsqfRUcsVZ+EtsLQkA3CFXWOTLelOZwX6a5GokIf EtrVe3KzdSvH7SLiSgTqBMROijgKOEobGNRtp02CvqygCsy6zY8VZPDiLM/9KzmLDIII NWkzJU29bbBvNmNQZ8CO16rtTGKjS93nV+Z8U8533HjNepDu0OG64EJsA/8irOAC/mB6 ayvzB3Wj8BQm+Uw+xtvjENqE1wyTPP+gXDeBfV0/xLW7Er0oWZaThDIVmnrN94QM5Hra qi+Wu8gNZ2i5ohrKXWLn43WgjnGL2FnLlnDdYbaFa0ILHEJ1KzThgXbvGZeP9XF0fVpU y+ow== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-transfer-encoding:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=wICfFLnXhIBKpRL3MkChT8cnTtZKk7MVOyrCJIfR7D4=; b=e19jZdKJJK68SdRQAPcPUCLCAA7qv7itf5RNjB1y0PG5xuhSsY/jWQA3H/4dnaJlC0 qU5RSZ3z14yGnAch3+PQ6Ytg5QHHFJRT6qhIBc+AR8BwGueCiBD3O1U7aUMAiktB9gJc xp41u0A25stNOcsz1u+G5/xwKWLLzucd9sUtFgAMtgfeXzaLhfp4JIUOLmv80r6PyDcr FoMWhMDMcuCRJLGP6NAZPzDwrWylT+ApYgHTPCp9vPQ8XLQjDcZs7by7R5GuRUsSw66O R01ZZKGAAw8xNPbfOMdHaS3yvKLckeNBc7HZGxf2RJdZp+BG37M4QhmfQkcVPiNBEmag iLfA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=jWDr4u7K; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id c22si9510745plz.361.2019.08.19.02.51.41; Mon, 19 Aug 2019 02:51:57 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=jWDr4u7K; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726992AbfHSJun (ORCPT + 99 others); Mon, 19 Aug 2019 05:50:43 -0400 Received: from mail-wm1-f68.google.com ([209.85.128.68]:38909 "EHLO mail-wm1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726491AbfHSJum (ORCPT ); Mon, 19 Aug 2019 05:50:42 -0400 Received: by mail-wm1-f68.google.com with SMTP id m125so1026266wmm.3 for ; Mon, 19 Aug 2019 02:50:40 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:content-transfer-encoding:in-reply-to :user-agent; bh=wICfFLnXhIBKpRL3MkChT8cnTtZKk7MVOyrCJIfR7D4=; b=jWDr4u7KdKLlFacXo7dujEGjOc/1AXUmMpT0Ji/Pdu4LLH2ALWJ8i7wPh/C1iVIbYn bwZnMTvkfCMFE4O3yPzd4bDvO1mXRsSRESmgwtTEetC0GVmNHDe4GX+8vIsFeHZfjLbK jAujLEvOtZxgzNlXLRW8NmUlr0QvI0c7rKtlMg42PU86FWlSxy0epJzqjrqiSupx2Z4w ZNP1BvKM2hnEZXgCYNgLKtW1CdFKQ49JTia96GIE6vT1jKxOdQ4NaKCpgArrzD2rZ3qV q4p6uw1juHGyc8DfyirFfCO0V/w4034IBfD/1/m/bAB1mZlnjXSBY+3d2Xdza74dTIRi 4sNw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:content-transfer-encoding :in-reply-to:user-agent; bh=wICfFLnXhIBKpRL3MkChT8cnTtZKk7MVOyrCJIfR7D4=; b=iJxaoGf9RifnyLwfKRLrz6ohJtG0zeIN8trh+eWU5OImTnJV/nsQ2GCozx1X8e4gIA ygTx0MW7AmcHcaLgvjSAAmKHVs1rqfShJvDUJxTTj9dcA6d4BZt2wRCzu7JcSeprplKw N57s6fWPwcJsmg0QgXTNFYApr94Ec8XsY2ZOFgmAS2QRBWQ4Bp+pHFrafwCaAZGQU6Kt Miy41jsZwZpwwILAR9t8DqsplzhNHTFhmSuyqeXST5YGFDdsswnlnYzdsm9wOIT6J1LD fJ0fb6skpSOCH0Kb8+CTEZ+TVx8YZf8tkup4yZDAFDNrJ+4Rm8pbb6OasapO7cyo0h5t a2GA== X-Gm-Message-State: APjAAAXT4A0prcOW/57VaTtTFyoSy24v0xNKG3xkT82OHz+uga+Lxw6y zZMFJGGvkzJmOWz6Jk3wrWpNOQ== X-Received: by 2002:a1c:630b:: with SMTP id x11mr19227174wmb.135.1566208239870; Mon, 19 Aug 2019 02:50:39 -0700 (PDT) Received: from holly.lan (cpc141214-aztw34-2-0-cust773.18-1.cable.virginm.net. [86.9.19.6]) by smtp.gmail.com with ESMTPSA id f13sm4491631wrr.5.2019.08.19.02.50.38 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 19 Aug 2019 02:50:39 -0700 (PDT) Date: Mon, 19 Aug 2019 10:50:37 +0100 From: Daniel Thompson To: Uwe =?utf-8?Q?Kleine-K=C3=B6nig?= Cc: Matthias Kaehlcke , Thierry Reding , Lee Jones , Jingoo Han , Bartlomiej Zolnierkiewicz , linux-pwm@vger.kernel.org, dri-devel@lists.freedesktop.org, linux-fbdev@vger.kernel.org, linux-kernel@vger.kernel.org, Enric Balletbo i Serra , Douglas Anderson , Brian Norris , Pavel Machek , Jacek Anaszewski , kernel@pengutronix.de Subject: Re: [PATCH v3 2/4] backlight: Expose brightness curve type through sysfs Message-ID: <20190819095037.h3gig3quyhnzshm7@holly.lan> References: <20190709190007.91260-1-mka@chromium.org> <20190709190007.91260-3-mka@chromium.org> <20190816165148.7keg45fmlndr22fl@pengutronix.de> <20190816175157.GT250418@google.com> <20190816194754.ldzjqy2yjonfvaat@pengutronix.de> <20190816211051.GV250418@google.com> <20190819054628.asw3cxp46w3rpml7@pengutronix.de> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <20190819054628.asw3cxp46w3rpml7@pengutronix.de> User-Agent: NeoMutt/20180716 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Aug 19, 2019 at 07:46:28AM +0200, Uwe Kleine-K?nig wrote: > Hello Matthias, > > On Fri, Aug 16, 2019 at 02:10:51PM -0700, Matthias Kaehlcke wrote: > > On Fri, Aug 16, 2019 at 09:47:54PM +0200, Uwe Kleine-K?nig wrote: > > > On Fri, Aug 16, 2019 at 10:51:57AM -0700, Matthias Kaehlcke wrote: > > > > Hi Uwe, > > > > > > > > On Fri, Aug 16, 2019 at 06:51:48PM +0200, Uwe Kleine-K?nig wrote: > > > > > On Tue, Jul 09, 2019 at 12:00:05PM -0700, Matthias Kaehlcke wrote: > > > > > > Backlight brightness curves can have different shapes. The two main > > > > > > types are linear and non-linear curves. The human eye doesn't > > > > > > perceive linearly increasing/decreasing brightness as linear (see > > > > > > also 88ba95bedb79 "backlight: pwm_bl: Compute brightness of LED > > > > > > linearly to human eye"), hence many backlights use non-linear (often > > > > > > logarithmic) brightness curves. The type of curve currently is opaque > > > > > > to userspace, so userspace often uses more or less reliable heuristics > > > > > > (like the number of brightness levels) to decide whether to treat a > > > > > > backlight device as linear or non-linear. > > > > > > > > > > > > Export the type of the brightness curve via the new sysfs attribute > > > > > > 'scale'. The value of the attribute can be 'linear', 'non-linear' or > > > > > > 'unknown'. For devices that don't provide information about the scale > > > > > > of their brightness curve the value of the 'scale' attribute is 'unknown'. > > > > > > > > > > > > Signed-off-by: Matthias Kaehlcke > > > > > > > > > > I wonder what kind of problem you are solving here. Can you describe > > > > > that in a few words? > > > > > > > > The human eye perceives brightness in a logarithmic manner. For > > > > backlights with a linear brightness curve brightness controls like > > > > sliders need to use a mapping to achieve a behavior that is perceived > > > > as linear-ish (more details: http://www.pathwaylighting.com/products/downloads/brochure/technical_materials_1466797044_Linear+vs+Logarithmic+Dimming+White+Paper.pdf) > > > > > > > > As of now userspace doesn't have information about the type of the > > > > brightness curve, and often uses heuristics to make a guess, which may > > > > be right most of the time, but not always. The new attribute eliminates > > > > the need to guess. > > > > > > This is about backlights right? So the kernel provides to userspace an > > > interval [0, x] for some x and depending on the physics of the the > > > backlight configuring x/2 (probably?) either means 50% measured light or > > > 50% perceived light, right? > > > > correct > > > > > I wonder if it would be possible instead of giving different backlight > > > implementations the freedom to use either linear or logarithmic (or > > > quadratic?) scaling and tell userspace which of the options were picked > > > require the drivers to provide a (say) linear scaling and then userspace > > > wouldn't need to care about the exact physics. > > > > In an ideal world the backlight interface would be consistent as you > > suggest, however there are plenty of existing devices which use the > > 'other' scaling (regardless of which is chosen as the 'correct' > > one). Userspace still has to deal with these. And changing previously > > 'logarithmic' drivers to linear (or viceversa) may 'break' userspace, > > when it keeps using its 'old' scaling, which now isn't correct anymore. > > It might be subjective, or maybe I'm just too optimistic, but I think if > there was no policy before about the meaning of > > echo 17 > brightness > > other than "brighter than lower values and darker than higher ones" > introducing (say) the scale is intended to represent a linear brightness > curve is ok. > > Unless userspace jumps through hoops and tries to identify the actual > device it is running on it is wrong on some machines anyhow and we're > only shifting the set of affected machines with a tighter policy (until > that userspace application is fixed). I believe that there are two common approaches by userspace at present: 1. Assume the scale is perceptual and we can directly map a slider to the backlight value. This is common simply because most ACPI backlights are perceptual and therefore when tested in a laptop it works OK. 2. Assume that is max brightness is small (e.g. ACPI) then the scale is perceptual and if the max brightness is large (e.g. a PWM) then the scale is linear and apply a correction function between the slider and the control. That historic baggage makes is diffcult to "just define a standardized scale"... especially given that if we selected a standardized scale we would probably want a perceptual scale with lots of steps (e.g. break the heuristic). > And the big upside is that in the end (i.e. when all kernel drivers and > userspace applications are adapted to provide/consume the "correct" > curve) the result is simpler. My view is that this convergence will eventually be achieved but it will happen through the obsolescence of the backlight sysfs interface. The sysfs interface has other flaws, in particular no integration with the DRM connector API. Thus I would expect an alternative interface to emerge, most likely as part of the DRM connector API. I'd expect such a new API to a perceptual scale and to have a fixed max brightness with enough steps to support animated backlight effects (IIRC 0..100 has been proposed in the past) In the mean time getting the existing collection of backlight drivers marked up as linear/logarithmic/etc will ease the introduction of that API because, within the kernel, we might have gathered enough knowledge to have some hope of correctly mapping each backlight onto a standardized scale. Daniel.