Commit 91a1abfb authored by Janusz Krzysztofik's avatar Janusz Krzysztofik Committed by Miquel Raynal

mtd: rawnand: ams-delta: Write protect device during probe

Initialise NWP GPIO pin as asserted to protect the device from hazard
during setup of other GPIO pins.
Signed-off-by: default avatarJanusz Krzysztofik <jmkrzyszt@gmail.com>
Signed-off-by: default avatarMiquel Raynal <miquel.raynal@bootlin.com>
Link: https://lore.kernel.org/linux-mtd/20200212003929.6682-2-jmkrzyszt@gmail.com
parent c4b7dd35
...@@ -251,8 +251,8 @@ static int ams_delta_init(struct platform_device *pdev) ...@@ -251,8 +251,8 @@ static int ams_delta_init(struct platform_device *pdev)
platform_set_drvdata(pdev, priv); platform_set_drvdata(pdev, priv);
/* Set chip enabled, but */ /* Set chip enabled but write protected */
priv->gpiod_nwp = devm_gpiod_get(&pdev->dev, "nwp", GPIOD_OUT_HIGH); priv->gpiod_nwp = devm_gpiod_get(&pdev->dev, "nwp", GPIOD_OUT_LOW);
if (IS_ERR(priv->gpiod_nwp)) { if (IS_ERR(priv->gpiod_nwp)) {
err = PTR_ERR(priv->gpiod_nwp); err = PTR_ERR(priv->gpiod_nwp);
dev_err(&pdev->dev, "NWP GPIO request failed (%d)\n", err); dev_err(&pdev->dev, "NWP GPIO request failed (%d)\n", err);
...@@ -309,6 +309,17 @@ static int ams_delta_init(struct platform_device *pdev) ...@@ -309,6 +309,17 @@ static int ams_delta_init(struct platform_device *pdev)
nand_controller_init(&priv->base); nand_controller_init(&priv->base);
this->controller = &priv->base; this->controller = &priv->base;
/*
* FIXME: We should release write protection only after nand_scan() to
* be on the safe side but we can't do that until we have a generic way
* to assert/deassert WP from the core. Even if the core shouldn't
* write things in the nand_scan() path, it should have control on this
* pin just in case we ever need to disable write protection during
* chip detection/initialization.
*/
/* Release write protection */
gpiod_set_value(priv->gpiod_nwp, 1);
/* Scan to find existence of the device */ /* Scan to find existence of the device */
err = nand_scan(this, 1); err = nand_scan(this, 1);
if (err) if (err)
...@@ -336,6 +347,9 @@ static int ams_delta_cleanup(struct platform_device *pdev) ...@@ -336,6 +347,9 @@ static int ams_delta_cleanup(struct platform_device *pdev)
struct ams_delta_nand *priv = platform_get_drvdata(pdev); struct ams_delta_nand *priv = platform_get_drvdata(pdev);
struct mtd_info *mtd = nand_to_mtd(&priv->nand_chip); struct mtd_info *mtd = nand_to_mtd(&priv->nand_chip);
/* Apply write protection */
gpiod_set_value(priv->gpiod_nwp, 0);
/* Unregister device */ /* Unregister device */
nand_release(mtd_to_nand(mtd)); nand_release(mtd_to_nand(mtd));
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment