Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp11880072imu; Tue, 1 Jan 2019 08:48:38 -0800 (PST) X-Google-Smtp-Source: ALg8bN4TxlPsbUMsdMURH2BblisFLCmbRTnXX9UanK8/cf52fSDau+dw7Uoe9tY5LIb7yj20nIlI X-Received: by 2002:a63:f201:: with SMTP id v1mr10341969pgh.232.1546361318884; Tue, 01 Jan 2019 08:48:38 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1546361318; cv=none; d=google.com; s=arc-20160816; b=M44jygAVs1CC9wNr+RktUEUFmrl5t3phSTQMS280n+0R9cqAEIemy5VMoY9K5SoKBy M77npS+UpOYVDfO9Ofrlo2D0B49EYAZvQn+a0yn9XD6JnuVZ3b/KVdEPKNoz3X7M1m3l vn44YeoIoFG2S/A06idRBda0Vzk624pPI9avDubnEd+uYkrIuGHZeGj+vwfWV3spRjCL vlhS/I+MrDwDGyxv3ZXXZs7IJ3S6S1xMSXJR1gRYIsMza++XwAjn4wov3heJRijz6mdC bVaGd/HbBGw8GPFHaBuRmcHaPga+60nW2Hcl6jgs3uhwViP5FaM+P93G43SurchTO3aN FK3g== 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:references:cc:to:from:subject:dkim-signature; bh=o2z4H14agerhx3ZWVsYjp2VFXAfFy62GGUEhmyu6iWo=; b=t9Le7pbZj+GKwJv0bHdiZSYsG2b/BVS5bqvGhQFSPRTsAoNOAcqZWoIQ7uJpAcIr6l U0Ob9Sccq4plt/iR4Qx2uv1Dsczbr3po+SN2cVD0Y2tDDQNrjDkl35Ojc7ntbMzt9LpZ Gdi0EJ6E+slIZJ7XKvfLc/vaFtB6P9JXzvTxYx5YYn2jGkSF2Py31nfzxjyfJZfLwhnu t5FYeaWDiUAoOLHxNwgaxmeh6yD3anV9IBGgMzzCinsVtlSCeZgWr7bcm+a4FUnTZqaP 1JhOsmM3N/yOhQU/tb2XLe6WOGDcuwSNrPntiqb/vKM+69ZSQIdLujxfWd3Mck0K75PB oajQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b="G1/bZS7r"; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x6si6145578pln.425.2019.01.01.08.48.20; Tue, 01 Jan 2019 08:48:38 -0800 (PST) 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=@gmail.com header.s=20161025 header.b="G1/bZS7r"; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728827AbfAANpx (ORCPT + 99 others); Tue, 1 Jan 2019 08:45:53 -0500 Received: from mail-lj1-f194.google.com ([209.85.208.194]:35325 "EHLO mail-lj1-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727224AbfAANpx (ORCPT ); Tue, 1 Jan 2019 08:45:53 -0500 Received: by mail-lj1-f194.google.com with SMTP id x85-v6so25159879ljb.2; Tue, 01 Jan 2019 05:45:49 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:from:to:cc:references:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=o2z4H14agerhx3ZWVsYjp2VFXAfFy62GGUEhmyu6iWo=; b=G1/bZS7rQCP6iSgwWOs42hrbhlg59hR30dedgJi/4LaUHiWDtVObQFm6Gq0INnadjF eSG150ejULFTpOxi1FDvT+0FUuN9S6tswco8KBDtJaHc290o9A/MFkPXPNkjSTtPtWLg Vvul/fLfn++v5Lq36Dv/LyXyK+ARQnZdrYS//39JRArr6b+bOqP0vjVhH7VGZfqaNcYX HoB/7izFzR89LSCvxzmu8FY2zqefHfkLM00iMhweHgYUqCFM2Kzy7NS42mCP4N1Vk0vj ZTGEz2u0si4oIWDs6iqpzpUbiJjCRf4s8x4J+nDO5q/3FqDBYV8mwWxFfXvXod5XAmOF 6GgQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:from:to:cc:references:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=o2z4H14agerhx3ZWVsYjp2VFXAfFy62GGUEhmyu6iWo=; b=d2isPrBoFiqh/88fzv16jtrpC6Wqj2gPQyTU2M9/j2ZOwRfoeE+jV6kC04jvVQz4VB 3DLF2EgtJRizwc647F9+9vKYruaTlzHxVHLAej18PC/MyviHZ1mE390N3bz562nwbxCJ tlM8PBflJL6Qx4sxOZeBOafrFuIybOopvXHLIK3QdyCf+S81ijX84rb/rmIUEYVCU5Pw Y9m6+NqZEwpHz0Kq7oTordYCEW4MOdQBfHZ+M4ZDiQEuqW3NvwBHzvu/rsP7slq20Erk GLCK94b3jwnsMRHsrXxxJ1gmprheWFeyPm9+DOXt98J1fTR/iuodd/leRSyKN8dyPiqU NMkA== X-Gm-Message-State: AJcUukfREq5MljtHhkFKRxrfuPC03RcPI7cTKMqmCHWubEJXf/v8zvwK XyIehGZZ0ANTMNV5XoQkfZX1vK9WLeY= X-Received: by 2002:a2e:750a:: with SMTP id q10-v6mr18417904ljc.39.1546350348629; Tue, 01 Jan 2019 05:45:48 -0800 (PST) Received: from ?IPv6:2001:14ba:8017:3300:a8d6:b9d0:3570:3f11? (dtynxhygk6689yqntj8kt-3.rev.dnainternet.fi. [2001:14ba:8017:3300:a8d6:b9d0:3570:3f11]) by smtp.googlemail.com with ESMTPSA id u15-v6sm11793572lja.63.2019.01.01.05.45.47 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Tue, 01 Jan 2019 05:45:47 -0800 (PST) Subject: Re: [PATCH 2/2] leds: lp5024: Add the LP5024/18 RGB LED driver From: =?UTF-8?B?VmVzYSBKw6TDpHNrZWzDpGluZW4=?= To: Dan Murphy , Jacek Anaszewski , Pavel Machek Cc: robh+dt@kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-leds@vger.kernel.org References: <20181219162626.12297-1-dmurphy@ti.com> <20181219162626.12297-3-dmurphy@ti.com> <20181219193455.GA21159@amd> <8740cfd6-a6b5-ad27-313b-984a9febf18a@ti.com> <20181219201047.GA23448@amd> <54f28115-0a7d-8e9c-3bec-6e91fb3981ec@gmail.com> Message-ID: <986b5105-2fdb-bd25-7c8a-ca8fd1ade821@gmail.com> Date: Tue, 1 Jan 2019 15:45:46 +0200 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.14; rv:60.0) Gecko/20100101 Thunderbird/60.3.3 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi All, On 20/12/2018 14.40, Vesa Jääskeläinen wrote: > Idea was to define preset colors in device tree as an example when you > are dealing with multi-color LEDs without PWM. In that case you only > have GPIOs to control and then have a problem what does those GPIO's mean. > > With preset definitions one can use color names to act as a shortcut to > configure GPIO's to proper state for that particular color. > > For more flexible setups where you have PWM or such control you have > larger space of available colors. In this case you need to somehow > define also meaning of those controls. > > Also we may not have LED with only red, green and blue elements. There > might in example be amber, ultraviolet, white elements. > > This is where device tree is concerned. It helps us craft the logical > definition for LED so that we can control it from user space in common way. > > Now the next problem then is how does user space work then. > > For multi-color LEDs it it important to change the color atomically so > that no wrong colors are being shown as user space got interrupted when > controlling it. > > Also we have brightness setting that would be useful for PWM controlled > LEDs. > > Setting color is easy when you use preset names then you only need to > deal with brightness value (eg. RGB -> HSV * brightness -> RGB). Of > course here additional problem is other color elements are they then > scaled according to brightness value?. > > Setting color as "raw" values is then next problem. In order to do it > atomically it needs to be one atomic activation and could be eg. one > write to "color" sysfs entry with combination of all color elements and > perhaps additionally also brightness value. Next question is then what > is the format for such entry then? What are the value ranges? In here we > can utilize device tree definition to help define what kind of LED we do > have and what kind of capabilities it does have. > > Additional problem risen also in discussion was non-linearity of some > control mechanisms vs. perceived color. So there might be a need for > curve mapping similarly what is with backlight control and that would be > defined either in device tree and possibly in user space if there is a > need for that. I suppose golden curve definition in device tree should > be good enough. > > Then there was additional discussion about possible animation support > but I would leave that for future design as that would then be utilizing > the same framework. > > I suppose color space handling and that kind of stuff should be in some > led core functionality and then raw control should be part of physical > led driver. > > I was planning to play with it during holiday season but lets see how it > goes. Feel free to also experiment with the idea. I was playing with this and got some results with PWM LED driver. I would like to get feedback now even thou it is not yet ready for patch sending. They still need more work but the idea can be seen here: https://github.com/vesajaaskelainen/linux/tree/wip-multi-color-led This branch is now based on Linux kernel 4.20 release. Consider that branch as volatile as I will forcibly update it when there are updates. From there specifically in commits (while they last): drivers: leds: Add core support for multi color element LEDs https://github.com/vesajaaskelainen/linux/commit/55d553906d0a158591435bb6323a318462079d59 WIP: drivers: leds: leds-pwm: Add multi color element LED support. https://github.com/vesajaaskelainen/linux/commit/efccef08cbf3b2e1e49b95b69ff81cd380519fe3 What is there now: - led-core supports color elements - led-class supports users space configuration - both led-core and led-class are driver agnostic so they should be treated as generic code. - leds-pwm: my testing code with PWM led. - no HSV support for brightness as there could be multiple color elements out from traditional red-green-blue space or odd combinations of colors and they are a bit hard to map to HSV formula (and it needs fixed point math). - no color presets that could be optionally be selected - when I configure led trigger to heartbeat it actually blinks with color specified -- thou trigger gets zeroed out with one sets new color or brightness as that was previous functionality with brightness. - some documentation added - code should pass checkpatch What I was planning to do next: - cleanup PWM LED driver so that it works with and without LED_MULTI_COLOR_LED being defined. - improve documentation - try out how my other device behaves which have dual color element LED controlled with GPIO's and see how it would integrate to gpio-led driver. I would like to get feedback on: - Device tree idea - Internal logic - Should the trigger be really reseted when one changes value of brightness? I would think it should function like setting brightness entry from sysfs would set current brightness for trigger when it is lit. Setting color should change color and brightness and it should be active from there one until trigger is disabled from trigger sysfs node. My testing device has RGB LED with all color elements controlled with individual PWM channels from TI's AM335x's integrated PWM controller. In device tree I have following: multi-color-leds { compatible = "pwm-leds"; status-led { label = "status"; element-red { pwms = <&ehrpwm0 0 100000 0>; }; element-green { pwms = <&ehrpwm1 0 100000 0>; }; element-blue { pwms = <&ehrpwm1 1 100000 0>; }; }; }; For my second test device I was planning to replace "pwms" with "gpios" or such entries. In user space one can use it like: # --- start of snippet --- hostname ~ # cd /sys/class/leds/ hostname leds # ls status hostname leds # cd status hostname status # ls brightness color device max_brightness max_color power subsystem trigger uevent hostname status # cat color brightness=0 red=0 green=0 blue=0 # some notes about color value here. # - red, green, and blue are directly coming from device tree # definition. if one would add eg. element-white or element-uv entries # then they would appear here as well. # - brightness is hardcoded entry hostname status # cat max_color brightness=255 red=255 green=255 blue=255 hostname status # cat brightness 0 hostname status # cat max_brightness 255 # Set color and brightness to maximum values eg. "white" hostname status # cat max_color > color # Zero out red and green elements to make color blue hostname status # echo "red=0 green=0" > color # Configure individual color elements hostname status # echo "red=55 green=22 blue=11" > color # Start with max brightness and then dim it with each step hostname status # echo 255 > brightness hostname status # echo 128 > brightness hostname status # echo 32 > brightness # And finally with brightness=0 LED is OFF hostname status # echo 0 > brightness # --- end of snippet --- About color presets... I believe the optional color preset thing could work like: multi-color-leds { compatible = "pwm-leds"; status-led { label = "status"; element-red { pwms = <&ehrpwm0 0 100000 0>; }; element-green { pwms = <&ehrpwm1 0 100000 0>; }; element-blue { pwms = <&ehrpwm1 1 100000 0>; }; color-orange = 255,128,0; }; }; Then in user space: hostname status # echo "orange" > color or with combined brightness: hostname status # echo "brightness=255 orange" > color But then again -- I am a bit unsure here myself is it a good idea. I need to try out how the dual color element GPIO LED variant works first. My current hunch is that we might not need the color presets as one can now set all color elements in one go. It just changes a bit logic how it is used. With dual color element LED with GPIO control it might as well be: # for orange: echo "brightness=255 red=255 green=128" > color # or max value as GPIO led doesn't really care: echo "brightness=255 red=255 green=255" > color # for red: echo "brightness=255 red=255 green=0" > color # for green: echo "brightness=255 red=0 green=255" > color # for off: echo "brightness=0" > color # or echo 0 > brightness Thanks, Vesa Jääskeläinen