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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? irnet_ppp.c

?? 優龍2410linux2.6.8內核源代碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
/* *	IrNET protocol module : Synchronous PPP over an IrDA socket. * *		Jean II - HPL `00 - <jt@hpl.hp.com> * * This file implement the PPP interface and /dev/irnet character device. * The PPP interface hook to the ppp_generic module, handle all our *	relationship to the PPP code in the kernel (and by extension to pppd), *	and exchange PPP frames with this module (send/receive). * The /dev/irnet device is used primarily for 2 functions : *	1) as a stub for pppd (the ppp daemon), so that we can appropriately *	generate PPP sessions (we pretend we are a tty). *	2) as a control channel (write commands, read events) */#include "irnet_ppp.h"		/* Private header *//* Please put other headers in irnet.h - Thanks *//************************* CONTROL CHANNEL *************************//* * When a pppd instance is not active on /dev/irnet, it acts as a control * channel. * Writing allow to set up the IrDA destination of the IrNET channel, * and any application may be read events happening in IrNET... *//*------------------------------------------------------------------*//* * Write is used to send a command to configure a IrNET channel * before it is open by pppd. The syntax is : "command argument" * Currently there is only two defined commands : *	o name : set the requested IrDA nickname of the IrNET peer. *	o addr : set the requested IrDA address of the IrNET peer. * Note : the code is crude, but effective... */static inline ssize_tirnet_ctrl_write(irnet_socket *	ap,		 const char __user *buf,		 size_t		count){  char		command[IRNET_MAX_COMMAND];  char *	start;		/* Current command being processed */  char *	next;		/* Next command to process */  int		length;		/* Length of current command */  DENTER(CTRL_TRACE, "(ap=0x%p, count=%Zd)\n", ap, count);  /* Check for overflow... */  DABORT(count >= IRNET_MAX_COMMAND, -ENOMEM,	 CTRL_ERROR, "Too much data !!!\n");  /* Get the data in the driver */  if(copy_from_user(command, buf, count))    {      DERROR(CTRL_ERROR, "Invalid user space pointer.\n");      return -EFAULT;    }  /* Safe terminate the string */  command[count] = '\0';  DEBUG(CTRL_INFO, "Command line received is ``%s'' (%Zd).\n",	command, count);  /* Check every commands in the command line */  next = command;  while(next != NULL)    {      /* Look at the next command */      start = next;      /* Scrap whitespaces before the command */      while(isspace(*start))	start++;      /* ',' is our command separator */      next = strchr(start, ',');      if(next)	{	  *next = '\0';			/* Terminate command */	  length = next - start;	/* Length */	  next++;			/* Skip the '\0' */	}      else	length = strlen(start);      DEBUG(CTRL_INFO, "Found command ``%s'' (%d).\n", start, length);      /* Check if we recognised one of the known command       * We can't use "switch" with strings, so hack with "continue" */            /* First command : name -> Requested IrDA nickname */      if(!strncmp(start, "name", 4))	{	  /* Copy the name only if is included and not "any" */	  if((length > 5) && (strcmp(start + 5, "any")))	    {	      /* Strip out trailing whitespaces */	      while(isspace(start[length - 1]))		length--;	      /* Copy the name for later reuse */	      memcpy(ap->rname, start + 5, length - 5);	      ap->rname[length - 5] = '\0';	    }	  else	    ap->rname[0] = '\0';	  DEBUG(CTRL_INFO, "Got rname = ``%s''\n", ap->rname);	  /* Restart the loop */	  continue;	}      /* Second command : addr, daddr -> Requested IrDA destination address       * Also process : saddr -> Requested IrDA source address */      if((!strncmp(start, "addr", 4)) ||	 (!strncmp(start, "daddr", 5)) ||	 (!strncmp(start, "saddr", 5)))	{	  __u32		addr = DEV_ADDR_ANY;	  /* Copy the address only if is included and not "any" */	  if((length > 5) && (strcmp(start + 5, "any")))	    {	      char *	begp = start + 5;	      char *	endp;	      /* Scrap whitespaces before the command */	      while(isspace(*begp))		begp++;	      /* Convert argument to a number (last arg is the base) */	      addr = simple_strtoul(begp, &endp, 16);	      /* Has it worked  ? (endp should be start + length) */	      DABORT(endp <= (start + 5), -EINVAL,		     CTRL_ERROR, "Invalid address.\n");	    }	  /* Which type of address ? */	  if(start[0] == 's')	    {	      /* Save it */	      ap->rsaddr = addr;	      DEBUG(CTRL_INFO, "Got rsaddr = %08x\n", ap->rsaddr);	    }	  else	    {	      /* Save it */	      ap->rdaddr = addr;	      DEBUG(CTRL_INFO, "Got rdaddr = %08x\n", ap->rdaddr);	    }	  /* Restart the loop */	  continue;	}      /* Other possible command : connect N (number of retries) */      /* No command matched -> Failed... */      DABORT(1, -EINVAL, CTRL_ERROR, "Not a recognised IrNET command.\n");    }  /* Success : we have parsed all commands successfully */  return(count);}#ifdef INITIAL_DISCOVERY/*------------------------------------------------------------------*//* * Function irnet_read_discovery_log (self) * *    Read the content on the discovery log * * This function dump the current content of the discovery log * at the startup of the event channel. * Return 1 if written on the control channel... * * State of the ap->disco_XXX variables : *	at socket creation :	disco_index = 0 ; disco_number = 0 *	while reading :		disco_index = X ; disco_number = Y *	After reading :		disco_index = Y ; disco_number = -1 */static inline intirnet_read_discovery_log(irnet_socket *	ap,			 char *		event){  int		done_event = 0;  DENTER(CTRL_TRACE, "(ap=0x%p, event=0x%p)\n",	 ap, event);  /* Test if we have some work to do or we have already finished */  if(ap->disco_number == -1)    {      DEBUG(CTRL_INFO, "Already done\n");      return 0;    }  /* Test if it's the first time and therefore we need to get the log */  if(ap->disco_index == 0)    {      __u16		mask = irlmp_service_to_hint(S_LAN);      /* Ask IrLMP for the current discovery log */      ap->discoveries = irlmp_get_discoveries(&ap->disco_number, mask,					      DISCOVERY_DEFAULT_SLOTS);      /* Check if the we got some results */      if(ap->discoveries == NULL)	ap->disco_number = -1;      DEBUG(CTRL_INFO, "Got the log (0x%p), size is %d\n",	    ap->discoveries, ap->disco_number);    }  /* Check if we have more item to dump */  if(ap->disco_index < ap->disco_number)    {      /* Write an event */      sprintf(event, "Found %08x (%s) behind %08x {hints %02X-%02X}\n",	      ap->discoveries[ap->disco_index].daddr,	      ap->discoveries[ap->disco_index].info,	      ap->discoveries[ap->disco_index].saddr,	      ap->discoveries[ap->disco_index].hints[0],	      ap->discoveries[ap->disco_index].hints[1]);      DEBUG(CTRL_INFO, "Writing discovery %d : %s\n",	    ap->disco_index, ap->discoveries[ap->disco_index].info);      /* We have an event */      done_event = 1;      /* Next discovery */      ap->disco_index++;    }  /* Check if we have done the last item */  if(ap->disco_index >= ap->disco_number)    {      /* No more items : remove the log and signal termination */      DEBUG(CTRL_INFO, "Cleaning up log (0x%p)\n",	    ap->discoveries);      if(ap->discoveries != NULL)	{	  /* Cleanup our copy of the discovery log */	  kfree(ap->discoveries);	  ap->discoveries = NULL;	}      ap->disco_number = -1;    }  return done_event;}#endif /* INITIAL_DISCOVERY *//*------------------------------------------------------------------*//* * Read is used to get IrNET events */static inline ssize_tirnet_ctrl_read(irnet_socket *	ap,		struct file *	file,		char __user *	buf,		size_t		count){  DECLARE_WAITQUEUE(wait, current);  char		event[64];	/* Max event is 61 char */  ssize_t	ret = 0;  DENTER(CTRL_TRACE, "(ap=0x%p, count=%Zd)\n", ap, count);  /* Check if we can write an event out in one go */  DABORT(count < sizeof(event), -EOVERFLOW, CTRL_ERROR, "Buffer to small.\n");#ifdef INITIAL_DISCOVERY  /* Check if we have read the log */  if(irnet_read_discovery_log(ap, event))    {      /* We have an event !!! Copy it to the user */      if(copy_to_user(buf, event, strlen(event)))	{	  DERROR(CTRL_ERROR, "Invalid user space pointer.\n");	  return -EFAULT;	}      DEXIT(CTRL_TRACE, "\n");      return(strlen(event));    }#endif /* INITIAL_DISCOVERY */  /* Put ourselves on the wait queue to be woken up */  add_wait_queue(&irnet_events.rwait, &wait);  current->state = TASK_INTERRUPTIBLE;  for(;;)    {      /* If there is unread events */      ret = 0;      if(ap->event_index != irnet_events.index)	break;      ret = -EAGAIN;      if(file->f_flags & O_NONBLOCK)	break;      ret = -ERESTARTSYS;      if(signal_pending(current))	break;      /* Yield and wait to be woken up */      schedule();    }  current->state = TASK_RUNNING;  remove_wait_queue(&irnet_events.rwait, &wait);  /* Did we got it ? */  if(ret != 0)    {      /* No, return the error code */      DEXIT(CTRL_TRACE, " - ret %Zd\n", ret);      return ret;    }  /* Which event is it ? */  switch(irnet_events.log[ap->event_index].event)    {    case IRNET_DISCOVER:      sprintf(event, "Discovered %08x (%s) behind %08x {hints %02X-%02X}\n",	      irnet_events.log[ap->event_index].daddr,	      irnet_events.log[ap->event_index].name,	      irnet_events.log[ap->event_index].saddr,	      irnet_events.log[ap->event_index].hints.byte[0],	      irnet_events.log[ap->event_index].hints.byte[1]);      break;    case IRNET_EXPIRE:      sprintf(event, "Expired %08x (%s) behind %08x {hints %02X-%02X}\n",	      irnet_events.log[ap->event_index].daddr,	      irnet_events.log[ap->event_index].name,	      irnet_events.log[ap->event_index].saddr,	      irnet_events.log[ap->event_index].hints.byte[0],	      irnet_events.log[ap->event_index].hints.byte[1]);      break;    case IRNET_CONNECT_TO:      sprintf(event, "Connected to %08x (%s) on ppp%d\n",	      irnet_events.log[ap->event_index].daddr,	      irnet_events.log[ap->event_index].name,	      irnet_events.log[ap->event_index].unit);      break;    case IRNET_CONNECT_FROM:      sprintf(event, "Connection from %08x (%s) on ppp%d\n",	      irnet_events.log[ap->event_index].daddr,	      irnet_events.log[ap->event_index].name,	      irnet_events.log[ap->event_index].unit);      break;    case IRNET_REQUEST_FROM:      sprintf(event, "Request from %08x (%s) behind %08x\n",	      irnet_events.log[ap->event_index].daddr,	      irnet_events.log[ap->event_index].name,	      irnet_events.log[ap->event_index].saddr);      break;    case IRNET_NOANSWER_FROM:      sprintf(event, "No-answer from %08x (%s) on ppp%d\n",	      irnet_events.log[ap->event_index].daddr,	      irnet_events.log[ap->event_index].name,	      irnet_events.log[ap->event_index].unit);      break;    case IRNET_BLOCKED_LINK:      sprintf(event, "Blocked link with %08x (%s) on ppp%d\n",	      irnet_events.log[ap->event_index].daddr,	      irnet_events.log[ap->event_index].name,	      irnet_events.log[ap->event_index].unit);      break;    case IRNET_DISCONNECT_FROM:      sprintf(event, "Disconnection from %08x (%s) on ppp%d\n",	      irnet_events.log[ap->event_index].daddr,	      irnet_events.log[ap->event_index].name,	      irnet_events.log[ap->event_index].unit);      break;    case IRNET_DISCONNECT_TO:      sprintf(event, "Disconnected to %08x (%s)\n",	      irnet_events.log[ap->event_index].daddr,	      irnet_events.log[ap->event_index].name);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
另类成人小视频在线| 午夜精彩视频在线观看不卡| 加勒比av一区二区| 制服丝袜在线91| 久久精品国产久精国产| 久久久另类综合| 粗大黑人巨茎大战欧美成人| 国产精品每日更新| 欧美性受xxxx黑人xyx| 日韩黄色免费网站| 久久人人超碰精品| av电影在线观看一区| 亚洲国产精品久久人人爱| 日韩免费看网站| 成人午夜av电影| 日韩美女视频一区| 欧美剧在线免费观看网站| 精品一区二区三区在线播放视频| 国产色一区二区| 色视频一区二区| 久久99精品网久久| 亚洲三级电影网站| 91精品免费在线| 国产麻豆精品在线观看| 亚洲免费观看在线观看| 91精品国产91久久久久久一区二区| 国内精品第一页| 依依成人精品视频| 亚洲精品在线免费播放| 色又黄又爽网站www久久| 老司机精品视频线观看86 | 日韩在线播放一区二区| 久久嫩草精品久久久久| 欧美日韩国产一二三| 国产宾馆实践打屁股91| 性欧美大战久久久久久久久| 国产欧美日韩另类视频免费观看| 欧美色精品天天在线观看视频| 韩国理伦片一区二区三区在线播放| 亚洲男人的天堂一区二区| 欧美大片一区二区三区| 在线视频欧美精品| 高清不卡一区二区| 蜜臀久久99精品久久久画质超高清 | 91免费国产在线观看| 国内精品国产成人国产三级粉色| 亚洲中国最大av网站| 国产精品久久久久久亚洲毛片| 欧美一级片在线观看| 色婷婷亚洲综合| 成人va在线观看| 精品一区二区成人精品| 视频在线观看国产精品| 一区二区三区四区亚洲| 亚洲国产精品t66y| 欧美精品一区二区高清在线观看| 欧美网站大全在线观看| av一二三不卡影片| 国产精品一二三区在线| 精品亚洲成a人| 日韩影院在线观看| 亚洲最大成人网4388xx| 最新欧美精品一区二区三区| 2024国产精品视频| 2020日本不卡一区二区视频| 欧美一区二区三区四区高清| 欧美久久一二区| 91福利在线免费观看| 91尤物视频在线观看| 91无套直看片红桃| 91亚洲精华国产精华精华液| 不卡av电影在线播放| 国产成人福利片| 国产成人综合在线观看| 国产成人在线电影| 国产成人aaa| 懂色av一区二区三区免费看| 国产精品自在欧美一区| 国产福利一区在线观看| 夫妻av一区二区| 成人综合激情网| 97精品电影院| 在线欧美一区二区| 欧美日韩一区 二区 三区 久久精品| 欧美综合久久久| 欧美色综合影院| 日韩亚洲欧美一区二区三区| 日韩一级片网址| 欧美成人精品福利| 久久久另类综合| 国产精品久久久久久久久动漫| 国产精品网站一区| 亚洲小少妇裸体bbw| 日韩成人dvd| 久久99国产精品成人| 高清不卡一区二区在线| 色就色 综合激情| 欧美精品 日韩| 精品国产乱码久久久久久牛牛| 精品国产乱码久久久久久久久| 欧美激情在线看| 亚洲激情av在线| 日本一不卡视频| 国产激情视频一区二区三区欧美| 成人白浆超碰人人人人| 欧美日韩精品免费观看视频| 精品三级在线看| 国产精品毛片大码女人| 亚洲第一在线综合网站| 九色综合国产一区二区三区| av亚洲产国偷v产偷v自拍| 欧美日韩国产免费| 久久久国产午夜精品| 亚洲码国产岛国毛片在线| 美腿丝袜亚洲综合| 成人少妇影院yyyy| 欧美日韩成人综合在线一区二区 | 国产suv精品一区二区三区| 91麻豆国产在线观看| 欧美大片在线观看| 亚洲男人的天堂网| 韩国成人福利片在线播放| 91年精品国产| 久久久久成人黄色影片| 亚洲成av人片观看| 粉嫩av一区二区三区在线播放| 欧美日韩三级在线| 国产精品国产三级国产aⅴ原创| 亚洲一区在线观看免费 | 久久成人精品无人区| 94色蜜桃网一区二区三区| 精品人伦一区二区色婷婷| 亚洲免费在线电影| 国产精品亚洲人在线观看| 4438x成人网最大色成网站| 亚洲视频每日更新| 国产精品一线二线三线精华| 欧美日本精品一区二区三区| 中文字幕亚洲区| 国产精品原创巨作av| 日韩精品一区二区三区在线 | 在线成人高清不卡| 中文字幕视频一区| 国产成人一区在线| 精品国产一区二区三区久久久蜜月| 一区二区三区色| 97久久人人超碰| 国产欧美日韩三区| 国产麻豆9l精品三级站| 91精品国产综合久久婷婷香蕉| 亚洲永久精品大片| 色噜噜偷拍精品综合在线| 中文字幕一区二区三区色视频 | 99麻豆久久久国产精品免费 | 91丨porny丨在线| 国产精品美女一区二区三区 | 精品不卡在线视频| 奇米四色…亚洲| 欧美精品高清视频| 婷婷久久综合九色国产成人 | 欧美bbbbb| 337p亚洲精品色噜噜| 午夜激情一区二区| 欧美年轻男男videosbes| 婷婷综合久久一区二区三区| 欧美日韩三级一区二区| 亚洲午夜久久久久久久久电影院| 91看片淫黄大片一级在线观看| 1024精品合集| 色综合色综合色综合 | 国产日产欧美一区二区视频| 国产一区二区久久| 国产欧美综合在线观看第十页| 国产在线不卡一卡二卡三卡四卡| 精品福利二区三区| 韩国成人精品a∨在线观看| 久久久综合视频| 国产精品99久久久久久久女警 | 国产一区二区三区观看| 久久婷婷国产综合国色天香| 国产一区不卡在线| 久久综合丝袜日本网| 成人开心网精品视频| 亚洲欧美欧美一区二区三区| 在线观看视频欧美| 日韩精彩视频在线观看| 日韩欧美精品在线视频| 黄色小说综合网站| 国产精品乱人伦中文| 色妹子一区二区| 五月天欧美精品| 精品免费日韩av| 国产高清一区日本| 亚洲自拍偷拍网站| 日韩午夜在线观看视频| 国产成人av一区二区三区在线 | 中文字幕精品一区| 99国内精品久久| 三级影片在线观看欧美日韩一区二区 | 国产精品国产成人国产三级|