static void kpoc_power_off_check(struct mtk_charger *info) { unsigned int boot_mode = info->bootmode; int vbus = 0; int counter = 0; /* 8 = KERNEL_POWER_OFF_CHARGING_BOOT */ /* 9 = LOW_POWER_OFF_CHARGING_BOOT */ if (boot_mode == 8 || boot_mode == 9) { vbus = get_vbus(info); if ((vbus >= 0 && vbus < 2500 && !mtk_is_charger_on(info) && !info->pd_reset) || (vbus >= 0 && vbus < 2500 && get_charger_type(info) == POWER_SUPPLY_TYPE_WIRELESS)) { chr_err("Unplug Charger/USB in KPOC mode, vbus=%d, shutdown\n", vbus); while (1) { if (counter >= 20000) { chr_err("%s, wait too long\n", __func__); kernel_power_off(); break; } if (info->is_suspend == false) { chr_err("%s, not in suspend, shutdown\n", __func__); kernel_power_off(); } else { chr_err("%s, suspend! cannot shutdown\n", __func__); msleep(20); } counter++; } } charger_send_kpoc_uevent(info); } }请详细分析一下这段函数
时间: 2024-04-21 20:25:23 浏览: 8
这段函数是用于检测充电器状态并在特定情况下自动关机的函数。该函数接受一个指向 mtk_charger 结构体的指针作为参数。
函数首先获取当前设备的启动模式,如果启动模式为8或9,则表示当前设备处于KERNEL_POWER_OFF_CHARGING_BOOT或LOW_POWER_OFF_CHARGING_BOOT模式下。
如果设备处于这两种模式之一,则检查当前USB的电压值和充电器类型。如果USB电压小于2500,且充电器未插入或处于无线充电状态,则需要自动关机。
在此之后,函数会进入一个无限循环,检查设备是否在挂起状态。如果设备不在挂起状态,则直接关机。如果设备在挂起状态,则等待20毫秒,然后再次检查是否在挂起状态。如果等待时间超过20000,函数会输出错误信息并执行关机操作。
最后,函数会发送一个uevent事件通知,以通知其他组件设备已经进入了KPOC模式。
相关问题
static int cps_wls_register_psy(struct cps_wls_chrg_chip *chip) { struct power_supply_config cps_wls_psy_cfg = {}; struct power_supply *chg_psy = NULL; struct mtk_charger *info = NULL; chg_psy = power_supply_get_by_name("mtk-master-charger"); if (chg_psy == NULL || IS_ERR(chg_psy)) { pr_info("%s Couldn't get chg_psy\n", func); } info = (struct mtk_charger )power_supply_get_drvdata(chg_psy); if (info == NULL) { pr_info("%s Couldn't get chg_psy\n", func); } chip->boot_mode = info->bootmode; / 8 = KERNEL_POWER_OFF_CHARGING_BOOT / / 9 = LOW_POWER_OFF_CHARGING_BOOT */ if (chip->boot_mode != 8 && chip->boot_mode != 9) { cps_wls_rx_send_ept_packet(0x0B); pr_info("probe reset RX !\n"); } chip->wl_psd.name = CPS_WLS_CHRG_PSY_NAME; chip->wl_psd.type = POWER_SUPPLY_TYPE_UNKNOWN; chip->wl_psd.properties = cps_wls_chrg_props; chip->wl_psd.num_properties = ARRAY_SIZE(cps_wls_chrg_props); chip->wl_psd.get_property = cps_wls_chrg_get_property; chip->wl_psd.set_property = cps_wls_chrg_set_property; chip->wl_psd.property_is_writeable = cps_wls_chrg_property_is_writeable; chip->wl_psd.external_power_changed = cps_wls_charger_external_power_changed; cps_wls_psy_cfg.drv_data = chip; cps_wls_psy_cfg.of_node = chip->dev->of_node; chip->wl_psy = power_supply_register(chip->dev, &chip->wl_psd, &cps_wls_psy_cfg); if (IS_ERR(chip->wl_psy)) { return PTR_ERR(chip->wl_psy); } return CPS_WLS_SUCCESS; }请详细分析一下这段函数
这是一个在CPS(Charge Pump System)中注册一个无线充电器电源供应器(power supply)的函数。函数的参数是指向一个cps_wls_chrg_chip结构体的指针,该结构体包含了无线充电器的相关信息。
函数首先创建一个power_supply_config结构体,并将其初始化为空。然后通过power_supply_get_by_name函数获取名为“mtk-master-charger”的电源供应器,如果获取失败则打印错误信息。
接着,通过power_supply_get_drvdata函数获取chg_psy电源供应器的私有数据指针,该指针指向一个mtk_charger结构体。如果获取失败则打印错误信息。
然后,将无线充电器的boot_mode设置为mtk_charger的bootmode。如果boot_mode不是8或9,则调用cps_wls_rx_send_ept_packet函数发送0x0B的数据包,并打印“probe reset RX !”信息。
接下来,初始化无线充电器的电源供应器属性,包括名称、类型、属性、属性数量、获取属性函数、设置属性函数、属性是否可写和外部电源变化回调函数。
然后,创建一个power_supply_config结构体,并将其drv_data成员设置为指向cps_wls_chrg_chip结构体的指针,of_node成员设置为该结构体的of_node成员。
最后,调用power_supply_register函数注册无线充电器的电源供应器,并将其返回值作为函数的返回值。如果注册失败,则返回PTR_ERR(chip->wl_psy)。
解释如下代码 * @brief dma init config with its default value. * @param dma_init_struct : pointer to a dma_init_type structure which will * be initialized. * @retval none */ void dma_default_para_init(dma_init_type* dma_init_struct) { dma_init_struct->peripheral_base_addr = 0x0; dma_init_struct->memory_base_addr = 0x0; dma_init_struct->direction = DMA_DIR_PERIPHERAL_TO_MEMORY; dma_init_struct->buffer_size = 0x0; dma_init_struct->peripheral_inc_enable = FALSE; dma_init_struct->memory_inc_enable = FALSE; dma_init_struct->peripheral_data_width = DMA_PERIPHERAL_DATA_WIDTH_BYTE; dma_init_struct->memory_data_width = DMA_MEMORY_DATA_WIDTH_BYTE; dma_init_struct->loop_mode_enable = FALSE; dma_init_struct->priority = DMA_PRIORITY_LOW; /* Initialize the DMA_M2M member */ dma_init_struct->DMA_MTOM = DMA_MEMTOMEM_DISABLE; }
这段代码是初始化DMA(直接存储器访问)的参数,它将一个指向 dma_init_type 结构的指针作为输入参数,并将其各个成员变量设置为默认值。这个结构体包含了DMA的各个参数,例如传输方向,外设和存储器的基地址,缓冲区大小,数据宽度,循环模式等等。该函数设置了 DMA_M2M 成员为禁用,表示当前初始化的 DMA 是外设到存储器的传输。最后,函数不返回任何值。