首页 > 其他分享 >SATA系列专题之二《2.2 Link layer链路层加扰/解扰/CRC解析》

SATA系列专题之二《2.2 Link layer链路层加扰/解扰/CRC解析》

时间:2024-11-05 15:43:55浏览次数:1  
标签:layer SATA SOF CRC 加扰 Link 资料

文章目录

 


前言

一、故事前传

我们之前说到Link layer的结构,link layer的作用大致可以包括以下几点:

  • Frame flow control

  • CRC的生成与检测

  • 对数据与控制字符的Scrmable/Descramble

  • 8b/10b编解码(已解析,详细见历史文章)

  • 将传输层进来的数据转为Frame

二、加扰(Scramble)/解扰(Descramble)

资料在进行8b/10b 编码之前,必须先行资料加扰(Scramble)的处理,目的是為了降低EMI(Electromagnetic Interference,电磁干扰)。 

 

实现方式是由LFSR(Linear Feedback Shift Register)的方式来实践;

基本原理是将资料的8 位元与LFSR 寄存器的16 位元输出做XOR 的处理。

 

  • 规定LFSR的初始值為0xFFFF,

  • LFSR必须在SOF标志前就要被初始化,

  • 在SOF与EOF之间的资料,包括CRC值都需要加扰。

  • 对于控制基元Primitive是不需要加扰的 。

 

SATA协议中资料处理流程如下 :

  1. 对于一个资料包,在SOF后的资料就必须计算其CRC值,同时这个资料必须和扰码器的输出进行XOR操作,操作结果送往8B/10B编码器编码;

  2. 反之,在接收方,资料先通过10B/8B解码,再与扰码器的输出结果进行XOR操作,最后计算资料的CRC值。

 

三、CRC(Cyclic Redundancy Check)循环冗余校验码

CRC的计算范围包括SOF和EOF之间的所有资料(即不包括控制基元),以Dword(32-bit)为单位,如果资料的内容不是Dword的整数倍,需要在资料包的后面用'0’来补充。

 

  • 协议规定CRC的初始值為0x52325032,

  • SOF和EOF之间的所有资料不能超过2064个Dwords

总结

 

标签:layer,SATA,SOF,CRC,加扰,Link,资料
From: https://www.cnblogs.com/FireLife-Cheng/p/18528133

相关文章

  • SATA系列专题之二《2.3 Link layer链路层 Frame结构以及Primitive基元解析》
    文章目录系列文章目录前言一、故事前传二、Frame结构解析二、Primitive基元解析总结 前言  一、故事前传我们之前说到Linklayer的结构,linklayer的作用大致可以包括以下几点:FrameflowcontrolCRC的生成与检测(已解析,详细见历史文章)对数据与控制......
  • SATA系列专题之三《3.0 Transport Layer传输层概述》
    系列文章目录文章目录前言一、故事前传二、SATATransportLayer传输层概述总结 前言 一、故事前传在之前的文章中,我们有提到SATA主要包括:应用层(ApplicationLayer),传输层(TransportLayer),链路层(LinkLayer)以及物理层(PhysicalLayer),SATA结构如下图:......
  • SATA系列专题之三:3.2 Transport Layer传输层FIS Retry机制解析
    一、故事前传在之前的文章中,已经解析了SATA协议的部分相关内容。较为详细解释请见之前的文章:1,浅析SATAPhysicalLayer物理层OOB信号;2,SATALinklayer链路层解析2.0-2.3;3,SATATransportlayer链路层解析3.0-3.1;我们这里主要解析TransportlayerFISRetry机制相关内容。......
  • SATA系列专题之三:3.3 Transport Layer传输层Flow Control机制解析
    一、故事前传在之前的文章中,已经解析了SATA协议的部分相关内容。较为详细解释请见之前的文章:1,浅析SATAPhysicalLayer物理层OOB信号;2,SATALinklayer链路层解析2.0-2.3;3,SATATransportlayer链路层解析3.0-3.2;我们这里主要解析TransportlayerFlowControl机制相关内容......
  • SATA系列专题之一《1.0 Physical Layer物理层OOB信号》
    文章目录前言一、SATA物理层概述二、OOB(OutofBand)信号解析三、实例解析总结前言一、SATA物理层概述说OOB之前,首先得了解一下SATA结构以及物理层的含义。SATA主要包括:应用层(ApplicationLayer), 传输层(TransportLayer),链路层(LinkLayer)、物理层(P......
  • 数据安全官CCRC-DSO:数据安全守护者
    在当今的信息化时代,数据已成为企业最宝贵的资产。然而,随着网络风险的不断上升和数据泄露事件的频繁发生,保障数据安全变得尤为关键。在这一背景下,数据安全官CCRC-DSO的角色变得至关重要。本文旨在探讨数据安全官CCRC-DSO在数据安全领域中的关键职责和影响力。数据安全官CCRC-D......
  • Openlayers高级交互(15/20):显示海量多边形,10ms加载完成
    本示例演示在vue+openlayers项目中通过WebGLVectorLayerRenderer方式加载海量多边形数据。这里相当于将海量的数据放在同一个层的source中,然后通过webglTile的方式渲染出这一层。本示例数据为5000个多边形,加载速度超级快。一、示例效果专栏名称内容介绍Openlay......
  • Openlayers高级交互(14/20):汽车移动轨迹动画(开始、暂停、结束)
    本示例演示在vue+openlayers中实现轨迹动画,这里设置了小汽车开始,暂停,结束等的控制键,采用了线段步长位置获取坐标来定位点的方式来显示小车的动态。效果图专栏名称内容介绍Openlayers基础实战(72篇)专栏提供73篇文章,为小白群体提供基础知识及示例演示,能解决基础......
  • 【深度学习】从公式推导来深入理解误差反向传播算法2:《深度学习入门基于Python的理论
    《深度学习入门基于Python的理论与实现》中实现了2层全连接神经网络的代码对MNIST数据集的28x28像素0-9手写数字灰度图像进行分类,本文将重点对代码中的two_layer_net类的gradient函数中的误差反向传播的代码进行公式推导验证。验证小批量数据的交叉熵损失函数对第2层权重......
  • CRC校验与ChekSum的概念与应用
    CRC(CyclicRedundancyCheck,循环冗余校验)和Checksum(校验和)是两种常用的数据完整性校验方法,主要用于检测在数据传输或存储过程中发生的错误。尽管它们的目的相似,但它们的计算方式和应用场景有所不同。1.CRC(循环冗余校验)概念CRC是一种基于二进制除法的错误检测码。它将数据......