From patchwork Mon Jul 18 22:14:50 2016 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: David Hsu X-Patchwork-Id: 72259 Delivered-To: patch@linaro.org Received: by 10.140.29.52 with SMTP id a49csp348617qga; Mon, 18 Jul 2016 15:15:13 -0700 (PDT) X-Received: by 10.98.43.68 with SMTP id r65mr49550094pfr.148.1468880113364; Mon, 18 Jul 2016 15:15:13 -0700 (PDT) Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j10si28876342pax.283.2016.07.18.15.15.13; Mon, 18 Jul 2016 15:15:13 -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=@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=pass (p=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752031AbcGRWO6 (ORCPT + 29 others); Mon, 18 Jul 2016 18:14:58 -0400 Received: from mail-pa0-f46.google.com ([209.85.220.46]:34675 "EHLO mail-pa0-f46.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751427AbcGRWO4 (ORCPT ); Mon, 18 Jul 2016 18:14:56 -0400 Received: by mail-pa0-f46.google.com with SMTP id fi15so146077pac.1 for ; Mon, 18 Jul 2016 15:14:55 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20120113; h=from:to:cc:subject:date:message-id; bh=98QO/oK6gCnmr9RJgPMDheROhCnnLfbuXyczAwqjqSs=; b=A11aPvWjgXgKmWwDTDRP8BnMhep8VG0sAkfywLfaStmqed+XITa0bn/qyavvk1G9Vu OhVd59XUFTsy4uFEcKZX1gUzPv4HLxn4Z6IkzSTCtqigl3SS73Mpmr/klC1QGywbPTMi M1dwnzp3np/iXek6pyes5uKrQp1fVmpa1OsuZEoK2ET0JZ+GaCGGvCctpFVufslo9+aL lNGIeTPjwN5SNHawTYHXVqan2qDDPduSvQwUhyTsBFOQRnTUGszqLJAHgnH8X8Oc514p zkobHHe45JHt2qZ6t6Iq2C3zGdH+KZRDk+JM1M5nScXpME/1vUC/Hx0AmiSd/jGlXdyM b3NA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=98QO/oK6gCnmr9RJgPMDheROhCnnLfbuXyczAwqjqSs=; b=NR/1VKnx/0JVHGoM43PjvxTYXPRiFv1YwxBskxKUWwbzcl1YdMcM8W83c+3UX6a6o8 J77/DwP1fRbyOsiApWyNatS11ALtPjSF9V70bGMQwmd4fNOcWuRJwmrB1NWVcQ8sLJxf rgWLGd/23Ub1KHJhC/6yXywsazuikAvJYTJz1DttjI99lFiVzRQjdJxhFlwaghLOWnq1 ArLD3gnxnEIJoOOXeZob2wsuNEpVySIsDCF2d9DeCix6BsFfcx7bsYjKg2zdBqVNtz7Z /wCFrRDfMZ9/G4gLs01/fYO40uLq+h+3icb0GIjRqQ/T9sOU+lGJE3OuPBkpCLVKuAyQ Wlog== X-Gm-Message-State: ALyK8tJiLmfvr6Wh6VKI6njnDKpr1s7M7xXnnWaeyjUemVX3bLsggWJ3Y+2BuZUzF281dv/4 X-Received: by 10.66.254.39 with SMTP id af7mr59217599pad.37.1468880094870; Mon, 18 Jul 2016 15:14:54 -0700 (PDT) Received: from localhost ([2620:0:1000:6509:dc78:5625:b83e:91ae]) by smtp.gmail.com with ESMTPSA id c64sm7250500pfg.35.2016.07.18.15.14.54 (version=TLS1_2 cipher=AES128-SHA bits=128/128); Mon, 18 Jul 2016 15:14:54 -0700 (PDT) From: David Hsu To: thierry.reding@gmail.com Cc: gregkh@linuxfoundation.org, sspatil@google.com, linux-pwm@vger.kernel.org, linux-kernel@vger.kernel.org, davidhsu@google.com Subject: [PATCH v2] pwm: Create device class for pwm channels Date: Mon, 18 Jul 2016 15:14:50 -0700 Message-Id: <1468880090-46076-1-git-send-email-davidhsu@google.com> X-Mailer: git-send-email 2.8.0.rc3.226.g39d4020 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Pwm channels don't send uevents when exported, this change adds the channels to a pwm class and set their device type to pwm_channel so uevents are sent. To do this properly, the device names need to change to uniquely identify a channel. This change is from pwmN to pwmchipM:N Signed-off-by: David Hsu --- v2: Use parent name instead of chip->base for channel naming. Documentation/pwm.txt | 6 ++++-- drivers/pwm/sysfs.c | 18 +++++++++++++----- 2 files changed, 17 insertions(+), 7 deletions(-) -- 2.8.0.rc3.226.g39d4020 diff --git a/Documentation/pwm.txt b/Documentation/pwm.txt index 789b27c..8453435 100644 --- a/Documentation/pwm.txt +++ b/Documentation/pwm.txt @@ -80,9 +80,11 @@ unexport - Unexports a PWM channel from sysfs (write-only). The PWM channels are numbered using a per-chip index from 0 to npwm-1. -When a PWM channel is exported a pwmX directory will be created in the +When a PWM channel is exported a pwmchipN:X directory will be created in the pwmchipN directory it is associated with, where X is the number of the -channel that was exported. The following properties will then be available: +channel that was exported. It will also be exposed at /sys/class/pwm/ and +can be identified by the pwm_channel device type. +The following properties will then be available: period - The total period of the PWM signal (read/write). Value is in nanoseconds and is the sum of the active and inactive diff --git a/drivers/pwm/sysfs.c b/drivers/pwm/sysfs.c index 01695d4..cb2b376 100644 --- a/drivers/pwm/sysfs.c +++ b/drivers/pwm/sysfs.c @@ -23,6 +23,8 @@ #include #include +static struct class pwm_class; + struct pwm_export { struct device child; struct pwm_device *pwm; @@ -222,6 +224,10 @@ static struct attribute *pwm_attrs[] = { }; ATTRIBUTE_GROUPS(pwm); +static const struct device_type pwm_channel_type = { + .name = "pwm_channel", +}; + static void pwm_export_release(struct device *child) { struct pwm_export *export = child_to_pwm_export(child); @@ -248,9 +254,11 @@ static int pwm_export_child(struct device *parent, struct pwm_device *pwm) export->child.release = pwm_export_release; export->child.parent = parent; + export->child.type = &pwm_channel_type; export->child.devt = MKDEV(0, 0); + export->child.class = &pwm_class; export->child.groups = pwm_groups; - dev_set_name(&export->child, "pwm%u", pwm->hwpwm); + dev_set_name(&export->child, "%s:%u", dev_name(parent), pwm->hwpwm); ret = device_register(&export->child); if (ret) { @@ -355,7 +363,6 @@ ATTRIBUTE_GROUPS(pwm_chip); static struct class pwm_class = { .name = "pwm", .owner = THIS_MODULE, - .dev_groups = pwm_chip_groups, }; static int pwmchip_sysfs_match(struct device *parent, const void *data) @@ -368,14 +375,15 @@ void pwmchip_sysfs_export(struct pwm_chip *chip) struct device *parent; /* - * If device_create() fails the pwm_chip is still usable by + * If device_create_with_groups() fails the pwm_chip is still usable by * the kernel its just not exported. */ - parent = device_create(&pwm_class, chip->dev, MKDEV(0, 0), chip, + parent = device_create_with_groups(&pwm_class, chip->dev, MKDEV(0, 0), + chip, pwm_chip_groups, "pwmchip%d", chip->base); if (IS_ERR(parent)) { dev_warn(chip->dev, - "device_create failed for pwm_chip sysfs export\n"); + "device_create_with_groups failed for pwm_chip sysfs export\n"); } }