From patchwork Wed Apr 29 16:34:44 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Rayagonda Kokatanur X-Patchwork-Id: 1279523 X-Patchwork-Delegate: trini@ti.com Return-Path: X-Original-To: incoming@patchwork.ozlabs.org Delivered-To: patchwork-incoming@bilbo.ozlabs.org Authentication-Results: ozlabs.org; spf=pass (sender SPF authorized) smtp.mailfrom=lists.denx.de (client-ip=2a01:238:438b:c500:173d:9f52:ddab:ee01; helo=phobos.denx.de; envelope-from=u-boot-bounces@lists.denx.de; receiver=) Authentication-Results: ozlabs.org; dmarc=pass (p=quarantine dis=none) header.from=broadcom.com Authentication-Results: ozlabs.org; dkim=pass (1024-bit key; unprotected) header.d=broadcom.com header.i=@broadcom.com header.a=rsa-sha256 header.s=google header.b=fhKH4RtR; dkim-atps=neutral Received: from phobos.denx.de (phobos.denx.de [IPv6:2a01:238:438b:c500:173d:9f52:ddab:ee01]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) by ozlabs.org (Postfix) with ESMTPS id 49C3zc4dNLz9sRf for ; Thu, 30 Apr 2020 02:35:56 +1000 (AEST) Received: from h2850616.stratoserver.net (localhost [IPv6:::1]) by phobos.denx.de (Postfix) with ESMTP id 0E39E82106; Wed, 29 Apr 2020 18:35:50 +0200 (CEST) Authentication-Results: phobos.denx.de; dmarc=pass (p=quarantine dis=none) header.from=broadcom.com Authentication-Results: phobos.denx.de; spf=pass smtp.mailfrom=u-boot-bounces@lists.denx.de Authentication-Results: phobos.denx.de; dkim=pass (1024-bit key; unprotected) header.d=broadcom.com header.i=@broadcom.com header.b="fhKH4RtR"; dkim-atps=neutral Received: by phobos.denx.de (Postfix, from userid 109) id 9063282106; Wed, 29 Apr 2020 18:35:48 +0200 (CEST) X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on phobos.denx.de X-Spam-Level: X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,SPF_HELO_NONE,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.2 Received: from mail-wm1-x343.google.com (mail-wm1-x343.google.com [IPv6:2a00:1450:4864:20::343]) (using TLSv1.3 with cipher TLS_AES_128_GCM_SHA256 (128/128 bits)) (No client certificate requested) by phobos.denx.de (Postfix) with ESMTPS id 8493982123 for ; Wed, 29 Apr 2020 18:35:42 +0200 (CEST) Authentication-Results: phobos.denx.de; dmarc=pass (p=quarantine dis=none) header.from=broadcom.com Authentication-Results: phobos.denx.de; spf=pass smtp.mailfrom=rayagonda.kokatanur@broadcom.com Received: by mail-wm1-x343.google.com with SMTP id u127so2747191wmg.1 for ; Wed, 29 Apr 2020 09:35:42 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=broadcom.com; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=IqzZ7SYUu0iFE+3t2CB6tsMv3jze/764v5pf0sSAbek=; b=fhKH4RtRFypZ5OzANpWQ1R3V+nsbUeLVmKfJcxyBucMK3VelHipT2DId6xR8ATx695 cq0s0LqUXNJqsqX5NG1z6SI1xsj5nr9CpMkw/iG/BTn8lwzcNwTCixZj8lT9QlhCregH OHPgf7YKXMx1MzKq4ckCNmf/lFxgwwoxdykIk= 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; bh=IqzZ7SYUu0iFE+3t2CB6tsMv3jze/764v5pf0sSAbek=; b=FLYYq2SHIb8iJ5ZabCZHyZ5qjg/Ao28eWsYyVs1AZfSv9g1GXN3krSfw//nFXmTQwi GeQt23WBsZjGPwBxtDtL43vjlKL7pzPp9tDK5J53kuPlz/q4WBJXfmBx9AGIjgyCQDaU 7ofMhxyFYBdjzC9MJyWEx4DPvbDYpkzCxxTFy1YfDyfT0JX5j2az3H5DQy52vjOUMAUx KXgem09+n1M43Rk1+WyX/iHVkevmy+Lb9qOdWV00Cu9HMtcHdCea2q6JMxCIG/cY3NJ/ LTI2VFMcpUR2W4mnHhYVvKRkZ3ZjWg9TAFkyYMxrS1NvpUEGr8+qnFtrwpYUKdIBTc0r AUpQ== X-Gm-Message-State: AGi0PuZUoOOC8n8wgErXT+RetfxfATqJDrw5i3d6q1iaznpCno3ccLeN DpkEZJA4hGUeoUyAVlw5fXKzNJlEzJLn92JTgmb1QQ/x3LD6ksUG+/fqTH8Te9XJp7CfZ79bFxV d0+MX2xt357340Zq13Iiurq0KJ5LKlkZ1rBPdLHBXfT6ZfXoDyDSeie9XI6x+3zu+5KP7YU3KOZ IgiNOInA== X-Google-Smtp-Source: APiQypJL2Zq+yU163NoAzR1keTmC0yu+r26NlQzHLCI+NRUmqOy/yd+FVKQOz7u962NQnPLzsvMahA== X-Received: by 2002:a1c:770f:: with SMTP id t15mr4088025wmi.178.1588178141535; Wed, 29 Apr 2020 09:35:41 -0700 (PDT) Received: from rayagonda.dhcp.broadcom.net ([192.19.234.250]) by smtp.gmail.com with ESMTPSA id l6sm31513657wrb.75.2020.04.29.09.35.38 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 29 Apr 2020 09:35:40 -0700 (PDT) From: Rayagonda Kokatanur To: u-boot@lists.denx.de Cc: Simon Glass , Patrick Delaunay , Adam Ford , Lokesh Vutla , Rayagonda Kokatanur Subject: [PATCH v1 1/3] drivers: pinctrl-single: handle different register width Date: Wed, 29 Apr 2020 22:04:44 +0530 Message-Id: <20200429163446.15390-2-rayagonda.kokatanur@broadcom.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200429163446.15390-1-rayagonda.kokatanur@broadcom.com> References: <20200429163446.15390-1-rayagonda.kokatanur@broadcom.com> X-BeenThere: u-boot@lists.denx.de X-Mailman-Version: 2.1.30rc1 Precedence: list List-Id: U-Boot discussion List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: u-boot-bounces@lists.denx.de Sender: "U-Boot" X-Virus-Scanned: clamav-milter 0.102.2 at phobos.denx.de X-Virus-Status: Clean Add support to use different register read/write api's based on register width. Signed-off-by: Rayagonda Kokatanur --- drivers/pinctrl/pinctrl-single.c | 98 ++++++++++++++++++++++++-------- 1 file changed, 74 insertions(+), 24 deletions(-) diff --git a/drivers/pinctrl/pinctrl-single.c b/drivers/pinctrl/pinctrl-single.c index 738f5bd636..aed113b083 100644 --- a/drivers/pinctrl/pinctrl-single.c +++ b/drivers/pinctrl/pinctrl-single.c @@ -10,12 +10,24 @@ #include #include +/** + * struct single_pdata - pinctrl device instance + * @base first configuration register + * @offset index of last configuration register + * @mask configuration-value mask bits + * @width configuration register bit width + * @bits_per_mux + * @read register read function to use + * @write register write function to use + */ struct single_pdata { fdt_addr_t base; /* first configuration register */ int offset; /* index of last configuration register */ u32 mask; /* configuration-value mask bits */ int width; /* configuration register bit width */ bool bits_per_mux; + u32 (*read)(phys_addr_t reg); + void (*write)(u32 val, phys_addr_t reg); }; struct single_fdt_pin_cfg { @@ -23,6 +35,36 @@ struct single_fdt_pin_cfg { fdt32_t val; /* configuration register value */ }; +static u32 __maybe_unused single_readb(phys_addr_t reg) +{ + return readb(reg); +} + +static u32 __maybe_unused single_readw(phys_addr_t reg) +{ + return readw(reg); +} + +static u32 __maybe_unused single_readl(phys_addr_t reg) +{ + return readl(reg); +} + +static void __maybe_unused single_writeb(u32 val, phys_addr_t reg) +{ + writeb(val, reg); +} + +static void __maybe_unused single_writew(u32 val, phys_addr_t reg) +{ + writew(val, reg); +} + +static void __maybe_unused single_writel(u32 val, phys_addr_t reg) +{ + writel(val, reg); +} + struct single_fdt_bits_cfg { fdt32_t reg; /* configuration register offset */ fdt32_t val; /* configuration register value */ @@ -60,18 +102,9 @@ static int single_configure_pins(struct udevice *dev, } reg += pdata->base; val = fdt32_to_cpu(pins->val) & pdata->mask; - switch (pdata->width) { - case 16: - writew((readw(reg) & ~pdata->mask) | val, reg); - break; - case 32: - writel((readl(reg) & ~pdata->mask) | val, reg); - break; - default: - dev_warn(dev, "unsupported register width %i\n", - pdata->width); - continue; - } + val |= (pdata->read(reg) & ~pdata->mask); + pdata->write(val, reg); + dev_dbg(dev, " reg/val 0x%pa/0x%08x\n", ®, val); } return 0; @@ -97,18 +130,8 @@ static int single_configure_bits(struct udevice *dev, mask = fdt32_to_cpu(pins->mask); val = fdt32_to_cpu(pins->val) & mask; - switch (pdata->width) { - case 16: - writew((readw(reg) & ~mask) | val, reg); - break; - case 32: - writel((readl(reg) & ~mask) | val, reg); - break; - default: - dev_warn(dev, "unsupported register width %i\n", - pdata->width); - continue; - } + val |= (pdata->read(reg) & ~mask); + pdata->write(val, reg); dev_dbg(dev, " reg/val 0x%pa/0x%08x\n", ®, val); } return 0; @@ -148,6 +171,32 @@ static int single_set_state(struct udevice *dev, return len; } +static int single_probe(struct udevice *dev) +{ + struct single_pdata *pdata = dev->platdata; + + switch (pdata->width) { + case 8: + pdata->read = single_readb; + pdata->write = single_writeb; + break; + case 16: + pdata->read = single_readw; + pdata->write = single_writew; + break; + case 32: + pdata->read = single_readl; + pdata->write = single_writel; + break; + default: + dev_warn(dev, "%s: unsupported register width %d\n", + __func__, pdata->width); + return -EINVAL; + } + + return 0; +} + static int single_ofdata_to_platdata(struct udevice *dev) { fdt_addr_t addr; @@ -193,4 +242,5 @@ U_BOOT_DRIVER(single_pinctrl) = { .ops = &single_pinctrl_ops, .platdata_auto_alloc_size = sizeof(struct single_pdata), .ofdata_to_platdata = single_ofdata_to_platdata, + .probe = single_probe, }; From patchwork Wed Apr 29 16:34:45 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Rayagonda Kokatanur X-Patchwork-Id: 1279524 X-Patchwork-Delegate: trini@ti.com Return-Path: X-Original-To: incoming@patchwork.ozlabs.org Delivered-To: patchwork-incoming@bilbo.ozlabs.org Authentication-Results: ozlabs.org; spf=pass (sender SPF authorized) smtp.mailfrom=lists.denx.de (client-ip=85.214.62.61; helo=phobos.denx.de; envelope-from=u-boot-bounces@lists.denx.de; receiver=) Authentication-Results: ozlabs.org; dmarc=pass (p=quarantine dis=none) header.from=broadcom.com Authentication-Results: ozlabs.org; dkim=pass (1024-bit key; unprotected) header.d=broadcom.com header.i=@broadcom.com header.a=rsa-sha256 header.s=google header.b=O4d2f+oA; dkim-atps=neutral Received: from phobos.denx.de (phobos.denx.de [85.214.62.61]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits)) (No client certificate requested) by ozlabs.org (Postfix) with ESMTPS id 49C3zm5v09z9sRf for ; Thu, 30 Apr 2020 02:36:04 +1000 (AEST) Received: from h2850616.stratoserver.net (localhost [IPv6:::1]) by phobos.denx.de (Postfix) with ESMTP id 2228382124; Wed, 29 Apr 2020 18:35:58 +0200 (CEST) Authentication-Results: phobos.denx.de; dmarc=pass (p=quarantine dis=none) header.from=broadcom.com Authentication-Results: phobos.denx.de; spf=pass smtp.mailfrom=u-boot-bounces@lists.denx.de Authentication-Results: phobos.denx.de; dkim=pass (1024-bit key; unprotected) header.d=broadcom.com header.i=@broadcom.com header.b="O4d2f+oA"; dkim-atps=neutral Received: by phobos.denx.de (Postfix, from userid 109) id 191C582123; Wed, 29 Apr 2020 18:35:55 +0200 (CEST) X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on phobos.denx.de X-Spam-Level: X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,SPF_HELO_NONE,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.2 Received: from mail-wr1-x442.google.com (mail-wr1-x442.google.com [IPv6:2a00:1450:4864:20::442]) (using TLSv1.3 with cipher TLS_AES_128_GCM_SHA256 (128/128 bits)) (No client certificate requested) by phobos.denx.de (Postfix) with ESMTPS id ACC7482123 for ; Wed, 29 Apr 2020 18:35:51 +0200 (CEST) Authentication-Results: phobos.denx.de; dmarc=pass (p=quarantine dis=none) header.from=broadcom.com Authentication-Results: phobos.denx.de; spf=pass smtp.mailfrom=rayagonda.kokatanur@broadcom.com Received: by mail-wr1-x442.google.com with SMTP id x17so3325703wrt.5 for ; Wed, 29 Apr 2020 09:35:51 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=broadcom.com; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=nNsf9+2bnwWkmorBjc+Fpf6KdzXZU6rf1STy7JDXNfk=; b=O4d2f+oAFwMxLCMnJF4K+Wl/ZC04oYrZ25l5HVoOQdlJz509QhArDUa11i3KpOgo01 b1ENNSZPDxkoYONb+xs1+D3O+t+MoUlsW2vHAdxXkrjS/b93hLtenhO6nxunvBjGn+fE v97y+nFNi12//2ZyHrZOT1MjiH9hirBNuovRs= 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; bh=nNsf9+2bnwWkmorBjc+Fpf6KdzXZU6rf1STy7JDXNfk=; b=MdD1ZlBeX9vE6drV0RMxXM16+RLaK3jli4XBGHApaarEvxL+hBBlwhhFTo2iPBY0Mr AOneh/Z10j7XhqoKCBAjDkgN/tC2NEydmYbXXOeL0by0hCKzEn8epzPYSJbAGLUunehC XRaWjhtK7YO0l0LspK/U/ZIMvoYAKtvdvLK4u8EOFNJZSSCNb5f61taQZufrzNItzows Le4pAhDRRcAl9OErb+l44MRUsqzPc40lZWLFR5GJgVacSsjjKzr6Lv8Z8e83ItRfsbQZ ovY1C1rnvqWntUtJbXb5OdMdRNM8J65yS5mbyurMDH9zrtMyqmpJQ34yJDICx5CjDOl0 74YA== X-Gm-Message-State: AGi0PuacvjCVL96RXb7lDVV0NSW+svCZbUsEXpAGtN/0LF40VHwig8+T boGV/WeBK4au1MqDjluvCQGdQC4ZjBcgIXhvX9+783kvuHAfgngha+ZJTWKh9PFXoNUZdKrvQ2X vAq6ULUEctRMQkWsluakGisgR7ps0+jyEf5aMU/rCVRNsrsJyl65fE01+XSXeTlh7hMMU/ExdBq KWZVCMDA== X-Google-Smtp-Source: APiQypKQFIrG+AsQDcGiyoScBn3wtRvFMD3WyzCqrcbXd9n/MHwqmc2YPUp7yhtodTpm6vBiv9Yiag== X-Received: by 2002:adf:f2c5:: with SMTP id d5mr37423636wrp.285.1588178150672; Wed, 29 Apr 2020 09:35:50 -0700 (PDT) Received: from rayagonda.dhcp.broadcom.net ([192.19.234.250]) by smtp.gmail.com with ESMTPSA id l6sm31513657wrb.75.2020.04.29.09.35.47 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 29 Apr 2020 09:35:50 -0700 (PDT) From: Rayagonda Kokatanur To: u-boot@lists.denx.de Cc: Simon Glass , Patrick Delaunay , Adam Ford , Lokesh Vutla , Rayagonda Kokatanur Subject: [PATCH v1 2/3] drivers: pinctrl-single: add support to parse gpio properties Date: Wed, 29 Apr 2020 22:04:45 +0530 Message-Id: <20200429163446.15390-3-rayagonda.kokatanur@broadcom.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200429163446.15390-1-rayagonda.kokatanur@broadcom.com> References: <20200429163446.15390-1-rayagonda.kokatanur@broadcom.com> X-BeenThere: u-boot@lists.denx.de X-Mailman-Version: 2.1.30rc1 Precedence: list List-Id: U-Boot discussion List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: u-boot-bounces@lists.denx.de Sender: "U-Boot" X-Virus-Scanned: clamav-milter 0.102.2 at phobos.denx.de X-Virus-Status: Clean Parse different gpio properties from dt as part of probe function. This detail will be used to enable pinctrl pad later when gpio lines are requested. Signed-off-by: Rayagonda Kokatanur --- drivers/pinctrl/pinctrl-single.c | 62 +++++++++++++++++++++++++++++++- 1 file changed, 61 insertions(+), 1 deletion(-) diff --git a/drivers/pinctrl/pinctrl-single.c b/drivers/pinctrl/pinctrl-single.c index aed113b083..fe79a218ee 100644 --- a/drivers/pinctrl/pinctrl-single.c +++ b/drivers/pinctrl/pinctrl-single.c @@ -6,10 +6,26 @@ #include #include #include +#include +#include #include #include #include +/** + * struct single_gpiofunc_range - pin ranges with same mux value of gpio fun + * @offset: offset base of pins + * @npins: number pins with the same mux value of gpio function + * @gpiofunc: mux value of gpio function + * @node: list node + */ +struct single_gpiofunc_range { + u32 offset; + u32 npins; + u32 gpiofunc; + struct list_head node; +}; + /** * struct single_pdata - pinctrl device instance * @base first configuration register @@ -17,6 +33,8 @@ * @mask configuration-value mask bits * @width configuration register bit width * @bits_per_mux + * @mutex mutex protecting the list + * @gpiofuncs list of gpio functions * @read register read function to use * @write register write function to use */ @@ -26,6 +44,8 @@ struct single_pdata { u32 mask; /* configuration-value mask bits */ int width; /* configuration register bit width */ bool bits_per_mux; + struct mutex mutex; + struct list_head gpiofuncs; u32 (*read)(phys_addr_t reg); void (*write)(u32 val, phys_addr_t reg); }; @@ -171,9 +191,42 @@ static int single_set_state(struct udevice *dev, return len; } +static int single_add_gpio_func(struct udevice *dev, + struct single_pdata *pdata) +{ + const char *propname = "pinctrl-single,gpio-range"; + const char *cellname = "#pinctrl-single,gpio-range-cells"; + struct single_gpiofunc_range *range; + struct ofnode_phandle_args gpiospec; + int ret, i; + + for (i = 0; ; i++) { + ret = ofnode_parse_phandle_with_args(dev->node, propname, + cellname, 0, i, &gpiospec); + /* Do not treat it as error. Only treat it as end condition. */ + if (ret) { + ret = 0; + break; + } + range = devm_kzalloc(dev, sizeof(*range), GFP_KERNEL); + if (!range) { + ret = -ENOMEM; + break; + } + range->offset = gpiospec.args[0]; + range->npins = gpiospec.args[1]; + range->gpiofunc = gpiospec.args[2]; + mutex_lock(&pdata->mutex); + list_add_tail(&range->node, &pdata->gpiofuncs); + mutex_unlock(&pdata->mutex); + } + return ret; +} + static int single_probe(struct udevice *dev) { struct single_pdata *pdata = dev->platdata; + int ret; switch (pdata->width) { case 8: @@ -194,7 +247,14 @@ static int single_probe(struct udevice *dev) return -EINVAL; } - return 0; + mutex_init(&pdata->mutex); + INIT_LIST_HEAD(&pdata->gpiofuncs); + + ret = single_add_gpio_func(dev, pdata); + if (ret < 0) + dev_err(dev, "%s: Failed to add gpio functions\n", __func__); + + return ret; } static int single_ofdata_to_platdata(struct udevice *dev) From patchwork Wed Apr 29 16:34:46 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Rayagonda Kokatanur X-Patchwork-Id: 1279525 X-Patchwork-Delegate: trini@ti.com Return-Path: X-Original-To: incoming@patchwork.ozlabs.org Delivered-To: patchwork-incoming@bilbo.ozlabs.org Authentication-Results: ozlabs.org; spf=pass (sender SPF authorized) smtp.mailfrom=lists.denx.de (client-ip=85.214.62.61; helo=phobos.denx.de; envelope-from=u-boot-bounces@lists.denx.de; receiver=) Authentication-Results: ozlabs.org; dmarc=pass (p=quarantine dis=none) header.from=broadcom.com Authentication-Results: ozlabs.org; dkim=pass (1024-bit key; unprotected) header.d=broadcom.com header.i=@broadcom.com header.a=rsa-sha256 header.s=google header.b=I71fw36h; dkim-atps=neutral Received: from phobos.denx.de (phobos.denx.de [85.214.62.61]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits)) (No client certificate requested) by ozlabs.org (Postfix) with ESMTPS id 49C4011B8rz9sPF for ; Thu, 30 Apr 2020 02:36:16 +1000 (AEST) Received: from h2850616.stratoserver.net (localhost [IPv6:::1]) by phobos.denx.de (Postfix) with ESMTP id 2AA7E8213C; Wed, 29 Apr 2020 18:36:07 +0200 (CEST) Authentication-Results: phobos.denx.de; dmarc=pass (p=quarantine dis=none) header.from=broadcom.com Authentication-Results: phobos.denx.de; spf=pass smtp.mailfrom=u-boot-bounces@lists.denx.de Authentication-Results: phobos.denx.de; dkim=pass (1024-bit key; unprotected) header.d=broadcom.com header.i=@broadcom.com header.b="I71fw36h"; dkim-atps=neutral Received: by phobos.denx.de (Postfix, from userid 109) id F171D8213C; Wed, 29 Apr 2020 18:36:05 +0200 (CEST) X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on phobos.denx.de X-Spam-Level: X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,SPF_HELO_NONE,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.2 Received: from mail-wm1-x341.google.com (mail-wm1-x341.google.com [IPv6:2a00:1450:4864:20::341]) (using TLSv1.3 with cipher TLS_AES_128_GCM_SHA256 (128/128 bits)) (No client certificate requested) by phobos.denx.de (Postfix) with ESMTPS id 27BBB82130 for ; Wed, 29 Apr 2020 18:36:02 +0200 (CEST) Authentication-Results: phobos.denx.de; dmarc=pass (p=quarantine dis=none) header.from=broadcom.com Authentication-Results: phobos.denx.de; spf=pass smtp.mailfrom=rayagonda.kokatanur@broadcom.com Received: by mail-wm1-x341.google.com with SMTP id u127so2748271wmg.1 for ; Wed, 29 Apr 2020 09:36:02 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=broadcom.com; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=2HXNqdwTeZCUWCXy2rsp310UCzDgJX+nZVLEPO0oIVQ=; b=I71fw36h35aQQDT/eUuN7bU957yR7aMU5Tg5FHlguhN7Bs9PgpRdM0AChLMgLbF2zF QxebE4HmoPCnAk/hmkl/mT44QLJRvleKhfz7GiUwpL01ubVpcqUugzI2Da1X+qu1chKv /bhzaHCnSB41+N3DXCHrXQZk3s4mJhCmCc7lw= 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; bh=2HXNqdwTeZCUWCXy2rsp310UCzDgJX+nZVLEPO0oIVQ=; b=ZHzLkvFbZxjsxGDml5Ly1eKUAgmDFOdESe4yaqiNO1Q57Bkq0MwJXJvkDST9xcyGMf BVQlVG2FQ/CfaJipBAQ8x2OhJZBT48zmk4KQrAsCbTrMITr8VmDb3cewJQRYJnl2TlJI QdM7wiNrGYxvke4xpcpB1ylRgM/H/s/k/AcjRiKd1zwek0i3bfZZztXEWe04cahPCQy2 WIecsE5wSHFQhKLVmYT6u+Jf5HELSFEVMytC/7FQ0x0L6YEST0sC0Usq5EzZJOIXGH2l QE9ozfLAQHid2Fm9ZCRaQ2qe2+pcWATYXG6ENIB2gLx148QNucUQoELchkiJA9P6ZIVn j4AQ== X-Gm-Message-State: AGi0PubocqSVdissdEJKDsCmvUwea+mDb4QLY70VsJE9aEFw0c2uVsGK JzmxndDjW6CmdVoTR+qPiK1Cn9SdsvePzQW+TzI2aG6kqMd9+fV8wu5AaJN3CVf8R5pNxIrkA3J 9Xj1WlB1hBvYpAkjXlQONyXnaNF4KX13yuDaz4BRm6+yPzXOS5Vt5hm+t3ddPDQ7qzVZ04NmOao rTCTjjCQ== X-Google-Smtp-Source: APiQypLl8imKW4zvjor0FG6P9XYXTU2XVVL0n3jnUs8TExPvma1Ap9ZcUHQXZJXX9vffdlopPndwVg== X-Received: by 2002:a1c:96c6:: with SMTP id y189mr4440924wmd.106.1588178161095; Wed, 29 Apr 2020 09:36:01 -0700 (PDT) Received: from rayagonda.dhcp.broadcom.net ([192.19.234.250]) by smtp.gmail.com with ESMTPSA id l6sm31513657wrb.75.2020.04.29.09.35.58 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 29 Apr 2020 09:36:00 -0700 (PDT) From: Rayagonda Kokatanur To: u-boot@lists.denx.de Cc: Simon Glass , Patrick Delaunay , Adam Ford , Lokesh Vutla , Rayagonda Kokatanur Subject: [PATCH v1 3/3] drivers: pinctrl-single: add request api Date: Wed, 29 Apr 2020 22:04:46 +0530 Message-Id: <20200429163446.15390-4-rayagonda.kokatanur@broadcom.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200429163446.15390-1-rayagonda.kokatanur@broadcom.com> References: <20200429163446.15390-1-rayagonda.kokatanur@broadcom.com> X-BeenThere: u-boot@lists.denx.de X-Mailman-Version: 2.1.30rc1 Precedence: list List-Id: U-Boot discussion List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: u-boot-bounces@lists.denx.de Sender: "U-Boot" X-Virus-Scanned: clamav-milter 0.102.2 at phobos.denx.de X-Virus-Status: Clean Add pinctrl_ops->request api to configure pctrl pad register in gpio mode. Signed-off-by: Rayagonda Kokatanur --- drivers/pinctrl/pinctrl-single.c | 29 +++++++++++++++++++++++++++++ 1 file changed, 29 insertions(+) diff --git a/drivers/pinctrl/pinctrl-single.c b/drivers/pinctrl/pinctrl-single.c index fe79a218ee..2cdba1d338 100644 --- a/drivers/pinctrl/pinctrl-single.c +++ b/drivers/pinctrl/pinctrl-single.c @@ -130,6 +130,34 @@ static int single_configure_pins(struct udevice *dev, return 0; } +static int single_request(struct udevice *dev, int pin, int flags) +{ + struct single_pdata *pdata = dev->platdata; + struct single_gpiofunc_range *frange = NULL; + struct list_head *pos, *tmp; + int mux_bytes = 0; + u32 data; + + if (!pdata->mask) + return -ENOTSUPP; + + list_for_each_safe(pos, tmp, &pdata->gpiofuncs) { + frange = list_entry(pos, struct single_gpiofunc_range, node); + if ((pin >= frange->offset + frange->npins) || + pin < frange->offset) + continue; + + mux_bytes = pdata->width / BITS_PER_BYTE; + data = pdata->read(pdata->base + pin * mux_bytes); + data &= ~pdata->mask; + data |= frange->gpiofunc; + pdata->write(data, pdata->base + pin * mux_bytes); + break; + } + + return 0; +} + static int single_configure_bits(struct udevice *dev, const struct single_fdt_bits_cfg *pins, int size) @@ -288,6 +316,7 @@ static int single_ofdata_to_platdata(struct udevice *dev) const struct pinctrl_ops single_pinctrl_ops = { .set_state = single_set_state, + .request = single_request, }; static const struct udevice_id single_pinctrl_match[] = {