/* SPDX-License-Identifier: GPL-2.0-only */ #include #include #include #include #include #include #include #include struct gpio_with_delay { gpio_t gpio; unsigned int delay_msecs; }; static void power_off_lte_module(u8 slp_typ) { const struct gpio_with_delay lte_power_off_gpios[] = { { GPIO_161, /* AVS_I2S1_MCLK -- PLT_RST_LTE_L */ 30, }, { GPIO_117, /* PCIE_WAKE1_B -- FULL_CARD_POWER_OFF */ 100 }, { GPIO_67, /* UART2-CTS_B -- EN_PP3300_DX_LTE_SOC */ 0 } }; for (int i = 0; i < ARRAY_SIZE(lte_power_off_gpios); i++) { gpio_output(lte_power_off_gpios[i].gpio, 0); mdelay(lte_power_off_gpios[i].delay_msecs); } } const char *mainboard_vbt_filename(void) { uint32_t sku_id; sku_id = google_chromeec_get_board_sku(); switch (sku_id) { case SKU_9_HDMI: case SKU_19_HDMI_TS: case SKU_50_HDMI: return "vbt_garg_hdmi.bin"; default: return "vbt.bin"; } } void variant_smi_sleep(u8 slp_typ) { /* Currently use cases here all target to S5 therefore we do early return * here for saving one transaction to the EC for getting SKU ID. */ if (slp_typ != ACPI_S5) return; switch (google_chromeec_get_board_sku()) { case SKU_17_LTE: case SKU_18_LTE_TS: power_off_lte_module(slp_typ); return; default: return; } }