Mercurial > hg > dhcpcd
view platform-linux.c @ 1693:829716214dbc draft dhcpcd-5.6.0
Improve IPv6 RA support by allowing dhcpcd to manage the address and routes
instead of the kernel. dhcpcd will only do this if RA is disabled in the kernel
or dhcpcd has been instructed to do this via dhcpcd.conf(5) ipv6ra_own and
ipv6ra_own_default directives.
Send and process IPv6 Neighbor Solicitions and Adverts to prove router
reachability. If a router cannot be reached in this way then it is expired.
When debugging, all ND messages are displayed which will create a lot of log
spam.
To ease packaging, ./configure now accepts LDFLAGS and --enable-static.
| author | Roy Marples <roy@marples.name> |
|---|---|
| date | Thu, 05 Jul 2012 16:37:41 +0000 |
| parents | 80301c098bc6 |
| children | 2f2700ce3dba |
line wrap: on
line source
/* * dhcpcd - DHCP client daemon * Copyright (c) 2006-2012 Roy Marples <roy@marples.name> * 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, this list 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 AUTHOR 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 AUTHOR 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. */ #include <errno.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <syslog.h> #include "common.h" #include "if-options.h" #include "platform.h" static const char *mproc = #if defined(__alpha__) "system type" #elif defined(__arm__) "Hardware" #elif defined(__avr32__) "cpu family" #elif defined(__bfin__) "BOARD Name" #elif defined(__cris__) "cpu model" #elif defined(__frv__) "System" #elif defined(__i386__) || defined(__x86_64__) "vendor_id" #elif defined(__ia64__) "vendor" #elif defined(__hppa__) "model" #elif defined(__m68k__) "MMU" #elif defined(__mips__) "system type" #elif defined(__powerpc__) || defined(__powerpc64__) "machine" #elif defined(__s390__) || defined(__s390x__) "Manufacturer" #elif defined(__sh__) "machine" #elif defined(sparc) || defined(__sparc__) "cpu" #elif defined(__vax__) "cpu" #else NULL #endif ; char **restore; ssize_t nrestore; char * hardware_platform(void) { FILE *fp; char *buf, *p; if (mproc == NULL) { errno = EINVAL; return NULL; } fp = fopen("/proc/cpuinfo", "r"); if (fp == NULL) return NULL; p = NULL; while ((buf = get_line(fp))) { if (strncmp(buf, mproc, strlen(mproc)) == 0) { p = strchr(buf, ':'); if (p != NULL && ++p != NULL) { while (*p == ' ') p++; break; } } } fclose(fp); if (p == NULL) errno = ESRCH; return p; } static int check_proc_int(const char *path) { FILE *fp; char *buf; fp = fopen(path, "r"); if (fp == NULL) return -1; buf = get_line(fp); fclose(fp); if (buf == NULL) return -1; return atoi(buf); } static ssize_t write_path(const char *path, const char *val) { FILE *fp; ssize_t r; fp = fopen(path, "w"); if (fp == NULL) return -1; r = fprintf(fp, "%s\n", val); fclose(fp); return r; } static const char *prefix = "/proc/sys/net/ipv6/conf"; static void restore_kernel_ra(void) { char path[256]; for (nrestore--; nrestore >= 0; nrestore--) { syslog(LOG_INFO, "%s: restoring Kernel IPv6 RA support", restore[nrestore]); snprintf(path, sizeof(path), "%s/%s/accept_ra", prefix, restore[nrestore]); if (write_path(path, "1") == -1) syslog(LOG_ERR, "write_path: %s: %m", path); #ifdef DEBUG_MEMORY free(restore[nrestore]); #endif } #ifdef DEBUG_MEMORY free(restore); #endif } int check_ipv6(const char *ifname) { int r, ex; char path[256]; if (ifname == NULL) { ifname = "all"; ex = 1; } else ex = 0; snprintf(path, sizeof(path), "%s/%s/accept_ra", prefix, ifname); r = check_proc_int(path); if (r == 0) options |= DHCPCD_IPV6RA_OWN; else if (options & DHCPCD_IPV6RA_OWN) { syslog(LOG_INFO, "disabling Kernel IPv6 RA support"); if (write_path(path, "0") == -1) { syslog(LOG_ERR, "write_path: %s: %m", path); return 0; } restore = realloc(restore, (nrestore + 1) * sizeof(char *)); if (restore == NULL) { syslog(LOG_ERR, "realloc: %m"); exit(EXIT_FAILURE); } restore[nrestore++] = xstrdup(ifname); if (ex) atexit(restore_kernel_ra); } if (r != 2) { snprintf(path, sizeof(path), "%s/%s/forwarding", prefix, ifname); if (check_proc_int(path) != 0) { syslog(LOG_WARNING, "%s: configured as a router, not a host", ifname); return 0; } } return 1; }
