[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <af3692dba69e85fa8136ab3d170bef39@walle.cc>
Date: Mon, 16 Dec 2019 11:29:52 +0100
From: Michael Walle <michael@...le.cc>
To: Vignesh Raghavendra <vigneshr@...com>
Cc: linux-mtd@...ts.infradead.org, devicetree@...r.kernel.org,
linux-kernel@...r.kernel.org,
Miquel Raynal <miquel.raynal@...tlin.com>,
Richard Weinberger <richard@....at>,
Rob Herring <robh+dt@...nel.org>,
Mark Rutland <mark.rutland@....com>,
Tudor Ambarus <tudor.ambarus@...rochip.com>
Subject: Re: [PATCH 1/2] dt-bindings: mtd: spi-nor: document new flag
Hi,
Am 2019-12-16 09:54, schrieb Vignesh Raghavendra:
> Hi,
>
> On 15/12/19 12:49 am, Michael Walle wrote:
>> Document the new flag "no-unlock".
>>
>> Signed-off-by: Michael Walle <michael@...le.cc>
>> ---
>> Does the property need a prefix? I couldn't find any hint. If so, what
>> should it be? "m25p," or "spi-nor," ?
>>
>> Documentation/devicetree/bindings/mtd/jedec,spi-nor.txt | 6 ++++++
>> 1 file changed, 6 insertions(+)
>>
>> diff --git a/Documentation/devicetree/bindings/mtd/jedec,spi-nor.txt
>> b/Documentation/devicetree/bindings/mtd/jedec,spi-nor.txt
>> index f03be904d3c2..2d305c893ed7 100644
>> --- a/Documentation/devicetree/bindings/mtd/jedec,spi-nor.txt
>> +++ b/Documentation/devicetree/bindings/mtd/jedec,spi-nor.txt
>> @@ -78,6 +78,12 @@ Optional properties:
>> cannot reboot properly if the flash is left in the "wrong"
>> state. This boolean flag can be used on such systems, to
>> denote the absence of a reliable reset mechanism.
>> +- no-unlock : By default, linux unlocks the whole flash because there
>> + are legacy flash devices which are locked by default
>> + after reset. Set this flag if you don't want linux to
>> + unlock the whole flash automatically. In this case you
>> + can control the non-volatile bits by the
>> + flash_lock/flash_unlock tools.
>>
>
> Current SPI NOR framework unconditionally unlocks entire flash which
> I agree is not the best thing to do, but I don't think we need
> new DT property here. MTD cmdline partitions and DT partitions already
> provide a way to specify that a partition should remain locked[1][2]
I know that the MTD layer has the same kind of unlocking. But that
unlocking is done on a per mtd partition basis. Eg. consider something
like the following
mtd1 bootloader (locked)
mtd2 firmware (locked)
mtd3 kernel
mtd4 environment
Further assume, that the end of mtd2 aligns with one of the possible
locking areas which are supported by the flash chip. Eg. the first
quarter.
The mtd layer would do two (or four, if "lock" property is set) unlock()
calls, one for mtd1 and one for mtd2.
My point here is, that the mtd partitions doesn't always map to the
locking regions of the SPI flash (at least if the are not merged
together).
> SPI NOR framework should instead set MTD_POWERUP_LOCK flags in
> mtd->flags
> for flash devices that power up with lock bits set. And MTD core will
> take care of unlocking flash regions while taking into account
> partition
> flags defined by user as part of MTD partitions defined in DT or
> via cmdline args.
>
> So that change should to be set MTD_POWERUP_LOCK for
> in SPI NOR core. Can you check below[3] (untested) diff helps?
> This should prevent unlocking partitions that are to remain locked
> as specified in DT/cmdline
As this change may help my use-case, unlocking is skipped because the
partitions are marked as read only; I fear that the old behaviour will
change. See above.
Mhh. thinking more about it, doesn't the calls also wear out the
non-volatile bits in the NOR flash?
In any case, I'll try your suggestion.
-michael
>
> [1] Documentation/devicetree/bindings/mtd/partition.txt
> [2] drivers/mtd/parsers/cmdlinepart.c (see "lk" parameter)
>
> [3]
>
> diff --git a/drivers/mtd/spi-nor/spi-nor.c
> b/drivers/mtd/spi-nor/spi-nor.c
> index 1082b6bb1393..6adb950849f6 100644
> --- a/drivers/mtd/spi-nor/spi-nor.c
> +++ b/drivers/mtd/spi-nor/spi-nor.c
> @@ -4914,23 +4914,6 @@ static int spi_nor_quad_enable(struct spi_nor
> *nor)
> return nor->params.quad_enable(nor);
> }
>
> -/**
> - * spi_nor_unlock_all() - Unlocks the entire flash memory array.
> - * @nor: pointer to a 'struct spi_nor'.
> - *
> - * Some SPI NOR flashes are write protected by default after a
> power-on reset
> - * cycle, in order to avoid inadvertent writes during power-up.
> Backward
> - * compatibility imposes to unlock the entire flash memory array at
> power-up
> - * by default.
> - */
> -static int spi_nor_unlock_all(struct spi_nor *nor)
> -{
> - if (nor->flags & SNOR_F_HAS_LOCK)
> - return spi_nor_unlock(&nor->mtd, 0, nor->params.size);
> -
> - return 0;
> -}
> -
> static int spi_nor_init(struct spi_nor *nor)
> {
> int err;
> @@ -4941,11 +4924,11 @@ static int spi_nor_init(struct spi_nor *nor)
> return err;
> }
>
> - err = spi_nor_unlock_all(nor);
> - if (err) {
> - dev_dbg(nor->dev, "Failed to unlock the entire flash memory
> array\n");
> - return err;
> - }
> + /*
> + * Flashes may power up locked. Set this flag so that MTD core
> + * takes care of unlocking partitions as required.
> + */
> + nor->mtd.flags |= MTD_POWERUP_LOCK;
>
> if (nor->addr_width == 4 && !(nor->flags & SNOR_F_4B_OPCODES)) {
> /*
Powered by blists - more mailing lists