On Tue, Feb 21, 2017 at 5:10 AM, Philipp Tomsich <philipp.toms...@theobroma-systems.com> wrote: > This adds a rewrite of the SPI driver we had in use for the A31-uQ7 > (sun6i), A80-Q7 (sun9i) and A64-uQ7 (sun50i) boards, which includes > support for: > * cs-gpios (i.e. GPIOs as additional chip-selects) > * clocking, reset and pinctrl based on the device-model > * dual-IO data receive for controllers that support it (sun50i) > > The key difference to the earlier incarnation that we provided as part > of our BSP is the removal of the legacy reset and clocking code and > added resilience to configuration errors (i.e. timeouts for the inner > loops) and converstion to the device-model. This was possible due to a > non-device-model driver now being present for use with in the SPL. > > This has been verified against the A64-uQ7 with data rates up to > 100MHz and dual-IO ("Fast Read Dual Output" opcode) from the on-board > SPI-NOR flash. > > Signed-off-by: Philipp Tomsich <philipp.toms...@theobroma-systems.com> > --- > drivers/spi/Kconfig | 14 ++ > drivers/spi/Makefile | 1 + > drivers/spi/sunxi_spi.c | 571 > ++++++++++++++++++++++++++++++++++++++++++++++++ > 3 files changed, 586 insertions(+) > create mode 100644 drivers/spi/sunxi_spi.c > > diff --git a/drivers/spi/Kconfig b/drivers/spi/Kconfig > index f3f7dbe..64b6430 100644 > --- a/drivers/spi/Kconfig > +++ b/drivers/spi/Kconfig > @@ -132,6 +132,20 @@ config STM32_QSPI > used to access the SPI NOR flash chips on platforms embedding > this ST IP core. > > +config SUNXI_SPI > + bool "Allwinner (sunxi) SPI driver" > + help > + Enable the SPI driver for Allwinner SoCs. > + > + This driver can be used to access the SPI NOR flash on for > + communciation with SPI peripherals platforms embedding the > + Allwinner SoC. This driver supports the device-model (only) > + and has support for GPIOs as additional chip-selects. > + > + For recent platforms (e.g. sun50i), dual-IO receive mode is > + also supported, when configured for a SPI-NOR flash in the > + device tree. > + > config TEGRA114_SPI > bool "nVidia Tegra114 SPI driver" > help > diff --git a/drivers/spi/Makefile b/drivers/spi/Makefile > index fa9a1d2..aab31b4 100644 > --- a/drivers/spi/Makefile > +++ b/drivers/spi/Makefile > @@ -40,6 +40,7 @@ obj-$(CONFIG_OMAP3_SPI) += omap3_spi.o > obj-$(CONFIG_PIC32_SPI) += pic32_spi.o > obj-$(CONFIG_ROCKCHIP_SPI) += rk_spi.o > obj-$(CONFIG_SANDBOX_SPI) += sandbox_spi.o > +obj-$(CONFIG_SUNXI_SPI) += sunxi_spi.o > obj-$(CONFIG_SH_SPI) += sh_spi.o > obj-$(CONFIG_SH_QSPI) += sh_qspi.o > obj-$(CONFIG_STM32_QSPI) += stm32_qspi.o > diff --git a/drivers/spi/sunxi_spi.c b/drivers/spi/sunxi_spi.c > new file mode 100644 > index 0000000..cd2cb1d > --- /dev/null > +++ b/drivers/spi/sunxi_spi.c > @@ -0,0 +1,571 @@ > +/* > + * SPI driver for Allwinner sunxi SoCs > + * > + * Copyright (C) 2015-2017 Theobroma Systems Design und Consulting GmbH > + * > + * This program is free software; you can redistribute it and/or > + * modify it under the terms of the GNU General Public License as > + * published by the Free Software Foundation; either version 2 of > + * the License, or (at your option) any later version. > + */ > + > +#include <common.h> > +#ifdef CONFIG_DM_GPIO > +#include <asm/gpio.h> > +#endif > +#include <asm/io.h> > +#include <clk.h> > +#include <dm.h> > +#include <errno.h> > +#include <fdtdec.h> > +#include <linux/iopoll.h> > +#include <reset.h> > +#include <spi.h> > + > +DECLARE_GLOBAL_DATA_PTR; > + > +/* The SPI flash opcode for a FAST READ DUAL OUTPUT operation. */ > +#define CMD_READ_DUAL_OUTPUT_FAST 0x3b
Flash(slave) specific opcodes shouldn't use it on spi driver, try to implement the spi in generic way instead of making to handle only specific slave. thanks! -- Jagan Teki Free Software Engineer | www.openedev.com U-Boot, Linux | Upstream Maintainer Hyderabad, India. _______________________________________________ U-Boot mailing list U-Boot@lists.denx.de http://lists.denx.de/mailman/listinfo/u-boot