- 1、本文档共5页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
模擬以太帧的发送过程
基于Linux的Ethernet桢的发送过程模拟
2007-09-13 15:20
/*基于Linux的Ethernet桢的发送过程模拟
网络四班 彭华
*/
#include unistd.h /*包含类型pid_t的定义*/
#include stdio.h
#include sys/wait.h
#include sys/ipc.h
#include sys/shm.h
#include sys/types.h
#include error.h
#define ERROR_SHMGET -1
#define ERROR_SHMAT -2
#define ERROR_WAIT -3
#define ERROR_FORK -4
#define SLOT_TIME 51.2
/*截止二进制指数后退算法的实现
随机延迟重发.最典型的CSMA/CD后退延迟算法是截止二进制指数后退延迟算法,该算法可以表示为:
τ=2k?R?a .τ为结点重新发送需要的后退延迟时间,a为冲突窗口值,R为随机数;限定k的范围,k=min(n,10);如果重发次数n10,则取k=n;如果重发次数n≥10时,则k取值为10;第n次重发延迟是分布在0与[2min(n,10)-1]个时间片之间,最大可能延迟时间为1023 个时间片;在到后退延迟时间之后,重新判断总线忙、闲状态,重复发送流程;当冲突次数超过16时,表示发送失败,放弃该帧发送。
*/
static unsigned long get_backoff(const int n)
{
double exp_rand_slot;
unsigned long backoff;
int k = n;
k = 16 - k;
if(k 10)
{
k = 10;
}
exp_rand_slot = (1k)*random()*SLOT_TIME;/*slot time有的书译为“碰撞槽时间”是在局域网中传输一个帧的最小时间。若一个帧的传输时间超过了slot time都没有检测到冲突,则此站点的后续帧就永远不会再出现冲突的问题。而若一个帧的传输时间小于slot time则此站点就有可能在发完一个帧后检测不到可能存在的冲突。*/
backoff = ((unsigned long)exp_rand_slot)%1024;
return backoff;
}
/*发送数据流程*/
static void send_msg(const void *addr, const pid_t pid)
{
pid_t *shm_value = (pid_t *)addr;
int i;
int collision; //冲突计数器
for(i = 0; i 10; i++)
{
collision = 16;
do
{
while(*shm_value != 0); //总线不空闲,循环等待
usleep(SLOT_TIME); //延时51.2微秒
*shm_value|= pid; //将子进程的进程号与共享内存中的\数据作或运算,模拟发送数据
usleep(SLOT_TIME);
//判断是否冲突,共享内存与写入内存比较,若相同则无冲突,否则发生冲突.
if(*shm_value != pid)
{
*shm_value = 0; //复原总线为0
collision--;
if(collision 0)
{
printf(%d send collision.\n, pid);
usleep(get_backoff(collision)); //随机延时
}
else
{
printf(%d send failure.\n, pid); //发送失败
break;
}
}
else
您可能关注的文档
最近下载
- 资本主义的发展历程(萌芽、制度确立、扩展)课件+++2024年湖南省中考二轮专题复习.pptx VIP
- 施耐德电气 SD328B 步进电机驱动器 产品手册.pdf
- J B-T 8975-2006 低压信号灯-机械行业标准规范.pdf VIP
- 医保支付方式改革—DRG与DIP.pptx
- 《10kV电杆结构部分计算书》.doc
- 《艺术学概论》随堂测验1-9答案.docx VIP
- 银行业防火演练方案.docx VIP
- 中医病历模板(腰突5).doc VIP
- Long-Term-Development-in-Sport-and-Physical-Activity-3.0体育运动中的长期发展.pdf
- 2023年陕西投资集团有限公司校园招聘考试笔试题库及答案解析.docx
文档评论(0)