Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp3024735ybi; Mon, 10 Jun 2019 03:01:37 -0700 (PDT) X-Google-Smtp-Source: APXvYqyIzBnq86MV5k84gm/V+zIXmt9V3SVyjJzoOAiApIekpveZf3Ernf6k/h9/gs5itro2Sz6S X-Received: by 2002:a63:eb0a:: with SMTP id t10mr13511318pgh.99.1560160896864; Mon, 10 Jun 2019 03:01:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1560160896; cv=none; d=google.com; s=arc-20160816; b=Ko5nLe172mFaN0lW3pUrLHKHCe1P8UwRkwhz/MY6n7DCuFlM1HORnDDX+WrfCsoNzl tnkuc009N1Ng2BlTIJC8X5ZGy6wmW3l9wrq3iRMxWf3aMxzZdPPyG84ckV9YzMYaoPY8 G3//4fbAw6Hnp/x46TlT+XrkQEQpURKs87Ly6N/Q/J8vDqHdUxDxA12956QQgwB6d426 hDl4NMSBnbFJn9nDTLs808T4Guadgtkj172aVaEvU2G2tcuba5uFPoI58oEfZQ+W98yA ckXEu5LIvmvfdbT54H2xPQ9aHZUTeJtl6vpwnP62B8v05htOAy3AUEkd5xheMXSG2B14 Kr5g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=c5Nt70UUo5VACImfAKqt1vBsuLLn4Re4hNK/xrmxjnM=; b=Ilap+0yP5X/iQ52A3ziuHOlXNQwAsHdzddEFVkF31+J3f+ueHW1KW36pOVyiKl53os Gzylrw3Sijz7kxKUnQlBOvmtNHo1FM9mqxpYIF6I3vUfg+tG7i/B/VeeRERXrTytPR51 KAVVqob4ziRiAjTgunTj48rCTl6Ut2xxA6KvIQlL2G7NuEegKZjfLK6rkLAFHnM79eJ8 FLtiSQ3rci5Xej9K4IJ0YQHtzfHDgNi2+MAi4Bz/O4A1Z4GgOD8fKhvRdQlnbTvL7fbS eoTHaTRSPO3kc8jJCclpfEzihBLYc0NCDQsMIkdyFjO2s8zAVlfkLespg6anFr4j4lbD 6Kzg== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id o3si9087251plk.167.2019.06.10.03.01.21; Mon, 10 Jun 2019 03:01:36 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388925AbfFJKAI (ORCPT + 99 others); Mon, 10 Jun 2019 06:00:08 -0400 Received: from bhuna.collabora.co.uk ([46.235.227.227]:56332 "EHLO bhuna.collabora.co.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388056AbfFJKAH (ORCPT ); Mon, 10 Jun 2019 06:00:07 -0400 Received: from [127.0.0.1] (localhost [127.0.0.1]) (Authenticated sender: eballetbo) with ESMTPSA id 7C75E279009 Subject: Re: [PATCH v3 3/4] backlight: pwm_bl: compute brightness of LED linearly to human eye. To: Pavel Machek , Matthias Kaehlcke Cc: Daniel Thompson , Doug Anderson , Rob Herring , Jingoo Han , Richard Purdie , Jacek Anaszewski , Brian Norris , Guenter Roeck , Lee Jones , Alexandru Stan , linux-leds@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, kernel@collabora.com References: <20180208113032.27810-1-enric.balletbo@collabora.com> <20180208113032.27810-4-enric.balletbo@collabora.com> <20190607220947.GR40515@google.com> <20190608210226.GB2359@xo-6d-61-c0.localdomain> From: Enric Balletbo i Serra Message-ID: <819ecbcd-18e3-0f6b-6121-67cb363df440@collabora.com> Date: Mon, 10 Jun 2019 12:00:02 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.7.0 MIME-Version: 1.0 In-Reply-To: <20190608210226.GB2359@xo-6d-61-c0.localdomain> Content-Type: text/plain; charset=utf-8 Content-Language: en-GB Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Matthias, On 8/6/19 23:02, Pavel Machek wrote: > Hi! > >>> + * Note that this method is based on empirical testing on different >>> + * devices with PWM of 8 and 16 bits of resolution. >>> + */ >>> + n = period; >>> + while (n) { >>> + counter += n % 2; >>> + n >>= 1; >>> + } >> >> I don't quite follow the heuristics above. Are you sure the number of >> PWM bits can be infered from the period? What if the period value (in >> ns) doesn't directly correspond to a register value? And even if it >> did, counting the number of set bits (the above loops is a >> re-implementation of ffs()) doesn't really result in the dividers >> mentioned in the comment. E.g. a period of 32768 ns (0x8000) results >> in a divider of 1, i.e. 32768 brighness levels. >> Right, I think that only works on the cases that we only have one pwm cell, and looks like during my tests I did only tests on devices with one pwm cell :-( And as you point the code is broken for other cases (pwm-cells > 1) >> On veyron minnie the period is 1000000 ns, which results in 142858 >> levels (1000000 / 7)! >> >> Not sure if there is a clean solution using heuristics, a DT property >> specifying the number of levels could be an alternative. This could >> also be useful to limit the number of (mostly) redundant levels, even >> the intended max of 4096 seems pretty high. >> Looking again looks like we _can not_ deduce the number of bits of a pwm, it is not exposed at all, so I think we will need to end adding a property to specify this. Something similar to what leds-pwm binding does, it has: max-brightness : Maximum brightness possible for the LED Enric >> Another (not directly related) observation is that on minnie the >> actual brightness at a nominal 50% is close to 0 (duty cycle ~3%). I >> haven't tested with other devices, but I wonder if it would make >> sense to have an option to drop the bottom N% of levels, since the >> near 0 brightness in the lower 50% probably isn't very useful in most >> use cases, but maybe it looks different on other devices. > > Eye percieves logarithm(duty cycle), mostly, and I find very low brightness > levels quite useful when trying to use machine in dark room. > > But yes, specifying if brightness is linear or exponential would be quite > useful. > Pavel >