list_for_each_entry(entry, &dispdrv_list, list) { if (!strcmp(entry->drv->name, name) && (entry->drv->init)) { ret = entry->drv->init((struct mxc_dispdrv_handle *) entry, setting); if (ret >= 0) { entry->active = true; found = 1; break; } } }
时间: 2024-02-29 14:56:09 浏览: 22
这段代码是一个遍历链表的循环,在Linux内核中常用于遍历数据结构体链表。这个链表是dispdrv_list,entry是链表中的每个元素,list是链表中的指向下一个元素的指针。在循环中,首先判断entry的驱动名是否和name相同,如果相同并且驱动的init函数存在,则调用驱动的init函数,并将setting作为参数传入。如果init函数返回值大于等于0,则表示初始化成功,将entry的active标志设置为true,设置found为1,跳出循环。如果在整个循环中没有找到对应的驱动,则返回错误。
相关问题
解释一下这段代码void erase_wifi(char* ssid) { int i = 0; uint8_t is_wifi_exist = 0; if (NULL == ssid || 0 == strcmp(ssid, "")) { wifi_error("ssid is NULL or ssid empty"); goto exit; } for (i = 0; i < s_wifi_list->wifi_cnt; i++) { if (0 == strcmp(s_wifi_list->wifi_info[i].ssid, ssid)) { is_wifi_exist = 1; break; } } OS_MutexLock(&record_wifi_list_opt_mutex, OS_WAIT_FOREVER); if (!is_wifi_exist) { wifi_error("wifi [%s] not exist.", ssid); goto exit; } else { app_wifi_set_erase_wifi_info(s_wifi_list->wifi_info[i].ssid, s_wifi_list->wifi_info[i].pwd); strncpy(s_wifi_list->wifi_info[i].ssid, s_wifi_list->wifi_info[s_wifi_list->wifi_cnt - 1].ssid, MAX_SSID_LEN); strncpy(s_wifi_list->wifi_info[i].pwd, s_wifi_list->wifi_info[s_wifi_list->wifi_cnt - 1].pwd, MAX_PWD_LEN); memset(s_wifi_list->wifi_info[s_wifi_list->wifi_cnt - 1].ssid, 0, MAX_SSID_LEN); memset(s_wifi_list->wifi_info[s_wifi_list->wifi_cnt - 1].pwd, 0, MAX_PWD_LEN); if (s_wifi_list->wifi_cnt == WIFI_INFO_CNT) { s_wifi_list->write_idx = 9; } else { s_wifi_list->write_idx -= 1; } s_wifi_list->wifi_cnt -= 1; } #if CFG_USE_LFS _wifi_info_save_to_lfs(); #else _wifi_info_save(); #endif exit: OS_MutexUnlock(&record_wifi_list_opt_mutex); return; }
这段代码是一个函数,用于删除特定的Wi-Fi网络信息。函数接受参数ssid,表示要删除的Wi网络的名称。
首函数会检查参数的有效性。如果ssid为NULL或为空字符串会打印错误消息并跳转到末尾。
接下来,函数会遍存储Wi-Fi信息的s_wifi_list,查与参数ssid匹配的-Fi网络。如果找到了匹的网络,则将is_wifi_exist志设置为1,并循环。
在进入临界区之前,函数会使用互斥锁(OS_MutexLock)锁定对记录Wi-Fi列表进行操作的互斥访问。
如果is_wifi_exist标志为0,表示未找到与参数ssid匹配的Wi-Fi网络,则会打印错误消息并跳转到函数末尾。
如果找到了匹配的Wi-Fi网络,函数会使用app_wifi_set_erase_wifi_info函数设置要删除的Wi-Fi网络的信息,并将该网络信息替换为数组中最后一个Wi-Fi网络的信息。然后,将最后一个Wi-Fi网络的信息清空。
接下来,根据Wi-Fi网络信息的数量进行一些调整。如果当前Wi-Fi网络数量等于WIFI_INFO_CNT,则将write_idx设置为9;否则,将write_idx减1。然后,将Wi-Fi网络数量减1。
最后,根据预编译指令选择调用_wifi_info_save_to_lfs函数将Wi-Fi网络信息保存到LFS(Local File System)中,或调用_wifi_info_save函数将Wi-Fi网络信息保存到其他存储介质中。
最后,释放临界区的互斥锁(OS_MutexUnlock)并返回函数。
这段代码的作用是从Wi-Fi网络列表中删除指定的Wi-Fi网络信息,并将修改后的列表保存到存储介质中。
link_s = list_entry(poss, struct m0_node_list, list); printf("---------------------"); printf("links :%s %d %d\n", link_s->node.name, link_s->node.key, link_s->node.type); printf("---------------------"); printf("---------------------"); if (strcmp(link_s->node.name, "temp") == 0) { stm->key = link_s->node.key; stm->new_val.f_val = cJSON_GetObjectItem(cjson_r, "temp")->valuedouble; //解析对象 stm->type = link_s->node.type; printf("temp %f %d %d\n", stm->new_val.f_val, stm->key, stm->type); } if (strcmp(link_s->node.name, "humi") == 0) { stm->key = link_s->node.key; stm->new_val.i_val = cJSON_GetObjectItem(cjson_r, "humi")->valueint; //解析对象 stm->type = link_s->node.type; printf("humi %d %d %d\n", stm->new_val.i_val, stm->key, stm->type); } if (strcmp(link_s->node.name, "bat") == 0) { stm->key = link_s->node.key; stm->new_val.i_val = cJSON_GetObjectItem(cjson_r, "bat")->valueint; //解析对象 stm->type = link_s->node.type; printf("bat %d %d %d\n", stm->new_val.i_val, stm->key, stm->type); } if (strcmp(link_s->node.name, "led") == 0) { printf("---------------------"); stm->key = link_s->node.key; stm->new_val.b_val = cJSON_GetObjectItem(cjson_r, "led")->valueint; //解析对象 stm->type = link_s->node.type; printf("led %d %d %d\n", stm->new_val.b_val, stm->key, stm->type); }
这段代码看起来像是从一个链表中取出节点,然后根据节点的名称解析 JSON 数据,并将解析结果存储到一个结构体变量 stm 中。具体来说,这段代码的流程可能是这样的:
1. 从 poss 中取出一个节点 link_s。
2. 判断 link_s 的名称,如果是 "temp",则从 cjson_r 中解析出 "temp" 字段的值,赋值给 stm 的 new_val.f_val 字段。
3. 如果是 "humi",则从 cjson_r 中解析出 "humi" 字段的值,赋值给 stm 的 new_val.i_val 字段。
4. 如果是 "bat",则从 cjson_r 中解析出 "bat" 字段的值,赋值给 stm 的 new_val.i_val 字段。
5. 如果是 "led",则从 cjson_r 中解析出 "led" 字段的值,赋值给 stm 的 new_val.b_val 字段。
最后,将 stm 的 key 字段和 type 字段赋值为 link_s 的对应值。
需要注意的是,这段代码无法单独看出来是什么意思,需要结合上下文和相关代码才能理解。