summaryrefslogtreecommitdiffstats
path: root/arch/arm/cpu/armv7/socfpga/reset_manager.c
diff options
context:
space:
mode:
authorStefan Roese <sr@denx.de>2014-11-07 13:50:30 +0100
committerMarek Vasut <marex@denx.de>2014-11-07 16:09:10 +0100
commita877bec3ecd7961211a59b2c130e055e0f771976 (patch)
treeb4a94f10ecdcb027435a470c2c6232d9825ac39e /arch/arm/cpu/armv7/socfpga/reset_manager.c
parentd2bb937db911b19ed38dd4e5a30b5bf4f2e5a951 (diff)
downloadblackbird-obmc-uboot-a877bec3ecd7961211a59b2c130e055e0f771976.tar.gz
blackbird-obmc-uboot-a877bec3ecd7961211a59b2c130e055e0f771976.zip
arm: socfpga: Add socfpga_spim_enable() to reset_manager.c
This function will be needed by the upcoming Designware master SPI driver. As the SPI master controller is held in reset by the current Preloader implementation. So we need to release the reset for the driver to communicate with the controller. This function is called from arch_early_init_r() if the SPI driver is enabled. Signed-off-by: Stefan Roese <sr@denx.de> Cc: Chin Liang See <clsee@altera.com> Cc: Dinh Nguyen <dinguyen@altera.com> Cc: Vince Bridgers <vbridger@altera.com> Cc: Marek Vasut <marex@denx.de> Cc: Pavel Machek <pavel@denx.de>
Diffstat (limited to 'arch/arm/cpu/armv7/socfpga/reset_manager.c')
-rw-r--r--arch/arm/cpu/armv7/socfpga/reset_manager.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/arch/arm/cpu/armv7/socfpga/reset_manager.c b/arch/arm/cpu/armv7/socfpga/reset_manager.c
index 1d3a95d0c8..af9db850fe 100644
--- a/arch/arm/cpu/armv7/socfpga/reset_manager.c
+++ b/arch/arm/cpu/armv7/socfpga/reset_manager.c
@@ -104,3 +104,12 @@ void socfpga_emac_reset(int enable)
#endif
}
}
+
+/* SPI Master enable (its held in reset by the preloader) */
+void socfpga_spim_enable(void)
+{
+ const void *reset = &reset_manager_base->per_mod_reset;
+
+ clrbits_le32(reset, 1 << RSTMGR_PERMODRST_SPIM0_LSB);
+ clrbits_le32(reset, 1 << RSTMGR_PERMODRST_SPIM1_LSB);
+}
OpenPOWER on IntegriCloud