2011-05-04 00:14:48 +08:00
|
|
|
/*
|
|
|
|
* Copyright (C) ST-Ericsson SA 2010
|
|
|
|
*
|
|
|
|
* License Terms: GNU General Public License v2
|
|
|
|
*
|
|
|
|
* U5500 PRCMU API.
|
|
|
|
*/
|
2011-08-12 16:28:10 +08:00
|
|
|
#ifndef __MFD_DB5500_PRCMU_H
|
|
|
|
#define __MFD_DB5500_PRCMU_H
|
2011-05-04 00:14:48 +08:00
|
|
|
|
2011-08-12 16:28:10 +08:00
|
|
|
#ifdef CONFIG_MFD_DB5500_PRCMU
|
2011-05-04 00:14:48 +08:00
|
|
|
|
|
|
|
void db5500_prcmu_early_init(void);
|
2011-08-12 16:28:10 +08:00
|
|
|
int db5500_prcmu_set_epod(u16 epod_id, u8 epod_state);
|
|
|
|
int db5500_prcmu_set_display_clocks(void);
|
|
|
|
int db5500_prcmu_disable_dsipll(void);
|
|
|
|
int db5500_prcmu_enable_dsipll(void);
|
2011-05-04 00:14:48 +08:00
|
|
|
int db5500_prcmu_abb_read(u8 slave, u8 reg, u8 *value, u8 size);
|
|
|
|
int db5500_prcmu_abb_write(u8 slave, u8 reg, u8 *value, u8 size);
|
2011-08-12 16:28:10 +08:00
|
|
|
void db5500_prcmu_enable_wakeups(u32 wakeups);
|
|
|
|
int db5500_prcmu_request_clock(u8 clock, bool enable);
|
|
|
|
void db5500_prcmu_config_abb_event_readout(u32 abb_events);
|
|
|
|
void db5500_prcmu_get_abb_event_buffer(void __iomem **buf);
|
|
|
|
int prcmu_resetout(u8 resoutn, u8 state);
|
|
|
|
int db5500_prcmu_set_power_state(u8 state, bool keep_ulp_clk,
|
|
|
|
bool keep_ap_pll);
|
|
|
|
int db5500_prcmu_config_esram0_deep_sleep(u8 state);
|
|
|
|
void db5500_prcmu_system_reset(u16 reset_code);
|
|
|
|
u16 db5500_prcmu_get_reset_code(void);
|
|
|
|
bool db5500_prcmu_is_ac_wake_requested(void);
|
|
|
|
int db5500_prcmu_set_arm_opp(u8 opp);
|
|
|
|
int db5500_prcmu_get_arm_opp(void);
|
2011-05-04 00:14:48 +08:00
|
|
|
|
|
|
|
#else /* !CONFIG_UX500_SOC_DB5500 */
|
|
|
|
|
2011-08-12 16:28:10 +08:00
|
|
|
static inline void db5500_prcmu_early_init(void) {}
|
2011-05-04 00:14:48 +08:00
|
|
|
|
|
|
|
static inline int db5500_prcmu_abb_read(u8 slave, u8 reg, u8 *value, u8 size)
|
|
|
|
{
|
|
|
|
return -ENOSYS;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int db5500_prcmu_abb_write(u8 slave, u8 reg, u8 *value, u8 size)
|
|
|
|
{
|
|
|
|
return -ENOSYS;
|
|
|
|
}
|
|
|
|
|
2011-08-12 16:28:10 +08:00
|
|
|
static inline int db5500_prcmu_request_clock(u8 clock, bool enable)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int db5500_prcmu_set_display_clocks(void)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int db5500_prcmu_disable_dsipll(void)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int db5500_prcmu_enable_dsipll(void)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
2011-05-04 00:14:48 +08:00
|
|
|
|
2011-08-12 16:28:10 +08:00
|
|
|
static inline int db5500_prcmu_config_esram0_deep_sleep(u8 state)
|
2011-05-04 00:14:48 +08:00
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2011-08-12 16:28:10 +08:00
|
|
|
static inline void db5500_prcmu_enable_wakeups(u32 wakeups) {}
|
|
|
|
|
|
|
|
static inline int prcmu_resetout(u8 resoutn, u8 state)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int db5500_prcmu_set_epod(u16 epod_id, u8 epod_state)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void db5500_prcmu_get_abb_event_buffer(void __iomem **buf) {}
|
|
|
|
static inline void db5500_prcmu_config_abb_event_readout(u32 abb_events) {}
|
|
|
|
|
|
|
|
static inline int db5500_prcmu_set_power_state(u8 state, bool keep_ulp_clk,
|
|
|
|
bool keep_ap_pll)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void db5500_prcmu_system_reset(u16 reset_code) {}
|
|
|
|
|
|
|
|
static inline u16 db5500_prcmu_get_reset_code(void)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline bool db5500_prcmu_is_ac_wake_requested(void)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int db5500_prcmu_set_arm_opp(u8 opp)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int db5500_prcmu_get_arm_opp(void)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#endif /* CONFIG_MFD_DB5500_PRCMU */
|
|
|
|
|
|
|
|
#endif /* __MFD_DB5500_PRCMU_H */
|