From patchwork Thu Mar 14 16:37:24 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Jerome Brunet X-Patchwork-Id: 160359 Delivered-To: patch@linaro.org Received: by 2002:a02:5cc1:0:0:0:0:0 with SMTP id w62csp15721228jad; Thu, 14 Mar 2019 09:37:39 -0700 (PDT) X-Google-Smtp-Source: APXvYqz0FGDa0PteAeh0WRWFh//bYiabJLRfN1f2oWgxJq6j7eD04W5DgngpFsRfZDJ7DJ+b7yNy X-Received: by 2002:a63:4e1d:: with SMTP id c29mr46587443pgb.433.1552581459499; Thu, 14 Mar 2019 09:37:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1552581459; cv=none; d=google.com; s=arc-20160816; b=rAiq5dWq1aGv0NiVGjM2UinXpZRrifkfOkuCaftMsbbK1DdCRQBwkE1zyhAUwIk4ip XJsEx9dwiwQ7TV/sDnPxqkoPucLY4kNE/pBFufibrrcglLeA8laebym0qb+0JHyByfnT 2YC+pUc5TzTfkdEuMA/b09554ARkijFmcMpwkLTJElH4dIjflGz3b3vozgBzrym05LIu ENgJhFM2Rj1AQ3A4F2KeVtG/VPuZVE+AWr4SBUkzlAMG3wZTZjDw2Ov4NJrekqbgejXI g2lSkFvkbE8IHViV2z+ZW2tGhSZHXfj50FqSqkXbErD7G/gMZ4FM6O+LSPaBhx+hX90S cPyg== 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=hyyOz1m96O4p/E0V0P2WXHuhjOVs41Ijnx22pgX7mwI=; b=dfQgmO3TB69wKPPX9K81hjTW3zq9KwHV751mGopiLe6uOq6POH92pdksZtyjKPu+WC oGsKBqI6xPOTfFviBltvIQsi39n3HsBj9NWsOaJ38ryPxnDAc/r79+Jg2JPYxsmB9zWz 395JiQGSG2824YjtofGBqWG1lNa+fUfWwEWHnzEj6ethSNCtrQcql+l/PV2UWeGwmZnx RQKMmC5bFIxAgvGdyQAFv66TZzA2Ss2FdjZJyeiCL4NdA/zhWyQ3fujhtJFHmLSa4rXJ JWmVC4EUyHigCNL9esSTUWtT7stFOi4m4C6hHnT+9qfYBlKwlau2iVPdd2PTIsHyK4cM Asjg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=BAnt22Re; spf=pass (google.com: best guess record for domain of devicetree-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=devicetree-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 k1si11579541pgo.417.2019.03.14.09.37.39; Thu, 14 Mar 2019 09:37:39 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of devicetree-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=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=BAnt22Re; spf=pass (google.com: best guess record for domain of devicetree-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=devicetree-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727531AbfCNQhi (ORCPT + 7 others); Thu, 14 Mar 2019 12:37:38 -0400 Received: from mail-wm1-f66.google.com ([209.85.128.66]:52354 "EHLO mail-wm1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727247AbfCNQhh (ORCPT ); Thu, 14 Mar 2019 12:37:37 -0400 Received: by mail-wm1-f66.google.com with SMTP id f65so3723778wma.2 for ; Thu, 14 Mar 2019 09:37:36 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baylibre-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=hyyOz1m96O4p/E0V0P2WXHuhjOVs41Ijnx22pgX7mwI=; b=BAnt22RecllUp0V+7xCOYepXPwGttiyuNcJNvDKMMkzz0QqM9GS+pfP2K+/htHQDY+ RQixqU28hjnQsM3Y/0SH3MGRqcmFlvT+PExX1T40zyhfliqB09ZDuXKAzovTAr3TD4m5 LJ6vje5losjhjqV/ljE0oJylp1X+7wOynqU/RXwJ9bltp/zMywHpW2VRT/LrZ8XHV89f eWSQ4rAokoXGtamaV7oq9ktYo3/Ys/nm3VwhFsXm7ffbmvxujYKYcjYhkyWajcJvSmbi 61rbR9G/HKDVLWNGE36lLsHTIZKanJ2I9F/+GfXUg75vRRT76rx9vGcoUNYJFpzElY18 ZffA== 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=hyyOz1m96O4p/E0V0P2WXHuhjOVs41Ijnx22pgX7mwI=; b=ie7OrXlSWbr04MgE24xg7cJMHT4nHHkUFLtq/z/ci37yL6ED0W0ODxQNNCS1UFqTC5 3Zx/NE9zP4U1/BpoWM5gtmRzgrB5ar6o0M83vevoDqaE5hl1CpURqZO8LFiizBTRYJrB utE7KD3w0ZYyaOL7ZilvOSNDN+FAbEumv/AVr2W7aX8NOIzmMQahM7FPuL3tUbqDWZ8k uxAVvlu7gS2r8MZEjY8ZnP7iGFpTSxtOpsTfQ6CrHCQgeFWbQ84WTYE0eH7UaSXbX+EI J3Ol+MeqFtjhYsvhYrejXLEKw8VUgq06Ce2TA8EjPQz3+M3iv8HjW+TkZiSK2G/c5fMS bLSQ== X-Gm-Message-State: APjAAAXB5XMIS1yvX4G8xdKxv6RBqTevIWop6juaioaW+ZsqeXtxfOML 9JFvUbzA62pTwe014fR39X8z3Q== X-Received: by 2002:a1c:2283:: with SMTP id i125mr3173986wmi.24.1552581455474; Thu, 14 Mar 2019 09:37:35 -0700 (PDT) Received: from boomer.local ([2a01:e34:eeb6:4690:106b:bae3:31ed:7561]) by smtp.googlemail.com with ESMTPSA id u17sm45003315wrg.71.2019.03.14.09.37.33 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Thu, 14 Mar 2019 09:37:34 -0700 (PDT) From: Jerome Brunet To: Linus Walleij , Kevin Hilman Cc: Guillaume La Roque , devicetree@vger.kernel.org, linux-amlogic@lists.infradead.org, linux-kernel@vger.kernel.org, linux-gpio@vger.kernel.org, Jerome Brunet Subject: [PATCH 1/2] dt-bindings: pinctrl: meson: Add drive-strength property Date: Thu, 14 Mar 2019 17:37:24 +0100 Message-Id: <20190314163725.7918-2-jbrunet@baylibre.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190314163725.7918-1-jbrunet@baylibre.com> References: <20190314163725.7918-1-jbrunet@baylibre.com> MIME-Version: 1.0 Sender: devicetree-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: devicetree@vger.kernel.org From: Guillaume La Roque Add optional drive-strength property Signed-off-by: Guillaume La Roque Signed-off-by: Jerome Brunet --- Documentation/devicetree/bindings/pinctrl/meson,pinctrl.txt | 3 +++ 1 file changed, 3 insertions(+) -- 2.20.1 diff --git a/Documentation/devicetree/bindings/pinctrl/meson,pinctrl.txt b/Documentation/devicetree/bindings/pinctrl/meson,pinctrl.txt index a47dd990a8d3..4e3d5a27c91c 100644 --- a/Documentation/devicetree/bindings/pinctrl/meson,pinctrl.txt +++ b/Documentation/devicetree/bindings/pinctrl/meson,pinctrl.txt @@ -51,6 +51,9 @@ Configuration nodes support the generic properties "bias-disable", "bias-pull-up" and "bias-pull-down", described in file pinctrl-bindings.txt +Optional properties : + - drive-strength: Drive strength for the specified pins in uA. + === Example === pinctrl: pinctrl@c1109880 { From patchwork Thu Mar 14 16:37:25 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Jerome Brunet X-Patchwork-Id: 160360 Delivered-To: patch@linaro.org Received: by 2002:a02:5cc1:0:0:0:0:0 with SMTP id w62csp15721303jad; Thu, 14 Mar 2019 09:37:44 -0700 (PDT) X-Google-Smtp-Source: APXvYqzXuoWKyrwkMY32hKFdNfHbwKXoE9nB8pYem0BxMFiOLiZGJYw2/lBIw7081WIMX4O8JTYe X-Received: by 2002:aa7:8150:: with SMTP id d16mr50567951pfn.172.1552581464016; Thu, 14 Mar 2019 09:37:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1552581464; cv=none; d=google.com; s=arc-20160816; b=PI9ixb0swea+T8TVnVLjgzUhn1fU2BuVeQwEVTTOsFt+X5ruQV4HD2lQ+efqBVEXA9 IWVK6C5+fc/CffwmILjp54zZJX/q4oRCIFyQ1G1o82eOnw1lAEws5Z9GokGhu2Zlz/lK I9hKoERMroBTYNAMDKZUC425pCDuYH+uHIAxIP5BNaRcZkeYRchfp5EVJ+uBryWkEGho JkhzPcAtGv4kU/sg7P66bAVKkpR9/LW3apBWplF9Rk5cHbKox9bP1WD6vNWI5gYcYNSQ RV69Y6CMEOyxXzMAwxcfi0HqgH99Au97V7BAYZrHK2GyEeRqU5JBmjyjWsVf3bY7iZ0l Ssig== 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=3EiWbWRN93h/NWe41N/AubEalZGmqmPngrZfTt6A0e4=; b=TzIB/cfHUtPWFb8CVFBS638x85ecEZUU6yYfWPkGCamjmqTgc4Df9XxCIkdkFNXaJE BuYsHtxJ+4NtGmX5A2+rUuT22dmXV58Wp9ia5h6uB3kA6hi2O55WVgJSHCDCrP3O6qss EY7cahUdB2QiVwPAwuuNKzccbAqXNufKVAjUNvZAvAi5lNGu7eukRoKaO56aSCVjLPFY PK8SznTI4NXE7O11LBkWimyaOq6dgmuxzMfvgW4mILflA9ELDrdiWJSeqikRdADGCj35 CSaE+otPqSLtTCnYYF2Cn+SqE9xLGivXr6Ak/absala7y+F68vaIBLtVEhpZTQ3ixP1e GWDA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=y3bBwXXV; spf=pass (google.com: best guess record for domain of devicetree-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=devicetree-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 c15si13015061pgj.13.2019.03.14.09.37.43; Thu, 14 Mar 2019 09:37:44 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of devicetree-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=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=y3bBwXXV; spf=pass (google.com: best guess record for domain of devicetree-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=devicetree-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727474AbfCNQhl (ORCPT + 7 others); Thu, 14 Mar 2019 12:37:41 -0400 Received: from mail-wr1-f67.google.com ([209.85.221.67]:44823 "EHLO mail-wr1-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727536AbfCNQhk (ORCPT ); Thu, 14 Mar 2019 12:37:40 -0400 Received: by mail-wr1-f67.google.com with SMTP id w2so6558050wrt.11 for ; Thu, 14 Mar 2019 09:37:38 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baylibre-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=3EiWbWRN93h/NWe41N/AubEalZGmqmPngrZfTt6A0e4=; b=y3bBwXXV8JGLlzOQbd+ek2EZsz6sGBcS577RgoxHfKUPNETEg3rxbKiGGdcxUsyX5C ZIyOiVBz7xCBZ6R/EWITvppM/Cq9v28iaZh96lg9RfuZOkOTeX26kCMcNW8DeGLDKp+T GsYBdjnFiTUvKVQKZzKZ9rNbMRe46Pu4Yz7D9TffMpfnD6GTgOfS6pKiaaiXzhw4QCgr P7j4c+C47sAnc67Sq8dqMd9NXKQ8iS6EdBtOBy0zkkMZfyJQ6W1ThvF4/i2d0+YjKli1 Fu9cBN67zAjlL0lshZxQf1Wq2LODGzXNAPoF5qLRLDmpiuHIehY2Q8O8n/bMRwYJsQ83 WQ4Q== 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=3EiWbWRN93h/NWe41N/AubEalZGmqmPngrZfTt6A0e4=; b=rmC0hyRF8dlUIZCT2lCKNtkEAopsIOsV9QWuODTx0YmQ7R4hYWP24lPKpVbBnaslul nR92lpfS4H+PkQfCG2DjCTTYN6PXJ+iQA9HHzReJ6gbagbv71KPKTQNIiHVH1tZ0TzCi PUKhGNe/sMEAVCaP3a10uvnONgGdcrWpQlFexnWWwTg8ObW+MxkVEFAPxW6uVIzeICT1 7Y8B5g2UQ+l1FitxZHd+I0kuGEPnnx9/Y6ugm5Ug8tYj8nXmbdV9TG1+58nUpRMzKLK3 d9z1Wk6N8Tyrj3FEUcoACqO/9ANaMog7pes5VZxrnU7cNTc0xyk08oW6uqBIGLM1kviu 4giw== X-Gm-Message-State: APjAAAXExkyrQm1/tur549fz4JkharuXYUwnuGfNGTkIqfpyv0XROxEH oSPLZkzi0+2zV+/vzJDyqD3Jig== X-Received: by 2002:a05:6000:104b:: with SMTP id c11mr34094780wrx.9.1552581457582; Thu, 14 Mar 2019 09:37:37 -0700 (PDT) Received: from boomer.local ([2a01:e34:eeb6:4690:106b:bae3:31ed:7561]) by smtp.googlemail.com with ESMTPSA id u17sm45003315wrg.71.2019.03.14.09.37.35 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Thu, 14 Mar 2019 09:37:36 -0700 (PDT) From: Jerome Brunet To: Linus Walleij , Kevin Hilman Cc: Guillaume La Roque , devicetree@vger.kernel.org, linux-amlogic@lists.infradead.org, linux-kernel@vger.kernel.org, linux-gpio@vger.kernel.org, Jerome Brunet Subject: [PATCH 2/2] pinctrl: meson: add support of drive-strength Date: Thu, 14 Mar 2019 17:37:25 +0100 Message-Id: <20190314163725.7918-3-jbrunet@baylibre.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190314163725.7918-1-jbrunet@baylibre.com> References: <20190314163725.7918-1-jbrunet@baylibre.com> MIME-Version: 1.0 Sender: devicetree-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: devicetree@vger.kernel.org From: Guillaume La Roque drive-strength is a new feature needed for G12A SoC. the default DS setting after boot is usually 0.5mA and it is not enough for many functions. We need to be able to set the drive strength to reliably enable things like MMC, I2C, etc ... Signed-off-by: Guillaume La Roque Signed-off-by: Jerome Brunet --- drivers/pinctrl/meson/pinctrl-meson-g12a.c | 36 ++--- drivers/pinctrl/meson/pinctrl-meson.c | 166 ++++++++++++++++----- drivers/pinctrl/meson/pinctrl-meson.h | 20 ++- 3 files changed, 162 insertions(+), 60 deletions(-) -- 2.20.1 diff --git a/drivers/pinctrl/meson/pinctrl-meson-g12a.c b/drivers/pinctrl/meson/pinctrl-meson-g12a.c index d494492e98e9..3475cd7bd2af 100644 --- a/drivers/pinctrl/meson/pinctrl-meson-g12a.c +++ b/drivers/pinctrl/meson/pinctrl-meson-g12a.c @@ -1304,28 +1304,28 @@ static struct meson_pmx_func meson_g12a_aobus_functions[] = { }; static struct meson_bank meson_g12a_periphs_banks[] = { - /* name first last irq pullen pull dir out in */ - BANK("Z", GPIOZ_0, GPIOZ_15, 12, 27, - 4, 0, 4, 0, 12, 0, 13, 0, 14, 0), - BANK("H", GPIOH_0, GPIOH_8, 28, 36, - 3, 0, 3, 0, 9, 0, 10, 0, 11, 0), - BANK("BOOT", BOOT_0, BOOT_15, 37, 52, - 0, 0, 0, 0, 0, 0, 1, 0, 2, 0), - BANK("C", GPIOC_0, GPIOC_7, 53, 60, - 1, 0, 1, 0, 3, 0, 4, 0, 5, 0), - BANK("A", GPIOA_0, GPIOA_15, 61, 76, - 5, 0, 5, 0, 16, 0, 17, 0, 18, 0), - BANK("X", GPIOX_0, GPIOX_19, 77, 96, - 2, 0, 2, 0, 6, 0, 7, 0, 8, 0), + /* name first last irq pullen pull dir out in ds */ + BANK_DS("Z", GPIOZ_0, GPIOZ_15, 12, 27, + 4, 0, 4, 0, 12, 0, 13, 0, 14, 0, 5, 0), + BANK_DS("H", GPIOH_0, GPIOH_8, 28, 36, + 3, 0, 3, 0, 9, 0, 10, 0, 11, 0, 4, 0), + BANK_DS("BOOT", BOOT_0, BOOT_15, 37, 52, + 0, 0, 0, 0, 0, 0, 1, 0, 2, 0, 0, 0), + BANK_DS("C", GPIOC_0, GPIOC_7, 53, 60, + 1, 0, 1, 0, 3, 0, 4, 0, 5, 0, 1, 0), + BANK_DS("A", GPIOA_0, GPIOA_15, 61, 76, + 5, 0, 5, 0, 16, 0, 17, 0, 18, 0, 6, 0), + BANK_DS("X", GPIOX_0, GPIOX_19, 77, 96, + 2, 0, 2, 0, 6, 0, 7, 0, 8, 0, 2, 0), }; static struct meson_bank meson_g12a_aobus_banks[] = { - /* name first last irq pullen pull dir out in */ - BANK("AO", GPIOAO_0, GPIOAO_11, 0, 11, - 3, 0, 2, 0, 0, 0, 4, 0, 1, 0), + /* name first last irq pullen pull dir out in ds */ + BANK_DS("AO", GPIOAO_0, GPIOAO_11, 0, 11, 3, 0, 2, 0, 0, 0, 4, 0, 1, 0, + 0, 0), /* GPIOE actually located in the AO bank */ - BANK("E", GPIOE_0, GPIOE_2, 97, 99, - 3, 16, 2, 16, 0, 16, 4, 16, 1, 16), + BANK_DS("E", GPIOE_0, GPIOE_2, 97, 99, 3, 16, 2, 16, 0, 16, 4, 16, 1, + 16, 1, 0), }; static struct meson_pmx_bank meson_g12a_periphs_pmx_banks[] = { diff --git a/drivers/pinctrl/meson/pinctrl-meson.c b/drivers/pinctrl/meson/pinctrl-meson.c index 96a4a72708e4..786640f98f83 100644 --- a/drivers/pinctrl/meson/pinctrl-meson.c +++ b/drivers/pinctrl/meson/pinctrl-meson.c @@ -174,65 +174,108 @@ int meson_pmx_get_groups(struct pinctrl_dev *pcdev, unsigned selector, return 0; } -static int meson_pinconf_set(struct pinctrl_dev *pcdev, unsigned int pin, - unsigned long *configs, unsigned num_configs) +static int meson_pinconf_set_bias(struct meson_pinctrl *pc, unsigned int pin, + enum pin_config_param conf) +{ + struct meson_bank *bank; + unsigned int reg, bit, val = 0; + int ret; + + ret = meson_get_bank(pc, pin, &bank); + if (ret) + return ret; + + meson_calc_reg_and_bit(bank, pin, REG_PULLEN, ®, &bit); + + if (conf == PIN_CONFIG_BIAS_DISABLE) { + ret = regmap_update_bits(pc->reg_pullen, reg, BIT(bit), 0); + if (ret) + return ret; + } else { + meson_calc_reg_and_bit(bank, pin, REG_PULL, ®, &bit); + if (conf == PIN_CONFIG_BIAS_PULL_UP) + val = BIT(bit); + + ret = regmap_update_bits(pc->reg_pull, reg, BIT(bit), val); + if (ret) + return ret; + + meson_calc_reg_and_bit(bank, pin, REG_PULLEN, ®, &bit); + ret = regmap_update_bits(pc->reg_pullen, reg, BIT(bit), + BIT(bit)); + if (ret) + return ret; + } + + return 0; +} + +static int meson_pinconf_set_drive_strength(struct meson_pinctrl *pc, + unsigned int pin, u16 arg) { - struct meson_pinctrl *pc = pinctrl_dev_get_drvdata(pcdev); struct meson_bank *bank; - enum pin_config_param param; unsigned int reg, bit; - int i, ret; + unsigned int ds_val; + int ret; + + if (!pc->reg_ds) { + dev_err(pc->dev, "drive-strength not supported\n"); + return -ENOTSUPP; + } ret = meson_get_bank(pc, pin, &bank); if (ret) return ret; + meson_calc_reg_and_bit(bank, pin, REG_DS, ®, &bit); + bit = bit << 1; + + if (arg <= 500) { + ds_val = MESON_PINCONF_DRV_500UA; + } else if (arg <= 2500) { + ds_val = MESON_PINCONF_DRV_2500UA; + } else if (arg <= 3000) { + ds_val = MESON_PINCONF_DRV_3000UA; + } else if (arg <= 4000) { + ds_val = MESON_PINCONF_DRV_4000UA; + } else { + dev_warn_once(pc->dev, + "pin %u: invalid drive-strength : %d , default to 4mA\n", + pin, arg); + ds_val = MESON_PINCONF_DRV_4000UA; + } + + ret = regmap_update_bits(pc->reg_ds, reg, 0x3 << bit, ds_val << bit); + if (ret) + return ret; + + return 0; +} + +static int meson_pinconf_set(struct pinctrl_dev *pcdev, unsigned int pin, + unsigned long *configs, unsigned num_configs) +{ + struct meson_pinctrl *pc = pinctrl_dev_get_drvdata(pcdev); + enum pin_config_param param; + unsigned int arg; + int i, ret; + for (i = 0; i < num_configs; i++) { param = pinconf_to_config_param(configs[i]); switch (param) { case PIN_CONFIG_BIAS_DISABLE: - dev_dbg(pc->dev, "pin %u: disable bias\n", pin); - - meson_calc_reg_and_bit(bank, pin, REG_PULLEN, ®, - &bit); - ret = regmap_update_bits(pc->reg_pullen, reg, - BIT(bit), 0); - if (ret) - return ret; - break; case PIN_CONFIG_BIAS_PULL_UP: - dev_dbg(pc->dev, "pin %u: enable pull-up\n", pin); - - meson_calc_reg_and_bit(bank, pin, REG_PULLEN, - ®, &bit); - ret = regmap_update_bits(pc->reg_pullen, reg, - BIT(bit), BIT(bit)); - if (ret) - return ret; - - meson_calc_reg_and_bit(bank, pin, REG_PULL, ®, &bit); - ret = regmap_update_bits(pc->reg_pull, reg, - BIT(bit), BIT(bit)); - if (ret) - return ret; - break; case PIN_CONFIG_BIAS_PULL_DOWN: - dev_dbg(pc->dev, "pin %u: enable pull-down\n", pin); - - meson_calc_reg_and_bit(bank, pin, REG_PULLEN, - ®, &bit); - ret = regmap_update_bits(pc->reg_pullen, reg, - BIT(bit), BIT(bit)); + ret = meson_pinconf_set_bias(pc, pin, param); if (ret) return ret; - - meson_calc_reg_and_bit(bank, pin, REG_PULL, ®, &bit); - ret = regmap_update_bits(pc->reg_pull, reg, - BIT(bit), 0); + break; + case PIN_CONFIG_DRIVE_STRENGTH: + arg = pinconf_to_config_argument(configs[i]); + ret = meson_pinconf_set_drive_strength(pc, pin, arg); if (ret) return ret; - break; default: return -ENOTSUPP; } @@ -275,12 +318,51 @@ static int meson_pinconf_get_pull(struct meson_pinctrl *pc, unsigned int pin) return conf; } +static int meson_pinconf_get_drive_strength(struct meson_pinctrl *pc, + unsigned int pin, u16 *arg) +{ + struct meson_bank *bank; + unsigned int reg, bit; + unsigned int val; + int ret; + + ret = meson_get_bank(pc, pin, &bank); + if (ret) + return ret; + + meson_calc_reg_and_bit(bank, pin, REG_DS, ®, &bit); + + ret = regmap_read(pc->reg_ds, reg, &val); + if (ret) + return ret; + + switch ((val >> bit) & 0x3) { + case MESON_PINCONF_DRV_500UA: + *arg = 500; + break; + case MESON_PINCONF_DRV_2500UA: + *arg = 2500; + break; + case MESON_PINCONF_DRV_3000UA: + *arg = 3000; + break; + case MESON_PINCONF_DRV_4000UA: + *arg = 4000; + break; + default: + return -EINVAL; + } + + return 0; +} + static int meson_pinconf_get(struct pinctrl_dev *pcdev, unsigned int pin, unsigned long *config) { struct meson_pinctrl *pc = pinctrl_dev_get_drvdata(pcdev); enum pin_config_param param = pinconf_to_config_param(*config); u16 arg; + int ret; switch (param) { case PIN_CONFIG_BIAS_DISABLE: @@ -291,6 +373,10 @@ static int meson_pinconf_get(struct pinctrl_dev *pcdev, unsigned int pin, else return -EINVAL; break; + case PIN_CONFIG_DRIVE_STRENGTH: + ret = meson_pinconf_get_drive_strength(pc, pin, &arg); + if (ret) + return ret; default: return -ENOTSUPP; } diff --git a/drivers/pinctrl/meson/pinctrl-meson.h b/drivers/pinctrl/meson/pinctrl-meson.h index 5eaab925f427..1a88103dcb9b 100644 --- a/drivers/pinctrl/meson/pinctrl-meson.h +++ b/drivers/pinctrl/meson/pinctrl-meson.h @@ -71,9 +71,20 @@ enum meson_reg_type { REG_DIR, REG_OUT, REG_IN, + REG_DS, NUM_REG, }; +/** + * enum meson_pinconf_drv - value of drive-strength supported + */ +enum meson_pinconf_drv { + MESON_PINCONF_DRV_500UA, + MESON_PINCONF_DRV_2500UA, + MESON_PINCONF_DRV_3000UA, + MESON_PINCONF_DRV_4000UA, +}; + /** * struct meson bank * @@ -132,7 +143,8 @@ struct meson_pinctrl { .num_groups = ARRAY_SIZE(fn ## _groups), \ } -#define BANK(n, f, l, fi, li, per, peb, pr, pb, dr, db, or, ob, ir, ib) \ +#define BANK_DS(n, f, l, fi, li, per, peb, pr, pb, dr, db, or, ob, ir, ib, \ + dsr, dsb) \ { \ .name = n, \ .first = f, \ @@ -145,8 +157,12 @@ struct meson_pinctrl { [REG_DIR] = { dr, db }, \ [REG_OUT] = { or, ob }, \ [REG_IN] = { ir, ib }, \ + [REG_DS] = { dsr, dsb }, \ }, \ - } + } + +#define BANK(n, f, l, fi, li, per, peb, pr, pb, dr, db, or, ob, ir, ib) \ + BANK_DS(n, f, l, fi, li, per, peb, pr, pb, dr, db, or, ob, ir, ib, 0, 0) #define MESON_PIN(x) PINCTRL_PIN(x, #x)