亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? ether_wake.c

?? linux鏈路層源碼
?? C
字號:
/*	This program generates and transmits a Wake-On-LAN (WOL) "Magic Packet",	used for restarting machines that have been soft-powered-down	(ACPI D3-warm state).  It currently generates the standard AMD Magic Packet	format, with an optional password appended.	This software may be used and distributed according to the terms	of the GNU Public License, incorporated herein by reference.	Contact the author for use under other terms.	This source file was originally part of the network tricks package, and	is now distributed to support the Scyld Beowulf system.	Copyright 1999-2003 Donald Becker and Scyld Computing Corporation.	The author may be reached as becker@scyld, or C/O	 Scyld Computing Corporation	 410 Severn Ave., Suite 210	 Annapolis MD 21403  Notes:  On some systems dropping root capability allows the process to be  dumped, traced or debugged.  If someone traces this program, they get control of a raw socket.  Linux handles this safely, but beware when porting this program.  An alternative to needing 'root' is using a UDP broadcast socket, however  doing so only works with adapters configured for unicast+broadcast Rx  filter.  That configuration consumes more power.*/#include <unistd.h>#include <stdlib.h>#include <stdio.h>#include <errno.h>#include <ctype.h>#include <string.h>#if 0							/* Only exists on some versions. */#include <ioctls.h>#endif#include <sys/socket.h>#include <sys/types.h>#include <sys/ioctl.h>#include <linux/if.h>#include <features.h>#if __GLIBC__ >= 2 && __GLIBC_MINOR >= 1#include <netpacket/packet.h>#include <net/ethernet.h>#else#include <asm/types.h>#include <linux/if_packet.h>#include <linux/if_ether.h>#endif#include <netdb.h>#include <netinet/ether.h>/* Grrr, no consistency between include versions.   Enable this if setsockopt() isn't declared with your library. */#if 0extern int setsockopt __P ((int __fd, int __level, int __optname,							__ptr_t __optval, int __optlen));#else				/* New, correct head files.  */#include <sys/socket.h>#endif#ifdef USE_SENDMSG#include <iovec.h>#endifu_char outpack[1000];int outpack_sz = 0;int debug = 0;u_char wol_passwd[6];int wol_passwd_sz = 0;u_char usage_msg[10]="hello";u_char brief_usage_msg[10]="hello";  u_char version_msg[10]="hello";static int opt_no_src_addr = 0, opt_broadcast = 0; static int get_dest_addr(const char *arg, struct ether_addr *eaddr);static int get_fill(unsigned char *pkt, struct ether_addr *eaddr);static int get_wol_pw(const char *optarg);int main(int argc, char *argv[]){	char *ifname = "eth0";	int one = 1;				/* True, for socket options. */	int s;						/* Raw socket */	int errflag = 0, verbose = 0, do_version = 0;	int perm_failure = 0;	int i, c, pktsize;#if defined(PF_PACKET)	struct sockaddr_ll whereto;#else	struct sockaddr whereto;	/* who to wake up */#endif	struct ether_addr eaddr;	while ((c = getopt(argc, argv, "bDi:p:uvV")) != -1)		switch (c) {		case 'b': opt_broadcast++;	break;		case 'D': debug++;			break;		case 'i': ifname = optarg;	break;		case 'p': get_wol_pw(optarg); break;		case 'u': printf(usage_msg); return 0;		case 'v': verbose++;		break;		case 'V': do_version++;		break;		case '?':			errflag++;		}	if (verbose || do_version)		printf("%s\n", version_msg);	if (errflag) {		fprintf(stderr, brief_usage_msg);		return 3;	}	if (optind == argc) {		fprintf(stderr, "Specify the Ethernet address as 00:11:22:33:44:55.\n");		return 3;	}	/* Note: PF_INET, SOCK_DGRAM, IPPROTO_UDP would allow SIOCGIFHWADDR to	   work as non-root, but we need SOCK_PACKET to specify the Ethernet	   destination address. */#if defined(PF_PACKET)	s = socket(PF_PACKET, SOCK_RAW, 0);#else	s = socket(AF_INET, SOCK_PACKET, SOCK_PACKET);#endif	if (s < 0) {		if (errno == EPERM)			fprintf(stderr, "ether-wake: This program must be run as root.\n");		else			perror("ether-wake: socket");		perm_failure++;	}	/* Don't revert if debugging allows a normal user to get the raw socket. */	setuid(getuid());	/* We look up the station address before reporting failure so that	   errors may be reported even when run as a normal user.	*/	if (get_dest_addr(argv[optind], &eaddr) != 0)		return 3;	if (perm_failure && ! debug)		return 2;	pktsize = get_fill(outpack, &eaddr);	/* Fill in the source address, if possible.	   The code to retrieve the local station address is Linux specific. */	if (! opt_no_src_addr) {		struct ifreq if_hwaddr;		unsigned char *hwaddr = if_hwaddr.ifr_hwaddr.sa_data;		strcpy(if_hwaddr.ifr_name, ifname);		if (ioctl(s, SIOCGIFHWADDR, &if_hwaddr) < 0) {			fprintf(stderr, "SIOCGIFHWADDR on %s failed: %s\n", ifname,					strerror(errno));			/* Magic packets still work if our source address is bogus, but			   we fail just to be anal. */			return 1;		}		memcpy(outpack+6, if_hwaddr.ifr_hwaddr.sa_data, 6);		if (verbose) {			printf("The hardware address (SIOCGIFHWADDR) of %s is type %d  "				   "%2.2x:%2.2x:%2.2x:%2.2x:%2.2x:%2.2x.\n", ifname,				   if_hwaddr.ifr_hwaddr.sa_family, hwaddr[0], hwaddr[1],				   hwaddr[2], hwaddr[3], hwaddr[4], hwaddr[5]);		}	}	if (wol_passwd_sz > 0) {		memcpy(outpack+pktsize, wol_passwd, wol_passwd_sz);		pktsize += wol_passwd_sz;	}	if (verbose > 1) {		printf("The final packet is: ");		for (i = 0; i < pktsize; i++)			printf(" %2.2x", outpack[i]);		printf(".\n");	}	/* This is necessary for broadcasts to work */	if (setsockopt(s, SOL_SOCKET, SO_BROADCAST, (char *)&one, sizeof(one)) < 0)		perror("setsockopt: SO_BROADCAST");#if defined(PF_PACKET)	{		struct ifreq ifr;		strncpy(ifr.ifr_name, ifname, sizeof(ifr.ifr_name));		if (ioctl(s, SIOCGIFINDEX, &ifr) == -1) {			fprintf(stderr, "SIOCGIFINDEX on %s failed: %s\n", ifname,					strerror(errno));			return 1;		}		memset(&whereto, 0, sizeof(whereto));		whereto.sll_family = AF_PACKET;		whereto.sll_ifindex = ifr.ifr_ifindex;		/* The manual page incorrectly claims the address must be filled.		   We do so because the code may change to match the docs. */		whereto.sll_halen = ETH_ALEN;		memcpy(whereto.sll_addr, outpack, ETH_ALEN);	}#else	whereto.sa_family = 0;	strcpy(whereto.sa_data, ifname);#endif	if ((i = sendto(s, outpack, pktsize, 0, (struct sockaddr *)&whereto,					sizeof(whereto))) < 0)		perror("sendto");	else if (debug)		printf("Sendto worked ! %d.\n", i);#ifdef USE_SEND	if (bind(s, &whereto, sizeof(whereto)) < 0)		perror("bind");	else if (send(s, outpack, 100, 0) < 0)		perror("send");#endif#ifdef USE_SENDMSG	{		struct msghdr msghdr;		struct iovec iovector[1];		msghdr.msg_name = &whereto;		msghdr.msg_namelen = sizeof(whereto);		msghdr.msg_iov = iovector;		msghdr.msg_iovlen = 1;		iovector[0].iov_base = outpack;		iovector[0].iov_len = pktsize;		if ((i = sendmsg(s, &msghdr, 0)) < 0)			perror("sendmsg");		else if (debug)			printf("sendmsg worked, %d (%d).\n", i, errno);	}#endif	return 0;}/* Convert the host ID string to a MAC address.   The string may be a	Host name    IP address string	MAC address string*/static int get_dest_addr(const char *hostid, struct ether_addr *eaddr){	struct ether_addr *eap;	eap = ether_aton(hostid);	if (eap) {		*eaddr = *eap;		if (debug)			fprintf(stderr, "The target station address is %s.\n",					ether_ntoa(eaddr));	} else if (ether_hostton(hostid, eaddr) == 0) {		if (debug)			fprintf(stderr, "Station address for hostname %s is %s.\n",					hostid, ether_ntoa(eaddr));	} else {		(void)fprintf(stderr,					  "ether-wake: The Magic Packet host address must be "					  "specified as\n"					  "  - a station address, 00:11:22:33:44:55, or\n"					  "  - a hostname with a known 'ethers' entry.\n");		return -1;	}	return 0;}static int get_fill(unsigned char *pkt, struct ether_addr *eaddr){	int offset, i;	unsigned char *station_addr = eaddr->ether_addr_octet;	if (opt_broadcast)		memset(pkt+0, 0xff, 6);	else		memcpy(pkt, station_addr, 6);	memcpy(pkt+6, station_addr, 6);	pkt[12] = 0x08;				/* Or 0x0806 for ARP, 0x8035 for RARP */	pkt[13] = 0x42;	offset = 14;	memset(pkt+offset, 0xff, 6);	offset += 6;	for (i = 0; i < 16; i++) {		memcpy(pkt+offset, station_addr, 6);		offset += 6;	}	if (debug) {		fprintf(stderr, "Packet is ");		for (i = 0; i < offset; i++)			fprintf(stderr, " %2.2x", pkt[i]);		fprintf(stderr, ".\n");	}	return offset;}static int get_wol_pw(const char *optarg){	int passwd[6];	int byte_cnt;	int i;	byte_cnt = sscanf(optarg, "%2x:%2x:%2x:%2x:%2x:%2x",					  &passwd[0], &passwd[1], &passwd[2],					  &passwd[3], &passwd[4], &passwd[5]);	if (byte_cnt < 4)		byte_cnt = sscanf(optarg, "%d.%d.%d.%d",						  &passwd[0], &passwd[1], &passwd[2], &passwd[3]);	if (byte_cnt < 4) {		fprintf(stderr, "Unable to read the Wake-On-LAN password.\n");		return 0;	}	printf(" The Magic packet password is %2.2x %2.2x %2.2x %2.2x (%d).\n",		   passwd[0], passwd[1], passwd[2], passwd[3], byte_cnt);	for (i = 0; i < byte_cnt; i++)		wol_passwd[i] = passwd[i];	return wol_passwd_sz = byte_cnt;}#if 0{	to = (struct sockaddr_in *)&whereto;	to->sin_family = AF_INET;	if (inet_aton(target, &to->sin_addr)) {		hostname = target;	}	memset (&sa, 0, sizeof sa);	sa.sa_family = AF_INET;	strncpy (sa.sa_data, interface, sizeof sa.sa_data);	sendto (sock, buf, bufix + len, 0, &sa, sizeof sa);	strncpy (sa.sa_data, interface, sizeof sa.sa_data);#if 1	sendto (sock, buf, bufix + len, 0, &sa, sizeof sa);#else	bind (sock, &sa, sizeof sa);	connect();	send (sock, buf, bufix + len, 0);#endif}#endif/* * Local variables: *  compile-command: "gcc -O -Wall -o ether-wake ether-wake.c" *  c-indent-level: 4 *  c-basic-offset: 4 *  c-indent-level: 4 *  tab-width: 4 * End: */

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产午夜亚洲精品理论片色戒| 国产呦萝稀缺另类资源| 91麻豆免费观看| 亚洲精品菠萝久久久久久久| 在线欧美日韩精品| 日韩精品欧美成人高清一区二区| 欧美精品日日鲁夜夜添| 美女诱惑一区二区| 国产欧美va欧美不卡在线| 99精品桃花视频在线观看| 亚洲免费高清视频在线| 欧美电影影音先锋| 久久精品国产成人一区二区三区| 久久网这里都是精品| 北岛玲一区二区三区四区| 一区二区三区高清不卡| 日韩欧美中文一区| 成人污视频在线观看| 亚洲激情中文1区| 亚洲天堂a在线| 欧美这里有精品| 奇米888四色在线精品| 国产日韩欧美高清在线| 在线国产亚洲欧美| 蜜桃一区二区三区四区| 国产精品乱人伦中文| 欧美午夜电影网| 国产成人综合在线| 亚洲图片自拍偷拍| 国产亚洲精品中文字幕| 欧美在线|欧美| 激情综合五月天| 一区二区三区在线观看动漫| 欧美成人猛片aaaaaaa| 91小视频在线免费看| 蜜臀久久99精品久久久画质超高清 | 亚洲日本在线看| 欧美一级一级性生活免费录像| 丁香五精品蜜臀久久久久99网站| 亚洲成人7777| 中文字幕在线视频一区| 日韩欧美国产午夜精品| 色综合久久中文字幕综合网 | 精品国精品自拍自在线| 91丨porny丨中文| 国产在线视视频有精品| 亚洲高清免费观看 | 国产精品久久久久久久久果冻传媒 | 欧美亚洲国产一区二区三区va| 韩国精品在线观看| 亚洲国产欧美日韩另类综合 | 久久99国产精品久久99果冻传媒 | 亚洲视频 欧洲视频| 2020日本不卡一区二区视频| 欧美性感一区二区三区| 成人福利在线看| 强制捆绑调教一区二区| 依依成人综合视频| 国产精品乱码久久久久久| 日韩欧美国产精品| 欧美一区二区网站| 欧美四级电影网| 色狠狠桃花综合| www.亚洲色图| 成人午夜电影久久影院| 国产一区二区三区最好精华液| 日韩中文字幕亚洲一区二区va在线 | 国产精品国产三级国产aⅴ原创| 欧美电影免费观看高清完整版在 | 亚洲色图清纯唯美| 久久免费美女视频| 亚洲影视在线观看| 亚洲免费观看高清完整版在线| 国产精品免费视频观看| 国产精品免费人成网站| 国产精品九色蝌蚪自拍| 国产精品亲子伦对白| 国产精品久久久久9999吃药| 国产精品私人自拍| 中文字幕一区二区三区乱码在线| 国产精品女主播av| 亚洲人成电影网站色mp4| 亚洲欧美欧美一区二区三区| 亚洲精品乱码久久久久久日本蜜臀| 中文字幕在线一区免费| 亚洲精品成人精品456| 一区二区三区四区国产精品| 亚洲综合激情另类小说区| 亚洲一区在线播放| 日韩成人精品在线| 精品伊人久久久久7777人| 精品在线观看免费| 国产二区国产一区在线观看| 成人动漫在线一区| 日本精品视频一区二区| 欧美日韩国产高清一区| 精品卡一卡二卡三卡四在线| 国产偷国产偷亚洲高清人白洁| 中文字幕中文乱码欧美一区二区| 亚洲免费观看高清完整版在线| 亚洲国产美女搞黄色| 蜜臀va亚洲va欧美va天堂 | 国产精品久久久久三级| 伊人一区二区三区| 日韩国产在线观看一区| 国产一区二区三区在线观看免费视频 | 久久精品视频在线免费观看| 亚洲欧洲日本在线| 亚洲成人av中文| 狠狠狠色丁香婷婷综合久久五月| jiyouzz国产精品久久| 欧美色电影在线| 亚洲bt欧美bt精品777| 久久精品72免费观看| 成人app在线观看| 91.麻豆视频| 国产精品每日更新| 免费在线成人网| 99精品桃花视频在线观看| 制服丝袜成人动漫| 国产精品乱码人人做人人爱| 亚洲成人在线观看视频| 九色综合狠狠综合久久| 色综合久久99| 国产亚洲美州欧州综合国| 午夜天堂影视香蕉久久| 国产99久久久国产精品免费看| 欧美日韩黄色一区二区| 国产精品久久久久久久久免费丝袜| 午夜精品久久久久久| av一本久道久久综合久久鬼色| 91精品国产综合久久香蕉的特点 | 另类中文字幕网| 色美美综合视频| 久久久精品一品道一区| 图片区小说区国产精品视频| 丁香六月综合激情| 日韩精品在线一区二区| 亚洲自拍欧美精品| 成人av电影免费在线播放| 日韩视频一区二区三区| 亚洲一区二区三区视频在线播放| 国产成人免费高清| 精品乱码亚洲一区二区不卡| 午夜精品视频在线观看| 日本乱人伦一区| 亚洲天堂免费在线观看视频| 国产69精品久久99不卡| 欧美精品一区二区三区视频| 婷婷久久综合九色综合伊人色| 色婷婷精品久久二区二区蜜臂av| 亚洲国产精品传媒在线观看| 国产综合色精品一区二区三区| 欧美人妖巨大在线| 亚洲一二三区不卡| 色狠狠色噜噜噜综合网| 1区2区3区精品视频| 成人国产精品免费网站| 国产日韩欧美麻豆| 国产91精品露脸国语对白| 久久精品人人做| 国产一区视频在线看| 精品国产91亚洲一区二区三区婷婷 | 午夜天堂影视香蕉久久| 欧美日韩在线一区二区| 亚洲午夜精品久久久久久久久| 91年精品国产| 又紧又大又爽精品一区二区| 91蜜桃免费观看视频| 日韩一区在线播放| 色综合久久久久久久久| 亚洲一级二级在线| 欧美三级电影一区| 视频一区视频二区中文| 日韩视频免费观看高清完整版 | 激情国产一区二区| 精品久久人人做人人爱| 国产一区二区在线影院| 国产农村妇女毛片精品久久麻豆| 国产成人小视频| 国产精品九色蝌蚪自拍| 色婷婷综合久久久久中文一区二区| 日韩毛片高清在线播放| 欧美最新大片在线看| 日韩高清不卡一区二区| 精品国产一区久久| 北条麻妃国产九九精品视频| 亚洲天堂免费看| 91麻豆精品久久久久蜜臀| 黄网站免费久久| 中文字幕日韩一区| 欧美日韩国产小视频在线观看| 日本v片在线高清不卡在线观看| 精品蜜桃在线看| 9久草视频在线视频精品| 亚洲一区二区精品久久av| 日韩欧美第一区| 不卡在线视频中文字幕| 亚洲va韩国va欧美va精品| 精品精品国产高清a毛片牛牛|