Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp3711102imm; Sat, 25 Aug 2018 00:53:00 -0700 (PDT) X-Google-Smtp-Source: ANB0VdbNgBqgbOsrbKTcbY1l19TQqZ2siMAwvNbZmHWTX6PUlLolxShpireSX6+2Hfn0gRrDFFdM X-Received: by 2002:a62:6a01:: with SMTP id f1-v6mr5221214pfc.156.1535183579981; Sat, 25 Aug 2018 00:52:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1535183579; cv=none; d=google.com; s=arc-20160816; b=Y/RExNcRlx78LhZMML0UwelZaN1Ep2STPH6AgeNp03Mzd7K8JBmD6Y30IeWKLr8f3f HJMCRyPQOU34nFW5qB/qQ5O2GV9HhooGQm5ePuhAyhiCui4rZxta/C4gvGEUsLxDxara fohWsEviB7E5ZkvOShFD/DpuwKSPYTl2LiPLAFFg/TfS3YSstmJc0rq3WE/dieiogFB3 K9U9t0DDvMeDuZu1vqxq41F8uFUbDYhpqd1Uobr9tzEa86TcpLV9/Wx6bPk4oehwHvKN p0ILeCJLsaZ7+53dEmeyu1Cv8SocquyVoh3NmLQd/sNBJzpL/YQXodvscHWeOV/wggNs xUhw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :references:in-reply-to:mime-version:dkim-signature :arc-authentication-results; bh=w94XvNIDaxuxplSz74v/yiDlfPwGt6W09h8RHLWI2ow=; b=KuxsuH3VANtxcyzse2GAgdIA67+JQ7Ey80Zdzv06/9Xnl4E1hpXiOTVlxJHPlKVCLr JgrmENPckERX2OjBYCCHTk8eFRX4cG7A27KZX97/nPIu7vVN1+YiEIimUCO7Qe/Ohcxh 40lPHJCKTq2AT0iZBzBddYIx3eqYPFidcJsxjdwbfOMjd4E31spEFYyWJQ4zeVoS+ynn ekjamW9f2ml5VFDP34y8yNlr6qvMWTGMkJmYSyW2AQddVHdh7/egBNcONCc8S+v9Ezbv i90BaYqdfMMi33q3yXk3LdUbOEJUuLuiEYNa3de2W6OHqsfaweNW7WLLvDNkXDm41kJb O8Jg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=bQ72ohH7; 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 n137-v6si9759449pfd.177.2018.08.25.00.52.42; Sat, 25 Aug 2018 00:52:59 -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=bQ72ohH7; 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 S1726802AbeHYL3l (ORCPT + 99 others); Sat, 25 Aug 2018 07:29:41 -0400 Received: from mail-oi0-f67.google.com ([209.85.218.67]:43600 "EHLO mail-oi0-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726412AbeHYL3l (ORCPT ); Sat, 25 Aug 2018 07:29:41 -0400 Received: by mail-oi0-f67.google.com with SMTP id b15-v6so19171484oib.10 for ; Sat, 25 Aug 2018 00:51:34 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=mime-version:in-reply-to:references:from:date:message-id:subject:to :cc; bh=w94XvNIDaxuxplSz74v/yiDlfPwGt6W09h8RHLWI2ow=; b=bQ72ohH7lqSS0b7sqBFuc13NAUKa8Dgh8gLd3VChuMvvoA2LVLkpFhUdciJ2piiK/w 93zz+8J+eOZ6hu17A5/jKlTupGE+trCXFY0MYS6fsLdtSekN2SxqOfB/2zwY57BUOR9n sekurPV7H2zit7kbH9iro7s1mCnUuyCDrxecs= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:in-reply-to:references:from:date :message-id:subject:to:cc; bh=w94XvNIDaxuxplSz74v/yiDlfPwGt6W09h8RHLWI2ow=; b=UA/IFZQa5AD3sub1xU1PVt3wW7HHElpi1Ttudj+OxEJeqSvTCQBSnnQdgepiPbOBST Yp/yYGoo5Dmzzl3aCF1hqdF+zjnVHJAtokKLNjwmuZzv3C/+gJpu6NYvHWXoSTzVQMjO KHJjKcWevR7T94x3mWLzV+0VFyvyYK381kaOF8wru6yHSuswTTrPiji7FNLWWWqrFJCs hhYp+YKBMnZPKDdNxD3K6Lx1fT/1AkdLuF2H7p+kuKcM1y/5MdNAre64+ucHlyrG2QXo jzzfrLS/9PFJuWYwlqiS+tuLbP5rr1h2e6RalOfEaZ01BfG5xgy6NSy28phKLef3W9KC aJkA== X-Gm-Message-State: APzg51C9lk8zbNDS7wSErVNofOtfvKVgWIDBE3jtHc8yUFyzHGkZtaTt IgxLiWPyL3ON5jDZeFrDdKljE4fbLD23uMB95aRlWw== X-Received: by 2002:aca:44c5:: with SMTP id r188-v6mr4835681oia.280.1535183494313; Sat, 25 Aug 2018 00:51:34 -0700 (PDT) MIME-Version: 1.0 Received: by 2002:a9d:29:0:0:0:0:0 with HTTP; Sat, 25 Aug 2018 00:51:33 -0700 (PDT) In-Reply-To: References: <1dc5d394324b2bf1ffe229b8e42691fab6d749e0.1533556992.git.baolin.wang@linaro.org> <20180824101145.GA1510@amd> <9bb7ac19-36a6-d11a-6d46-fc65c2026201@gmail.com> <20180824201227.GB17146@amd> From: Baolin Wang Date: Sat, 25 Aug 2018 15:51:33 +0800 Message-ID: Subject: Re: [PATCH v5 1/2] leds: core: Introduce LED pattern trigger To: Jacek Anaszewski Cc: Pavel Machek , rteysseyre@gmail.com, Bjorn Andersson , Mark Brown , Linux LED Subsystem , LKML Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 25 August 2018 at 04:44, Jacek Anaszewski wrote: > On 08/24/2018 10:12 PM, Pavel Machek wrote: >> On Fri 2018-08-24 21:49:50, Jacek Anaszewski wrote: >>> Hi Pavel, >>> >>> On 08/24/2018 12:11 PM, Pavel Machek wrote: >>>> Hi! >>>> >>>>> I think that it would be more flexible if software pattern fallback >>>>> was applied in case of pattern_set failure. Otherwise, it would >>>>> lead to the situation where LED class devices that support hardware >>>>> blinking couldn't be applied the same set of patterns as LED class >>>>> devices that don't implement pattern_set. The latter will always have to >>>>> resort to using software pattern engine which will accept far greater >>>>> amount of pattern combinations. >>>>> >>>>> In this case we need to discuss on what basis the decision will be >>>>> made on whether hardware or software engine will be used. >>>>> >>>>> Possible options coming to mind: >>>>> - an interface will be provided to determine max difference between >>>>> the settings supported by the hardware and the settings requested by >>>>> the user, that will result in aligning user's setting to the hardware >>>>> capabilities >>>>> - the above alignment rate will be predefined instead >>>>> - hardware engine will be used only if user requests supported settings >>>>> on the whole span of the requested pattern >>>>> - in each of the above cases it would be worth to think of the >>>>> interface to show the scope of the settings supported by hardware >>>> >>>> I'd recommend keeping it simple. We use hardware engine if driver >>>> author thinks pattern is "close enough". >>> >>> The thing is that in the ledtrig-pattern v5 implementation there >>> is no option of using software fallback if pattern_set op >>> is initialized: >>> >>> + if (led_cdev->pattern_set) { >>> + return led_cdev->pattern_set(led_cdev, data->patterns, >>> + data->npatterns, data->repeat); >>> + } >> >> Yeah, that sounds wrong. (Sorry I did not pay enough attention). >> >> It pattern_set() returns special error code, it should just continue >> and use software pattern fallback. > > And now we can get back to the issue I was concerned about in the > email you replied to, i.e. what series of [brightness delta_t] tuples > should be written to the pattern file to enable hardware breathing > engine. OK. So now we've made a consensus to use the software pattern fallback if failed to set hardware pattern. How about introduce one interface to convert hardware patterns to software patterns if necessary? diff --git a/drivers/leds/trigger/ledtrig-pattern.c b/drivers/leds/trigger/ledtrig-pattern.c index 63b94a2..d46a641 100644 --- a/drivers/leds/trigger/ledtrig-pattern.c +++ b/drivers/leds/trigger/ledtrig-pattern.c @@ -66,8 +66,15 @@ static int pattern_trig_start_pattern(struct pattern_trig_data *data, return 0; if (led_cdev->pattern_set) { - return led_cdev->pattern_set(led_cdev, data->patterns, - data->npatterns, data->repeat); + ret = led_cdev->pattern_set(led_cdev, data->patterns, + data->npatterns, data->repeat); + if (!ret) + return 0; + + dev_warn(led_cdev->dev, "Failed to set hardware pattern\n"); + + if (led_cdev->pattern_convert) + led_cdev->pattern_convert(led_cdev, data->patterns, &data->npatterns); } data->curr = data->patterns; @@ -106,8 +113,7 @@ static ssize_t repeat_store(struct device *dev, struct device_attribute *attr, if (err) return err; - if (!led_cdev->pattern_set) - del_timer_sync(&data->timer); + del_timer_sync(&data->timer); mutex_lock(&data->lock); @@ -161,8 +167,7 @@ static ssize_t pattern_store(struct device *dev, struct device_attribute *attr, struct pattern_trig_data *data = led_cdev->trigger_data; int ccount, cr, offset = 0, err = 0; - if (!led_cdev->pattern_set) - del_timer_sync(&data->timer); + del_timer_sync(&data->timer); mutex_lock(&data->lock); @@ -232,9 +237,8 @@ static void pattern_trig_deactivate(struct led_classdev *led_cdev) if (led_cdev->pattern_clear) led_cdev->pattern_clear(led_cdev); - else - del_timer_sync(&data->timer); + del_timer_sync(&data->timer); led_set_brightness(led_cdev, LED_OFF); kfree(data); led_cdev->activated = false; diff --git a/include/linux/leds.h b/include/linux/leds.h index 74fc2c6..04f3eaf 100644 --- a/include/linux/leds.h +++ b/include/linux/leds.h @@ -93,6 +93,8 @@ struct led_classdev { struct led_pattern *pattern, int len, unsigned int repeat); int (*pattern_clear)(struct led_classdev *led_cdev); + int (*pattern_convert)(struct led_classdev *led_cdev, + struct led_pattern *pattern, int *len); struct device *dev; const struct attribute_group **groups; -- Baolin Wang Best Regards