1. 16 5月, 2017 2 次提交
    • C
      mtd: m25p80: add support of SPI 1-2-2 and 1-4-4 protocols · 138f5dc6
      Cyrille Pitchen 提交于
      Before this patch, m25p80_read() supported few SPI protocols:
      - regular SPI 1-1-1
      - SPI Dual Output 1-1-2
      - SPI Quad Output 1-1-4
      On the other hand, m25p80_write() only supported SPI 1-1-1.
      
      This patch updates both m25p80_read() and m25p80_write() functions to let
      them support SPI 1-2-2 and SPI 1-4-4 protocols for Fast Read and Page
      Program SPI commands.
      
      It adopts a conservative approach to avoid regressions. Hence the new
      implementations try to be as close as possible to the old implementations,
      so the main differences are:
      - the tx_nbits values now being set properly for the spi_transfer
        structures carrying the (op code + address/dummy) bytes
      - and the spi_transfer structure being split into 2 spi_transfer
        structures when the numbers of I/O lines are different for op code and
        for address/dummy byte transfers on the SPI bus.
      
      Besides, the current spi-nor framework supports neither the SPI 2-2-2 nor
      the SPI 4-4-4 protocols. So, for now, we don't need to update the
      m25p80_{read|write}_reg() functions as SPI 1-1-1 is the only one possible
      protocol.
      Signed-off-by: NCyrille Pitchen <cyrille.pitchen@atmel.com>
      Reviewed-by: NMarek Vasut <marek.vasut@gmail.com>
      138f5dc6
    • C
      mtd: spi-nor: introduce SPI 1-2-2 and SPI 1-4-4 protocols · cfc5604c
      Cyrille Pitchen 提交于
      This patch changes the prototype of spi_nor_scan(): its 3rd parameter
      is replaced by a 'struct spi_nor_hwcaps' pointer, which tells the spi-nor
      framework about the actual hardware capabilities supported by the SPI
      controller and its driver.
      
      Besides, this patch also introduces a new 'struct spi_nor_flash_parameter'
      telling the spi-nor framework about the hardware capabilities supported by
      the SPI flash memory and the associated settings required to use those
      hardware caps.
      
      Then, to improve the readability of spi_nor_scan(), the discovery of the
      memory settings and the memory initialization are now split into two
      dedicated functions.
      
      1 - spi_nor_init_params()
      
      The spi_nor_init_params() function is responsible for initializing the
      'struct spi_nor_flash_parameter'. Currently this structure is filled with
      legacy values but further patches will allow to override some parameter
      values dynamically, for instance by reading the JESD216 Serial Flash
      Discoverable Parameter (SFDP) tables from the SPI memory.
      The spi_nor_init_params() function only deals with the hardware
      capabilities of the SPI flash memory: especially it doesn't care about
      the hardware capabilities supported by the SPI controller.
      
      2 - spi_nor_setup()
      
      The second function is called once the 'struct spi_nor_flash_parameter'
      has been initialized by spi_nor_init_params().
      With both 'struct spi_nor_flash_parameter' and 'struct spi_nor_hwcaps',
      the new argument of spi_nor_scan(), spi_nor_setup() computes the best
      match between hardware caps supported by both the (Q)SPI memory and
      controller hence selecting the relevant settings for (Fast) Read and Page
      Program operations.
      Signed-off-by: NCyrille Pitchen <cyrille.pitchen@atmel.com>
      Reviewed-by: NMarek Vasut <marek.vasut@gmail.com>
      cfc5604c
  2. 12 5月, 2017 12 次提交
  3. 11 5月, 2017 12 次提交
  4. 10 5月, 2017 6 次提交
  5. 09 5月, 2017 8 次提交