km/spi: overwrite kirkwood_spi weak functions for KM Kirkwood boards
authorPascal Linder <pascal.linder@edu.hefr.ch>
Tue, 18 Jun 2019 06:41:02 +0000 (08:41 +0200)
committerStefan Roese <sr@denx.de>
Thu, 11 Jul 2019 08:58:03 +0000 (10:58 +0200)
As the SPI NOR and NAND devices share the same hardware pins, the MPP
configuration has to be changed when claiming/releasing the bus. The
current configuration is saved when claiming and restored when releasing.
Furthermore, a general-purpose output is used to switch the chip-select
signal. This is now also implemented for the DM part of the kirkwood_spi
driver.

Signed-off-by: Pascal Linder <pascal.linder@edu.hefr.ch>
Signed-off-by: Holger Brunck <holger.brunck@ch.abb.com>
Signed-off-by: Stefan Roese <sr@denx.de>
board/keymile/km_arm/km_arm.c

index ea03be9eb37cf30c5223ae81d31cb7543bd438b4..7087cc520fdb04b6755cfe2219c0c19e61ab26ef 100644 (file)
@@ -322,6 +322,37 @@ void board_spi_release_bus(struct spi_slave *slave)
        kw_gpio_set_value(KM_FLASH_GPIO_PIN, 1);
 }
 
+static const u32 spi_mpp_config[] = {
+       MPP1_SPI_MOSI,
+       MPP2_SPI_SCK,
+       MPP3_SPI_MISO,
+       0
+};
+
+static u32 spi_mpp_backup[4];
+
+int mvebu_board_spi_claim_bus(struct udevice *dev)
+{
+       spi_mpp_backup[3] = 0;
+
+       /* set new spi mpp config and save current one */
+       kirkwood_mpp_conf(spi_mpp_config, spi_mpp_backup);
+
+       kw_gpio_set_value(KM_FLASH_GPIO_PIN, 0);
+
+       return 0;
+}
+
+int mvebu_board_spi_release_bus(struct udevice *dev)
+{
+       /* restore saved mpp config */
+       kirkwood_mpp_conf(spi_mpp_backup, NULL);
+
+       kw_gpio_set_value(KM_FLASH_GPIO_PIN, 1);
+
+       return 0;
+}
+
 #if (defined(CONFIG_KM_PIGGY4_88E6061))
 
 #define        PHY_LED_SEL_REG         0x18