2016-08-25 19:40:25 +00:00
|
|
|
/*
|
2018-02-23 03:11:43 +00:00
|
|
|
* Copyright (c) 2016-2017, Marie Helene Kvello-Aune
|
2016-08-25 19:40:25 +00:00
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without modification,
|
|
|
|
* are permitted provided that the following conditions are met:
|
|
|
|
*
|
|
|
|
* 1. Redistributions of source code must retain the above copyright notice,
|
|
|
|
* thislist of conditions and the following disclaimer.
|
|
|
|
*
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
|
|
|
* this list of conditions and the following disclaimer in the documentation and/or
|
|
|
|
* other materials provided with the distribution.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
|
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
|
|
|
|
* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
|
|
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
|
|
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
|
|
|
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
|
|
|
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
|
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*
|
|
|
|
* $FreeBSD$
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <err.h>
|
|
|
|
#include <errno.h>
|
|
|
|
#include <net/if.h>
|
|
|
|
#include <sys/ioctl.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
2016-09-02 18:33:08 +00:00
|
|
|
#include <libifconfig.h>
|
2016-08-25 19:40:25 +00:00
|
|
|
|
|
|
|
|
2016-09-04 20:55:27 +00:00
|
|
|
int
|
|
|
|
main(int argc, char *argv[])
|
2016-08-25 19:40:25 +00:00
|
|
|
{
|
2016-09-04 20:55:27 +00:00
|
|
|
char *ifname, *ifactualname;
|
2018-02-23 03:11:43 +00:00
|
|
|
ifconfig_handle_t *lifh;
|
2016-09-04 20:55:27 +00:00
|
|
|
|
2016-08-25 19:40:25 +00:00
|
|
|
if (argc != 2) {
|
|
|
|
errx(EINVAL, "Invalid number of arguments."
|
|
|
|
" Only one argument is accepted, and it should be the name"
|
|
|
|
" of the interface to be created.");
|
|
|
|
}
|
|
|
|
|
|
|
|
/* We have a static number of arguments. Therefore we can do it simple. */
|
|
|
|
ifname = strdup(argv[1]);
|
|
|
|
|
|
|
|
printf("Requested interface name: %s\n", ifname);
|
|
|
|
|
2018-02-23 03:11:43 +00:00
|
|
|
lifh = ifconfig_open();
|
|
|
|
if (lifh == NULL) {
|
|
|
|
errx(ENOMEM, "Failed to open libifconfig handle.");
|
|
|
|
return (-1);
|
|
|
|
}
|
|
|
|
|
2016-09-02 18:33:08 +00:00
|
|
|
if (ifconfig_create_interface(lifh, ifname, &ifactualname) == 0) {
|
2016-08-25 19:40:25 +00:00
|
|
|
printf("Successfully created interface '%s'\n", ifactualname);
|
2016-09-02 18:33:08 +00:00
|
|
|
ifconfig_close(lifh);
|
2016-08-25 19:40:25 +00:00
|
|
|
lifh = NULL;
|
|
|
|
free(ifname);
|
|
|
|
free(ifactualname);
|
|
|
|
return (0);
|
2016-09-04 20:55:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
switch (ifconfig_err_errtype(lifh)) {
|
|
|
|
case SOCKET:
|
|
|
|
warnx("couldn't create socket. This shouldn't happen.\n");
|
|
|
|
break;
|
|
|
|
case IOCTL:
|
|
|
|
if (ifconfig_err_ioctlreq(lifh) == SIOCIFCREATE2) {
|
2016-08-25 19:40:25 +00:00
|
|
|
warnx(
|
2016-09-04 20:55:27 +00:00
|
|
|
"Failed to create interface (SIOCIFCREATE2)\n");
|
2016-08-25 19:40:25 +00:00
|
|
|
}
|
2016-09-04 20:55:27 +00:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
warnx(
|
|
|
|
"This is a thorough example accommodating for temporary"
|
|
|
|
" 'not implemented yet' errors. That's likely what happened"
|
|
|
|
" now. If not, your guess is as good as mine. ;)"
|
|
|
|
" Error code: %d\n", ifconfig_err_errno(
|
|
|
|
lifh));
|
|
|
|
break;
|
2016-08-25 19:40:25 +00:00
|
|
|
}
|
2016-09-04 20:55:27 +00:00
|
|
|
|
|
|
|
ifconfig_close(lifh);
|
|
|
|
lifh = NULL;
|
|
|
|
free(ifname);
|
|
|
|
free(ifactualname);
|
|
|
|
return (-1);
|
2016-08-25 19:40:25 +00:00
|
|
|
}
|