blob: c5d5c204628f58cac615efa1e08952f9f75e957b [file] [log] [blame] [edit]
/* SPDX-License-Identifier: GPL-2.0 */
/*
* Copyright 2021 Google, LLC
*
*/
#ifndef MAX77779_USECASE_H_
#define MAX77779_USECASE_H_
struct max77779_usecase_data {
int otg_enable; /* enter/exit from OTG cases */
bool rx_otg_en; /* enable WLC_RX -> WLC_RX + OTG case */
int dc_sw_gpio; /* WLC-DC switch enable */
int vin_is_valid; /* MAX20339 STATUS1.vinvalid */
int wlc_en; /* wlcrx/chgin coex */
int wlc_vbus_en; /* b/202526678 */
u8 otg_ilim; /* TODO: TCPM to control this? */
u8 otg_vbyp; /* TODO: TCPM to control this? */
u8 otg_orig; /* restore value */
u8 otg_value; /* CHG_CNFG_11:VBYPSET for USB OTG Voltage */
struct i2c_client *client;
bool init_done;
int use_case;
};
enum gsu_usecases {
GSU_RAW_MODE = -1, /* raw mode, default, */
GSU_MODE_STANDBY = 0, /* 8, PMIC mode 0 */
GSU_MODE_USB_CHG = 1, /* 1-1 wired mode 0x4, mode 0x5 */
GSU_MODE_USB_DC = 2, /* 1-2 wired mode 0x0 */
GSU_MODE_USB_CHG_WLC_TX = 3, /* 2-1, 1041, */
GSU_MODE_WLC_RX = 5, /* 3-1, mode 0x4, mode 0x5 */
GSU_MODE_WLC_DC = 6, /* 3-2, mode 0x0 */
GSU_MODE_USB_OTG_WLC_RX = 7, /* 7, 524, */
GSU_MODE_USB_OTG = 9, /* 5-1, 516,*/
GSU_MODE_USB_OTG_FRS = GSU_MODE_USB_OTG,
GSU_MODE_WLC_TX = 11, /* 6-2, 1056, */
GSU_MODE_USB_OTG_WLC_TX = 12,
GSU_MODE_USB_WLC_RX = 13,
};
extern int gs201_wlc_en(struct max77779_usecase_data *uc_data, bool wlc_on);
extern int gs201_to_standby(struct max77779_usecase_data *uc_data, int use_case);
extern int gs201_to_usecase(struct max77779_usecase_data *uc_data, int use_case);
extern int gs201_force_standby(struct max77779_usecase_data *uc_data);
extern bool gs201_setup_usecases(struct max77779_usecase_data *uc_data,
struct device_node *node);
extern void gs201_dump_usecasase_config(struct max77779_usecase_data *uc_data);
extern int max77779_otg_vbyp_mv_to_code(u8 *code, int vbyp);
#endif