Received: by 2002:ac0:950c:0:0:0:0:0 with SMTP id f12csp3275360imc; Wed, 13 Mar 2019 13:27:30 -0700 (PDT) X-Google-Smtp-Source: APXvYqxef6lNnCARHViulVkF52b3INm1KtH0olEe0j4X4XiP+Pr8YzkWRzkGwZY6k5f1vDJU55KG X-Received: by 2002:a17:902:8497:: with SMTP id c23mr773098plo.99.1552508850504; Wed, 13 Mar 2019 13:27:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1552508850; cv=none; d=google.com; s=arc-20160816; b=QhM15OEu2YnI9FtXAHEvBBQD3e1g6rftCdSGLXpXtWijteAt1WnCaPm7EpWNJogo/i 7hS1NYUTbqY5HuGe+FVuJXdODDH2M5HbxpomfPnZDGPpLJ5ymhWqTvF2tQ39KhleaxQO tFx/AMZX4pM6La0AxESMsL9XO0c6bBxjvjmXeGyDodPRTRyTe1B2xjGpx7wQFVuYeiuJ 3RKSja3eSeRo9yRIHE29GPrtxq0vYxPE+RzQfmiBxRAMGvkdj9Rv9DnmWeNiubEi+Yrx FoEbfEZ9NhmK7lPVJoAxkxu22rHIWDcQkNB9cwPT1HnY4Uf5DtevoDJmncZ6hdh08VM3 drdA== 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:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=391achGSbEwlOcz+XVWozH1Rc+0QP7rUHnU2cfCzNwc=; b=laY9yjKsy3f6612jWAU6kBvWpy5zNTuJxoZEUGYsTSBhsCKWaX9ppItfJlw7mtiEQv 7HogaWNOZzqMNvZUau7j9K1DTxIr3dyJ7g04DH21NRPK59dhaeog8eBf517TYjYkIhsT oVW06O52KccxEAtYXqr/cs8bh89Jc+2ftE6v1lyOUPHpI/5VwSF0dLiD3RJfiGAeWwsK xLwjxCA1OI4toOK+xIXDTu815pI+9g7WORQ1Hp4COriv8p4+2aZBazVE1E/68NxSDDF0 MQXP9i9HXm/e+xNFBXeavhIIsTKMxdh5BkNqBYK3P/x4sXC8fyov1Zk4OWvNp3q9vVEq 143g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@rasmusvillemoes.dk header.s=google header.b=KaX15mB5; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id y19si11703204pfc.229.2019.03.13.13.27.14; Wed, 13 Mar 2019 13:27:30 -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=@rasmusvillemoes.dk header.s=google header.b=KaX15mB5; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727386AbfCMU0j (ORCPT + 99 others); Wed, 13 Mar 2019 16:26:39 -0400 Received: from mail-ed1-f68.google.com ([209.85.208.68]:39440 "EHLO mail-ed1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727315AbfCMU0Z (ORCPT ); Wed, 13 Mar 2019 16:26:25 -0400 Received: by mail-ed1-f68.google.com with SMTP id p27so2700028edc.6 for ; Wed, 13 Mar 2019 13:26:23 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=rasmusvillemoes.dk; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=391achGSbEwlOcz+XVWozH1Rc+0QP7rUHnU2cfCzNwc=; b=KaX15mB5igIUUWZAPZiEgalxtbUj0wwluQRyzctZsOEbWsvMLuMNrKMDqHmSUkCcIC EjxYEa9/hMcYWsYOZ0vT8RdDrtNYks7wU7AZikdqVfMf0hrd8+OAJWZiQVgg95D5zrif FFrpNfNy1dOSIcOpm6ykf+iTdYa1wSYSDDNDI= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=391achGSbEwlOcz+XVWozH1Rc+0QP7rUHnU2cfCzNwc=; b=Mi28q3QGt9ZmcrqZXupjnojcYng60Xs583wF3NYo8oyAmVLF1IqN9JZMTdBS3aAr9E AWd7mTHh0bm8LOMubrbHWcoLmFjSskQzuT/115S0gNhDsSty+exJAGFlt/HFqKEMytqx D/TeHzYj5XckfwTnZkEImQJBuX/Av91TmLvXgf9ZW1kKcOMqRfXN6xCY2iz2H1Pno0Uj oU7PDrEg0cwMPgjGN745GrD5Ff7qHf1yp/5fPaPzoEKFwbJ7Cx2hFYEwR02GanSq8mK2 AHSujPTSQ2NO/hiHbDgvfU0+637qjgZ1HQwIVoz9gXofXjLu9y/6dXsXDTiVxU0B9/Lf YnSA== X-Gm-Message-State: APjAAAVaynwGwk79DB9q76AYMe17dQaT4LDcCxtl2tvVwPu3roty1xDY HkSpQLW2/6xJfIOAJ+KqGhJP+g== X-Received: by 2002:a50:b613:: with SMTP id b19mr8854964ede.214.1552508783213; Wed, 13 Mar 2019 13:26:23 -0700 (PDT) Received: from prevas-ravi.prevas.se (ip-5-186-119-202.cgn.fibianet.dk. [5.186.119.202]) by smtp.gmail.com with ESMTPSA id m32sm940170edc.17.2019.03.13.13.26.22 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 13 Mar 2019 13:26:22 -0700 (PDT) From: Rasmus Villemoes To: Pavel Machek , =?UTF-8?q?Uwe=20Kleine-K=C3=B6nig?= , Jacek Anaszewski Cc: LKML , Rasmus Villemoes , linux-leds@vger.kernel.org, devicetree@vger.kernel.org, linux-can@vger.kernel.org, netdev@vger.kernel.org Subject: [PATCH 4/4] leds: netdev trigger: allow setting initial values in device tree Date: Wed, 13 Mar 2019 21:26:15 +0100 Message-Id: <20190313202615.22883-5-linux@rasmusvillemoes.dk> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190313202615.22883-1-linux@rasmusvillemoes.dk> References: <20190311144227.GA4404@amd> <20190313202615.22883-1-linux@rasmusvillemoes.dk> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org It can be quite convenient to initialize a netdev-triggered LED with a device name and setting the rx,tx,link properties from device tree, instead of having to do that in an init script in userspace. My main motivation for this is to be able to switch away from the deprecated CONFIG_CAN_LEDS, so add an example based on that and add a pointer in the net/can/Kconfig file. Signed-off-by: Rasmus Villemoes --- .../devicetree/bindings/leds/common.txt | 17 ++++++++++ drivers/leds/trigger/ledtrig-netdev.c | 31 +++++++++++++++++++ drivers/net/can/Kconfig | 3 +- 3 files changed, 50 insertions(+), 1 deletion(-) diff --git a/Documentation/devicetree/bindings/leds/common.txt b/Documentation/devicetree/bindings/leds/common.txt index 7cb88460a47c..4f3a97e73417 100644 --- a/Documentation/devicetree/bindings/leds/common.txt +++ b/Documentation/devicetree/bindings/leds/common.txt @@ -43,6 +43,23 @@ Optional properties for child nodes: Documentation/ABI/testing/sysfs-class-led-trigger-netdev) to reflect the state and activity of a net device. + The optional child node netdev can be used to + configure initial values for the link, rx, tx and + device_name properties. For example, setting + linux,default-trigger = "netdev" and adding the child + node + + netdev { + rx; + tx; + link; + device-name = "can0"; + }; + + can be used to replace 'linux,default-trigger = + "can0-rxtx"' that relies on the deprecated + CONFIG_CAN_LEDS. + - led-pattern : Array of integers with default pattern for certain triggers. Each trigger may parse this property differently: - one-shot : two numbers specifying delay on and delay off (in ms), diff --git a/drivers/leds/trigger/ledtrig-netdev.c b/drivers/leds/trigger/ledtrig-netdev.c index 55153a7e8433..1f7c86df1e91 100644 --- a/drivers/leds/trigger/ledtrig-netdev.c +++ b/drivers/leds/trigger/ledtrig-netdev.c @@ -20,6 +20,7 @@ #include #include #include +#include #include #include #include "../leds.h" @@ -395,6 +396,35 @@ static void netdev_trig_work(struct work_struct *work) (atomic_read(&trigger_data->interval)*2)); } +static void netdev_trig_of_init(struct led_classdev *led_cdev, + struct led_netdev_data *trigger_data) +{ + struct device_node *np = led_cdev->dev->of_node; + const char *device_name; + + if (!np) + return; + np = of_get_child_by_name(np, "netdev"); + if (!np) + return; + + if (of_property_read_bool(np, "link")) + __set_bit(NETDEV_LED_LINK, &trigger_data->mode); + if (of_property_read_bool(np, "tx")) + __set_bit(NETDEV_LED_TX, &trigger_data->mode); + if (of_property_read_bool(np, "rx")) + __set_bit(NETDEV_LED_RX, &trigger_data->mode); + if (!of_property_read_string(np, "device-name", &device_name)) { + unsigned len = strlen(device_name); + + if (len < IFNAMSIZ) + set_device(trigger_data, device_name, len); + } + set_baseline_state(trigger_data); + + of_node_put(np); +} + static int netdev_trig_activate(struct led_classdev *led_cdev) { struct led_netdev_data *trigger_data; @@ -418,6 +448,7 @@ static int netdev_trig_activate(struct led_classdev *led_cdev) trigger_data->mode = 0; atomic_set(&trigger_data->interval, msecs_to_jiffies(50)); trigger_data->last_activity = 0; + netdev_trig_of_init(led_cdev, trigger_data); led_set_trigger_data(led_cdev, trigger_data); diff --git a/drivers/net/can/Kconfig b/drivers/net/can/Kconfig index e0f0ad7a550a..91703a96b636 100644 --- a/drivers/net/can/Kconfig +++ b/drivers/net/can/Kconfig @@ -77,7 +77,8 @@ config CAN_LEDS # everything that this driver is doing. This is marked as broken # because it uses stuff that is intended to be changed or removed. # Please consider switching to the netdev trigger and confirm it - # fulfills your needs instead of fixing this driver. + # fulfills your needs instead of fixing this driver. See e.g. + # Documentation/devicetree/bindings/leds/common.txt depends on BROKEN select LEDS_TRIGGERS ---help--- -- 2.20.1