[PATCH v4 0/7] mtd: spi-nor: add a new framework for SPI NOR

Jagan Teki jagannadh.teki at gmail.com
Fri Jan 17 02:06:08 EST 2014


On Fri, Jan 17, 2014 at 7:32 AM, Huang Shijie <b32955 at freescale.com> wrote:
> On Thu, Jan 16, 2014 at 03:09:13PM +0530, Jagan Teki wrote:
>> >>>     After this patch, the layer is like:
>> >>>                     MTD
>> >>>           ------------------------
>> >>>                    spi-nor
>> >>>           ------------------------
>> >>>                    m25p80
>> >>>           ------------------------
>> >>>                 spi bus driver
>> >>>           ------------------------
>> >>>                 SPI NOR chip
>>
>> Just for looking on your new framework, is that above link correct.
>> I guess it should be MTD -- m25p80 -- spi-nor -- spi bus driver -- SPI NOR chip
>
> I do not think so.
> The spi-nor layer does not contact with the spi bus driver directly.

Yes - now I understand the flow from seeing the code.
With your new framework
1. not an exact spi-nor
    have one controller driver at drivers/spi/* will register to spi core.
    have m25p80.c will scan the flash details from
drivers/mtd/spi-nor/spi-nor.c and
    m25p80 will register the MTD core and for transfer calls m25p80
will calls spi core.
2. spi-nor style
    have  one controller driver at drivers/mtd/spi-nor/fsl-quadspi.c
will register MTD core
    and scan the flash details from drivers/mtd/spi-nor/spi-nor.c and
for transfer will calls
    through direct writel and readl with cmd+data fashion.

Correct me If my understanding was wrong.
>
>> >> 3) Can you explain your framework precisely take an example of like
>> >> spi_controller_A with spi_flash_A
>> >> and qspi_controller_B and qspi_flash_B - how will this new framework
>> >> operates.
>> >>
>> > The framework is just cloned from the m25p80.c, and extract the common code,
>> > and provides more
>> > hooks such as
>> >
>> > @prepare/unpreare: used to do some work before or after the
>> >              read/write/erase/lock/unlock.
>> >     @read_xfer/write_xfer: We can use these two hooks to code all
>> >              the following hooks if the driver tries to implement them
>> >              by itself.
>> >     @read_reg: used to read the registers, such as read status register,
>> >              read configure register.
>> >     @write_reg: used to write the registers, such as write enable,
>> >              erase sector.
>> >     @read_id: read out the ID info.
>> >     @wait_till_ready: wait till the NOR becomes ready.
>> >     @read: read out the data from the NOR.
>> >     @write: write data to the NOR.
>> >     @erase: erase a sector of the NOR.
>> >
>>
>> My basic question is like I have a qspi spi controller in my SOC and I
>> designed two boards B1 and B2
>
> okay.
>
>> B1 with quad spi controller connected with non-flash as a slave and B2
>> with quad spi controller connected
>> with quad flash as a slave.
> You can use the framework for B2. But for B1, you should not use the framework,
> since this framework is just for the SPI-NOR. If you do not connected with
> a NOR, i think it's better to code another driver for your controller.

Means we have two separate controller drivers for same controller one
with spi-nor and
another with spi is it?

Do you think this is a good idea, I understand you have a complete and
well guided new
spi-nor framework.

-- 
Thanks,
Jagan.



More information about the linux-mtd mailing list