xref: /nrf52832-nimble/rt-thread/components/drivers/wlan/wlan_cfg.c (revision 104654410c56c573564690304ae786df310c91fc)
1*10465441SEvalZero /*
2*10465441SEvalZero  * Copyright (c) 2006-2018, RT-Thread Development Team
3*10465441SEvalZero  *
4*10465441SEvalZero  * SPDX-License-Identifier: Apache-2.0
5*10465441SEvalZero  *
6*10465441SEvalZero  * Change Logs:
7*10465441SEvalZero  * Date           Author       Notes
8*10465441SEvalZero  * 2018-08-06     tyx          the first version
9*10465441SEvalZero  */
10*10465441SEvalZero 
11*10465441SEvalZero #include <rtthread.h>
12*10465441SEvalZero #include <wlan_cfg.h>
13*10465441SEvalZero 
14*10465441SEvalZero #define DBG_ENABLE
15*10465441SEvalZero #ifdef RT_WLAN_CFG_DEBUG
16*10465441SEvalZero #define DBG_LEVEL DBG_LOG
17*10465441SEvalZero #else
18*10465441SEvalZero #define DBG_LEVEL DBG_INFO
19*10465441SEvalZero #endif
20*10465441SEvalZero #define DBG_SECTION_NAME  "WLAN.cfg"
21*10465441SEvalZero #define DBG_COLOR
22*10465441SEvalZero #include <rtdbg.h>
23*10465441SEvalZero 
24*10465441SEvalZero #define WLAN_CFG_LOCK()      (rt_mutex_take(&cfg_mutex, RT_WAITING_FOREVER))
25*10465441SEvalZero #define WLAN_CFG_UNLOCK()    (rt_mutex_release(&cfg_mutex))
26*10465441SEvalZero 
27*10465441SEvalZero #if RT_WLAN_CFG_INFO_MAX < 1
28*10465441SEvalZero #error "The minimum configuration is 1"
29*10465441SEvalZero #endif
30*10465441SEvalZero 
31*10465441SEvalZero struct cfg_save_info_head
32*10465441SEvalZero {
33*10465441SEvalZero     rt_uint32_t magic;
34*10465441SEvalZero     rt_uint32_t len;
35*10465441SEvalZero     rt_uint32_t num;
36*10465441SEvalZero     rt_uint32_t crc;
37*10465441SEvalZero };
38*10465441SEvalZero 
39*10465441SEvalZero struct rt_wlan_cfg_des
40*10465441SEvalZero {
41*10465441SEvalZero     rt_uint32_t num;
42*10465441SEvalZero     struct rt_wlan_cfg_info *cfg_info;
43*10465441SEvalZero };
44*10465441SEvalZero 
45*10465441SEvalZero static struct rt_wlan_cfg_des *cfg_cache;
46*10465441SEvalZero static const struct rt_wlan_cfg_ops *cfg_ops;
47*10465441SEvalZero static struct rt_mutex cfg_mutex;
48*10465441SEvalZero 
49*10465441SEvalZero /*
50*10465441SEvalZero  * CRC16_CCITT
51*10465441SEvalZero  */
rt_wlan_cal_crc(rt_uint8_t * buff,int len)52*10465441SEvalZero static rt_uint16_t rt_wlan_cal_crc(rt_uint8_t *buff, int len)
53*10465441SEvalZero {
54*10465441SEvalZero     rt_uint16_t wCRCin = 0x0000;
55*10465441SEvalZero     rt_uint16_t wCPoly = 0x1021;
56*10465441SEvalZero     rt_uint8_t  wChar = 0;
57*10465441SEvalZero 
58*10465441SEvalZero     while (len--)
59*10465441SEvalZero     {
60*10465441SEvalZero         wChar = *(buff++);
61*10465441SEvalZero         wCRCin ^= (wChar << 8);
62*10465441SEvalZero         for (int i = 0; i < 8; i++)
63*10465441SEvalZero         {
64*10465441SEvalZero             if (wCRCin & 0x8000)
65*10465441SEvalZero                 wCRCin = (wCRCin << 1) ^ wCPoly;
66*10465441SEvalZero             else
67*10465441SEvalZero                 wCRCin = wCRCin << 1;
68*10465441SEvalZero         }
69*10465441SEvalZero     }
70*10465441SEvalZero     return wCRCin;
71*10465441SEvalZero }
72*10465441SEvalZero 
rt_wlan_cfg_init(void)73*10465441SEvalZero void rt_wlan_cfg_init(void)
74*10465441SEvalZero {
75*10465441SEvalZero     /* init cache memory */
76*10465441SEvalZero     if (cfg_cache == RT_NULL)
77*10465441SEvalZero     {
78*10465441SEvalZero         cfg_cache = rt_malloc(sizeof(struct rt_wlan_cfg_des));
79*10465441SEvalZero         if (cfg_cache != RT_NULL)
80*10465441SEvalZero         {
81*10465441SEvalZero             rt_memset(cfg_cache, 0, sizeof(struct rt_wlan_cfg_des));
82*10465441SEvalZero         }
83*10465441SEvalZero         /* init mutex lock */
84*10465441SEvalZero         rt_mutex_init(&cfg_mutex, "wlan_cfg", RT_IPC_FLAG_FIFO);
85*10465441SEvalZero     }
86*10465441SEvalZero }
87*10465441SEvalZero 
rt_wlan_cfg_set_ops(const struct rt_wlan_cfg_ops * ops)88*10465441SEvalZero void rt_wlan_cfg_set_ops(const struct rt_wlan_cfg_ops *ops)
89*10465441SEvalZero {
90*10465441SEvalZero     rt_wlan_cfg_init();
91*10465441SEvalZero 
92*10465441SEvalZero     WLAN_CFG_LOCK();
93*10465441SEvalZero     /* save ops pointer */
94*10465441SEvalZero     cfg_ops = ops;
95*10465441SEvalZero     WLAN_CFG_UNLOCK();
96*10465441SEvalZero }
97*10465441SEvalZero 
98*10465441SEvalZero /* save config data */
rt_wlan_cfg_cache_save(void)99*10465441SEvalZero rt_err_t rt_wlan_cfg_cache_save(void)
100*10465441SEvalZero {
101*10465441SEvalZero     rt_err_t err = RT_EOK;
102*10465441SEvalZero     struct cfg_save_info_head *info_pkg;
103*10465441SEvalZero     int len = 0;
104*10465441SEvalZero 
105*10465441SEvalZero     if ((cfg_ops == RT_NULL) || (cfg_ops->write_cfg == RT_NULL))
106*10465441SEvalZero         return RT_EOK;
107*10465441SEvalZero 
108*10465441SEvalZero     WLAN_CFG_LOCK();
109*10465441SEvalZero     len = sizeof(struct cfg_save_info_head) + sizeof(struct rt_wlan_cfg_info) * cfg_cache->num;
110*10465441SEvalZero     info_pkg = rt_malloc(len);
111*10465441SEvalZero     if (info_pkg == RT_NULL)
112*10465441SEvalZero     {
113*10465441SEvalZero         WLAN_CFG_UNLOCK();
114*10465441SEvalZero         return -RT_ENOMEM;
115*10465441SEvalZero     }
116*10465441SEvalZero     info_pkg->magic = RT_WLAN_CFG_MAGIC;
117*10465441SEvalZero     info_pkg->len = len;
118*10465441SEvalZero     info_pkg->num = cfg_cache->num;
119*10465441SEvalZero     /* CRC */
120*10465441SEvalZero     info_pkg->crc = rt_wlan_cal_crc((rt_uint8_t *)cfg_cache->cfg_info, sizeof(struct rt_wlan_cfg_info) * cfg_cache->num);
121*10465441SEvalZero     rt_memcpy(((rt_uint8_t *)info_pkg) + sizeof(struct cfg_save_info_head),
122*10465441SEvalZero               cfg_cache->cfg_info, sizeof(struct rt_wlan_cfg_info) * cfg_cache->num);
123*10465441SEvalZero     if (cfg_ops->write_cfg(info_pkg, len) != len)
124*10465441SEvalZero         err =  -RT_ERROR;
125*10465441SEvalZero     rt_free(info_pkg);
126*10465441SEvalZero     WLAN_CFG_UNLOCK();
127*10465441SEvalZero     return err;
128*10465441SEvalZero }
129*10465441SEvalZero 
rt_wlan_cfg_cache_refresh(void)130*10465441SEvalZero rt_err_t rt_wlan_cfg_cache_refresh(void)
131*10465441SEvalZero {
132*10465441SEvalZero     int len = 0, i, j;
133*10465441SEvalZero     struct cfg_save_info_head *head;
134*10465441SEvalZero     void *data;
135*10465441SEvalZero     struct rt_wlan_cfg_info *t_info, *cfg_info;
136*10465441SEvalZero     rt_uint32_t crc;
137*10465441SEvalZero     rt_bool_t equal_flag;
138*10465441SEvalZero 
139*10465441SEvalZero     /* cache is full! exit */
140*10465441SEvalZero     if (cfg_cache == RT_NULL || cfg_cache->num >= RT_WLAN_CFG_INFO_MAX)
141*10465441SEvalZero         return -RT_ERROR;
142*10465441SEvalZero 
143*10465441SEvalZero     /* check callback */
144*10465441SEvalZero     if ((cfg_ops == RT_NULL) ||
145*10465441SEvalZero             (cfg_ops->get_len == RT_NULL) ||
146*10465441SEvalZero             (cfg_ops->read_cfg == RT_NULL))
147*10465441SEvalZero         return -RT_ERROR;
148*10465441SEvalZero 
149*10465441SEvalZero     WLAN_CFG_LOCK();
150*10465441SEvalZero     /* get data len */
151*10465441SEvalZero     if ((len = cfg_ops->get_len()) <= 0)
152*10465441SEvalZero     {
153*10465441SEvalZero         WLAN_CFG_UNLOCK();
154*10465441SEvalZero         return -RT_ERROR;
155*10465441SEvalZero     }
156*10465441SEvalZero 
157*10465441SEvalZero     head = rt_malloc(len);
158*10465441SEvalZero     if (head == RT_NULL)
159*10465441SEvalZero     {
160*10465441SEvalZero         WLAN_CFG_UNLOCK();
161*10465441SEvalZero         return -RT_ERROR;
162*10465441SEvalZero     }
163*10465441SEvalZero     /* get data */
164*10465441SEvalZero     if (cfg_ops->read_cfg(head, len) != len)
165*10465441SEvalZero     {
166*10465441SEvalZero         rt_free(head);
167*10465441SEvalZero         WLAN_CFG_UNLOCK();
168*10465441SEvalZero         return -RT_ERROR;
169*10465441SEvalZero     }
170*10465441SEvalZero     /* get config */
171*10465441SEvalZero     data = ((rt_uint8_t *)head) + sizeof(struct cfg_save_info_head);
172*10465441SEvalZero     crc = rt_wlan_cal_crc((rt_uint8_t *)data, len - sizeof(struct cfg_save_info_head));
173*10465441SEvalZero     LOG_D("head->magic:0x%08x  RT_WLAN_CFG_MAGIC:0x%08x", head->magic, RT_WLAN_CFG_MAGIC);
174*10465441SEvalZero     LOG_D("head->len:%d len:%d", head->len, len);
175*10465441SEvalZero     LOG_D("head->num:%d num:%d", head->num, (len - sizeof(struct cfg_save_info_head)) / sizeof(struct rt_wlan_cfg_info));
176*10465441SEvalZero     LOG_D("hred->crc:0x%04x crc:0x%04x", head->crc, crc);
177*10465441SEvalZero     /* check */
178*10465441SEvalZero     if ((head->magic != RT_WLAN_CFG_MAGIC) ||
179*10465441SEvalZero             (head->len != len) ||
180*10465441SEvalZero             (head->num != (len - sizeof(struct cfg_save_info_head)) / sizeof(struct rt_wlan_cfg_info)) ||
181*10465441SEvalZero             (head->crc != crc))
182*10465441SEvalZero     {
183*10465441SEvalZero         rt_free(head);
184*10465441SEvalZero         WLAN_CFG_UNLOCK();
185*10465441SEvalZero         return -RT_ERROR;
186*10465441SEvalZero     }
187*10465441SEvalZero 
188*10465441SEvalZero     /* remove duplicate config */
189*10465441SEvalZero     cfg_info = (struct rt_wlan_cfg_info *)data;
190*10465441SEvalZero     for (i = 0; i < head->num; i++)
191*10465441SEvalZero     {
192*10465441SEvalZero         equal_flag = RT_FALSE;
193*10465441SEvalZero         for (j = 0; j < cfg_cache->num; j++)
194*10465441SEvalZero         {
195*10465441SEvalZero             if ((cfg_cache->cfg_info[j].info.ssid.len == cfg_info[i].info.ssid.len) &&
196*10465441SEvalZero                     (rt_memcmp(&cfg_cache->cfg_info[j].info.ssid.val[0], &cfg_info[i].info.ssid.val[0],
197*10465441SEvalZero                                cfg_cache->cfg_info[j].info.ssid.len) == 0) &&
198*10465441SEvalZero                     (rt_memcmp(&cfg_cache->cfg_info[j].info.bssid[0], &cfg_info[i].info.bssid[0], RT_WLAN_BSSID_MAX_LENGTH) == 0))
199*10465441SEvalZero             {
200*10465441SEvalZero                 equal_flag = RT_TRUE;
201*10465441SEvalZero                 break;
202*10465441SEvalZero             }
203*10465441SEvalZero         }
204*10465441SEvalZero 
205*10465441SEvalZero         if (cfg_cache->num >= RT_WLAN_CFG_INFO_MAX)
206*10465441SEvalZero         {
207*10465441SEvalZero             break;
208*10465441SEvalZero         }
209*10465441SEvalZero 
210*10465441SEvalZero         if (equal_flag == RT_FALSE)
211*10465441SEvalZero         {
212*10465441SEvalZero             t_info = rt_realloc(cfg_cache->cfg_info, sizeof(struct rt_wlan_cfg_info) * (cfg_cache->num + 1));
213*10465441SEvalZero             if (t_info == RT_NULL)
214*10465441SEvalZero             {
215*10465441SEvalZero                 rt_free(head);
216*10465441SEvalZero                 WLAN_CFG_UNLOCK();
217*10465441SEvalZero                 return -RT_ERROR;
218*10465441SEvalZero             }
219*10465441SEvalZero             cfg_cache->cfg_info = t_info;
220*10465441SEvalZero             cfg_cache->cfg_info[cfg_cache->num] = cfg_info[i];
221*10465441SEvalZero             cfg_cache->num ++;
222*10465441SEvalZero         }
223*10465441SEvalZero     }
224*10465441SEvalZero 
225*10465441SEvalZero     rt_free(head);
226*10465441SEvalZero     WLAN_CFG_UNLOCK();
227*10465441SEvalZero     return RT_EOK;
228*10465441SEvalZero }
229*10465441SEvalZero 
rt_wlan_cfg_get_num(void)230*10465441SEvalZero int rt_wlan_cfg_get_num(void)
231*10465441SEvalZero {
232*10465441SEvalZero     rt_wlan_cfg_init();
233*10465441SEvalZero 
234*10465441SEvalZero     return cfg_cache->num;
235*10465441SEvalZero }
236*10465441SEvalZero 
rt_wlan_cfg_read(struct rt_wlan_cfg_info * cfg_info,int num)237*10465441SEvalZero int rt_wlan_cfg_read(struct rt_wlan_cfg_info *cfg_info, int num)
238*10465441SEvalZero {
239*10465441SEvalZero     rt_wlan_cfg_init();
240*10465441SEvalZero 
241*10465441SEvalZero     if ((cfg_info == RT_NULL) || (num <= 0))
242*10465441SEvalZero         return 0;
243*10465441SEvalZero     /* copy data */
244*10465441SEvalZero     WLAN_CFG_LOCK();
245*10465441SEvalZero     num = cfg_cache->num > num ? num : cfg_cache->num;
246*10465441SEvalZero     rt_memcpy(&cfg_cache->cfg_info[0], cfg_info, sizeof(struct rt_wlan_cfg_info) * num);
247*10465441SEvalZero     WLAN_CFG_UNLOCK();
248*10465441SEvalZero 
249*10465441SEvalZero     return num;
250*10465441SEvalZero }
251*10465441SEvalZero 
rt_wlan_cfg_save(struct rt_wlan_cfg_info * cfg_info)252*10465441SEvalZero rt_err_t rt_wlan_cfg_save(struct rt_wlan_cfg_info *cfg_info)
253*10465441SEvalZero {
254*10465441SEvalZero     rt_err_t err = RT_EOK;
255*10465441SEvalZero     struct rt_wlan_cfg_info *t_info;
256*10465441SEvalZero     int idx = -1, i = 0;
257*10465441SEvalZero 
258*10465441SEvalZero     rt_wlan_cfg_init();
259*10465441SEvalZero 
260*10465441SEvalZero     /* parameter check */
261*10465441SEvalZero     if ((cfg_info == RT_NULL) || (cfg_info->info.ssid.len == 0))
262*10465441SEvalZero     {
263*10465441SEvalZero         return -RT_EINVAL;
264*10465441SEvalZero     }
265*10465441SEvalZero     /* if (iteam == cache) exit */
266*10465441SEvalZero     WLAN_CFG_LOCK();
267*10465441SEvalZero     for (i = 0; i < cfg_cache->num; i++)
268*10465441SEvalZero     {
269*10465441SEvalZero         if ((cfg_cache->cfg_info[i].info.ssid.len == cfg_info->info.ssid.len) &&
270*10465441SEvalZero                 (rt_memcmp(&cfg_cache->cfg_info[i].info.ssid.val[0], &cfg_info->info.ssid.val[0],
271*10465441SEvalZero                            cfg_cache->cfg_info[i].info.ssid.len) == 0) &&
272*10465441SEvalZero                 (rt_memcmp(&cfg_cache->cfg_info[i].info.bssid[0], &cfg_info->info.bssid[0], RT_WLAN_BSSID_MAX_LENGTH) == 0))
273*10465441SEvalZero         {
274*10465441SEvalZero             idx = i;
275*10465441SEvalZero             break;
276*10465441SEvalZero         }
277*10465441SEvalZero     }
278*10465441SEvalZero 
279*10465441SEvalZero     if ((idx == 0) && (cfg_cache->cfg_info[i].key.len == cfg_info->key.len) &&
280*10465441SEvalZero             (rt_memcmp(&cfg_cache->cfg_info[i].key.val[0], &cfg_info->key.val[0], cfg_info->key.len) == 0))
281*10465441SEvalZero     {
282*10465441SEvalZero         WLAN_CFG_UNLOCK();
283*10465441SEvalZero         return RT_EOK;
284*10465441SEvalZero     }
285*10465441SEvalZero 
286*10465441SEvalZero     /* not find iteam with cache, Add iteam to the head   */
287*10465441SEvalZero     if ((idx == -1) && (cfg_cache->num < RT_WLAN_CFG_INFO_MAX))
288*10465441SEvalZero     {
289*10465441SEvalZero         t_info = rt_realloc(cfg_cache->cfg_info, sizeof(struct rt_wlan_cfg_info) * (cfg_cache->num + 1));
290*10465441SEvalZero         if (t_info == RT_NULL)
291*10465441SEvalZero         {
292*10465441SEvalZero             WLAN_CFG_UNLOCK();
293*10465441SEvalZero             return -RT_ENOMEM;
294*10465441SEvalZero         }
295*10465441SEvalZero         cfg_cache->cfg_info = t_info;
296*10465441SEvalZero         cfg_cache->num ++;
297*10465441SEvalZero     }
298*10465441SEvalZero 
299*10465441SEvalZero     /* move cache info */
300*10465441SEvalZero     i = (i >= RT_WLAN_CFG_INFO_MAX ? RT_WLAN_CFG_INFO_MAX - 1 : i);
301*10465441SEvalZero     for (; i; i--)
302*10465441SEvalZero     {
303*10465441SEvalZero         cfg_cache->cfg_info[i] = cfg_cache->cfg_info[i - 1];
304*10465441SEvalZero     }
305*10465441SEvalZero     /* add iteam to head */
306*10465441SEvalZero     cfg_cache->cfg_info[i] = *cfg_info;
307*10465441SEvalZero     WLAN_CFG_UNLOCK();
308*10465441SEvalZero 
309*10465441SEvalZero     /* save info to flash */
310*10465441SEvalZero     err = rt_wlan_cfg_cache_save();
311*10465441SEvalZero 
312*10465441SEvalZero     return err;
313*10465441SEvalZero }
314*10465441SEvalZero 
rt_wlan_cfg_read_index(struct rt_wlan_cfg_info * cfg_info,int index)315*10465441SEvalZero int rt_wlan_cfg_read_index(struct rt_wlan_cfg_info *cfg_info, int index)
316*10465441SEvalZero {
317*10465441SEvalZero     rt_wlan_cfg_init();
318*10465441SEvalZero 
319*10465441SEvalZero     if ((cfg_info == RT_NULL) || (index < 0))
320*10465441SEvalZero         return 0;
321*10465441SEvalZero 
322*10465441SEvalZero     WLAN_CFG_LOCK();
323*10465441SEvalZero     if (index >= cfg_cache->num)
324*10465441SEvalZero     {
325*10465441SEvalZero         WLAN_CFG_UNLOCK();
326*10465441SEvalZero         return 0;
327*10465441SEvalZero     }
328*10465441SEvalZero     /* copy data */
329*10465441SEvalZero     *cfg_info = cfg_cache->cfg_info[index];
330*10465441SEvalZero     WLAN_CFG_UNLOCK();
331*10465441SEvalZero     return 1;
332*10465441SEvalZero }
333*10465441SEvalZero 
rt_wlan_cfg_delete_index(int index)334*10465441SEvalZero int rt_wlan_cfg_delete_index(int index)
335*10465441SEvalZero {
336*10465441SEvalZero     struct rt_wlan_cfg_info *cfg_info;
337*10465441SEvalZero     int i;
338*10465441SEvalZero 
339*10465441SEvalZero     rt_wlan_cfg_init();
340*10465441SEvalZero 
341*10465441SEvalZero     if (index < 0)
342*10465441SEvalZero         return -1;
343*10465441SEvalZero 
344*10465441SEvalZero     WLAN_CFG_LOCK();
345*10465441SEvalZero     if (index >= cfg_cache->num)
346*10465441SEvalZero     {
347*10465441SEvalZero         WLAN_CFG_UNLOCK();
348*10465441SEvalZero         return -1;
349*10465441SEvalZero     }
350*10465441SEvalZero 
351*10465441SEvalZero     /* malloc new mem */
352*10465441SEvalZero     cfg_info = rt_malloc(sizeof(struct rt_wlan_cfg_info) * (cfg_cache->num - 1));
353*10465441SEvalZero     if (cfg_info == RT_NULL)
354*10465441SEvalZero     {
355*10465441SEvalZero         WLAN_CFG_UNLOCK();
356*10465441SEvalZero         return -1;
357*10465441SEvalZero     }
358*10465441SEvalZero     /* copy data to new mem */
359*10465441SEvalZero     for (i = 0; i < cfg_cache->num; i++)
360*10465441SEvalZero     {
361*10465441SEvalZero         if (i < index)
362*10465441SEvalZero         {
363*10465441SEvalZero             cfg_info[i] = cfg_cache->cfg_info[i];
364*10465441SEvalZero         }
365*10465441SEvalZero         else if (i > index)
366*10465441SEvalZero         {
367*10465441SEvalZero             cfg_info[i - 1] = cfg_cache->cfg_info[i];
368*10465441SEvalZero         }
369*10465441SEvalZero     }
370*10465441SEvalZero     rt_free(cfg_cache->cfg_info);
371*10465441SEvalZero     cfg_cache->cfg_info = cfg_info;
372*10465441SEvalZero     cfg_cache->num --;
373*10465441SEvalZero     WLAN_CFG_UNLOCK();
374*10465441SEvalZero 
375*10465441SEvalZero     return 0;
376*10465441SEvalZero }
377*10465441SEvalZero 
rt_wlan_cfg_delete_all(void)378*10465441SEvalZero void rt_wlan_cfg_delete_all(void)
379*10465441SEvalZero {
380*10465441SEvalZero     rt_wlan_cfg_init();
381*10465441SEvalZero 
382*10465441SEvalZero     /* delete all iteam */
383*10465441SEvalZero     WLAN_CFG_LOCK();
384*10465441SEvalZero     cfg_cache->num = 0;
385*10465441SEvalZero     rt_free(cfg_cache->cfg_info);
386*10465441SEvalZero     cfg_cache->cfg_info = RT_NULL;
387*10465441SEvalZero     WLAN_CFG_UNLOCK();
388*10465441SEvalZero }
389*10465441SEvalZero 
rt_wlan_cfg_dump(void)390*10465441SEvalZero void rt_wlan_cfg_dump(void)
391*10465441SEvalZero {
392*10465441SEvalZero     int index = 0;
393*10465441SEvalZero     struct rt_wlan_info *info;
394*10465441SEvalZero     struct rt_wlan_key *key;
395*10465441SEvalZero     char *security;
396*10465441SEvalZero 
397*10465441SEvalZero     rt_wlan_cfg_init();
398*10465441SEvalZero 
399*10465441SEvalZero     rt_kprintf("             SSID                           PASSWORD                   MAC            security     chn\n");
400*10465441SEvalZero     rt_kprintf("------------------------------- ------------------------------- -----------------  --------------  ---\n");
401*10465441SEvalZero     for (index = 0; index < cfg_cache->num; index ++)
402*10465441SEvalZero     {
403*10465441SEvalZero         info = &cfg_cache->cfg_info[index].info;
404*10465441SEvalZero         key = &cfg_cache->cfg_info[index].key;
405*10465441SEvalZero 
406*10465441SEvalZero         if (info->ssid.len)
407*10465441SEvalZero             rt_kprintf("%-32.32s", &info->ssid.val[0]);
408*10465441SEvalZero         else
409*10465441SEvalZero             rt_kprintf("%-32.32s", " ");
410*10465441SEvalZero 
411*10465441SEvalZero         if (key->len)
412*10465441SEvalZero             rt_kprintf("%-32.32s", &key->val[0]);
413*10465441SEvalZero         else
414*10465441SEvalZero             rt_kprintf("%-32.32s", " ");
415*10465441SEvalZero 
416*10465441SEvalZero         rt_kprintf("%02x:%02x:%02x:%02x:%02x:%02x  ",
417*10465441SEvalZero                    info->bssid[0],
418*10465441SEvalZero                    info->bssid[1],
419*10465441SEvalZero                    info->bssid[2],
420*10465441SEvalZero                    info->bssid[3],
421*10465441SEvalZero                    info->bssid[4],
422*10465441SEvalZero                    info->bssid[5]
423*10465441SEvalZero                   );
424*10465441SEvalZero         switch (info->security)
425*10465441SEvalZero         {
426*10465441SEvalZero         case SECURITY_OPEN:
427*10465441SEvalZero             security = "OPEN";
428*10465441SEvalZero             break;
429*10465441SEvalZero         case SECURITY_WEP_PSK:
430*10465441SEvalZero             security = "WEP_PSK";
431*10465441SEvalZero             break;
432*10465441SEvalZero         case SECURITY_WEP_SHARED:
433*10465441SEvalZero             security = "WEP_SHARED";
434*10465441SEvalZero             break;
435*10465441SEvalZero         case SECURITY_WPA_TKIP_PSK:
436*10465441SEvalZero             security = "WPA_TKIP_PSK";
437*10465441SEvalZero             break;
438*10465441SEvalZero         case SECURITY_WPA_AES_PSK:
439*10465441SEvalZero             security = "WPA_AES_PSK";
440*10465441SEvalZero             break;
441*10465441SEvalZero         case SECURITY_WPA2_AES_PSK:
442*10465441SEvalZero             security = "WPA2_AES_PSK";
443*10465441SEvalZero             break;
444*10465441SEvalZero         case SECURITY_WPA2_TKIP_PSK:
445*10465441SEvalZero             security = "WPA2_TKIP_PSK";
446*10465441SEvalZero             break;
447*10465441SEvalZero         case SECURITY_WPA2_MIXED_PSK:
448*10465441SEvalZero             security = "WPA2_MIXED_PSK";
449*10465441SEvalZero             break;
450*10465441SEvalZero         case SECURITY_WPS_OPEN:
451*10465441SEvalZero             security = "WPS_OPEN";
452*10465441SEvalZero             break;
453*10465441SEvalZero         case SECURITY_WPS_SECURE:
454*10465441SEvalZero             security = "WPS_SECURE";
455*10465441SEvalZero             break;
456*10465441SEvalZero         default:
457*10465441SEvalZero             security = "UNKNOWN";
458*10465441SEvalZero             break;
459*10465441SEvalZero         }
460*10465441SEvalZero         rt_kprintf("%-14.14s  ", security);
461*10465441SEvalZero         rt_kprintf("%3d    \n", info->channel);
462*10465441SEvalZero     }
463*10465441SEvalZero }
464