PPP驱动程序的基本原理.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
ppp驱动程序的基木原理 ppp设备是指在点对点的物理链路之间使用ppp帧进行分组交换的内核网络接口设备,由 于Linux内核将串行设备作为终端设备來驱动,于是引入PPP终端规程來实现终端设备与 PPP设备的接口.根据终端设备的物理传输特性的不同,PPP规程分为异步规程(N_PPP)和同 步规程(N_SYNC_PPP)两种,对于普通串口设备使用异步PPP规程. 在PPP驱动程序中,每一 tty终端设备对应于一条PPP传输通道(chanell),每一 ppp网络 设备対应于一个PPP接口单元(unit).从终端设备上接收到的数据流通过PPP传输通道解码 后转换成PPP帧传递到PPP网络接口单元,PPP接口单元再将PPP帧转换为PPP设备的接 收帧.反Z,当PPP设备发射数据帧时,发射帧通过PPP接口单元转换成PPP帧传递给PPP 通道,PPP通道负责将PPP帧编码后写入终端设备.在配置了多链路PPP时 (CONFIG_PPP_MULTILINK),多个PPP传输通道可连接到同一 PPP接口单元.PPP接口单元 将PPP帧分割成若干个片段传递给不同的PPP传输通道,反乙PPP传输通道接收到的PPP 帧片段被PPP接口单元重组成完整的PPP帧. 在Linux-2.4屮,应用程序可通过字符设备/dev/ppp监控内核PPP驱动程序.用户可以用 ioctl(PPPIOCATTACH)将文件绑定到PPP接口单元上,来读写PPP接口单元的输出帧,也可 以用ioctl(PPPIOCATTCHAN)将文件绑定到PPP传输通道上,来读写PPP传输通道的输入帧. PPP传输通道用channel结构描述,系统屮所有打开的传输通道在all_channels链表屮.PPP 接口单元用ppp结构描述,系统中所有建立的接口单元在all_ppp_units链表中.当终端设备 的物理链路连接成功后,用户使用ioctl(TIOCSETD)将终端切换到PPP规程.PPP规程初始化 时,将建立终端设备的传输通道和通道驱动结构.对于界步PPP规程來说,通道驱动结构为 asyncppp,它包含通道操作表async_ops.传输通道和接口单元各自包含自己的设备文件 (/dev/ppp)参数结构(ppp.file). ;drivers/char/tty_io.c: int tty_register_ldisc(int disc, struct ttyjdisc *new_ldisc) { if (disc N_TTY || disc = NR_LDISCS) return -EINVAL; if (newjdisc) { ldiscsfdiscl = *new」disc; ldiscs[disc].flags |= LDISC_FLAG_DEFINED; ldiscs[disc].num = disc; } else memset(ldiscs[disc], 0, sizeof(struct ttyjdisc)); return 0; int tty_ioctl(struct inode * inode, struct file * file, unsigned int cmd, unsigned long arg) { struct tty_struct *tty, *real_tty; int retval; tty = (struct tty_struct *)file-private_data; if (tty_paranoia_check(tty, inode-i_rdev, ntty_ioctlu)) return -EINVAL; real_tty = tty; if(tty-driver.type == TTY_DRIVER_TYPE_PTY tty-driver.subtype == PTY_TYPE_MASTER) real_tty = tty-link; switch (cmd) { ? ? ? case TIOCGETD: return put_user(tty-ldisc.num, (int *) arg); case TIOCSETD: return tiocsetd(tty, (int *) arg); ? ? ? } if (tty-drive匚ioctl) { int retval = (tty-driver.ioctl)(tty, file, cmd, arg); if (retval != -ENOIOCTLCMD) return retval; } if (tty-ldisc.ioctl) { int retval = (tty-ldisc.ioctl)(tty, file, cmd, arg); 讦(retval != -ENO

文档评论(0)

ggkkppp + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档