Received: by 2002:a25:e74b:0:0:0:0:0 with SMTP id e72csp136533ybh; Mon, 20 Jul 2020 12:19:40 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzhJFZkcsGNY30iZmNzzFs+y2ZQWLqjTmesOjWwZbzRsbCoq3F0xdeKZ7H+dr5sLrFUANGY X-Received: by 2002:a17:906:38d6:: with SMTP id r22mr19355141ejd.219.1595272780211; Mon, 20 Jul 2020 12:19:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1595272780; cv=none; d=google.com; s=arc-20160816; b=McUQMSLnMTcbQVkn5iZ53dwHWAFHmSSrxC+wKb5MuENatTHNboOiQPD6gjN+ski2pU Hv/h9YejdKBudaBunkyyHAerfG202DCp5KhjmGUen5zi7DDWH27Ks9jsMhA9WpoUT8OM zMbXuidWUHH2HHYFOZU97QmSIXMyJxc8FGEko22bFAzeliImh5CLh3/1YW5oi/Yjzv2+ EBiXk7XvUrHRHrmF7WEx1Y4W9yJIsJDuzYPCBvIw8oHBLBnt4o6YZKlae47wyK/+JD75 k1A99W9r4Ll7WfUP/1ct+W5cROTPeymLucXBY6x8xOOb5SvsL590e7M84opLOXRaKFFQ etKg== 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 :message-id:date:subject:cc:to:from:dkim-signature; bh=yaZqAO3nKIfmNsrLqv5DBCPJCzdK9eS546Xyk4jyW9M=; b=Tu4oUAVBHhe6rEDSF4ZALjq40pURWn1lwO8S+2J0jPFVEpgqogN7aMeMLM2NOAYqKm xhRU5hue2PYa8WYS2wQGyk5P2pJDBeAMCl2ihHtr2Ww0bcb43MqnFU8AaSZTPpAIOg5Y RDB/Yu3pUQCHfzkMboSXTfLjHmV6H3MmKGw+c+00YNX/9xEijVnEZMmP1ET2M+aHsSdA s6QUS3DAPOnzpMZ5f9WhsCfPwFfLqe4hz9g786/acl2dMR2B65Tc0cZmwE4k94YKz/tj wadytuvwB2aoKHLIkTWcRz1AMUysS5MejH2wosdJ6/GT0exhUzsjsVH9BDu8b2kvWewF xT1w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@beagleboard-org.20150623.gappssmtp.com header.s=20150623 header.b=H+amt+np; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id gl18si10586102ejb.588.2020.07.20.12.19.17; Mon, 20 Jul 2020 12:19:40 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@beagleboard-org.20150623.gappssmtp.com header.s=20150623 header.b=H+amt+np; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730928AbgGTTSO (ORCPT + 99 others); Mon, 20 Jul 2020 15:18:14 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44410 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729093AbgGTTSN (ORCPT ); Mon, 20 Jul 2020 15:18:13 -0400 Received: from mail-wm1-x341.google.com (mail-wm1-x341.google.com [IPv6:2a00:1450:4864:20::341]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 66522C0619D2 for ; Mon, 20 Jul 2020 12:18:13 -0700 (PDT) Received: by mail-wm1-x341.google.com with SMTP id q15so575072wmj.2 for ; Mon, 20 Jul 2020 12:18:13 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=beagleboard-org.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=yaZqAO3nKIfmNsrLqv5DBCPJCzdK9eS546Xyk4jyW9M=; b=H+amt+npvX6KeGem+yMAg+AytnxNVrgytC9J++r9xdn9WFECt5ptyKvMmOQuW3wOgb hY3oCDsRRs58U3AMFtvo/WBy2nyN1AeFd1mHzp4unfFJnsGNk3ASB0zLJg8aw3LI1nXb NHncGxOI2uDd8RdVVDqvEMOrSmyIYRUUUGYMk5UkZfInVQR5LBPMGrF2KInKIo/WhyjM K1O27qZe3NoHk8/GEYFCs4mBc4Isj2i14W5qLzMlMIyns9vXbwK1cIbbCIpI3Wd3c6Z5 A4tmfx3nhFBLCqh50edU/PtGJa+wlPyxfV2P7XjMmITxBbIyuGG12KoNlwp7jUxHE1du 5T1Q== 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:mime-version :content-transfer-encoding; bh=yaZqAO3nKIfmNsrLqv5DBCPJCzdK9eS546Xyk4jyW9M=; b=Drsjo2z2xXJUNrbbIk2ddtCOErWNvGhSQdgCRSGfVqmPvPqY+fzDjd33EuRgZemPMM yz0xbQgM+DzL5kkqEsrl/O0ppr4Egu0UShF12oIEkCmwpJqaP5zC4orpQU7POG7GE5I0 nDylclA2QuLpfXOAQZ5cGpma3RPA7GuALmsV2mwRYZnRKKuuRd5i0OJfM78tZz9zugHU JnoHV7QdI5s/M6WoG4OgztbsJkbZrd1Ft2F1uXjPcot5o/PXJ64UHYOQSVutnJGCr8Qe SHsiONV5Eg2UeQcyi9gDfoiZYq4pWtQlkCMQtE6Z3kK7qqGiBLs2Kc97+EcxNoYa1s1z oBqA== X-Gm-Message-State: AOAM533CtmOxgDtVMqxggnBgNjlcKHPe0b8Ag7cXHSdkTPqN8Syrl1WR RwH1Q6mvKWOQxV0N1BBt5Ywvzw== X-Received: by 2002:a1c:a557:: with SMTP id o84mr728057wme.42.1595272692062; Mon, 20 Jul 2020 12:18:12 -0700 (PDT) Received: from localhost.localdomain (50.red-80-27-209.dynamicip.rima-tde.net. [80.27.209.50]) by smtp.gmail.com with ESMTPSA id t4sm666716wmf.4.2020.07.20.12.18.10 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 20 Jul 2020 12:18:10 -0700 (PDT) From: Drew Fustini To: Andy Shevchenko , Tony Lindgren , Linus Walleij , linux-omap@vger.kernel.org, linux-gpio@vger.kernel.org, linux-kernel@vger.kernel.org, Jason Kridner , Robert Nelson Cc: Drew Fustini Subject: [PATCH v2] pinctrl: core: print gpio in pins debugfs file Date: Mon, 20 Jul 2020 21:17:41 +0200 Message-Id: <20200720191740.1974132-1-drew@beagleboard.org> X-Mailer: git-send-email 2.25.1 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 If there is a gpio range mapping for the pin, then print out the gpio number for the pin in the debugfs 'pins' file. Here is an example output on the BeagleBone Black from: /sys/kernel/debug/pinctrl/44e10800.pinmux-pinctrl-single/pins pin 100 (PIN100) gpiochip:gpio-96-127 line-name:P1.36 [PWM0A] 44e10990 00000001 pinctrl-single pin 101 (PIN101) gpiochip:gpio-96-127 line-name:P1.33 [PRU0.1] 44e10994 00000027 pinctrl-single pin 102 (PIN102) gpiochip:gpio-96-127 line-name:P2.32 [PRU0.2] 44e10998 00000027 pinctrl-single pin 103 (PIN103) gpiochip:gpio-96-127 line-name:P2.30 [PRU0.3] 44e1099c 00000027 pinctrl-single pin 104 (PIN104) gpiochip:gpio-96-127 line-name:P1.31 [PRU0.4] 44e109a0 0000002c pinctrl-single pin 105 (PIN105) gpiochip:gpio-96-127 line-name:P2.34 [PRU0.5] 44e109a4 00000027 pinctrl-single pin 106 (PIN106) gpiochip:gpio-96-127 line-name:P2.28 [PRU0.6] 44e109a8 00000027 pinctrl-single pin 107 (PIN107) gpiochip:gpio-96-127 line-name:P1.29 [PRU0.7] 44e109ac 00000027 pinctrl-single pin 108 (PIN108) gpiochip:gpio-0-31 line-name:P2.31 [SPI1_CS] 44e109b0 00000027 pinctrl-single pin 109 (PIN109) gpiochip:gpio-0-31 line-name:P1.20 [PRU0.16] 44e109b4 00000027 pinctrl-single pin 110 (PIN110) NA 44e109b8 00000030 pinctrl-single pin 111 (PIN111) NA 44e109bc 00000028 pinctrl-single pin 112 (PIN112) NA 44e109c0 00000030 pinctrl-single pin 113 (PIN113) NA 44e109c4 00000028 pinctrl-single pin 114 (PIN114) NA 44e109c8 00000028 pinctrl-single pin 115 (PIN115) NA 44e109cc 00000028 pinctrl-single Suggested-by: Andy Shevchenko Suggested-by: Tony Lindgren Signed-off-by: Drew Fustini --- drivers/pinctrl/core.c | 30 ++++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) v2 changes: - only include GPIO information if CONFIG_GPIOLIB - print gpiochip and line name instead of global GPIO number diff --git a/drivers/pinctrl/core.c b/drivers/pinctrl/core.c index 821242bb4b16..b61fab96c5c2 100644 --- a/drivers/pinctrl/core.c +++ b/drivers/pinctrl/core.c @@ -27,6 +27,7 @@ #include #ifdef CONFIG_GPIOLIB +#include "../gpio/gpiolib.h" #include #endif @@ -1601,6 +1602,11 @@ static int pinctrl_pins_show(struct seq_file *s, void *what) struct pinctrl_dev *pctldev = s->private; const struct pinctrl_ops *ops = pctldev->desc->pctlops; unsigned i, pin; + struct pinctrl_gpio_range *range; + unsigned int gpio_num; + struct gpio_chip *chip; + struct gpio_desc *gdesc; + seq_printf(s, "registered pins: %d\n", pctldev->desc->npins); @@ -1618,6 +1624,30 @@ static int pinctrl_pins_show(struct seq_file *s, void *what) seq_printf(s, "pin %d (%s) ", pin, desc->name); +#ifdef CONFIG_GPIOLIB + gpio_num = 0; + list_for_each_entry(range, &pctldev->gpio_ranges, node) { + if ((pin >= range->pin_base) && + (pin < (range->pin_base + range->npins))) { + gpio_num = range->base + (pin - range->pin_base); + break; + } + } + if (gpio_num > 0) { + chip = gpio_to_chip(gpio_num); + if (chip != NULL) { + if (chip->label) + seq_printf(s, "gpiochip:%s ", chip->label); + } + gdesc = gpio_to_desc(gpio_num); + if (gdesc != NULL) + if (gdesc->name) + seq_printf(s, "line-name:%s ", gdesc->name); + } else { + seq_puts(s, "NA "); + } +#endif + /* Driver-specific info per pin */ if (ops->pin_dbg_show) ops->pin_dbg_show(pctldev, s, pin); -- 2.25.1