Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp1834007ybl; Thu, 19 Dec 2019 03:52:58 -0800 (PST) X-Google-Smtp-Source: APXvYqxAf3y0/yrRyg67VhbG3bYy6RY8OjCRMLhs76RfOM/cX5UC3QOhuU9QWxgTNqFP3OapXhS2 X-Received: by 2002:a05:6830:1704:: with SMTP id 4mr8216600otk.294.1576756378833; Thu, 19 Dec 2019 03:52:58 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1576756378; cv=none; d=google.com; s=arc-20160816; b=cecGaCGFpbO3P6ibTbreRqNH0qYm/fPdGhAjnvBRTGfKNGRs43jm7WspWPbe8VswnZ Ljn4kJ5eADCTl4tyA9FSihldtKAbBOVlFrnPtc6YcbVU4hNoDoBxT8u0DAfIdZvinp6K //6GQ4oonqEqHb6hWtfTookH7mq1UCqo63NvTphz+HDCvz9cJRJXY9E0o+HE6ZfJSPOi N2rc/9bDi211fwzgTtcHyBvd3+9BgJfE1a5qVsynKzSV4z+6G3FFqz9LMIflTc7ilX8J q3U/jdMU3DTtRGpmgV+5BG8jy9WNj+kqbZAzn71VTWMeQgH7NgCEXo669Zd1/kUL/mnw yfUQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature; bh=inWqr0b7IGQSzA+ufbRqSvKpmxVDxis6ow/O4l0fxAk=; b=fixC+uwxp2X7k0+yK8iBJwJe7ruFIiXVJXMolObuw/DTmKopNLjQsTb6zn4fa5YZ/X +EBECaPfj5/Z9hgp1tAVP97/C/Pvh0JcuoFYyuc2SAWzMtw0hLkOV+Ln2cji96t+IJWI jb39GvjwExrz1MQWgbyIc9Pj6Gx8iRgL/KTSSf5QmXvSrXvv6YwXCZ/Tj0rFhNEtzOIs XxcxlxbVmF6ThP8ayTrf4trPfFUcsi3pPfFvTx5q+d4EQQdB9vYmb/j8htEo34KlWpNZ EM6xUprwgq0y9DGPQ2I0NBoDSopOZ4rYiz8GYTJovNRVzvK6uJUCNo/Cd0TUv834prIm emjA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=cYJEm41L; 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 x185si2816453oig.201.2019.12.19.03.52.45; Thu, 19 Dec 2019 03:52:58 -0800 (PST) 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=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=cYJEm41L; 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 S1726866AbfLSLwD (ORCPT + 99 others); Thu, 19 Dec 2019 06:52:03 -0500 Received: from mail-wm1-f68.google.com ([209.85.128.68]:52024 "EHLO mail-wm1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726752AbfLSLwB (ORCPT ); Thu, 19 Dec 2019 06:52:01 -0500 Received: by mail-wm1-f68.google.com with SMTP id d73so5144038wmd.1 for ; Thu, 19 Dec 2019 03:52:00 -0800 (PST) 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; bh=inWqr0b7IGQSzA+ufbRqSvKpmxVDxis6ow/O4l0fxAk=; b=cYJEm41L8jWpObSqVzKD+h4cAiqqjoBDu2rDMB+uofSR9yWLyQSN10iRib9bzE/ABn JYfn3p39+zc5bMk+s5neeREjbGH+ySUc+zrKHX2IyjfewHNNodKFnCdeiCnH/ewQC72R VBwXLDmQ6oKNpR0i6HsfMSw/2sPCfRL0bgsjYtJeg/sCayKz4JKYX5bke5fNh9Z0Cnxc iDG0rnFTxdhKVpqdU++pr7Kb90oF3g9YCSzJQStm5pyQCUMPvT8HHgfuLdzcL05Ot2YD S9WbHaEYgxlXPQeIpTii25CgdSH+u/efYHCYu+YdkARSt2GucHWjY6iX2oA2WlC3erY2 sHyw== 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=inWqr0b7IGQSzA+ufbRqSvKpmxVDxis6ow/O4l0fxAk=; b=rGhr72zKUwCzphdxbDVoxm4MirjKuIU6+oH67HfOTizB2BiABF1gSw157ToMwhU9F/ /LZechWEZMFMuIgwFXR9IvRuy0wqrSFo7WV8qow7pvWkU9KCEbol61Jk0q08+e+G4sY0 D+oQBFpdBvsD9kVqoB5sb9+qCD4YeQpF52762wpcSUjuq5Y5tmrB8m/qH6kvcwQH8LZL uIVSrZzucZYiss9U3FfENqRiwVo9AYGj5rxu40Mq72OmQj7lRU5dfR05n8zSkZb5KlkL vn4f6kOu/kUispwXidFbGIPACZrBcBGzO9upZgL54Hc3SJyzSPUo+h+836pfCpG3u+wj taTg== X-Gm-Message-State: APjAAAVZ5RFU6davIGQa7VXs2DP+u2h20MnNQMeJjR/y0qgm1ybrZSKl oRxCO8HvL4OB+Ce7sjJyVH2Yiw== X-Received: by 2002:a7b:c957:: with SMTP id i23mr9601630wml.49.1576756319784; Thu, 19 Dec 2019 03:51:59 -0800 (PST) Received: from localhost.localdomain (i16-les01-ntr-213-44-229-207.sfr.lns.abo.bbox.fr. [213.44.229.207]) by smtp.googlemail.com with ESMTPSA id k16sm6489660wru.0.2019.12.19.03.51.58 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 19 Dec 2019 03:51:59 -0800 (PST) From: Khouloud Touil To: bgolaszewski@baylibre.com, robh+dt@kernel.org, mark.rutland@arm.com, srinivas.kandagatla@linaro.org, baylibre-upstreaming@groups.io Cc: linux-kernel@vger.kernel.org, devicetree@vger.kernel.org, linux-i2c@vger.kernel.org, linus.walleij@linaro.org, Khouloud Touil Subject: [PATCH v3 2/4] nvmem: add support for the write-protect pin Date: Thu, 19 Dec 2019 12:51:39 +0100 Message-Id: <20191219115141.24653-3-ktouil@baylibre.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20191219115141.24653-1-ktouil@baylibre.com> References: <20191219115141.24653-1-ktouil@baylibre.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The write-protect pin handling looks like a standard property that could benefit other users if available in the core nvmem framework. Instead of modifying all the memory drivers to check this pin, make the NVMEM subsystem check if the write-protect GPIO being passed through the nvmem_config or defined in the device tree and pull it low whenever writing to the memory. There was a suggestion for introducing the gpiodesc from pdata, but as pdata is already removed it could be replaced by adding it to nvmem_config. Reference: https://lists.96boards.org/pipermail/dev/2018-August/001056.html Signed-off-by: Khouloud Touil Reviewed-by: Linus Walleij Acked-by: Srinivas Kandagatla --- drivers/nvmem/core.c | 19 +++++++++++++++++-- drivers/nvmem/nvmem.h | 2 ++ include/linux/nvmem-provider.h | 3 +++ 3 files changed, 22 insertions(+), 2 deletions(-) diff --git a/drivers/nvmem/core.c b/drivers/nvmem/core.c index 9f1ee9c766ec..3e1c94c4eee8 100644 --- a/drivers/nvmem/core.c +++ b/drivers/nvmem/core.c @@ -15,6 +15,7 @@ #include #include #include +#include #include #include #include "nvmem.h" @@ -54,8 +55,14 @@ static int nvmem_reg_read(struct nvmem_device *nvmem, unsigned int offset, static int nvmem_reg_write(struct nvmem_device *nvmem, unsigned int offset, void *val, size_t bytes) { - if (nvmem->reg_write) - return nvmem->reg_write(nvmem->priv, offset, val, bytes); + int ret; + + if (nvmem->reg_write) { + gpiod_set_value_cansleep(nvmem->wp_gpio, 0); + ret = nvmem->reg_write(nvmem->priv, offset, val, bytes); + gpiod_set_value_cansleep(nvmem->wp_gpio, 1); + return ret; + } return -EINVAL; } @@ -338,6 +345,14 @@ struct nvmem_device *nvmem_register(const struct nvmem_config *config) kfree(nvmem); return ERR_PTR(rval); } + if (config->wp_gpio) + nvmem->wp_gpio = config->wp_gpio; + else + nvmem->wp_gpio = gpiod_get_optional(config->dev, "wp", + GPIOD_OUT_HIGH); + if (IS_ERR(nvmem->wp_gpio)) + return PTR_ERR(nvmem->wp_gpio); + kref_init(&nvmem->refcnt); INIT_LIST_HEAD(&nvmem->cells); diff --git a/drivers/nvmem/nvmem.h b/drivers/nvmem/nvmem.h index eb8ed7121fa3..be0d66d75c8a 100644 --- a/drivers/nvmem/nvmem.h +++ b/drivers/nvmem/nvmem.h @@ -9,6 +9,7 @@ #include #include #include +#include struct nvmem_device { struct module *owner; @@ -26,6 +27,7 @@ struct nvmem_device { struct list_head cells; nvmem_reg_read_t reg_read; nvmem_reg_write_t reg_write; + struct gpio_desc *wp_gpio; void *priv; }; diff --git a/include/linux/nvmem-provider.h b/include/linux/nvmem-provider.h index fe051323be0a..6d6f8e5d24c9 100644 --- a/include/linux/nvmem-provider.h +++ b/include/linux/nvmem-provider.h @@ -11,6 +11,7 @@ #include #include +#include struct nvmem_device; struct nvmem_cell_info; @@ -45,6 +46,7 @@ enum nvmem_type { * @word_size: Minimum read/write access granularity. * @stride: Minimum read/write access stride. * @priv: User context passed to read/write callbacks. + * @wp-gpio: Write protect pin * * Note: A default "nvmem" name will be assigned to the device if * no name is specified in its configuration. In such case "" is @@ -58,6 +60,7 @@ struct nvmem_config { const char *name; int id; struct module *owner; + struct gpio_desc *wp_gpio; const struct nvmem_cell_info *cells; int ncells; enum nvmem_type type; -- 2.17.1