|
|
45db86 |
diff -up net-tools-2.0/ether-wake.c.interfaces net-tools-2.0/ether-wake.c
|
|
|
45db86 |
--- net-tools-2.0/ether-wake.c.interfaces 2015-09-15 18:02:18.595968129 +0200
|
|
|
45db86 |
+++ net-tools-2.0/ether-wake.c 2015-09-15 18:02:18.607968095 +0200
|
|
|
45db86 |
@@ -22,7 +22,7 @@ static char usage_msg[] =
|
|
|
45db86 |
" Options:\n"
|
|
|
45db86 |
" -b Send wake-up packet to the broadcast address.\n"
|
|
|
45db86 |
" -D Increase the debug level.\n"
|
|
|
45db86 |
-" -i ifname Use interface IFNAME instead of the default 'eth0'.\n"
|
|
|
45db86 |
+" -i ifname Use interface ifname instead of sending a wake packet to all interfaces.\n"
|
|
|
45db86 |
" -p <pw> Append the four or six byte password PW to the packet.\n"
|
|
|
45db86 |
" A password is only required for a few adapter types.\n"
|
|
|
45db86 |
" The password may be specified in ethernet hex format\n"
|
|
|
45db86 |
@@ -89,6 +89,9 @@ static char usage_msg[] =
|
|
|
45db86 |
#include <netdb.h>
|
|
|
45db86 |
#include <netinet/ether.h>
|
|
|
45db86 |
|
|
|
45db86 |
+#include "interface.h"
|
|
|
45db86 |
+#include "sockets.h"
|
|
|
45db86 |
+
|
|
|
45db86 |
/* Grrr, no consistency between include versions.
|
|
|
45db86 |
Enable this if setsockopt() isn't declared with your library. */
|
|
|
45db86 |
#if 0
|
|
|
45db86 |
@@ -110,20 +113,29 @@ static int get_dest_addr(const char *arg
|
|
|
45db86 |
static int get_fill(unsigned char *pkt, struct ether_addr *eaddr);
|
|
|
45db86 |
static int get_wol_pw(const char *optarg);
|
|
|
45db86 |
|
|
|
45db86 |
+typedef struct {
|
|
|
45db86 |
+ int s;
|
|
|
45db86 |
+ int verbose;
|
|
|
45db86 |
+ int pktsize;
|
|
|
45db86 |
+} if_info;
|
|
|
45db86 |
+
|
|
|
45db86 |
+static int send_wol_packet(char *ifname, int s, int verbose, int pktsize);
|
|
|
45db86 |
+
|
|
|
45db86 |
+static int do_wake(struct interface *ife, void *cookie) {
|
|
|
45db86 |
+ if_info *info = (if_info *)cookie;
|
|
|
45db86 |
+ send_wol_packet(ife->name, info->s, info->verbose, info->pktsize);
|
|
|
45db86 |
+ return 0;
|
|
|
45db86 |
+}
|
|
|
45db86 |
+
|
|
|
45db86 |
int main(int argc, char *argv[])
|
|
|
45db86 |
{
|
|
|
45db86 |
- char *ifname = "eth0";
|
|
|
45db86 |
- int one = 1; /* True, for socket options. */
|
|
|
45db86 |
+ char *ifname = NULL;
|
|
|
45db86 |
int s; /* Raw socket */
|
|
|
45db86 |
int errflag = 0, verbose = 0, do_version = 0;
|
|
|
45db86 |
int perm_failure = 0;
|
|
|
45db86 |
- int i, c, pktsize;
|
|
|
45db86 |
-#if defined(PF_PACKET)
|
|
|
45db86 |
- struct sockaddr_ll whereto;
|
|
|
45db86 |
-#else
|
|
|
45db86 |
- struct sockaddr whereto; /* who to wake up */
|
|
|
45db86 |
-#endif
|
|
|
45db86 |
+ int c, pktsize;
|
|
|
45db86 |
struct ether_addr eaddr;
|
|
|
45db86 |
+ if_info info;
|
|
|
45db86 |
|
|
|
45db86 |
while ((c = getopt(argc, argv, "bDi:p:uvV")) != -1)
|
|
|
45db86 |
switch (c) {
|
|
|
45db86 |
@@ -131,7 +143,7 @@ int main(int argc, char *argv[])
|
|
|
45db86 |
case 'D': debug++; break;
|
|
|
45db86 |
case 'i': ifname = optarg; break;
|
|
|
45db86 |
case 'p': get_wol_pw(optarg); break;
|
|
|
45db86 |
- case 'u': printf(usage_msg); return 0;
|
|
|
45db86 |
+ case 'u': printf("%s",usage_msg); return 0;
|
|
|
45db86 |
case 'v': verbose++; break;
|
|
|
45db86 |
case 'V': do_version++; break;
|
|
|
45db86 |
case '?':
|
|
|
45db86 |
@@ -140,7 +152,7 @@ int main(int argc, char *argv[])
|
|
|
45db86 |
if (verbose || do_version)
|
|
|
45db86 |
printf("%s\n", version_msg);
|
|
|
45db86 |
if (errflag) {
|
|
|
45db86 |
- fprintf(stderr, brief_usage_msg);
|
|
|
45db86 |
+ fprintf(stderr,"%s", brief_usage_msg);
|
|
|
45db86 |
return 3;
|
|
|
45db86 |
}
|
|
|
45db86 |
|
|
|
45db86 |
@@ -177,13 +189,45 @@ int main(int argc, char *argv[])
|
|
|
45db86 |
|
|
|
45db86 |
pktsize = get_fill(outpack, &eaddr);
|
|
|
45db86 |
|
|
|
45db86 |
+ if (ifname == NULL) {
|
|
|
45db86 |
+ info.s = s;
|
|
|
45db86 |
+ info.verbose = verbose;
|
|
|
45db86 |
+ info.pktsize = pktsize;
|
|
|
45db86 |
+
|
|
|
45db86 |
+ /* Create a channel to the NET kernel. */
|
|
|
45db86 |
+ if ((sockets_open(0)) < 0) {
|
|
|
45db86 |
+ perror("socket");
|
|
|
45db86 |
+ exit(1);
|
|
|
45db86 |
+ }
|
|
|
45db86 |
+
|
|
|
45db86 |
+ return for_all_interfaces(do_wake, &info;;
|
|
|
45db86 |
+ }
|
|
|
45db86 |
+
|
|
|
45db86 |
+ return send_wol_packet(ifname, s, verbose, pktsize);
|
|
|
45db86 |
+}
|
|
|
45db86 |
+
|
|
|
45db86 |
+/* Send a Wake-On-LAN (WOL) "Magic Packet" to Interface IFNAME using
|
|
|
45db86 |
+ Socket S with a packet size PKTSIZE. VERBOSE implies
|
|
|
45db86 |
+ verbosity. */
|
|
|
45db86 |
+
|
|
|
45db86 |
+static int send_wol_packet(char *ifname, int s, int verbose, int pktsize)
|
|
|
45db86 |
+{
|
|
|
45db86 |
+ int i;
|
|
|
45db86 |
+ int one = 1; /* True, for socket options. */
|
|
|
45db86 |
+#if defined(PF_PACKET)
|
|
|
45db86 |
+ struct sockaddr_ll whereto;
|
|
|
45db86 |
+#else
|
|
|
45db86 |
+ struct sockaddr whereto; /* who to wake up */
|
|
|
45db86 |
+#endif
|
|
|
45db86 |
+
|
|
|
45db86 |
/* Fill in the source address, if possible.
|
|
|
45db86 |
The code to retrieve the local station address is Linux specific. */
|
|
|
45db86 |
if (! opt_no_src_addr) {
|
|
|
45db86 |
struct ifreq if_hwaddr;
|
|
|
45db86 |
- unsigned char *hwaddr = if_hwaddr.ifr_hwaddr.sa_data;
|
|
|
45db86 |
+ const char *hwaddr = if_hwaddr.ifr_hwaddr.sa_data;
|
|
|
45db86 |
|
|
|
45db86 |
- strcpy(if_hwaddr.ifr_name, ifname);
|
|
|
45db86 |
+ strncpy(if_hwaddr.ifr_name, ifname, IFNAMSIZ);
|
|
|
45db86 |
+ if_hwaddr.ifr_name[IFNAMSIZ-1] = '\0';
|
|
|
45db86 |
if (ioctl(s, SIOCGIFHWADDR, &if_hwaddr) < 0) {
|
|
|
45db86 |
fprintf(stderr, "SIOCGIFHWADDR on %s failed: %s\n", ifname,
|
|
|
45db86 |
strerror(errno));
|
|
|
45db86 |
@@ -220,7 +264,8 @@ int main(int argc, char *argv[])
|
|
|
45db86 |
#if defined(PF_PACKET)
|
|
|
45db86 |
{
|
|
|
45db86 |
struct ifreq ifr;
|
|
|
45db86 |
- strncpy(ifr.ifr_name, ifname, sizeof(ifr.ifr_name));
|
|
|
45db86 |
+ strncpy(ifr.ifr_name, ifname, IFNAMSIZ);
|
|
|
45db86 |
+ ifr.ifr_name[IFNAMSIZ-1] = '\0';
|
|
|
45db86 |
if (ioctl(s, SIOCGIFINDEX, &ifr) == -1) {
|
|
|
45db86 |
fprintf(stderr, "SIOCGIFINDEX on %s failed: %s\n", ifname,
|
|
|
45db86 |
strerror(errno));
|
|
|
45db86 |
@@ -240,11 +285,14 @@ int main(int argc, char *argv[])
|
|
|
45db86 |
strcpy(whereto.sa_data, ifname);
|
|
|
45db86 |
#endif
|
|
|
45db86 |
|
|
|
45db86 |
+ char senderrmsg[IFNAMSIZ+16] = "'";
|
|
|
45db86 |
+ strcat(senderrmsg, ifname);
|
|
|
45db86 |
+ strcat(senderrmsg, "', sendto");
|
|
|
45db86 |
if ((i = sendto(s, outpack, pktsize, 0, (struct sockaddr *)&whereto,
|
|
|
45db86 |
sizeof(whereto))) < 0)
|
|
|
45db86 |
- perror("sendto");
|
|
|
45db86 |
+ perror(senderrmsg);
|
|
|
45db86 |
else if (debug)
|
|
|
45db86 |
- printf("Sendto worked ! %d.\n", i);
|
|
|
45db86 |
+ printf("'%s', Sendto worked ! %d.\n", ifname, i);
|
|
|
45db86 |
|
|
|
45db86 |
#ifdef USE_SEND
|
|
|
45db86 |
if (bind(s, (struct sockaddr *)&whereto, sizeof(whereto)) < 0)
|
|
|
45db86 |
diff -up net-tools-2.0/Makefile.interfaces net-tools-2.0/Makefile
|
|
|
45db86 |
--- net-tools-2.0/Makefile.interfaces 2015-09-15 18:02:18.608968093 +0200
|
|
|
45db86 |
+++ net-tools-2.0/Makefile 2015-09-15 18:04:06.273668275 +0200
|
|
|
45db86 |
@@ -193,6 +193,9 @@ ipmaddr: $(NET_LIB) ipmaddr.o
|
|
|
45db86 |
mii-tool: $(NET_LIB) mii-tool.o
|
|
|
45db86 |
$(CC) $(CFLAGS) $(LDFLAGS) -o $@ mii-tool.o $(NLIB)
|
|
|
45db86 |
|
|
|
45db86 |
+ether-wake: $(NET_LIB) ether-wake.o
|
|
|
45db86 |
+ $(CC) $(CFLAGS) $(LDFLAGS) -o ether-wake ether-wake.o $(NLIB)
|
|
|
45db86 |
+
|
|
|
45db86 |
installbin:
|
|
|
45db86 |
@echo
|
|
|
45db86 |
@echo "######################################################"
|
|
|
45db86 |
diff -up net-tools-2.0/man/en_US/ether-wake.8.interfaces net-tools-2.0/man/en_US/ether-wake.8
|
|
|
45db86 |
--- net-tools-2.0/man/en_US/ether-wake.8.interfaces 2015-09-15 18:02:18.597968123 +0200
|
|
|
45db86 |
+++ net-tools-2.0/man/en_US/ether-wake.8 2015-09-15 18:02:18.608968093 +0200
|
|
|
45db86 |
@@ -49,7 +49,7 @@ Send the wake-up packet to the broadcast
|
|
|
45db86 |
Increase the Debug Level.
|
|
|
45db86 |
.TP
|
|
|
45db86 |
.B \-i ifname
|
|
|
45db86 |
-Use interface ifname instead of the default "eth0".
|
|
|
45db86 |
+Use interface ifname instead of sending a wake packet to all interfaces.
|
|
|
45db86 |
.TP
|
|
|
45db86 |
.B \-p passwd
|
|
|
45db86 |
Append a four or six byte password to the packet. Only a few adapters
|