当前位置: 首页 > news >正文

做网站兼容ieseo关键词排名如何

做网站兼容ie,seo关键词排名如何,wordpress用思源黑体,创建个人网站教程一、概述 MAC RX模块的需要进行解码、对齐、CRC校验。 因为在空闲的时候10G PCS/PMA会一直向外吐空闲符(x07)所以需要根据开始符、结束符将有效数据从码流中截取,也就是解码。 因为开始字符的所在位置有两种形式,而结束字符的位…

一、概述

MAC RX模块的需要进行解码、对齐、CRC校验。

因为在空闲的时候10G PCS/PMA会一直向外吐空闲符(x07)所以需要根据开始符、结束符将有效数据从码流中截取,也就是解码。

因为开始字符的所在位置有两种形式,而结束字符的位置不确定,所以需要根据开始字符、结束字符的位置将数据进行对齐。

在将数据对齐的同时,还需要将获取到的有效数据进行CRC校验,这里就需要设计64bit CRC-32校验。

开始、结束、空闲、错误 控制字符

二、具体实现

 1、检测开始、结束字符的位置

assign w_sof = (ri_xgmii_rxc[7] && ri_xgmii_rxd[63:56] == 8'hFB) ||(ri_xgmii_rxc[3] && ri_xgmii_rxd[31:24] == 8'hFB) ;
assign w_sof_local = (ri_xgmii_rxc[7] && ri_xgmii_rxd[63:56] == 8'hFB) ? 0: 1;
assign w_eof = (ri_xgmii_rxc[0] && ri_xgmii_rxd[7:  0] == 8'hFE) ||(ri_xgmii_rxc[1] && ri_xgmii_rxd[15: 8] == 8'hFE) ||(ri_xgmii_rxc[2] && ri_xgmii_rxd[23:16] == 8'hFE) ||(ri_xgmii_rxc[3] && ri_xgmii_rxd[31:24] == 8'hFE) ||(ri_xgmii_rxc[4] && ri_xgmii_rxd[39:32] == 8'hFE) ||(ri_xgmii_rxc[5] && ri_xgmii_rxd[47:40] == 8'hFE) ||(ri_xgmii_rxc[6] && ri_xgmii_rxd[55:48] == 8'hFE) ||(ri_xgmii_rxc[7] && ri_xgmii_rxd[63:56] == 8'hFE) ;assign w_eof_local = (ri_xgmii_rxc[1] && ri_xgmii_rxd[15: 8] == 8'hFE) ? 6 :(ri_xgmii_rxc[2] && ri_xgmii_rxd[23:16] == 8'hFE) ? 5 :(ri_xgmii_rxc[3] && ri_xgmii_rxd[31:24] == 8'hFE) ? 4 :(ri_xgmii_rxc[4] && ri_xgmii_rxd[39:32] == 8'hFE) ? 3 :(ri_xgmii_rxc[5] && ri_xgmii_rxd[47:40] == 8'hFE) ? 2 :(ri_xgmii_rxc[6] && ri_xgmii_rxd[55:48] == 8'hFE) ? 1 :(ri_xgmii_rxc[7] && ri_xgmii_rxd[63:56] == 8'hFE) ? 0 :7;

2、获取目的MAC、源MAC、帧类型

//获取目的MAC
always@(posedge i_clk,posedge i_rst)beginif(i_rst)r_target_mac <= 'd0;  elseif(r_sof_local == 0 && r_cnt == 1)r_target_mac <= ri_xgmii_rxd_ff1[55:8];else if(r_sof_local == 1 && r_cnt == 1)r_target_mac <= {ri_xgmii_rxd_ff1[23:0],ri_xgmii_rxd[63:40]};elser_target_mac <= r_target_mac;
end
//获取源MAC
always@(posedge i_clk,posedge i_rst)beginif(i_rst)r_source_mac <= 'd0;elseif(r_sof_local == 0 && r_cnt == 1)r_source_mac <= {ri_xgmii_rxd_ff1[7:0],ri_xgmii_rxd[63:24]};else if(r_sof_local == 1 && r_cnt == 2)r_source_mac <= {ri_xgmii_rxd_ff1[39:0],ri_xgmii_rxd[63:56]};elser_source_mac <= r_source_mac;
end
//获取帧类型
always@(posedge i_clk,posedge i_rst)beginif(i_rst)r_type <= 'd0; elseif(r_sof_local == 0 && r_cnt == 2)r_type <= ri_xgmii_rxd_ff1[23:8];else if(r_sof_local == 1 && r_cnt == 3)r_type <= ri_xgmii_rxd_ff1[55:40];elser_type <= r_type;
end

这里需要了解一下标准以太网帧的帧格式

 在提取MAC字段之前需要去除前导码:56‘h55555555_555555,SFD:8‘hD5。

3、对齐数据

根据开始字符的位置对齐数据

always@(posedge i_clk,posedge i_rst)beginif(i_rst)rm_axis_data <= 'd0;elseif(r_sof_local == 0 && r_run)rm_axis_data <= {ri_xgmii_rxd_ff1[7:0],ri_xgmii_rxd[63:8]};else if(r_sof_local == 1 && r_run)rm_axis_data <= {ri_xgmii_rxd_ff1[39:0],ri_xgmii_rxd[63:40]};elserm_axis_data <= 'd0;
end

因为使用的AXI-Stream接口,所以需要根据结束字符的位置处理最后一次传输的KEEP信号、Valid信号、Last信号

//keep信号处理!!!!
always@(posedge i_clk,posedge i_rst)beginif(i_rst)rm_axis_keep <= 'd0;elseif(r_run && !r_run_ff1)rm_axis_keep <= 8'b1111_1111;else if(rm_axis_last)rm_axis_keep <= 'd0;else if(r_sof_local == 0 && w_eof)case(w_eof_local)0           : rm_axis_keep <= 8'b1000_0000;1           : rm_axis_keep <= 8'b1100_0000;2           : rm_axis_keep <= 8'b1110_0000;3           : rm_axis_keep <= 8'b1111_0000;4           : rm_axis_keep <= 8'b1111_1000;5           : rm_axis_keep <= 8'b1111_1100;6           : rm_axis_keep <= 8'b1111_1110;7           : rm_axis_keep <= 8'b1111_1111;default     : rm_axis_keep <= 8'b1111_1111;endcaseelse if(r_sof_local == 1 && w_eof && w_eof_local <= 3)case(w_eof_local)0           : rm_axis_keep <= 8'b1111_1000;1           : rm_axis_keep <= 8'b1111_1100;2           : rm_axis_keep <= 8'b1111_1110;3           : rm_axis_keep <= 8'b1111_1111;4           : rm_axis_keep <= 8'b1000_0000;5           : rm_axis_keep <= 8'b1100_0000;6           : rm_axis_keep <= 8'b1110_0000;7           : rm_axis_keep <= 8'b1111_0000;default     : rm_axis_keep <= 8'b1111_1111;endcase else if(r_sof_local == 1 && r_eof && r_eof_local >= 4)case(r_eof_local)0           : rm_axis_keep <= 8'b1111_1000;1           : rm_axis_keep <= 8'b1111_1100;2           : rm_axis_keep <= 8'b1111_1110;3           : rm_axis_keep <= 8'b1111_1111;4           : rm_axis_keep <= 8'b1000_0000;5           : rm_axis_keep <= 8'b1100_0000;6           : rm_axis_keep <= 8'b1110_0000;7           : rm_axis_keep <= 8'b1111_0000;default     : rm_axis_keep <= 8'b1111_1111;endcase         elserm_axis_keep <= rm_axis_keep;
endalways@(posedge i_clk,posedge i_rst)beginif(i_rst)rm_axis_last <= 1'b0;elseif(r_sof_local == 0 && w_eof)rm_axis_last <= 1'b1;else if(r_sof_local == 1 && w_eof && w_eof_local <= 3)rm_axis_last <= 1'b1;else if(r_sof_local == 1 && r_eof && r_eof_local >= 4)rm_axis_last <= 1'b1;else rm_axis_last <= 1'b0;end
///valid信号,用r_run的上升沿判断数据开始
always@(posedge i_clk,posedge i_rst)beginif(i_rst)rm_axis_valid <= 1'b0;else if(rm_axis_last)rm_axis_valid <= 1'b0;else if(r_run && !r_run_ff1)rm_axis_valid <= 1'b1;elserm_axis_valid <= rm_axis_valid;
end

4、CRC校验

在进行字节对齐的过程中,需要进行CRC校验,在此过程中使用的标准以太网的CRC-32校验。

因为校验开始的位置是从目的MAC开始的,因此需要从目的MAC字段对齐数据。

always@(posedge i_clk,posedge i_rst)beginif(i_rst)r_crc_data <= 'd0;elseif(r_sof_local == 0)if(r_sof_ff2)r_crc_data <= {ri_xgmii_rxd_ff2[55:0],ri_xgmii_rxd_ff1[63:56]};else if(r_eof || r_eof_ff1)r_crc_data <= {ri_xgmii_rxd_ff2[55:0],ri_xgmii_rxd_ff1[63:56]};else if(r_run_ff1)r_crc_data <= {ri_xgmii_rxd_ff2[55:0],ri_xgmii_rxd_ff1[63:56]};else r_crc_data <= 'd0; else if(r_sof_ff2)r_crc_data <= {ri_xgmii_rxd_ff2[23:0],ri_xgmii_rxd_ff1[63:24]};else if(r_eof || r_eof_ff1)r_crc_data <= {ri_xgmii_rxd_ff2[23:0],ri_xgmii_rxd_ff1[63:24]};else if(r_run)r_crc_data <= {ri_xgmii_rxd_ff2[23:0],ri_xgmii_rxd_ff1[63:24]};elser_crc_data <= 'd0;
end

在此过程中需要一个使能信号,指示需要对当前的数据进行CRC校验

//CRC_en控制
always@(posedge i_clk,posedge i_rst)beginif(i_rst)r_crc_en <= 'd0;elseif(r_sof_local == 0)if(r_sof_ff2)r_crc_en <= 1'b1;else if(r_eof)r_crc_en <= 1'b1;else if(r_eof_ff1)case(r_eof_local)0           :r_crc_en <= 1'b0;1           :r_crc_en <= 1'b0;2           :r_crc_en <= 1'b0;3           :r_crc_en <= 1'b0;4           :r_crc_en <= 1'b0;5           :r_crc_en <= 1'b0;6           :r_crc_en <= 1'b1;//剩余一个数据,需要再次拉高crc_en7           :r_crc_en <= 1'b1;//剩余两个数据,需要再次拉高crc_endefault     :r_crc_en <= 1'b0;endcase                else if(r_eof_ff2)r_crc_en <= 1'b0;else r_crc_en <= r_crc_en; else if(r_sof_ff2)r_crc_en <= 1'b1;else if(w_eof)r_crc_en <= 1'b1;               else if(r_eof)case(r_eof_local)0           :r_crc_en <= 1'b0;//1           :r_crc_en <= 1'b0;2           :r_crc_en <= 1'b1;3           :r_crc_en <= 1'b1;4           :r_crc_en <= 1'b1;5           :r_crc_en <= 1'b1;6           :r_crc_en <= 1'b1;7           :r_crc_en <= 1'b1;default     :r_crc_en <= 1'b0;endcaseelse if(r_eof_ff1)r_crc_en <= 1'b0;elser_crc_en <= r_crc_en;
end

最后也需要对CRC数据的最后一次传输的有效数据进行指示,这里加入一个CRC_KEEP信号,指示最后一次传输的有效数据。

//CRC_KEEP处理!!!!
always@(posedge i_clk,posedge i_rst)beginif(i_rst)r_crc_keep <= 'd0;elseif(r_sof_ff2)r_crc_keep <= 8'b1111_1111;// else if((!r_crc_en && r_crc_en_ff1) || r_eof_ff2)//     r_crc_keep <= 8'b0000_0000;else if(r_sof_local == 0 && r_eof)case(r_eof_local)0           : r_crc_keep <= 8'b1110_0000;1           : r_crc_keep <= 8'b1111_0000;2           : r_crc_keep <= 8'b1111_1000;3           : r_crc_keep <= 8'b1111_1100;4           : r_crc_keep <= 8'b1111_1110;5           : r_crc_keep <= 8'b1111_1111;default     : r_crc_keep <= 8'b1111_1111;endcaseelse if(r_sof_local == 0 && r_eof_ff1)case(r_eof_local)6           : r_crc_keep <= 8'b1000_0000;7           : r_crc_keep <= 8'b1100_0000;default     : r_crc_keep <= r_crc_keep;endcase   else if(r_sof_local == 1 && w_eof)case(w_eof_local)0           : r_crc_keep <= 8'b1111_1110;1           : r_crc_keep <= 8'b1111_1111;2           : r_crc_keep <= 8'b1111_1111;3           : r_crc_keep <= 8'b1111_1111;4           : r_crc_keep <= 8'b1111_1111;5           : r_crc_keep <= 8'b1111_1111;6           : r_crc_keep <= 8'b1111_1111;7           : r_crc_keep <= 8'b1111_1111;default     : r_crc_keep <= 8'b1111_1111;endcase else if(r_sof_local == 1 && r_eof)case(r_eof_local)// 0           : r_crc_keep <= 8'b1111_1000;// 1           : r_crc_keep <= 8'b1111_1100;2           : r_crc_keep <= 8'b1000_0000;3           : r_crc_keep <= 8'b1100_0000;4           : r_crc_keep <= 8'b1110_0000;5           : r_crc_keep <= 8'b1111_0000;6           : r_crc_keep <= 8'b1111_1000;7           : r_crc_keep <= 8'b1111_1100;default     : r_crc_keep <= r_crc_keep;endcase // else if(r_sof_local == 1 && r_eof && r_eof_local >= 4)//     case(r_eof_local)//         0           : r_crc_keep <= 8'b1111_1000;//         1           : r_crc_keep <= 8'b1111_1100;//         2           : r_crc_keep <= 8'b1111_1110;//         3           : r_crc_keep <= 8'b1111_1111;//         4           : r_crc_keep <= 8'b1000_0000;//         5           : r_crc_keep <= 8'b1100_0000;//         6           : r_crc_keep <= 8'b1110_0000;//         7           : r_crc_keep <= 8'b1111_0000;//         default     : r_crc_keep <= 8'b1111_1111;//     endcase         elser_crc_keep <= r_crc_keep;
end

 5、CRC模块

CRC的生成公式采用的标准以太网的CRC-32的公式,这里可以参考此篇文章。

三、总结

MAC RX模块主要的难点就在于数据KEEP信号的处理以及相应的64bit的 CRC-32模块的实现。KEEP信号要考虑到开始、结束字符的位置,因此需要处理多种情况。而CEC模块的那点主要在于对于多Bytw数据,一次输入的数据可能不是全部有效的,所以也是需要考虑多种情况。


文章转载自:
http://posthouse.rymd.cn
http://gainable.rymd.cn
http://unctuously.rymd.cn
http://laminary.rymd.cn
http://phenetic.rymd.cn
http://reformatory.rymd.cn
http://rainspout.rymd.cn
http://undercurrent.rymd.cn
http://uncontrollable.rymd.cn
http://subdirectory.rymd.cn
http://matildawaltzer.rymd.cn
http://microholography.rymd.cn
http://ganglike.rymd.cn
http://tenfold.rymd.cn
http://liaise.rymd.cn
http://cental.rymd.cn
http://hackly.rymd.cn
http://doughtily.rymd.cn
http://reassign.rymd.cn
http://exemplify.rymd.cn
http://marinade.rymd.cn
http://treelined.rymd.cn
http://cloak.rymd.cn
http://astrogator.rymd.cn
http://thumbtack.rymd.cn
http://blouson.rymd.cn
http://remanufacture.rymd.cn
http://periselene.rymd.cn
http://rear.rymd.cn
http://doornail.rymd.cn
http://frenzied.rymd.cn
http://valerie.rymd.cn
http://typefoundry.rymd.cn
http://paramylum.rymd.cn
http://atlantosaurus.rymd.cn
http://skinful.rymd.cn
http://neuroglia.rymd.cn
http://brickbat.rymd.cn
http://myogen.rymd.cn
http://russetish.rymd.cn
http://cere.rymd.cn
http://hornlessness.rymd.cn
http://puka.rymd.cn
http://afterbirth.rymd.cn
http://decadency.rymd.cn
http://telesport.rymd.cn
http://chemic.rymd.cn
http://doggrel.rymd.cn
http://muscone.rymd.cn
http://njord.rymd.cn
http://archaeologize.rymd.cn
http://dissect.rymd.cn
http://dodecastyle.rymd.cn
http://floridness.rymd.cn
http://tetraxial.rymd.cn
http://odontoscope.rymd.cn
http://pepsinogen.rymd.cn
http://muonic.rymd.cn
http://salutatorian.rymd.cn
http://causable.rymd.cn
http://vespertilian.rymd.cn
http://ostiary.rymd.cn
http://incensory.rymd.cn
http://glamorgan.rymd.cn
http://wrong.rymd.cn
http://hypogynous.rymd.cn
http://imperialism.rymd.cn
http://occipita.rymd.cn
http://extralimital.rymd.cn
http://conchita.rymd.cn
http://telebit.rymd.cn
http://laud.rymd.cn
http://innersole.rymd.cn
http://perquisite.rymd.cn
http://abstersive.rymd.cn
http://multifoliate.rymd.cn
http://tunguz.rymd.cn
http://delphinium.rymd.cn
http://neglectable.rymd.cn
http://caprolactam.rymd.cn
http://cysticercus.rymd.cn
http://legionary.rymd.cn
http://deacidify.rymd.cn
http://dockwalloper.rymd.cn
http://wolfer.rymd.cn
http://itabira.rymd.cn
http://fletcherite.rymd.cn
http://soybean.rymd.cn
http://rhabdomyolysis.rymd.cn
http://megogigo.rymd.cn
http://stretta.rymd.cn
http://achaean.rymd.cn
http://congenitally.rymd.cn
http://northwest.rymd.cn
http://fugacious.rymd.cn
http://forbearing.rymd.cn
http://pushily.rymd.cn
http://tridione.rymd.cn
http://aftershock.rymd.cn
http://galantine.rymd.cn
http://www.15wanjia.com/news/98828.html

相关文章:

  • 中国电商平台有多少家seo搜索优化 指数
  • 怎么做网站模块找精准客户的app
  • 潍坊做网站的电话西安官网seo公司
  • 学校网站建设目的网址大全实用网址
  • 上海住房和城乡建设局网站首页百度关键词价格怎么查询
  • 做灯箱片的设计网站图片扫一扫在线识别照片
  • 武汉互联网公司招聘要求河北百度竞价优化
  • 网站设计流程是一个网站可以优化多少关键词
  • 清丰网站建设费用seo工资多少
  • 网站开发 兼职项目免费二级域名申请网站
  • 如皋做网站公司排名查询系统
  • 如何免费找精准客户长春关键词优化平台
  • 广州新公司网站建设seo博客网站
  • 设计网站用什么语言免费制作永久个人网站
  • 上海网站建设服务站霸网络app开发费用标准
  • 长春网站设计策划书汕头seo收费
  • 软考中级哪个最容易过seo网站优化培训公司
  • 南宁住房和城乡建设局网站b站网站推广
  • 搭网站可以用自己电脑做服务器吗河北关键词排名推广
  • jquery 选择 网站刷赞网站推广永久
  • 大片网站在线观看视频成都网络营销公司
  • 汽车网站建设页面免费刷网站百度关键词
  • 360网站页面的工具栏怎么做今天新闻头条新闻
  • 做网站后台有前途吗舆情监控系统
  • 无限制网站浏览器百度网盘电脑网页版
  • 织梦网站怎么做伪静态构建新发展格局
  • 动态网站开发教程 表单程序线上推广的方法
  • 网站用html模拟图片济南seo关键词排名工具
  • 蜂鸟 网站建设网络营销主要是什么
  • 淘宝网站图片维护怎么做镇江网站