wireless/wapi: Remove functionality that depends on the Linux procfs: This includes only 1) listing of available interfaces and 2) listing of all routes.
This commit is contained in:
parent
2d73f735fe
commit
322ffe193b
@ -1,6 +1,11 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* apps/include/wireless/wapi.h
|
* apps/include/wireless/wapi.h
|
||||||
*
|
*
|
||||||
|
* Copyright (C) 2011, 2017Gregory Nutt. All rights reserved.
|
||||||
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
|
*
|
||||||
|
* Adapted for Nuttx from WAPI:
|
||||||
|
*
|
||||||
* Copyright (c) 2010, Volkan YAZICI <volkan.yazici@gmail.com>
|
* Copyright (c) 2010, Volkan YAZICI <volkan.yazici@gmail.com>
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
@ -48,14 +53,6 @@
|
|||||||
|
|
||||||
#define WAPI_ESSID_MAX_SIZE IW_ESSID_MAX_SIZE
|
#define WAPI_ESSID_MAX_SIZE IW_ESSID_MAX_SIZE
|
||||||
|
|
||||||
/* Path to /proc/net/wireless. (Requires procfs mounted.) */
|
|
||||||
|
|
||||||
#define WAPI_PROC_NET_WIRELESS "/proc/net/wireless"
|
|
||||||
|
|
||||||
/* Path to /proc/net/route. (Requires procfs mounted.) */
|
|
||||||
|
|
||||||
#define WAPI_PROC_NET_ROUTE "/proc/net/route"
|
|
||||||
|
|
||||||
/* Buffer size while reading lines from PROC_NET_ files. */
|
/* Buffer size while reading lines from PROC_NET_ files. */
|
||||||
|
|
||||||
#define WAPI_PROC_LINE_SIZE 1024
|
#define WAPI_PROC_LINE_SIZE 1024
|
||||||
@ -293,19 +290,6 @@ int wapi_get_netmask(int sock, const char *ifname, struct in_addr *addr);
|
|||||||
|
|
||||||
int wapi_set_netmask(int sock, const char *ifname, const struct in_addr *addr);
|
int wapi_set_netmask(int sock, const char *ifname, const struct in_addr *addr);
|
||||||
|
|
||||||
/****************************************************************************
|
|
||||||
* Name: wapi_get_routes
|
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
* Parses routing table rows from WAPI_PROC_NET_ROUTE.
|
|
||||||
*
|
|
||||||
* Input Parameters:
|
|
||||||
* list - Pushes collected wapi_route_info_t into this list.
|
|
||||||
*
|
|
||||||
****************************************************************************/
|
|
||||||
|
|
||||||
int wapi_get_routes(wapi_list_t * list);
|
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: wapi_add_route_gw
|
* Name: wapi_add_route_gw
|
||||||
*
|
*
|
||||||
@ -572,19 +556,6 @@ int wapi_set_txpower(int sock, FAR const char *ifname, int power,
|
|||||||
|
|
||||||
int wapi_make_socket(void);
|
int wapi_make_socket(void);
|
||||||
|
|
||||||
/****************************************************************************
|
|
||||||
* Name: wapi_get_ifnames
|
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
* Parses WAPI_PROC_NET_WIRELESS.
|
|
||||||
*
|
|
||||||
* Returned Value:
|
|
||||||
* list Pushes collected wapi_string_t into this list.
|
|
||||||
*
|
|
||||||
****************************************************************************/
|
|
||||||
|
|
||||||
int wapi_get_ifnames(FAR wapi_list_t *list);
|
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: wapi_scan_init
|
* Name: wapi_scan_init
|
||||||
*
|
*
|
||||||
|
@ -1,6 +1,11 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* apps/wireless/wapi/examples/network.c
|
* apps/wireless/wapi/examples/network.c
|
||||||
*
|
*
|
||||||
|
* Copyright (C) 2011, 2017Gregory Nutt. All rights reserved.
|
||||||
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
|
*
|
||||||
|
* Adapted for Nuttx from WAPI:
|
||||||
|
*
|
||||||
* Copyright (c) 2010, Volkan YAZICI <volkan.yazici@gmail.com>
|
* Copyright (c) 2010, Volkan YAZICI <volkan.yazici@gmail.com>
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
@ -287,116 +292,6 @@ int wapi_set_netmask(int sock, FAR const char *ifname,
|
|||||||
return wapi_set_addr(sock, ifname, SIOCSIFNETMASK, addr);
|
return wapi_set_addr(sock, ifname, SIOCSIFNETMASK, addr);
|
||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
|
||||||
* Name: wapi_get_routes
|
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
* Parses routing table rows from WAPI_PROC_NET_ROUTE.
|
|
||||||
*
|
|
||||||
* Input Parameters:
|
|
||||||
* list - Pushes collected wapi_route_info_t into this list.
|
|
||||||
*
|
|
||||||
****************************************************************************/
|
|
||||||
|
|
||||||
int wapi_get_routes(FAR wapi_list_t *list)
|
|
||||||
{
|
|
||||||
FAR FILE *fp;
|
|
||||||
size_t bufsiz = WAPI_PROC_LINE_SIZE * sizeof(char);
|
|
||||||
char buf[WAPI_PROC_LINE_SIZE];
|
|
||||||
int ret;
|
|
||||||
|
|
||||||
WAPI_VALIDATE_PTR(list);
|
|
||||||
|
|
||||||
/* Open file for reading. */
|
|
||||||
|
|
||||||
fp = fopen(WAPI_PROC_NET_ROUTE, "r");
|
|
||||||
if (!fp)
|
|
||||||
{
|
|
||||||
WAPI_STRERROR("fopen(\"%s\", \"r\")", WAPI_PROC_NET_ROUTE);
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Skip header line. */
|
|
||||||
|
|
||||||
if (!fgets(buf, bufsiz, fp))
|
|
||||||
{
|
|
||||||
WAPI_ERROR("Invalid \"%s\" content!\n", WAPI_PROC_NET_ROUTE);
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Read lines. */
|
|
||||||
|
|
||||||
ret = 0;
|
|
||||||
while (fgets(buf, bufsiz, fp))
|
|
||||||
{
|
|
||||||
wapi_route_info_t *ri;
|
|
||||||
char ifname[WAPI_PROC_LINE_SIZE];
|
|
||||||
int refcnt, use, metric, mtu, window, irtt;
|
|
||||||
unsigned int dest, gw, flags, netmask;
|
|
||||||
|
|
||||||
/* Allocate route row buffer. */
|
|
||||||
|
|
||||||
ri = malloc(sizeof(wapi_route_info_t));
|
|
||||||
if (!ri)
|
|
||||||
{
|
|
||||||
WAPI_STRERROR("malloc()");
|
|
||||||
ret = -1;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Read and tokenize fields. */
|
|
||||||
|
|
||||||
sscanf(buf, "%s\t" /* ifname */
|
|
||||||
"%x\t" /* dest */
|
|
||||||
"%x\t" /* gw */
|
|
||||||
"%x\t" /* flags */
|
|
||||||
"%d\t" /* refcnt */
|
|
||||||
"%d\t" /* use */
|
|
||||||
"%d\t" /* metric */
|
|
||||||
"%x\t" /* mask */
|
|
||||||
"%d\t" /* mtu */
|
|
||||||
"%d\t" /* window */
|
|
||||||
"%d\t", /* irtt */
|
|
||||||
ifname, &dest, &gw, &flags, &refcnt, &use, &metric, &netmask, &mtu,
|
|
||||||
&window, &irtt);
|
|
||||||
|
|
||||||
/* Allocate "ifname". */
|
|
||||||
|
|
||||||
ri->ifname = malloc((strlen(ifname) + 1) * sizeof(char));
|
|
||||||
if (!ri->ifname)
|
|
||||||
{
|
|
||||||
WAPI_STRERROR("malloc()");
|
|
||||||
free(ri);
|
|
||||||
ret = -1;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Copy fields. */
|
|
||||||
|
|
||||||
sprintf(ri->ifname, "%s", ifname);
|
|
||||||
ri->dest.s_addr = dest;
|
|
||||||
ri->gw.s_addr = gw;
|
|
||||||
ri->flags = flags;
|
|
||||||
ri->refcnt = refcnt;
|
|
||||||
ri->use = use;
|
|
||||||
ri->metric = metric;
|
|
||||||
ri->netmask.s_addr = netmask;
|
|
||||||
ri->mtu = mtu;
|
|
||||||
ri->window = window;
|
|
||||||
ri->irtt = irtt;
|
|
||||||
|
|
||||||
/* Push parsed node to the list. */
|
|
||||||
|
|
||||||
ri->next = list->head.route;
|
|
||||||
list->head.route = ri;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Close file. */
|
|
||||||
|
|
||||||
fclose(fp);
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: wapi_add_route_gw
|
* Name: wapi_add_route_gw
|
||||||
*
|
*
|
||||||
|
@ -1,6 +1,11 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* apps/wireless/wapi/src/util.c
|
* apps/wireless/wapi/src/util.c
|
||||||
*
|
*
|
||||||
|
* Copyright (C) 2011, 2017Gregory Nutt. All rights reserved.
|
||||||
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
|
*
|
||||||
|
* Adapted for Nuttx from WAPI:
|
||||||
|
*
|
||||||
* Copyright (c) 2010, Volkan YAZICI <volkan.yazici@gmail.com>
|
* Copyright (c) 2010, Volkan YAZICI <volkan.yazici@gmail.com>
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
@ -76,87 +81,7 @@ int wapi_make_socket(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: wapi_get_ifnames
|
* Name: wapi_ioctl_command_name
|
||||||
*
|
|
||||||
* Description:
|
|
||||||
* Parses WAPI_PROC_NET_WIRELESS.
|
|
||||||
*
|
|
||||||
* Returned Value:
|
|
||||||
* list Pushes collected wapi_string_t into this list.
|
|
||||||
*
|
|
||||||
****************************************************************************/
|
|
||||||
|
|
||||||
int wapi_get_ifnames(FAR wapi_list_t *list)
|
|
||||||
{
|
|
||||||
FILE *fp;
|
|
||||||
int ret;
|
|
||||||
size_t tmpsize = WAPI_PROC_LINE_SIZE * sizeof(char);
|
|
||||||
char tmp[WAPI_PROC_LINE_SIZE];
|
|
||||||
|
|
||||||
WAPI_VALIDATE_PTR(list);
|
|
||||||
|
|
||||||
/* Open file for reading. */
|
|
||||||
|
|
||||||
fp = fopen(WAPI_PROC_NET_WIRELESS, "r");
|
|
||||||
if (!fp)
|
|
||||||
{
|
|
||||||
WAPI_STRERROR("fopen(\"%s\", \"r\")", WAPI_PROC_NET_WIRELESS);
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Skip first two lines. */
|
|
||||||
|
|
||||||
if (!fgets(tmp, tmpsize, fp) || !fgets(tmp, tmpsize, fp))
|
|
||||||
{
|
|
||||||
WAPI_ERROR("Invalid \"%s\" content!\n", WAPI_PROC_NET_WIRELESS);
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Iterate over available lines. */
|
|
||||||
|
|
||||||
ret = 0;
|
|
||||||
while (fgets(tmp, tmpsize, fp))
|
|
||||||
{
|
|
||||||
char *beg;
|
|
||||||
char *end;
|
|
||||||
wapi_string_t *string;
|
|
||||||
|
|
||||||
/* Locate the interface name region. */
|
|
||||||
|
|
||||||
for (beg = tmp; *beg && isspace(*beg); beg++);
|
|
||||||
for (end = beg; *end && *end != ':'; end++);
|
|
||||||
|
|
||||||
/* Allocate both wapi_string_t and char vector. */
|
|
||||||
|
|
||||||
string = malloc(sizeof(wapi_string_t));
|
|
||||||
if (string)
|
|
||||||
{
|
|
||||||
string->data = malloc(end - beg + sizeof(char));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!string || !string->data)
|
|
||||||
{
|
|
||||||
WAPI_STRERROR("malloc()");
|
|
||||||
ret = -1;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Copy region into the buffer. */
|
|
||||||
|
|
||||||
snprintf(string->data, (end - beg + sizeof(char)), "%s", beg);
|
|
||||||
|
|
||||||
/* Push string into the list. */
|
|
||||||
|
|
||||||
string->next = list->head.string;
|
|
||||||
list->head.string = string;
|
|
||||||
}
|
|
||||||
|
|
||||||
fclose(fp);
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
/****************************************************************************
|
|
||||||
* Name: wapi_get_ifnames
|
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
* Return name string for IOCTL command
|
* Return name string for IOCTL command
|
||||||
|
@ -1,6 +1,11 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* apps/wireless/wapi/src/util.h
|
* apps/wireless/wapi/src/util.h
|
||||||
*
|
*
|
||||||
|
* Copyright (C) 2011, 2017Gregory Nutt. All rights reserved.
|
||||||
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
|
*
|
||||||
|
* Adapted for Nuttx from WAPI:
|
||||||
|
*
|
||||||
* Copyright (c) 2010, Volkan YAZICI <volkan.yazici@gmail.com>
|
* Copyright (c) 2010, Volkan YAZICI <volkan.yazici@gmail.com>
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
|
@ -1,6 +1,11 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* apps/wireless/wapi/src/wapi.c
|
* apps/wireless/wapi/src/wapi.c
|
||||||
*
|
*
|
||||||
|
* Copyright (C) 2011, 2017Gregory Nutt. All rights reserved.
|
||||||
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
|
*
|
||||||
|
* Adapted for Nuttx from WAPI:
|
||||||
|
*
|
||||||
* Copyright (c) 2010, Volkan YAZICI <volkan.yazici@gmail.com>
|
* Copyright (c) 2010, Volkan YAZICI <volkan.yazici@gmail.com>
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
@ -321,71 +326,6 @@ int wapi_main(int argc, char *argv[])
|
|||||||
|
|
||||||
ifname = argv[1];
|
ifname = argv[1];
|
||||||
|
|
||||||
/* Get ifnames */
|
|
||||||
|
|
||||||
bzero(&list, sizeof(wapi_list_t));
|
|
||||||
ret = wapi_get_ifnames(&list);
|
|
||||||
printf("wapi_get_ifnames(): ret: %d", ret);
|
|
||||||
if (ret >= 0)
|
|
||||||
{
|
|
||||||
FAR wapi_string_t *str;
|
|
||||||
|
|
||||||
/* Print ifnames */
|
|
||||||
|
|
||||||
printf(", ifnames:");
|
|
||||||
for (str = list.head.string; str; str = str->next)
|
|
||||||
{
|
|
||||||
printf(" %s", str->data);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Free ifnames */
|
|
||||||
|
|
||||||
str = list.head.string;
|
|
||||||
while (str)
|
|
||||||
{
|
|
||||||
FAR wapi_string_t *tmp;
|
|
||||||
|
|
||||||
tmp = str->next;
|
|
||||||
free(str->data);
|
|
||||||
free(str);
|
|
||||||
str = tmp;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
putchar('\n');
|
|
||||||
|
|
||||||
/* Get routes */
|
|
||||||
|
|
||||||
bzero(&list, sizeof(wapi_list_t));
|
|
||||||
ret = wapi_get_routes(&list);
|
|
||||||
printf("wapi_get_routes(): ret: %d\n", ret);
|
|
||||||
if (ret >= 0)
|
|
||||||
{
|
|
||||||
wapi_route_info_t *ri;
|
|
||||||
|
|
||||||
/* Print route */
|
|
||||||
|
|
||||||
for (ri = list.head.route; ri; ri = ri->next)
|
|
||||||
{
|
|
||||||
printf(">> dest: %s, gw: %s, netmask: %s\n",
|
|
||||||
inet_ntoa(ri->dest), inet_ntoa(ri->gw),
|
|
||||||
inet_ntoa(ri->netmask));
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Free routes */
|
|
||||||
|
|
||||||
ri = list.head.route;
|
|
||||||
while (ri)
|
|
||||||
{
|
|
||||||
FAR wapi_route_info_t *tmpri;
|
|
||||||
|
|
||||||
tmpri = ri->next;
|
|
||||||
free(ri->ifname);
|
|
||||||
free(ri);
|
|
||||||
ri = tmpri;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Make a comm. sock. */
|
/* Make a comm. sock. */
|
||||||
|
|
||||||
sock = wapi_make_socket();
|
sock = wapi_make_socket();
|
||||||
|
@ -1,6 +1,11 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* apps/wireless/wapi/src/wireless.c
|
* apps/wireless/wapi/src/wireless.c
|
||||||
*
|
*
|
||||||
|
* Copyright (C) 2011, 2017Gregory Nutt. All rights reserved.
|
||||||
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
|
*
|
||||||
|
* Adapted for Nuttx from WAPI:
|
||||||
|
*
|
||||||
* Copyright (c) 2010, Volkan YAZICI <volkan.yazici@gmail.com>
|
* Copyright (c) 2010, Volkan YAZICI <volkan.yazici@gmail.com>
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
|
Loading…
Reference in New Issue
Block a user