diff options
author | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2013-12-12 09:11:00 +0100 |
---|---|---|
committer | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2014-01-30 16:23:03 +0100 |
commit | 917a78b209efbbcb3d16dd28f8b3cb067a7f5b87 (patch) | |
tree | 7de4f8c3b93820d563838e14d4470f229c9fe669 /testsuite/include/rtems | |
parent | DHCPCD(8): Add config.h (diff) | |
download | rtems-libbsd-917a78b209efbbcb3d16dd28f8b3cb067a7f5b87.tar.bz2 |
DHCPCD(8): Add basic support
Diffstat (limited to 'testsuite/include/rtems')
-rw-r--r-- | testsuite/include/rtems/bsd/test/default-network-init.h | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/testsuite/include/rtems/bsd/test/default-network-init.h b/testsuite/include/rtems/bsd/test/default-network-init.h index d5cdf258..b53a955a 100644 --- a/testsuite/include/rtems/bsd/test/default-network-init.h +++ b/testsuite/include/rtems/bsd/test/default-network-init.h @@ -29,9 +29,12 @@ * SUCH DAMAGE. */ +#include <sys/stat.h> + #include <net/if.h> #include <assert.h> +#include <fcntl.h> #include <ifaddrs.h> #include <stdio.h> #include <stdlib.h> @@ -43,6 +46,11 @@ #include <rtems/stackchk.h> #include <rtems/bsd/bsd.h> +#if defined(DEFAULT_NETWORK_DHCPCD_ENABLE) && \ + !defined(DEFAULT_NETWORK_NO_STATIC_IFCONFIG) +#define DEFAULT_NETWORK_NO_STATIC_IFCONFIG +#endif + #ifndef DEFAULT_NETWORK_NO_STATIC_IFCONFIG #include <rtems/bsd/test/network-config.h> #endif @@ -143,6 +151,60 @@ default_network_route_hwif0(char *ifname) #endif } +#ifdef DEFAULT_NETWORK_DHCPCD_ENABLE +static void +default_network_dhcpcd_task(rtems_task_argument arg) +{ + int exit_code; + char *dhcpcd[] = { + "dhcpcd", + NULL + }; + +#ifdef DEFAULT_NETWORK_DHCPCD_NO_DHCP_DISCOVERY + static const char cfg[] = "nodhcp\nnodhcp6\n"; + int fd; + int rv; + ssize_t n; + + fd = open("/etc/dhcpcd.conf", O_CREAT | O_WRONLY, + S_IRWXU | S_IRWXG | S_IRWXO); + assert(fd >= 0); + + n = write(fd, cfg, sizeof(cfg)); + assert(n == (ssize_t) sizeof(cfg)); + + rv = close(fd); + assert(rv == 0); +#endif + + exit_code = rtems_bsd_command_dhcpcd(RTEMS_BSD_ARGC(dhcpcd), dhcpcd); + assert(exit_code == EXIT_SUCCESS); +} +#endif + +static void +default_network_dhcpcd(void) +{ +#ifdef DEFAULT_NETWORK_DHCPCD_ENABLE + rtems_status_code sc; + rtems_id id; + + sc = rtems_task_create( + rtems_build_name('D', 'H', 'C', 'P'), + RTEMS_MAXIMUM_PRIORITY - 1, + RTEMS_MINIMUM_STACK_SIZE, + RTEMS_DEFAULT_MODES, + RTEMS_FLOATING_POINT, + &id + ); + assert(sc == RTEMS_SUCCESSFUL); + + sc = rtems_task_start(id, default_network_dhcpcd_task, 0); + assert(sc == RTEMS_SUCCESSFUL); +#endif +} + static void default_network_on_exit(int exit_code, void *arg) { @@ -199,6 +261,7 @@ Init(rtems_task_argument arg) default_network_ifconfig_lo0(); default_network_ifconfig_hwif0(ifname); default_network_route_hwif0(ifname); + default_network_dhcpcd(); test_main(); |