NR PDCP(一) overview

news2025/1/11 22:52:21

cd9b0cf7b391474bb4cc822508364c39.png

 这篇开始理下NR PDCP的内容,上图是38.300有关PDCP的服务和功能概括截图。PDCP功能包括对user plane或control plane data的传输;维护PDCP SN;使用ROHC和EHC协议进行header压缩和解压缩;加密(防止窃听)和解密;完整性保护和完整性验证(确保数据的正确性);对split bearers进行路由。

NR系统对数据的重排序功能由RLC层全部迁移到PDCP层,由PDCP层负责执行重排序功能,保证向高层进行按序递交;但是,如果某些场景需要按序传输时,就可以交由PDCP实现。在NR场景中很多时候,数据包的快速交付比按序传输更重要,PDCP层还支持乱序递交配置,一旦开启了该配置,则PDCP层不对数据进行重排序,直接将PDCP SDU立即递交给高层。乱序递交配置应用于对时延特别敏感的业务或者一些有特殊需求的业务。PDCP支持重传,其操作类似于RLC ARQ ,只是不支持分段。 PDCP会将一个count与每个SDU相关联,count是PDCP sn和HFN的组合。count用于识别丢失的 SDU以及请求重传;如果配置了reordering,则在传送到上层之前要将收到的SDU进行重新排序在送到上层。 reordering在处理buffer中的SDU时,需要将lower count的SDU有序传输到上层后,之后才能传递higher count的SDU。 PDCP还可以为每个 PDCP SDU 配置discard timer;当discard timer expires时,相应的 SDU 会被丢弃不进行传输;当然对重复的data也需要进行丢弃操作。另外重复传输是NR为应对低时延高可靠性传输需求引入的一项重要技术,详见NR PDCP duplication。

由于PDCP不允许COUNT在DL和UL中出现wrap around,因此需要网络侧具体实现来防止上述现象发生,例如,通过release和添加相应的RB或通过full configuration(38.331 5.3.5.11)避免。

2b358816ad1142c3aa1f28922e62f359.png

 上图是PDCP 子层的一种可能结构。

b01f4b51a07542c794a692e8a704f307.png

 PDCP需要根据RRC层参数配置。 PDCP用于将RB映射到 DCCH、DTCH、SCCH 和 STCH 类型的逻辑信道,PDCP不会用于除上述4种逻辑信道外的其他逻辑信道。

每个RB(除Uu interface的SRB0外)会与一个 PDCP entity相关联。 基于RB特性(例如单向/双向或split/non-split)或 RLC mode的不同,每个PDCP entity可能会与1/2/3/4/6/8个 RLC entity相关联,具体如下:

(1)split bearers,每个PDCP entity会于与两个 UM RLC entity(同一方向)、四个UM RLC entity(每个方向对应两个RLC entity)或两个 AM RLC entity相关联;

(2)对于配置有 PDCP duplication的RB,每个 PDCP entity会与 N UM RLC entity(相同方向)、2 × N UM RLC entity(每个方向对应N个)或 N 个AM RLC entity相关联,其中 2 <= N <= 4;详见PDCP duplication描述。

(3)对于 DAPS bearers,每个PDCP entity会与两个 UM RLC entity(同一方向上,一个用于source小区,一个用于target小区),四个UM RLC entity(source小区和target小区每个方向对应2个),或2个AM RLC entity(一个用于source小区,一个用于target小区);

(4)其他情况,每个 PDCP entity与一个 UM RLC entity、两个 UM RLC entity(每个方向各1个)或一个AM RLC entity相关联。

上面这段UM RLC entity和AM RLC entity的数量关系,可能看起来会比较迷惑,就拿(4)来说,正常情况下,一个PDCP entity只要关联一个AM RLC entity(不考虑方向),而却可能关联 1~2个UM RLC entity(考虑方向)?接着看下面这段RLC中的描述。

76b6bc62faa94552aafa506b946da5ba.png

 UM RLC entity可以被配置为transmitting UM RLC entity或receiving UM RLC entity。 transmitting UM RLC entity从PDCP 接收 RLC SDU,并通过MAC将 RLC PDU 发送到其对等 receiving UM RLC entity。 receiving UM RLC entity将 RLC SDU 传送到PDCP,并通过MAC从其对等传输 transmitting UM RLC entity接收RLC PDU。

AM RLC entity由transmitting side和receiving side组成。 AM RLC entity的transmitting side从PDCP接收 RLC SDU,并通过MAC将 RLC PDU 发送到其对等 AM RLC entity。 AM RLC entity的receiving side将RLC SDU传送到PDCP,并通过MAC从其对等AM RLC entity接收RLC PDU。

从上面这段话可以看出,UM RLC entity的UL和DL传输是分别需要transmitting UM RLC entity和receiving UM RLC entity,分别对应UL和DL,也就是2个UM RLC entities;而AM RLC entity由transmitting side和receiving side组成,也就是一个AM RLC entity就可以完成UL 和DL 的传输。

换而言之,对于UM mode ,进行UL和DL传输,是需要2个UM RLC entities的,分别进行UL和DL传输,而AM mode,只需要一个AM RLC entity就可以完成UL和DL传输。

如上面的截图38.322里就这样写的,我也就这么一说,具体实网中的几个SRB 和DRB的配置放在这里。

07431ecb0e704c12a6d0f3ccff5a92b1.png

 51751756ddf4450696c47260d7c1e85e.png

 除此之外R16之后的版本增加了sidelink的内容,除了Uu口外,UE之间还可以通过PC5 interface实现通信,sidelink的简单图示如下。

b247752ccf9a4ce191e69cf888d82574.png

 

PC5 interface是车的模组和车、路侧设备、人交互的接口。使用V2X业务的UE之间用户面进行D2D

(Device to Device)直接通信的接口。PC5可以作为没有无线网络覆盖时直接车车通信的途径,因而uu 和PC5可以共存。

当UE处于NG-RAN 覆盖范围内时,无论UE处于哪种 RRC 状态或者当UE 处于 NG-RAN 覆盖范围之外时,都支持通过PC5 interface进行的sidelink传输和接收。

668306df6afb4993ad18172b65248923.png

 

NR sidelink PC5 UE间通信相关架构图示如上,和常规的架构一样,PDCP介于RRC和RLC之间。

3340710fbac2462381b1afffdb91e4dd.png

 

为了支持5G ProSe UE-to-Network Relay(U2N Relay)功能,R17 引入Sidelink relay,以便为U2N remote UE提供网络连接;L2 U2N Relay架构的用户面和控制面的协议栈图示如上,这里PDCP和RLC之间多了个SRAP sublayer,主要用于Uu relay RLC和 PC5 relay RLC之间承载的映射。

98ce86a2b7484e27a3eb909b12993a0f.png

具体地说,PDCP entity位于PDCP子层。 可以为UE定义多个PDCP entity。 每个PDCP entity负责传输一个RB的data。PDCP entity可以与control plane或user plane相关联,具体取决于PDCP关联的是SRB还是DRB。

下图是PDCP entity的功能图;对于split bearer和DAPS bearer在发送数据时,需要发送PDCP entity进行data routing。

与DRB关联的PDCP entity可以根据RRC配置使用headerCompression,接收端可以配置具有相应解压缩功能的headerCompression,以便减少传输的bit数,这种机制特别适用于小负载,例如 IP 语音和 TCP确认场景。R16之后版本的PDCP支持ROHC和EHC的header压缩协议。header压缩是为了压缩 IP数据包而开发的,因此,它仅应用于数据部分,而不应用于 SDAP header和SDAP Control PDU。值得注意的是,每个header compression协议会针对DRB进行独立配置。

b06f98d98cdb49b59a902dbd604e27d3.png

 

下面是headerCompression IE的解释,

d56f8bc9a0644dc99b2ea889333d0f2a.png

 headerCompression:如果配置了 rohc,则 UE 应在UL和DL中应用配置的 ROHC 配置文件。 如果配置了uplinkOnlyROHC,UE 应在UL中应用配置的 ROHC 配置文件,在DL就不需要headerCompression。 ROHC 可以为任何RB配置。而ROHC和EHC可以同时为一个DRB 配置。 网络仅在涉及 PDCP重建的重配置时才会重新配置 headerCompression,并且不会配置任何drb-ContinueROHC。 当配置outOfOrderDelivery 时,网络会将headerCompression 配置为notUsed。 

drb-ContinueROHC:指示 PDCP entity在 PDCP 重建期间是继续还是重置ROHC 标头压缩协议。 该字段仅在恢复 RRC 连接或reconfiguration with sync的情况下配置,同时PDCP终止点未更改且未指示fullConfig的情况。 如果承载被配置为DAPS承载,则网络在配置时不包括该字段。

2a443784e5e1458a8eed23890d2ba56e.png

 另外,上面提到的DAPS HO属于NR 移动性增强的内容,为了减少HO期间中断时间而提出的解决方案,在DAPS HO中,UE 在会持续从source gNB接收DL data直到release source cell,在上行也会继续发送UL data直到成功完成target gNB的RA。对于 DAPS HO 来说,当收到HO command 时 UE 应该创建一个target cell 的MAC entity;对于target 建立RLC entity 及相关DTCH logical channel;对于DRB , 对于source 和target 应该配置独立的PDCP entity及ROHC RLC entity;保持剩余的source 配置,直到release掉source。当HO失败时,如果源链路仍然有效,则UE可以使用源链路进行恢复而不是重建。

上图对应的就是DAPS bearer关联的PDCP entity的功能图;参照上面的描述,对于DAPS Bearer,PDCP entity就需要配置两套安全功能和密钥,两套header compression协议用于source和target cell的传输。

0a3dbd1745c44ee4bd04fc96266a1117.png

 

PDCP层向RRC或SDAP 层提供服务包括用户和控制平面数据的传输;header compression,加密及完整保护。

PDCP SDU支持的最大size为9000 bytes, PDCP control PDU 的支持的最大size也为9000 bytes。

dcf6b082572f4499b786d9e0a7afd306.png

 PDCP entity需要RLC entity提供的service包括AM mode的数据传输,在成功传输PDCP PDU后需要反馈成功指示;UM mode数据传输服务。

 

最后一部分看下加密解密和完整性保护的内容。

 

Ciphering and deciphering

3f54efd07322433c826c719b84e1bd50.png

 加密是保护数据的重要手段。加密的作用是保障信息被截获后不能获取其内容,从而保护数据的隐秘性。加密功能包括加密和解密两部分。在加密功能被激活后,发送端根据每个PDCP data SDU对应的COUNT值和上层指定的加密算法及密钥对其对应的PDCP data PDU进行加密。接收端接收到PDCP数据PDU后,首先确定该PDU对应的COUNT值,然后采用上层指定的算法和密钥进行解密。需要加密的内容是MAC-I和PDCP data PDU(除了SDAP header和SDAP control PDU)。加密功能不应用于PDCP control PDU。

PDCP实体所使用的加密算法和密钥由高层RRC进行配置,加密功能由RRC消息激活。在安全性激活后,加密功能就可以用于上层指示的所有DL/UL的PDCP data PDU。

09cef8b8e6ea45819032d643451c4573.png

 

PDCP加密所需要的参数包括COUNT值、数据传输方向。加密算法根据这些参数对数据进行加密/解密操作。

需要高层提供的参数包括Bearer(取值由RB id减1得到)和加密密钥(用于控制平面和用户平面的完整性保护密钥分别为KRRCenc和KUPenc)。

9f48222375e04362a64eac35c75b9958.png

 

对于 DAPS bearers,要基于PDCP SDU 的去向决定,例如和source cell进行传输,就用source cell的加密算法和密钥对 PDCP SDU 执行;与target cell进行传输,就要用为target cell配置的加密算法和密钥对 PDCP SDU 执行。

c8f6c340749b4db9b3e4559de4fe3d1a.png

 NR sidelink,PDCP实体使用的加密算法和密钥由NAS进行配置,通过RRC消息激活PC5 unicast link的sidelink SRBs或DRBs的加密功能。作为加密和解密算法所需的输入包括 KEY (NRPIK)、COUNT、BEARER和 DIRECTION。加密和节目不用于MRBs和sidelin SRB4。

 

Integrity protection and verification

7efae22cd71445dc8985512805b93927.png

PDCP层执行的完整性保护功能包括完整性保护和完整性验证。完整性保护对PDCP PDU中未经加密的data部分以及PDCP PDU header进行保护。完整性保护对于SRB的PDCP data PDU总是开启,也可以用于DRB的PDCP data PDU,但不用于PDCP control PDU;同时也适用于sidelink SRB1 SRB2和SRB3。但是完整性保护和验证不用于MRBs和sidelin SRB4。

921546fd566b4e5c811c7491e05ca529.png

 在完整性保护功能激活后,发送端根据完整性保护算法计算出SRB/DRB对应的每个PDCP PDU的消息验证码(MAC-I),并将MAC-I填充在PDCP PDU对应的MAC-I域中,如上图示。在接收端接收到该PDCP PDU时,基于相应的输入参数计算出一个X-MAC,通过比较X-MAC与MAC-I是否一致来验证所接收PDCP PDU的完整性。如果计算得到的X-MAC与接收到的MAC-I一致,那么证明接收到的数据是完整的、没有被篡改的,否则向高层指示完整性验证失败。

4cb6c0886b284f069f8bb32ce0f966be.png

 PDCP实体使用的完整性保护算法和密钥由RRC进行配置,并通过RRC消息激活。在安全性激活后,完整性保护功能将应用到所有UL/DL的PDU,包括用于激活完整性保护的PDU在内。用于激活完整性保护的RRC消息本身采用该消息所携带的完整性保护配置进行完整性保护。因此,在对该消息进行完整性验证之前应该先将其发送给RRC实体,由RRC对该消息进行解码,然后PDCP实体根据RRC提供的完整性保护配置信息完成对消息的完整性验证。

PC5-S message也是同样的道理。

d08a1e00d2c6494f979e483a2390e396.png

 PDCP完整性保护所需要输入的参数包括COUNT值和data传输方向,完整性保护算法根据这些参数执行对数据的完整性保护。需要RRC提供的参数包括Bearer(取值由RB id减1得到)和完整性保护密钥-Key(用于控制平面和用户平面的完整性保护密钥分别为KRRCint和KUPint)。

0d2dcec6360e45c68a7d88836a886f13.png

 对于 DAPS bearers,要基于PDCP SDU 的去向决定,例如和source cell进行传输,就用source cell的完整性保护算法和密钥对 PDCP SDU 执行完整性保护或验证;与target cell进行传输,就要用为target cell配置的完整性保护算法和密钥对 PDCP SDU 执行完整性保护或验证。

85cf660c9d5f4a54bac41b4d0c257b26.png

 NR sidelink,PDCP实体使用的完整性保护算法和密钥由NAS进行配置,通过RRC消息激活PC5 unicast link的sidelink SRBs或DRBs的完整性保护功能。

对于需要进行完整性保护和验证的SLRB,作为完整性保护算法所需的输入包括 KEY (NRPIK)、COUNT、BEARER和 DIRECTION .

至此本篇结束下一步仍然会对PDCP相关的参数,变量及结构做一个总结,方便后续查看,然后会优先看下38.323中有关data transfer过程的描述,至于其他部分有时间慢慢再说。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/696476.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2、Redis7 十大数据类型(一)

命令官网 英文版&#xff1a;https://redis.io/commands/ 中文版&#xff1a;http://redis.cn/commands.html/ 1.1 类型说明 1.2 Key命令 命令不区分大小写&#xff0c;但是key区分 命令 说明 keys * //展示当前库的所有key exists key //判断某…

解决Word编号与标签之间间隙过大的问题

前言 今天在写文档时发现&#xff0c;当给标题设置中文编号&#xff08;一、二、三…&#xff09;后&#xff0c;编号与文字之间会产生一个非常大的间隙&#xff0c;使用的字体是“思源黑体M”&#xff0c;更换其他字体后依然如此&#xff0c;很不美观&#xff08;如图所示&am…

(二十二)数据符号化——矢量数据符号化②

数据符号化——矢量数据符号化② 目录 数据符号化——矢量数据符号化② 3.统计符号设置4.组合符号设置 3.统计符号设置 在 ArcMap 中可以使用符号系统来设置和定制地图元素的样式、颜色和标注。其中&#xff0c;统计符号可以用于表示一个或多个统计值的分布情况和趋势。 这是…

数据结构第六章 图 6.1-6.3 错题整理

6.1 6.C 加上一个点实现非连通 去除每个边都是一颗不同的生成树 一共n条边 13.C n个顶点、e条边的无向图&#xff0c;森林。树的角度看&#xff0c;除了根节点没有一条边与其对应&#xff0c;其他顶点都对应一条边&#xff0c;用顶点-边得出有多少颗树 14.A II 等于 也可以…

Git 分布式版本控制

Git概述 Git是分布式版本控制系统&#xff0c;可以快速高效地处理各种项目。具有廉价的本地库&#xff0c;方便的暂存区和多个工作流分支等特性。 版本控制目的&#xff1a;个人开发过渡到团队协作 分布式版本控制系统的优点&#xff1a; 1、服务器断网的情况下也可以…

DELL戴尔笔记本电脑Dell G5 15 5587原厂Win10系统镜像,原装OEM预装专用系统,恢复出厂状态

dell戴尔笔记本电脑&#xff0c;Dell G5 15 5587原厂Windows10系统镜像,原装OEM预装专用系统,恢复出厂状态 系统自带所有驱动、出厂主题壁纸LOGO、Office办公软件等预装程序 链接&#xff1a;https://pan.baidu.com/s/1Av93lwhHR16SRGJAf__NAg?pwdkqkc 提取码&#xff1a;kq…

maven官网下载,中央仓库官网,搜索官网

maven 官网 https://maven.apache.org/ maven 下载 https://maven.apache.org/ maven 各版本下载 maven中央仓库 https://repo.maven.apache.org/maven2/ maven 搜索jar文件版本 https://mvnrepository.com/ 阿里镜像官网&#xff0c; https://developer.aliyun.com/mirro…

iPhone手机如何添加桌面便签软件小组件?

iPhone手机的小组件功能受到了很多用户的喜爱&#xff0c;它可以让用户更加快捷的查看到APP里面的部分相关内容。这项功能和便签软件结合起来之后&#xff0c;甚至能产生1加1大于二的效果。那么iPhone手机如何添加桌面便签软件小组件呢&#xff1f;以iPhone手机端敬业签桌面便签…

Day 56 kMeans 聚类

代码&#xff1a; package dl;import java.io.FileReader; import java.util.Arrays; import java.util.Random; import weka.core.Instances;/*** kMeans clustering.*/ public class kMeans {/*** Manhattan distance.*/public static final int MANHATTAN 0;/*** Euclidea…

react中基于腾讯地图的地图选点,地址搜索逆向定位获取经纬度

react中基于腾讯地图的地图选点&#xff0c;地址搜索逆向定位获取经纬度 效果示例图地图组件tencentMap/index.jsx样式map.scss 使用案例 效果示例图 地图组件tencentMap/index.jsx import { useEffect, useRef, useState } from "react"; import "./map.scss&…

PHP函数、数组和错误处理:简单实用的开发技巧和错误处理方法

目录 PHP函数 函数的基本概念&#xff1a; 函数定义语法&#xff1a; 函数命名关系&#xff1a; 参数详解 形参 实参 ​编辑 默认值 引用传递 函数体 函数返回值 作用域 静态变量 可变函数 匿名函数 基本概念 闭包 伪类型 库函数 有关输出的函数 有关时间…

Linux守护进程详解、范例演示 ( 6 ) -【Linux通信架构系列 】

系列文章目录 C技能系列 Linux通信架构系列 C高性能优化编程系列 深入理解软件架构设计系列 高级C并发线程编程 期待你的关注哦&#xff01;&#xff01;&#xff01; 现在的一切都是为将来的梦想编织翅膀&#xff0c;让梦想在现实中展翅高飞。 Now everything is for the…

gitee 上传、下载代码

gitee push 代码 四步走 $ git add . $ git commit -m "修改了什么东西&#xff0c;改了哪个bug&#xff0c;加了一条long服务" $ git remote add origin https://gitee.com/666666666666666666.git $ git push -u origin master1. 先安装git &#xff0c;自行百度 …

大数据到底要学习一些什么内容

大数据本质上是海量数据。 以往的数据开发&#xff0c;需要一定的Java基础和工作经验&#xff0c;门槛高&#xff0c;入门难。 如果零基础入门数据开发行业的小伙伴&#xff0c;可以从Python语言入手。 Python语言简单易懂&#xff0c;适合零基础入门&#xff0c;在编程语言…

Spring Boot 中的 @CachePut 注解是什么,原理,如何使用

Spring Boot 中的 CachePut 注解是什么&#xff0c;原理&#xff0c;如何使用 简介 在 Spring Boot 中&#xff0c;CachePut 注解是用于缓存的注解之一&#xff0c;用于更新缓存中的数据。相比于 Cacheable 注解&#xff0c;CachePut 注解可以用于更新缓存中的数据&#xff0…

鞍山万象汇钢都夜巷3.0炫目回归——“钢刚好”遇见快乐

6月21日晚&#xff0c;鞍山万象汇钢都夜巷3.0市集快意回归&#xff0c;盛大启幕。在清爽宜人的晚风里、在热烈肆意的旋律中&#xff0c;这一场以快乐为基调的暑期市集&#xff0c;正式奏响钢都夏夜狂欢的乐章。汇聚多元场景&#xff0c;搜罗热门美食&#xff0c;消解盛夏酷暑&a…

VORS、CCDM模型、GeoDetector、GWR模型集成技术在城镇化与生态系统健康空间关系分析及影响效应中的应用

城市群是一国经济发展水平的象征&#xff0c;也是一国经济发展到一定阶段的标志&#xff0c;我国城市群建设体量不断增加&#xff0c;将成为全球经济的核心&#xff0c;中国城市群的建设逐步引领全球进入到了21世纪的中国新时代。然而&#xff0c;高速的城镇化发展&#xff0c;…

DBeaver使用ssh隧道远程连接

1&#xff0c;ssh 隧道的作用 SSH 隧道&#xff08;SSH tunnel&#xff09;是通过安全外壳协议&#xff08;SSH&#xff09;在公共网络上创建一个安全的通信通道的技术。它的作用是加密和保护数据通信&#xff0c;同时允许在不安全的网络环境中安全地传输数据。 以下是一些 SS…

《一步到位,走进一站式服务治理时代:Redis管理16个数据库的最佳实践》

目录 1. 我们为什么要使用Redis缓存数据库&#xff1f; 2. 关系型与非关系型数据库有哪些区别&#xff1f; 3. Redis中的缓存问题与解决方案&#xff1a;穿透、击穿、雪崩 4. 为什么要在一个项目中使用/管理16个数据库呢&#xff1f; 5. 使用16个数据库比使用1个数据库的…

OpenStack(T版)——网络(Neutron)服务介绍与安装

文章目录 OpenStack(T版)——网络(Neutron)服务介绍与安装安装和配置(controller)准备(1)创建数据库(2)加载admin user的环境变量(3)创建服务凭证 配置Neutron网络服务组件(1)安装软件(2)编辑文件/etc/neutron/neutron.conf&#xff0c;完成以下操作(3)配置Layer 2 (ML2)plug-i…