Hi Huiquan and Qipeng
On 04/21/2015 02:48 AM, qipeng.zha wrote:
From: Huiquan Zhong <huiquan.zhong@xxxxxxxxx>
Broxton have 3 SPI ports, PCI ids are 0x0ac2, 0x0ac4, 0x0ac6.
The LPSS SSP private register offset is 0x200. iDMA register offset
is 0x800.
Every Broxton SPI Controller have integrated one dedicated DMA IP.
Two DMA channels mapping:
channel[0] -> SPI Tx,
channel[1] -> SPI Rx.
BXT SSP SPI does not support DMA burst mode operation. Only iDMA
M-Size setting equal to 1(Single) is supported for all DMA
peripherial transfers from the SSP to the DMA and from the DMA
to the SSP, otherwise RX data corruption will happen.
Use a new parameter(.chip_select) for BXT dedicated cs control.
Signed-off-by: Huiquan Zhong <huiquan.zhong@xxxxxxxxx>
---
drivers/spi/spi-pxa2xx-pci.c | 103 ++++++++++++++++++++++++++++++++++++++++
drivers/spi/spi-pxa2xx.c | 105 +++++++++++++++++++++++++++++++++++++++++
drivers/spi/spi-pxa2xx.h | 1 +
include/linux/pxa2xx_ssp.h | 3 ++
include/linux/spi/pxa2xx_spi.h | 2 +
5 files changed, 214 insertions(+)
Can we hold this a bit and join our efforts? We have been cooking a
support for Skylake recently with a plan to extend to Broxton later.
Major difference to patch here is that we plan to use common code that
probes PCI and ACPI enumerated individual devices (I2C, SPI and UART)
and their integrated DMA (which doesn't have its own PCI or ACPI ID and
not all devices have it) and adds them as platform devices.
That module will take care of reset and clock management so for instance
this SPI code becomes a bit shorter and avoids similar code in I2C and
UART too. Our MFD loader has been posted recently but is not merged yet:
https://lkml.org/lkml/2015/3/31/258
--
Jarkko
--
To unsubscribe from this list: send the line "unsubscribe linux-spi" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html