2019-06-04 11:11:33 +03:00
/* SPDX-License-Identifier: GPL-2.0-only */
2007-07-10 01:06:53 +04:00
/*
2014-01-17 07:39:05 +04:00
* Copyright 2004 - 2014 Freescale Semiconductor , Inc . All Rights Reserved .
2007-07-10 01:06:53 +04:00
*/
# ifndef __ASM_ARCH_MXC_COMMON_H__
# define __ASM_ARCH_MXC_COMMON_H__
2013-07-09 03:01:40 +04:00
# include <linux/reboot.h>
2013-10-16 15:52:00 +04:00
struct irq_data ;
2008-09-09 12:19:40 +04:00
struct platform_device ;
2013-05-08 17:05:53 +04:00
struct pt_regs ;
2009-02-16 16:36:49 +03:00
struct clk ;
2014-04-05 19:57:45 +04:00
struct device_node ;
2011-09-06 11:08:40 +04:00
enum mxc_cpu_pwr_mode ;
2014-07-07 13:41:26 +04:00
struct of_device_id ;
2008-09-09 12:19:40 +04:00
2013-10-16 17:05:35 +04:00
void mx21_map_io ( void ) ;
void mx27_map_io ( void ) ;
void mx31_map_io ( void ) ;
void mx35_map_io ( void ) ;
void imx21_init_early ( void ) ;
void imx27_init_early ( void ) ;
void imx31_init_early ( void ) ;
void imx35_init_early ( void ) ;
void mxc_init_irq ( void __iomem * ) ;
void mx21_init_irq ( void ) ;
void mx27_init_irq ( void ) ;
void mx31_init_irq ( void ) ;
void mx35_init_irq ( void ) ;
void imx21_soc_init ( void ) ;
void imx27_soc_init ( void ) ;
void imx31_soc_init ( void ) ;
void imx35_soc_init ( void ) ;
int mx21_clocks_init ( unsigned long lref , unsigned long fref ) ;
int mx27_clocks_init ( unsigned long fref ) ;
int mx31_clocks_init ( unsigned long fref ) ;
int mx35_clocks_init ( void ) ;
struct platform_device * mxc_register_gpio ( char * name , int id ,
2011-06-05 20:07:55 +04:00
resource_size_t iobase , resource_size_t iosize , int irq , int irq_high ) ;
2013-10-16 17:05:35 +04:00
void mxc_set_cpu_type ( unsigned int type ) ;
void mxc_restart ( enum reboot_mode , const char * ) ;
void mxc_arch_reset_init ( void __iomem * ) ;
2016-06-24 13:49:56 +03:00
void imx1_reset_init ( void __iomem * ) ;
2013-10-16 17:05:35 +04:00
void imx_set_aips ( void __iomem * ) ;
2014-07-07 13:41:26 +04:00
void imx_aips_allow_unprivileged_access ( const char * compat ) ;
2013-10-16 17:05:35 +04:00
int mxc_device_init ( void ) ;
2013-08-13 09:54:02 +04:00
void imx_set_soc_revision ( unsigned int rev ) ;
2013-08-13 10:59:43 +04:00
void imx_init_revision_from_anatop ( void ) ;
2013-08-13 12:59:28 +04:00
struct device * imx_soc_device_init ( void ) ;
2014-12-17 07:24:12 +03:00
void imx6_enable_rbc ( bool enable ) ;
2015-03-13 19:05:37 +03:00
void imx_gpc_check_dt ( void ) ;
2014-12-17 07:24:12 +03:00
void imx_gpc_set_arm_power_in_lpm ( bool power_off ) ;
2018-06-03 05:33:44 +03:00
void imx_gpc_set_l2_mem_power_in_lpm ( bool power_off ) ;
2014-12-17 07:24:12 +03:00
void imx_gpc_set_arm_power_up_timing ( u32 sw2iso , u32 sw ) ;
void imx_gpc_set_arm_power_down_timing ( u32 sw2iso , u32 sw ) ;
2016-02-03 00:45:38 +03:00
void imx25_pm_init ( void ) ;
2016-06-28 05:22:16 +03:00
void imx27_pm_init ( void ) ;
2018-07-10 19:31:48 +03:00
void imx5_pmu_init ( void ) ;
2011-10-17 04:42:16 +04:00
2011-09-28 13:16:06 +04:00
enum mxc_cpu_pwr_mode {
WAIT_CLOCKED , /* wfi only */
WAIT_UNCLOCKED , /* WAIT */
WAIT_UNCLOCKED_POWER_OFF , /* WAIT + SRPG */
STOP_POWER_ON , /* just STOP */
STOP_POWER_OFF , /* STOP + SRPG */
} ;
2019-01-14 03:54:59 +03:00
enum ulp_cpu_pwr_mode {
ULP_PM_HSRUN , /* High speed run mode */
ULP_PM_RUN , /* Run mode */
ULP_PM_WAIT , /* Wait mode */
ULP_PM_STOP , /* Stop mode */
ULP_PM_VLPS , /* Very low power stop mode */
ULP_PM_VLLS , /* very low leakage stop mode */
} ;
2013-10-16 17:05:35 +04:00
void imx_enable_cpu ( int cpu , bool enable ) ;
void imx_set_cpu_jump ( int cpu , void * jump_addr ) ;
u32 imx_get_cpu_arg ( int cpu ) ;
void imx_set_cpu_arg ( int cpu , u32 arg ) ;
2011-09-06 10:59:40 +04:00
# ifdef CONFIG_SMP
2013-10-16 17:05:35 +04:00
void v7_secondary_startup ( void ) ;
void imx_scu_map_io ( void ) ;
void imx_smp_prepare ( void ) ;
2011-09-06 11:05:25 +04:00
# else
static inline void imx_scu_map_io ( void ) { }
2011-09-06 11:08:40 +04:00
static inline void imx_smp_prepare ( void ) { }
2011-09-06 10:59:40 +04:00
# endif
2013-10-16 17:05:35 +04:00
void imx_src_init ( void ) ;
2014-06-23 12:42:44 +04:00
void imx_gpc_pre_suspend ( bool arm_power_off ) ;
2013-10-16 17:05:35 +04:00
void imx_gpc_post_resume ( void ) ;
void imx_gpc_mask_all ( void ) ;
void imx_gpc_restore_all ( void ) ;
2014-12-02 19:05:26 +03:00
void imx_gpc_hwirq_mask ( unsigned int hwirq ) ;
void imx_gpc_hwirq_unmask ( unsigned int hwirq ) ;
2013-10-16 17:05:35 +04:00
void imx_anatop_init ( void ) ;
void imx_anatop_pre_suspend ( void ) ;
void imx_anatop_post_resume ( void ) ;
2015-04-25 17:59:19 +03:00
int imx6_set_lpm ( enum mxc_cpu_pwr_mode mode ) ;
2016-08-29 16:49:56 +03:00
void imx6_set_int_mem_clk_lpm ( bool enable ) ;
2014-01-09 12:03:16 +04:00
void imx6sl_set_wait_clk ( bool enter ) ;
2014-09-17 07:11:45 +04:00
int imx_mmdc_get_ddr_type ( void ) ;
2019-01-14 03:54:59 +03:00
int imx7ulp_set_lpm ( enum ulp_cpu_pwr_mode mode ) ;
2013-10-16 17:05:35 +04:00
void imx_cpu_die ( unsigned int cpu ) ;
int imx_cpu_kill ( unsigned int cpu ) ;
2011-09-08 16:15:22 +04:00
2014-02-26 15:48:33 +04:00
# ifdef CONFIG_SUSPEND
void v7_cpu_resume ( void ) ;
2015-05-12 16:31:03 +03:00
void imx53_suspend ( void __iomem * ocram_vbase ) ;
extern const u32 imx53_suspend_sz ;
2014-01-17 07:39:05 +04:00
void imx6_suspend ( void __iomem * ocram_vbase ) ;
2014-02-26 15:48:33 +04:00
# else
static inline void v7_cpu_resume ( void ) { }
2015-05-12 16:31:03 +03:00
static inline void imx53_suspend ( void __iomem * ocram_vbase ) { }
static const u32 imx53_suspend_sz ;
2014-02-26 15:48:33 +04:00
static inline void imx6_suspend ( void __iomem * ocram_vbase ) { }
# endif
2015-04-29 08:07:03 +03:00
void imx6_pm_ccm_init ( const char * ccm_compat ) ;
2013-10-16 17:05:35 +04:00
void imx6q_pm_init ( void ) ;
2014-01-17 07:39:05 +04:00
void imx6dl_pm_init ( void ) ;
void imx6sl_pm_init ( void ) ;
2014-06-20 09:20:54 +04:00
void imx6sx_pm_init ( void ) ;
2015-08-04 20:48:37 +03:00
void imx6ul_pm_init ( void ) ;
2018-11-10 18:13:04 +03:00
void imx7ulp_pm_init ( void ) ;
2014-01-17 07:39:05 +04:00
2014-02-18 06:35:05 +04:00
# ifdef CONFIG_PM
2014-05-20 10:55:15 +04:00
void imx51_pm_init ( void ) ;
void imx53_pm_init ( void ) ;
2011-12-21 18:38:23 +04:00
# else
2014-05-20 10:55:15 +04:00
static inline void imx51_pm_init ( void ) { }
static inline void imx53_pm_init ( void ) { }
2011-12-21 18:38:23 +04:00
# endif
2012-04-26 07:42:34 +04:00
# ifdef CONFIG_NEON
2013-10-16 17:05:35 +04:00
int mx51_neon_fixup ( void ) ;
2012-04-26 07:42:34 +04:00
# else
static inline int mx51_neon_fixup ( void ) { return 0 ; }
# endif
2013-07-08 17:45:20 +04:00
# ifdef CONFIG_CACHE_L2X0
2013-10-16 17:05:35 +04:00
void imx_init_l2cache ( void ) ;
2013-07-08 17:45:20 +04:00
# else
static inline void imx_init_l2cache ( void ) { }
# endif
2015-11-15 04:39:53 +03:00
extern const struct smp_operations imx_smp_ops ;
extern const struct smp_operations ls1021a_smp_ops ;
2011-09-08 16:15:22 +04:00
2007-07-10 01:06:53 +04:00
# endif