diff options
author | brian <brian@FreeBSD.org> | 1999-11-16 21:57:34 +0000 |
---|---|---|
committer | brian <brian@FreeBSD.org> | 1999-11-16 21:57:34 +0000 |
commit | e6e4bcef4357616b146553ad1ac922c436b9bd0f (patch) | |
tree | c0799c864d2517e318d3cc4c032dfe10a6ef9ac6 /usr.sbin/ppp/ether.c | |
parent | fa089ea40acd74f58a2bb83ae7c5939434527ff5 (diff) | |
download | FreeBSD-src-e6e4bcef4357616b146553ad1ac922c436b9bd0f.zip FreeBSD-src-e6e4bcef4357616b146553ad1ac922c436b9bd0f.tar.gz |
Use modfind() to check if a kld is already loaded.
Submitted mostly by: green
Diffstat (limited to 'usr.sbin/ppp/ether.c')
-rw-r--r-- | usr.sbin/ppp/ether.c | 16 |
1 files changed, 5 insertions, 11 deletions
diff --git a/usr.sbin/ppp/ether.c b/usr.sbin/ppp/ether.c index da20f9f..52ae083 100644 --- a/usr.sbin/ppp/ether.c +++ b/usr.sbin/ppp/ether.c @@ -49,6 +49,7 @@ #include <sys/fcntl.h> #if defined(__FreeBSD__) && !defined(NOKLDLOAD) #include <sys/linker.h> +#include <sys/module.h> #endif #include <sys/uio.h> #include <termios.h> @@ -409,22 +410,15 @@ ether_Create(struct physical *p) int ifacelen, providerlen, oldflag; char connectpath[sizeof dev->hook + 2]; /* .:<hook> */ -#ifdef KLDSYM_LOOKUP - /* First make sure we've got the right code loaded */ - char basesym[] = "ng_make_node", socksym[] = "ngdomain"; - struct kld_sym_lookup baselookup = { sizeof baselookup, basesym, 0, 0 }; - struct kld_sym_lookup socklookup = { sizeof socklookup, socksym, 0, 0 }; -#endif - p->fd--; /* We own the device - change fd */ -#ifdef KLDSYM_LOOKUP - if (kldsym(0, KLDSYM_LOOKUP, &baselookup) == -1) { - log_Printf(LogWARN, "Can't run without options NETGRAPH in the kernel\n"); +#if defined(__FreeBSD__) && !defined(NOKLDLOAD) + if (modfind("netgraph") == -1) { + log_Printf(LogWARN, "Netgraph is not built into the kernel\n"); return NULL; } - if (kldsym(0, KLDSYM_LOOKUP, &socklookup) == -1 && + if (modfind("ng_socket") == -1 && ID0kldload("ng_socket") == -1) { log_Printf(LogWARN, "kldload: ng_socket: %s\n", strerror(errno)); return NULL; |