wpa_supplicant 扫描不全问题处理--链表学习

2024-03-23 09:04

本文主要是介绍wpa_supplicant 扫描不全问题处理--链表学习,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近遇到一个wpa_supplicant 多次扫描后扫描结果未按照顺序进行排列的问题,这里针对扫描结果的链表进行排序,达到扫描列表根据rssi进行排序的效果

-----再牛逼的梦想,也抵不住傻逼般的坚持! --2024-03-22 11:21

一、问题背景

当周边存在大量ap热点时,通过wpa_supplicant获取扫描结果时,wpa_supplicant上报结果数量受到上层申请buf的大小的限制。
默认扫描结果是4K大小,这样就存在buf满导致部分热点搜索不到的问题。

二、问题分析

走读wpa_suppliant scan部分代码发现如下:

  1. wpa_supplicant 扫描结果存在一个list中。该list的大小默认保存64个struct wpa_bss的大小,当扫描结果大于64会自动增加到128,大于128会扩大到256(这个思想值得我们学习

  2. 每次扫描结果都会进行排序,但后续扫描,每次都会拿当前扫描结果与list中缓存扫描结果做对比,将新的扫描结果增加到链表后,这样就存在一个问题,当周边新增了一个热点,这个热点信号强度很强,但是由于扫描结果buf大小限制,那么每次上传的扫描结果都不会包含这个新增的热点。

三、问题处理

针对如上分析,想到两个解决方案:

方案1. 增大扫描结果缓存buf
方案2. 对扫描结果进行排序,每次上报扫描结果都优先选择信号强度较好的

上述方案修改如下:

方案1修改:

diff --git a/tool/wpa_supplicant-2.9/wpa_supplicant/ctrl_iface.c b/tool/wpa_supplicant-2.9/wpa_supplicant/ctrl_iface.c
index 325ec3d..d768310 100644
--- a/tool/wpa_supplicant-2.9/wpa_supplicant/ctrl_iface.c
+++ b/tool/wpa_supplicant-2.9/wpa_supplicant/ctrl_iface.c
@@ -9920,8 +9921,8 @@ char * wpa_supplicant_ctrl_iface_process(struct wpa_supplicant *wpa_s,char *buf, size_t *resp_len){char *reply;
-       const int reply_size = 4096;
+    const int reply_size = 8192;if (os_strncmp(buf, WPA_CTRL_RSP, os_strlen(WPA_CTRL_RSP)) == 0 ||os_strncmp(buf, "SET_NETWORK ", 12) == 0 ||
@@ -9947,7 +9948,7 @@ char * wpa_supplicant_ctrl_iface_process(struct wpa_supplicant *wpa_s,wpa_dbg(wpa_s, level, "Control interface command '%s'", buf);}-       reply = os_malloc(reply_size);
+    reply = os_malloc(reply_size);if (reply == NULL) {*resp_len = 1;return NULL;

方案2修改:

diff --git a/tool/wpa_supplicant-2.9/wpa_supplicant/events.c b/tool/wpa_supplicant-2.9/wpa_supplicant/events.c
index 457503d..4abbd80 100644
--- a/tool/wpa_supplicant-2.9/wpa_supplicant/events.c
+++ b/tool/wpa_supplicant-2.9/wpa_supplicant/events.c
@@ -1792,6 +1792,57 @@ static int wpa_supplicant_need_to_roam(struct wpa_supplicant *wpa_s,#endif /* CONFIG_NO_ROAMING */}+// RSSI比较函数作为qsort回调
+static int compare_scanres_by_rssi(const void *a, const void *b) {
+    const struct wpa_bss *scan_res_a = *(const struct wpa_bss **)a;
+    const struct wpa_bss *scan_res_b = *(const struct wpa_bss **)b;
+    return scan_res_b->level - scan_res_a->level;
+}
+
+// 创建一个临时数组,存储bss指针,然后对数组进行排序
+void sort_scanres_by_rssi(struct dl_list *head) 
+{
+    struct wpa_bss **scan_res = malloc(dl_list_len(head) * sizeof(struct wpa_bss *));
+    if (NULL == scan_res) {
+        perror("Failed to allocate memory for scan res array");
+        exit(EXIT_FAILURE);
+    }
+
+    struct wpa_bss *current, *tmp;
+    int index = 0;
+    dl_list_for_each

这篇关于wpa_supplicant 扫描不全问题处理--链表学习的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/837816

相关文章

Python自动化处理PDF文档的操作完整指南

《Python自动化处理PDF文档的操作完整指南》在办公自动化中,PDF文档处理是一项常见需求,本文将介绍如何使用Python实现PDF文档的自动化处理,感兴趣的小伙伴可以跟随小编一起学习一下... 目录使用pymupdf读写PDF文件基本概念安装pymupdf提取文本内容提取图像添加水印使用pdfplum

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

基于Redis自动过期的流处理暂停机制

《基于Redis自动过期的流处理暂停机制》基于Redis自动过期的流处理暂停机制是一种高效、可靠且易于实现的解决方案,防止延时过大的数据影响实时处理自动恢复处理,以避免积压的数据影响实时性,下面就来详... 目录核心思路代码实现1. 初始化Redis连接和键前缀2. 接收数据时检查暂停状态3. 检测到延时过

Java利用@SneakyThrows注解提升异常处理效率详解

《Java利用@SneakyThrows注解提升异常处理效率详解》这篇文章将深度剖析@SneakyThrows的原理,用法,适用场景以及隐藏的陷阱,看看它如何让Java异常处理效率飙升50%,感兴趣的... 目录前言一、检查型异常的“诅咒”:为什么Java开发者讨厌它1.1 检查型异常的痛点1.2 为什么说

解决Nginx启动报错Job for nginx.service failed because the control process exited with error code问题

《解决Nginx启动报错Jobfornginx.servicefailedbecausethecontrolprocessexitedwitherrorcode问题》Nginx启... 目录一、报错如下二、解决原因三、解决方式总结一、报错如下Job for nginx.service failed bec

SysMain服务可以关吗? 解决SysMain服务导致的高CPU使用率问题

《SysMain服务可以关吗?解决SysMain服务导致的高CPU使用率问题》SysMain服务是超级预读取,该服务会记录您打开应用程序的模式,并预先将它们加载到内存中以节省时间,但它可能占用大量... 在使用电脑的过程中,CPU使用率居高不下是许多用户都遇到过的问题,其中名为SysMain的服务往往是罪魁

Python利用PySpark和Kafka实现流处理引擎构建指南

《Python利用PySpark和Kafka实现流处理引擎构建指南》本文将深入解剖基于Python的实时处理黄金组合:Kafka(分布式消息队列)与PySpark(分布式计算引擎)的化学反应,并构建一... 目录引言:数据洪流时代的生存法则第一章 Kafka:数据世界的中央神经系统消息引擎核心设计哲学高吞吐

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

MySQ中出现幻读问题的解决过程

《MySQ中出现幻读问题的解决过程》文章解析MySQLInnoDB通过MVCC与间隙锁机制在可重复读隔离级别下解决幻读,确保事务一致性,同时指出性能影响及乐观锁等替代方案,帮助开发者优化数据库应用... 目录一、幻读的准确定义与核心特征幻读 vs 不可重复读二、mysql隔离级别深度解析各隔离级别的实现差异