KT24-1110_65E-HA-651B/include_lib/driver/cpu/br25/asm/power_interface.h

301 lines
6.7 KiB
C
Raw Normal View History

2024-11-10 10:44:17 +00:00
#ifndef POWER_INTERFACE_H
#define POWER_INTERFACE_H
// #include "asm/hwi.h"
//
#include "generic/typedef.h"
#define NEW_BASEBAND_COMPENSATION 0
#define AT_VOLATILE_RAM AT(.volatile_ram)
#define AT_VOLATILE_RAM_CODE AT(.volatile_ram_code)
#define AT_NON_VOLATILE_RAM AT(.non_volatile_ram)
#define AT_NON_VOLATILE_RAM_CODE AT(.non_volatile_ram_code)
extern u32 nvbss_begin;
extern u32 nvbss_length;
extern u32 nvdata_begin;
extern u32 nvdata_size;
extern u32 nvdata_addr;
#define NV_RAM_START &nvbss_begin
#define NV_RAM_SIZE &nvbss_length
#define NV_RAM_END (NV_RAM_START + NV_RAM_SIZE)
enum {
MAGIC_ADDR = 2,
ENTRY_ADDR = 3,
};
#define RAM1_MAGIC_ADDR (NV_RAM_END - MAGIC_ADDR*4)
#define RAM1_ENTRY_ADDR (NV_RAM_END - ENTRY_ADDR*4)
#define SLEEP_EN BIT(2)
#define SLEEP_SAVE_TIME_US 1L
#define BT_SLEEP_RECOVER_TIME_US 1500L
#define LRC_SLEEP_RECOVER_TIME_US 3500L
#define DEEP_SLEEP_EN BIT(1)
#define DSLEEP_SAVE_BEFORE_ENTER_MS 1
#define DSLEEP_RECOVER_AFTER_EXIT_MS 10
#define DEEP_SLEEP_TIMEOUT_MIN_US (60*625L) //间隔至少要60slot以上才进入power off
#define SLEEP_TICKS_UNIT (10*1000L) //
#define DEEP_SLEEP_TICKS_UNIT (20*1000L) //
enum {
OSC_TYPE_LRC = 0,
OSC_TYPE_RTC,
OSC_TYPE_BT_OSC,
};
enum {
PWR_NO_CHANGE = 0,
PWR_LDO33,
PWR_LDO15,
PWR_DCDC15,
};
enum {
LONG_4S_RESET = 0,
LONG_8S_RESET,
};
//Macro for VDDIOM_VOL_SEL
enum {
VDDIOM_VOL_22V = 0,
VDDIOM_VOL_24V,
VDDIOM_VOL_26V,
VDDIOM_VOL_28V,
VDDIOM_VOL_30V,
VDDIOM_VOL_32V,
VDDIOM_VOL_34V,
VDDIOM_VOL_36V,
};
//Macro for VDDIOW_VOL_SEL
enum {
VDDIOW_VOL_21V = 0,
VDDIOW_VOL_24V,
VDDIOW_VOL_28V,
VDDIOW_VOL_32V,
};
struct low_power_param {
u8 osc_type;
u32 btosc_hz;
u8 delay_us;
u8 config;
u8 btosc_disable;
u8 dcdc_port;
u8 vddiom_lev;
u8 vddiow_lev;
u8 pd_wdvdd_lev;
u8 vddio_keep;
u8 vdc13_keep; //如果进入低功耗时哒哒声可以将该标志置1。该位置1时会同时keep住vddio单耳功耗会大100ua左右对耳会大200ua左右。(哒哒声是由于电容的效应导致的)
u32 osc_delay_us;
u8 virtual_rtc;
u32 vir_rtc_trim_time;
u8 user_nv_timer_en;
u16 nv_timer_interval;
u8 rtc_clk;
};
#define BLUETOOTH_RESUME BIT(1)
#define RISING_EDGE 0
#define FALLING_EDGE 1
typedef enum {
PORT_FLT_NULL = 0,
PORT_FLT_32us,
PORT_FLT_64us,
PORT_FLT_128us,
PORT_FLT_256us,
PORT_FLT_512us,
PORT_FLT_1ms,
PORT_FLT_2ms,
} PORT_FLT;
struct port_wakeup {
u8 pullup_down_enable; //
u8 edge; //[0]: Rising / [1]: Falling
u8 attribute; //Relate operation bitmap OS_RESUME | BLUETOOTH_RESUME
u8 iomap; //Port Group-Port Index
u8 filter_enable;
};
struct charge_wakeup {
u8 attribute; //Relate operation bitmap OS_RESUME | BLUETOOTH_RESUME
};
struct alarm_wakeup {
u8 attribute; //Relate operation bitmap OS_RESUME | BLUETOOTH_RESUME
};
struct lvd_wakeup {
u8 attribute; //Relate operation bitmap OS_RESUME | BLUETOOTH_RESUME
};
struct sub_wakeup {
u8 attribute; //Relate operation bitmap OS_RESUME | BLUETOOTH_RESUME
};
//<Max hardware wakeup port
#define MAX_WAKEUP_PORT 8
struct wakeup_param {
const PORT_FLT filter;
struct port_wakeup *port[MAX_WAKEUP_PORT];
const struct charge_wakeup *charge;
const struct alarm_wakeup *alram;
const struct lvd_wakeup *lvd;
const struct sub_wakeup *sub;
};
struct reset_param {
u8 en;
u8 mode;
u8 level;
u8 iomap; //Port Group, Port Index
};
struct low_power_operation {
const char *name;
u32(*get_timeout)(void *priv);
void (*suspend_probe)(void *priv);
void (*suspend_post)(void *priv, u32 usec);
void (*resume)(void *priv, u32 usec);
void (*resume_post)(void *priv, u32 usec);
void (*off_probe)(void *priv);
void (*off_post)(void *priv, u32 usec);
void (*on)(void *priv);
};
u32 __tus_carry(u32 x);
u8 __power_is_poweroff(void);
void poweroff_recover(void);
void power_init(const struct low_power_param *param);
u8 power_is_low_power_probe(void);
u8 power_is_low_power_post(void);
void set_softoff_wakeup_time_ms(u32 ums);
void set_softoff_wakeup_time_sec(u32 sec);
void power_set_soft_poweroff(void);
void power_set_mode(u8 mode);
void power_keep_dacvdd_en(u8 en);
void power_set_callback(u8 mode, void (*powerdown_enter)(u8 step), void (*powerdown_exit)(u32), void (*soft_poweroff_enter)(void));
u8 power_is_poweroff_post(void);
// #define power_is_poweroff_post() 0
void power_set_proweroff(void);
u8 power_reset_source_dump(void);
/*-----------------------------------------------------------*/
void low_power_on(void);
void low_power_request(void);
void low_power_exit_request(void);
void low_power_lock(void);
void low_power_unlock(void);
void *low_power_get(void *priv, const struct low_power_operation *ops);
void low_power_put(void *priv);
void low_power_sys_request(void *priv);
void *low_power_sys_get(void *priv, const struct low_power_operation *ops);
void low_power_sys_put(void *priv);
u8 low_power_sys_is_idle(void);
s32 low_power_trace_drift(u32 usec);
void low_power_reset_osc_type(u8 type);
u8 low_power_get_default_osc_type(void);
u8 low_power_get_osc_type(void);
/*-----------------------------------------------------------*/
void power_wakeup_index_enable(u8 index);
void power_wakeup_index_disable(u8 index);
void power_wakeup_init(const struct wakeup_param *param);
void power_wakeup_port_set(u8 idx, struct port_wakeup *port);
void power_wakeup_init_test();
u8 get_wakeup_source(void);
u8 is_ldo5v_wakeup(void);
// void power_wakeup_callback(JL_SignalEvent_t cb_event);
void p33_soft_reset(void);
void port_edge_wkup_set_callback(void (*wakeup_callback)(u8 index, u32 gpio));
/*-----------------------------------------------------------*/
void power_reset_close();
void lrc_debug(u8 a, u8 b);
void sdpg_config(int enable);
void power_set_wvdd(u8 level);
int cpu_reset_by_soft();
/*-----------------------------------------------------------*/
void reset_vddiom_lev(u8 lev);
typedef u8(*idle_handler_t)(void);
struct lp_target {
char *name;
idle_handler_t is_idle;
};
#define REGISTER_LP_TARGET(target) \
const struct lp_target target sec(.lp_target)
extern const struct lp_target lp_target_begin[];
extern const struct lp_target lp_target_end[];
#define list_for_each_lp_target(p) \
for (p = lp_target_begin; p < lp_target_end; p++)
/*-----------------------------------------------------------*/
#endif