CN115696435A - 网络编码场景下的超时丢包方法、装置及可读存储介质 - Google Patents

网络编码场景下的超时丢包方法、装置及可读存储介质 Download PDF

Info

Publication number
CN115696435A
CN115696435A CN202110874205.2A CN202110874205A CN115696435A CN 115696435 A CN115696435 A CN 115696435A CN 202110874205 A CN202110874205 A CN 202110874205A CN 115696435 A CN115696435 A CN 115696435A
Authority
CN
China
Prior art keywords
pdcp
packet
layer
packets
data
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN202110874205.2A
Other languages
English (en)
Inventor
刘菁
董朋朋
曹振臻
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Huawei Technologies Co Ltd
Original Assignee
Huawei Technologies Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Huawei Technologies Co Ltd filed Critical Huawei Technologies Co Ltd
Priority to CN202110874205.2A priority Critical patent/CN115696435A/zh
Priority to PCT/CN2022/107865 priority patent/WO2023005909A1/zh
Publication of CN115696435A publication Critical patent/CN115696435A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W28/00Network traffic management; Network resource management
    • H04W28/02Traffic management, e.g. flow control or congestion control
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W28/00Network traffic management; Network resource management
    • H04W28/02Traffic management, e.g. flow control or congestion control
    • H04W28/06Optimizing the usage of the radio link, e.g. header compression, information sizing, discarding information

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Mobile Radio Communication Systems (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

本申请涉及移动通信领域,可应用于LTE或NR等协议框架下,尤其涉及一种网络编码场景下的超时丢包方法、装置及可读存储介质,该方法包括:取消现有一个PDCP SDU关联一个定时器的机制,而为一组待编码的PDCP SDU/PDU关联一个定时器;当这个定时器超时后,丢弃这一组PDCP SDU/PDU,以及由这一组PDCP SDU/PDU进行网络编码后生成的系统包和冗余包,或者原数据包和冗余包。这样可以在接入层引入网络编码的情况下,丢弃已经QoS失效的数据包,减少QoS失效的数据包在空口上传输造成的资源浪费,提升空口传输的效率。本申请可以应用于扩展现实XR业务,或者,其他对时延有要求的业务。

Description

网络编码场景下的超时丢包方法、装置及可读存储介质
技术领域
本申请涉及通信技术领域,尤其涉及一种网络编码场景下的超时丢包方法、装置及可读存储介质。
背景技术
现有长期演进(long term evolution,LTE)或新一代无线接入技术(new radioaccess technology,NR/5G)系统中,业务的可靠性主要通过两种机制来保证:混合自动重传请求(hybrid automatic repeat request,HARQ)机制和自动重传请求(automaticrepeat request,ARQ)机制。但这两种重传机制都是基于反馈的重传机制,通常时延比较大,包括:空口传输时延、接收端的数据处理时延、应答(acknowledgment,ACK)/否定应答(negative-acknowledgment,NACK)信息的反馈时延等,从而导致这两种重传机制的系统频谱效率低。
因此,为了解决时延大和系统频谱效率低的问题,LTE或NR协议考虑在接入层(比如,分组数据汇聚协议(packet data convergence protocol,PDCP)层内,或,PDCP层和无线链路控制(radio link control,RLC)层之间新定义的协议层)引入网络编码(networkcoding,NC)技术,采用网络编码技术对数据包进行网络编码操作,通过传输经过网络编码操作得到的编码包来兼顾时延和频谱效率性能。
然而,由于现有NR PDCP层为了保障服务质量(quality of service,QoS)设置了基于discardTimer(丢弃定时器)的超时丢包机制,所以在接入层(如PDCP层,或PDCP层与RLC层之间新定义的协议层)引入网络编码后,如何进行超时丢包处理成为了亟待解决的问题。
发明内容
本申请实施例提供一种网络编码场景下的超时丢包方法、装置及可读存储介质,可以在LTE或NR的接入层引入网络编码的场景下,进行超时丢包处理,比如丢弃已经QoS失效(即discardTimer超时)的数据包,从而减少QoS失效的数据包传输或存储造成的资源浪费,提升空口传输或存储的效率。
下面从不同的方面介绍本申请,应理解的是,下面的不同方面的实施方式和有益效果可以互相参考。
第一方面,本申请提供一种网络编码场景下的超时丢包方法,该方法包括:通信装置(从上层)获取(比如,接收)一组待编码的原始数据,并为该组原始数据关联一个定时器;若与该组原始数据关联的定时器超时,说明这一组原始数据已经QoS失效,则通信装置丢弃以下中的至少一项:该组原始数据,该组原始数据进行网络编码功能的处理生成的多个第一数据包。其中,该组原始数据用于一起/共同进行网络编码功能的处理生成多个第一数据包。因为网络编码功能的处理可能生成系统包和冗余包,也可能生成原数据包和冗余包,所以这多个第一数据包包括系统包和冗余包,或者,这多个第一数据包包括原数据包和冗余包。应理解,具体网络编码功能的介绍以及原数据包、系统包、冗余包的含义参考下文具体实施例方式部分的描述,此处篇幅限制不展开说明。
应理解,网络中可能存在某些业务具有较高的时延要求,如果这些业务的数据包传输到PDCP层已超过时延要求或即将超过时延要求,也就没有传到下一层处理的必要,所以在PDCP层就可以删除收到的这些数据包,从而节省空口资源。
可选的,上述通信装置是终端设备,如UE;或上述通信装置是网络设备,如基站(gNB)。其中,基站可以采用集中式单元(central unit,CU)-分布式单元(distributedunit,DU)分离架构,也可以采用非CU-DU分离架构。
可见,本方案通过直接为一组待编码的原始数据关联一个定时器,当这个定时器超时后,就丢弃这一组原始数据和这一组原始数据进行网络编码功能的处理后生成的系统包和冗余包,或者原数据包和冗余包,从而可以在LTE或NR的接入层(如PDCP层内,或PDCP层与RLC层之间新定义的协议层)引入网络编码场景下,丢弃已经QoS失效的数据包,减少QoS失效的数据包在空口上传输造成的资源浪费,提升空口传输的效率。
第二方面,本申请提供一种通信装置,该通信装置可以是终端设备或终端设备中的芯片;或者,该通信装置还可以是网络设备或网络设备中的芯片。该通信装置包括:获取模块,用于获取一组原始数据,该组原始数据关联一个定时器;丢弃模块,用于若与该组原始数据关联的定时器超时,丢弃以下中的至少一项:该组原始数据,该组原始数据进行网络编码功能的处理生成的多个第一数据包。其中,该组原始数据用于一起/共同进行网络编码功能的处理生成多个第一数据包。这多个第一数据包包括系统包和冗余包,或者,这多个第一数据包包括原数据包和冗余包。
上述任一方面的一种实现方式中,上述网络编码功能包括分割,级联,加填充(padding)等处理中的一项或多项,可选的该网络编码功能还包括编码处理。其中,分割处理用于将一个服务数据单元(service data unit,SDU)/协议数据单元(protocol dataunit,PDU)分割成多个数据段,级联处理用于将一个SDU/PDU的全部或部分与另一个SDU/PDU的全部或部分级联成一个数据段。加填充处理用于对小于一定大小的数据段或SDU/PDU进行填充,使其等于该一定大小。每个数据段添加包头后获得等大小的原数据包,对这些等大小的原数据包进行编码,以期得到系统包和冗余包,或者,冗余包。
可见,本方案引入网络编码,将不等大小的SDU/PDU进行分割,级联,加填充(padding)等处理中的一项或多项,以期得到等大小的原数据包,再对这些等大小的原数据包进行编码,得到系统包和冗余包,或者,冗余包,可以使网络编码技术在不依赖于SDU/PDU大小的场景下获得应用。
上述任一方面的一种实现方式中,上述通信装置包括PDCP层。上述方法还包括:通信装置关闭通信装置的PDCP层中PDCP SDU与丢弃定时器的关联功能。可见,本方案通过为一组原始数据关联一个定时器,并关闭现有一个PDCP SDU关联一个定时器的机制,可以减少通信装置的复杂度。
上述任一方面的一种实现方式中,上述原始数据可以是从上层接收到的PDCP SDU或PDCP PDU,或者上述原始数据可以是PDCP SDU/PDU经过分割,级联,加填充(padding)等处理中的一项或多项后,再添加包头得到原数据包。也就是说,本方案既可以是为从上层接收到的一组PDCP SDU/PDU关联一个定时器,也可以是为一组原数据包关联一个定时器。
上述任一方面的一种实现方式中,上述通信装置包括PDCP层。当网络编码功能位于PDCP层内时,上述原始数据为PDCP SDU。
可选的,上述一组PDCP SDU对应上述多个第一数据包。一个第一数据包对应一个PDCP PDU,具体的,一个第一数据包加PDCP头后得到一个PDCP PDU,换句话说,一个PDCPPDU包括一个第一数据包和PDCP头。若与上述一组原始数据(这里是PDCP SDU)关联的定时器超时,通信装置不仅丢弃以下中至少一项:该组原始数据,该组原始数据进行网络编码功能的处理生成的多个第一数据包,还丢弃这一组PDCP SDU对应的多个PDCP PDU。
其中,一个PDCP PDU对应N个PDCP SDU,一个PDCP PDU包括的第一数据包是系统包或原数据包,则这个PDCP PDU包括的第一数据包的数据来自这N个PDCP SDU中的每个PDCPSDU;或,一个PDCP PDU包括的第一数据包是冗余包,则这个PDCP PDU包括的与第一数据包满足网络编码关系的原数据包来自这N个PDCP SDU中的每个PDCP SDU。应理解,此处描述的PDCP PDU与PDCP SDU的关系适用于本申请提供的网络编码功能位于PDCP层内的任一实现方式,下文不再重复说明。
可见,本方案在PDCP层内引入网络编码功能的场景下,不仅丢弃PDCP SDU和第一数据包,还丢弃相应的PDCP PDU,不仅可以解决在PDCP层内引入网络编码功能后导致的PDCP SDU和PDCP PDU不再一一对应时,如何丢弃已经QoS失效的SDU和PDU的问题;还可以减少已经QoS失效的PDCP PDU传输至下一层的概率,从而节省空口资源。
上述任一方面的一种实现方式中,上述通信装置包括PDCP层、NC层以及RLC层。其中NC层主要用于实现网络编码功能。当NC层位于PDCP层之下或RLC层之上(即高于RLC层)时,上述原始数据为PDCP PDU。
可选的,若与上述一组原始数据(这里是PDCP PDU)关联的定时器超时,通信装置不仅丢弃以下中的至少一项:该组原始数据,该组原始数据进行网络编码功能的处理生成的多个第一数据包,还丢弃这一组PDCP PDU对应的PDCP SDU。其中一个PDCP PDU对应一个PDCP SDU,具体地,一个PDCP SDU加PDCP头得到一个PDCP PDU。
可见,本方案在PDCP层之下或RLC层之上引入网络编码功能后,不仅丢弃PDCP PDU和第一数据包,还丢弃相应的PDCP SDU,可以减少PDCP层利用已经QoS失效的PDCP SDU生成PDCP PDU传输至下层(即NC层),减少无效操作。
可选的,上述通信装置是集中式单元或用于集中式单元的芯片,上述NC层可以位于PDCP层之下。通信装置对一组PDCP PDU进行网络编码功能的处理生成多个第一数据包后,将生成的该多个第一数据包发送给分布式单元。因此,若与上述一组原始数据(这里是PDCP PDU)关联的定时器超时,通信装置向分布式单元发送指示信息,该指示信息用于指示分布式单元丢弃该组原始数据进行网络编码功能的处理生成的多个第一数据包。其中,该指示信息中包括以下任一项:这多个第一数据包各自的标识,比如数据包标识(packetID);这多个第一数据包的标识所属的范围,比如packet ID范围;这多个第一数据包所属的编码块的标识,比如块标识(block ID);这多个第一数据包各自对应的编码系数因子的标识,比如系数标识(Coeff_ID)。相应地,分布式单元从通信装置接收指示信息,该指示信息用于指示分布式单元丢弃上述一组原始数据进行网络编码操作生成的多个第一数据包。分布式单元根据该指示信息的指示,丢弃该组原始数据进行网络编码操作生成的多个第一数据包。比如,指示信息中包括第一数据包的编号(如packet ID),分布式单元丢弃该编号所标识的第一数据包;指示信息中包括block ID,分布式单元丢弃接收到的第一数据包中block ID字段与该block ID相同的第一数据包,等等。可选的,如果第一数据包是原数据包,原数据包不包括编码系数因子的标识,则指示信息不能通过编码系数因子的标识来实现。
应理解,如果CU将某个第一数据包发送至DU后,CU的存储空间(比如缓存)中就不存在该第一数据包了,则CU上与生成该第一数据包的一组PDCP PDU关联的定时器超时且该第一数据包已经被发送至DU后,CU无需自己执行丢弃该第一数据包的操作,可以通过指示信息指示DU去丢弃这个第一数据包。反之,如果CU将某个第一数据包发送至DU后,CU的存储空间(比如缓存)中仍然存在这个第一数据包,则该第一数据包被发送至DU后,如果与生成该第一数据包的一组PDCP PDU关联的定时器超时,则CU不仅自己丢弃该第一数据包,还可通过指示信息指示DU也丢弃该第一数据包。
可见,本方案针对NC层位于PDCP层之下的情况,由于PDCP PDU封装在第一数据包内,导致RLC层无法直接看到PDCP PDU,从而无法沿用现有机制来丢弃已经QoS失效的数据包;所以CU通过指示信息来指示DU丢弃已经QoS失效的数据包,从而可以减少QoS失效的数据在空口发送造成的资源浪费,提升空口传输的效率。
可选的,上述通信装置是分布式单元或用于分布式单元的芯片,上述NC层可以位于RLC层之上。此时,CU向通信装置发送的是PDCP PDU。通信装置的NC层对一组PDCP PDU进行网络编码功能的处理生成多个第一数据包后,将生成的该第一数据包发送给下层(即RLC层)。因此,若与上述一组原始数据(这里是PDCP PDU)关联的定时器超时,通信装置的NC层指示RLC层丢弃传输至该RLC层的该第一数据包。这里的指示可以通过层间交互实现。
可见,本方案针对NC层位于RLC层之上的情况,DU从CU接收到一组PDCP PDU,为这一组PDCP PDU关联一个定时器,并对这一组PDCP PDU进行网络编码功能的处理生成多个第一数据包;当定时器超时后,丢弃这一组PDCP PDU以及第一数据包,并且还可以通过层间交互指示RLC层丢弃传输至该RLC层且已经QoS失效的数据包,可以减少QoS失效的数据在空口发送造成的资源浪费,提升空口传输的效率。
可选的,上述通信装置是终端设备或用于终端设备的芯片。上述通信装置包括PDCP层、NC层、以及RLC层,NC层位于PDCP层和RLC层之间。通信装置获取(比如,接收)一组原始数据后,该方法还包括:通信装置的NC层为这一组PDCP PDU关联一个定时器。若该组PDCPPDU关联的定时器超时,通信装置的NC层丢弃以下中的至少一项:该组PDCP PDU,该组PDCPPDU进行网络编码功能的处理生成的多个第一数据包。
可选的,上述通信装置是终端设备或用于终端设备的芯片。上述通信装置包括PDCP层、NC层、以及RLC层,NC层位于PDCP层和RLC层之间。通信装置将上述一组PDCP PDU进行网络编码功能的处理生成的全部或部分第一数据包传输至通信装置的RLC层后,如果与这一组PDCP PDU关联的定时器超时,则通信装置的NC层指示通信装置的RLC层丢弃传输至该RLC层的第一数据包。相应地,通信装置的RLC层丢弃从通信装置的NC层接收到的第一数据包。应理解,如果通信装置的NC层已经将这一组PDCP PDU进行网络编码功能的处理生成的部分第一数据包发送至RLC层,则通信装置的NC层可以指示RLC层删除发送至该RLC层的这部分第一数据包,也就是说未发送至RLC层的第一数据包不需要NC层指示RLC层删除。其中,NC层与RLC层之间的交互可以通过原语来实现。
可见,本方案针对NC层位于PDCP层和RLC层之间的情况,由于PDCP PDU封装在第一数据包内,导致RLC层无法直接看到PDCP PDU,从而无法沿用现有机制来丢弃已经QoS失效的数据包;UE通过层间交互(原语)示RLC层丢弃已经QoS失效的数据包,从而可以减少QoS失效的数据在空口发送造成的资源浪费,提升空口传输的效率。
第三方面,本申请提供一种网络编码场景下的超时丢包方法,该方法包括:通信装置(从上层)获取(比如,接收)原始数据,并对该原始数据进行网络编码功能的处理生成多个第一数据包,再为生成的每个第一数据包关联一个定时器;若与某个第一数据包(比如这多个第一数据包中的第一数据包i,为便于描述,下文以与第一数据包i关联的定时器超时为例进行说明)关联的定时器超时,则通信装置丢弃该第一数据包。其中,因为网络编码功能的处理可能生成系统包和冗余包,也可能生成原数据包和冗余包,所以这多个第一数据包包括系统包和冗余包,或者,这多个第一数据包包括原数据包和冗余包。应理解,具体网络编码功能的介绍以及原数据包、系统包、冗余包的含义参考下文具体实施例方式部分的描述,此处篇幅限制不展开说明。
可选的,上述通信装置是终端设备,如UE;或上述通信装置是网络设备,如基站(gNB)。其中,基站可以采用CU-DU分离架构,也可以采用非CU-DU分离架构。
可见,本方案通过为每个第一数据包关联一个定时器,当这个定时器超时后,就丢弃这个第一数据包,从而可以在LTE或NR的接入层(如PDCP层内,或PDCP层与RLC层之间新定义的协议层)引入网络编码场景下,丢弃已经QoS失效的数据包,减少QoS失效的数据包在空口上传输造成的资源浪费,提升空口传输的效率。
第四方面,本申请提供一种通信装置,该通信装置可以是终端设备或终端设备中的芯片;或者,该通信装置还可以是网络设备或网络设备中的芯片。该通信装置包括:编码模块,用于对原始数据进行网络编码功能的处理生成多个第一数据包,一个该第一数据包关联一个定时器;丢弃模块,用于若多个第一数据包中的第一数据包i关联的定时器超时,丢弃该第一数据包i。其中,这多个第一数据包包括系统包和冗余包,或者,这多个第一数据包包括原数据包和冗余包。
上述第三或第四方面的一种实现方式中,上述网络编码功能包括分割,级联,加填充(padding)等处理中的一项或多项,可选的该网络编码功能还包括编码处理。其中,分割处理用于将一个SDU/PDU分割成多个数据段,级联处理用于将一个SDU/PDU的全部或部分与另一个SDU/PDU的全部或部分级联成一个数据段。加填充处理用于对小于一定大小的数据段或SDU/PDU进行填充,使其等于该一定大小。每个数据段添加包头后获得等大小的原数据包,对这些等大小的原数据包进行编码,以期得到系统包和冗余包,或者,冗余包。
上述第三或第四方面的一种实现方式中,上述原始数据可以包括一个或多个从上层接收到的PDCP SDU或PDCP PDU,或者,上述原始数据包括PDCP SDU/PDU经过分割,级联,加填充(padding)等处理中的一项或多项后,再添加包头得到多个原数据包。也就是说,本方案中原始数据包括的数据包可以是PDCP SDU/PDU,或者可以是原数据包。
上述第三或第四方面的一种实现方式中,上述通信装置包括PDCP层。上述方法还包括:通信装置关闭通信装置的PDCP层中PDCP SDU与丢弃定时器的关联功能。
上述第三或第四方面的一种实现方式中,上述通信装置包括PDCP层。当网络编码功能位于PDCP层内时,上述原始数据包括一个或多个PDCP SDU。一个第一数据包对应一个PDCP PDU,具体的,一个第一数据包加PDCP头后得到一个PDCP PDU,换句话说,一个PDCPPDU包括一个第一数据包和PDCP头。若与上述第一数据包i关联的定时器超时,通信装置不仅丢弃该第一数据包i,还丢弃该第一数据包i对应的PDCP PDU。
可选的,若与上述第一数据包i关联的定时器超时,通信装置不仅丢弃该第一数据包i和该第一数据包i对应的PDCP PDU,还丢弃该第一数据包i对应的PDCP SDU。其中一个第一数据包对应一个或多个PDCP SDU。
可见,本方案在定时器超时后,不仅丢弃相应的第一数据包,还丢弃该第一数据包对应的PDCP PDU(因为第一数据包已经QoS失效,由该第一数据包加PDCP头得到的PDCP PDU同样已经QoS失效)和/或PDCP SDU(因为第一数据包已经QoS失效,生成该第一数据包的PDCP SDU也即将/已经QoS失效),可以减少已经QoS失效的PDCP PDU传输至下一层的概率,从而节省空口资源。
上述第三或第四方面的一种实现方式中,上述通信装置包括PDCP层、NC层以及RLC层。其中NC层主要用于实现网络编码功能。当NC层位于PDCP层之下或RLC层之上时,上述原始数据包括一个或多个PDCP PDU。
可选的,上述通信装置是集中式单元或用于集中式单元的芯片,上述NC层可以位于PDCP层之下。通信装置对原始数据进行网络编码功能的处理生成多个第一数据包后,将生成的该多个第一数据包发送给分布式单元。因此,若与该第一数据包i关联的定时器超时,通信装置向分布式单元发送指示信息,该指示信息用于指示分布式单元丢弃该第一数据包i。其中,该指示信息中包括第一数据包i的标识,比如数据包标识(packet ID);或者,该指示信息中包括第一数据包i对应的编码系数因子的标识,比如系数标识(Coeff_ID)。相应地,分布式单元从通信装置接收指示信息,该指示信息用于指示分布式单元丢弃该第一数据包i;分布式单元根据该指示信息的指示,丢弃第一数据包i。可选的,如果第一数据包i是原数据包,原数据包不包括编码系数因子的标识,则指示信息不能通过编码系数因子的标识来实现。
可选的,上述通信装置是分布式单元或用于分布式单元的芯片,上述NC层可以位于RLC层之上。此时,CU向通信装置发送的是PDCP PDU。通信装置的NC层对原始数据进行网络编码功能的处理生成多个第一数据包后,将生成的该多个第一数据包发送给下层(即RLC层)。因此,若与该第一数据包i关联的定时器超时,通信装置的NC层指示RLC层丢弃传输至该RLC层的该第一数据包i。这里的指示可以通过层间交互实现。
可选的,上述通信装置是终端设备或用于终端设备的芯片。上述通信装置包括PDCP层、NC层、以及RLC层,NC层位于PDCP层和RLC层之间。通信装置将上述第一数据包i传输至通信装置的RLC层后,如果与该第一数据包i关联的定时器超时,则通信装置的NC层指示通信装置的RLC层丢弃传输至该RLC层的第一数据包i。相应地,通信装置的RLC层丢弃从通信装置的NC层接收到的该第一数据包i。
第五方面,本申请提供一种网络编码场景下的超时丢包方法,该方法包括:发送PDCP实体从上层接收一个PDCP SDU,并为该PDCP SDU关联一个定时器;若该PDCP SDU关联的定时器超时,发送PDCP实体丢弃该PDCP SDU;发送PDCP实体对一个或多个PDCP SDU进行网络编码功能的处理生成多个第一数据包,并对每个第一数据包添加PDCP头得到PDCP PDU(换句话说,一个PDCP头包括一个第一数据包和PDCP头);若该一个PDCP PDU对应的N个PDCPSDU关联的N个定时器中的K个定时器超时,发送PDCP实体丢弃该PDCP PDU。其中,一个第一数据包对应一个PDCP PDU。这里的网络编码功能位于PDCP层内。因为网络编码功能的处理可能生成系统包和冗余包,也可能生成原数据包和冗余包,所以这多个第一数据包包括系统包和冗余包,或者,这多个第一数据包包括原数据包和冗余包。应理解,具体网络编码功能的介绍以及原数据包、系统包、冗余包的含义参考下文具体实施例方式部分的描述,此处篇幅限制不展开说明。K为小于或等于N的正整数,且K大于预设阈值(比如N/2)。
可选的,一个PDCP PDU对应的N个PDCP SDU包括:一个PDCP PDU包括的第一数据包是系统包或原数据包,则这个PDCP PDU包括的第一数据包的数据来自这N个PDCP SDU中的每个PDCP SDU;或,一个PDCP PDU包括的第一数据包是冗余包,则这个PDCP PDU包括的与第一数据包满足网络编码关系的原数据包来自这N个PDCP SDU中的每个PDCP SDU。
换句话说,一旦一个PDCP SDU关联的定时器超时,则发送PDCP实体将丢弃该PDCPSDU,而PDCP PDU只有当其包含的所有或部分PDCP SDU关联的定时器都超时才被丢弃。
可见,本方案通过在网络编码场景下复用NR PDCP层的超时丢包机制并在此基础上修改丢弃PDCP PDU的原则,即复用一个PDCP SDU关联一个定时器,当该定时器超时,则丢弃该PDCP SDU,而PDCP PDU只有当其包含的所有或部分PDCP SDU关联的定时器都超时才能被丢弃,不仅可以减少对NR PDCP层的超时丢包机制的改动,还可以在网络编码场景下丢弃已经QoS失效的数据包,减少QoS失效的数据包在空口上传输造成的资源浪费,提升空口传输的效率,且可以减少误丢包的情况。
第六方面,本申请提供一种发送PDCP实体,该发送PDCP实体可以是终端设备或终端设备中的芯片;或者,该发送PDCP实体还可以是网络设备或网络设备中的芯片。该发送PDCP实体包括:丢弃模块,用于若PDCP SDU关联的定时器超时,丢弃该PDCP SDU,其中一个PDCP SDU关联一个定时器;编码模块,用于对一个或多个PDCP SDU进行网络编码功能的处理生成多个第一数据包,一个该第一数据包对应一个PDCP PDU,一个PDCP PDU包括一个第一数据包和PDCP头;该丢弃模块,还用于若该一个PDCP PDU对应的N个PDCP SDU关联的N个定时器中的K个定时器超时,丢弃该PDCP PDU。这里的网络编码功能位于PDCP层内。其中,这多个第一数据包包括系统包和冗余包,或者,这多个第一数据包包括原数据包和冗余包。K为小于或等于N的正整数,且K大于预设阈值(比如N/2)。
可选的,一个PDCP PDU对应的N个PDCP SDU包括:一个PDCP PDU包括的第一数据包是系统包或原数据包,则这个PDCP PDU包括的第一数据包的数据来自这N个PDCP SDU中的每个PDCP SDU;或,一个PDCP PDU包括的第一数据包是冗余包,则这个PDCP PDU包括的与第一数据包满足网络编码关系的原数据包来自这N个PDCP SDU中的每个PDCP SDU。
上述第五或第六方面的一种实现方式中,上述网络编码功能包括分割,级联,加填充(padding)等处理中的一项或多项,可选的该网络编码功能还包括编码处理。其中,分割处理用于将一个PDCP SDU分割成多个数据段,级联处理用于将一个PDCP SDU的全部或部分与另一个PDCP SDU的全部或部分级联成一个数据段。加填充处理用于对小于一定大小的数据段或PDCP SDU进行填充,使其等于该一定大小。每个数据段添加包头后获得等大小的原数据包,对这些等大小的原数据包进行编码,以期得到系统包和冗余包,或者,冗余包。
上述第五或第六方面的一种实现方式中,发送PDCP实体对一个或多个PDCP SDU进行网络编码功能的处理生成多个第一数据包之后,该方法还包括:若该一个PDCP SDU关联的定时器超时,发送PDCP实体丢弃该PDCP SDU对应的多个第一数据包中的全部或部分。这里可以是丢弃系统包和冗余包中的一种,或原数据包和冗余包中的一种;也可以是丢弃全部的第一数据包,即:既丢弃系统包也丢弃冗余包,或者既丢弃原数据包也丢弃冗余包。
可见,本方案在PDCP SDU关联的定时器超时后,不仅丢弃PDCP SDU,还丢弃相应的第一数据包,可以省略对已经QoS失效的第一数据包加PDCP头生成PDCP PDU的操作,从而减少将已经QoS失效的PDCP PDU传输至下一层的概率。
第七方面,本申请提供一种网络编码场景下的超时丢包方法,该方法包括:发送PDCP实体从上层接收一个PDCP SDU,并为该PDCP SDU关联一个定时器;发送PDCP实体对一个或多个PDCP SDU进行网络编码功能的处理生成多个第一数据包,这一个或多个PDCP SDU对应该多个第一数据包,一个该第一数据包对应一个PDCP PDU,一个PDCP PDU包括一个第一数据包和PDCP头,一个PDCP SDU对应多个PDCP PDU;若某个PDCP SDU(比如,该一个或多个PDCP SDU中的第一PDCP SDU,为便于描述,下文以第一PDCP SDU关联的定时器为例进行说明)关联的定时器超时,发送PDCP实体丢弃以下中的至少一项:第一PDCP SDU,第一PDCPSDU对应的多个PDCP PDU。这里的网络编码功能位于PDCP层内。其中,因为网络编码功能的处理可能生成系统包和冗余包,也可能生成原数据包和冗余包,所以这多个第一数据包包括系统包和冗余包,或者,这多个第一数据包包括原数据包和冗余包。应理解,具体网络编码功能的介绍以及原数据包、系统包、冗余包的含义参考下文具体实施例方式部分的描述,此处篇幅限制不展开说明。
可见,本方案通过在网络编码场景下复用NR PDCP层的超时丢包机制,当一个PDCPSDU关联的一个定时器超时后,丢弃该PDCP SDU以及该PDCP SDU对应的所有PDCP PDU,不仅可以减少对NR PDCP层的超时丢包机制的改动,还可以在网络编码场景下丢弃已经QoS失效的数据包,减少QoS失效的数据包在空口上传输造成的资源浪费以及减少接收端恢复出无效数据包的概率。
第八方面,本申请提供一种发送PDCP实体,该发送PDCP实体可以是终端设备或终端设备中的芯片;该发送PDCP实体还可以是网络设备或网络设备中的芯片。该发送PDCP实体包括:编码模块,用于对一个或多个PDCP SDU进行网络编码功能的处理生成多个第一数据包,该一个或多个PDCP SDU对应该多个第一数据包,一个该第一数据包对应一个PDCPPDU,一个PDCP PDU包括一个第一数据包和PDCP头,一个PDCP SDU对应多个PDCP PDU,该一个或多个PDCP SDU中的一个PDCP SDU关联一个定时器;丢弃模块,用于若该一个或多个PDCP SDU中的第一PDCP SDU关联的定时器超时,丢弃以下中的至少一项:该第一PDCP SDU,该第一PDCP SDU对应的多个PDCP PDU。这里的网络编码功能位于PDCP层内。其中,这多个第一数据包包括系统包和冗余包,或者,这多个第一数据包包括原数据包和冗余包。
可选的,上述网络编码功能包括分割,级联,加填充(padding)等处理中的一项或多项,可选的该网络编码功能还包括编码处理。其中,分割处理用于将一个PDCP SDU分割成多个数据段,级联处理用于将一个PDCP SDU的全部或部分与另一个PDCP SDU的全部或部分级联成一个数据段。加填充处理用于对小于一定大小的数据段或PDCP SDU进行填充,使其等于该一定大小。每个数据段添加包头后获得等大小的原数据包,对这些等大小的原数据包进行编码,以期得到系统包和冗余包,或者,得到冗余包。
上述第七或第八方面的一种实现方式中,上述方法还包括:发送PDCP实体丢弃该PDCP SDU对应的多个第一数据包中的全部或部分。这里可以是丢弃系统包和冗余包中的一种,或原数据包和冗余包中的一种,也可以是丢弃全部的第一数据包,即:既丢弃系统包也丢弃冗余包,或者既丢弃原数据包也丢弃冗余包。
可见,本方案在PDCP SDU关联的定时器超时后,不仅丢弃PDCP SDU和PDCP PDU,还丢弃相应的第一数据包,可以省略对已经QoS失效的第一数据包加PDCP头生成PDCP PDU的操作,从而减少将已经QoS失效的PDCP PDU传输至下一层的概率。
第九方面,本申请提供一种通信装置,该通信装置可以包括处理器和存储器,可选的包括收发器。其中,该存储器用于存储计算机程序,该收发器用于收发各种数据包或指示信息,该计算机程序包括程序指令,当该处理器运行该程序指令时,使得该通信装置执行上述第一方面、或上述第三方面、或上述第五方面、或上述第七方面、或其中任一方面的任意一种可能的实现方式描述的超时丢包方法。其中,收发器可以为通信装置中的射频模块,或,射频模块和天线的组合,或,芯片或电路的输入输出接口。
第十方面,本申请提供一种可读存储介质,该可读存储介质上存储有程序指令,当其在计算机上运行时,使得计算机执行上述第一方面、或上述第三方面、或上述第五方面、或上述第七方面、或其中任一方面的任意一种可能的实现方式描述的超时丢包方法。
第十一方面,本申请提供一种包含程序指令的程序产品,当其运行时,使得上述第一方面、或上述第三方面、或上述第五方面、或上述第七方面、或其中任一方面的任意一种可能的实现方式描述的超时丢包方法被执行。
第十二方面,本申请提供一种装置,该装置可以以芯片的形式实现,也可以为设备的形式,该装置包括处理器。该处理器用于读取并执行存储器中存储的程序,以执行上述第一方面、第三方面、第五方面、第七方面中的一项或多项,或,其中任一方面的任意可能的实现方式中的一项或多项提供的超时丢包方法。可选的,该装置还包括存储器,该存储器与该处理器通过电路连接。进一步可选的,该装置还包括通信接口,该处理器与该通信接口连接。该通信接口用于接收待处理的数据包和/或信息,该处理器从该通信接口获取该数据包和/或信息,并对该数据包和/或信息进行处理,并通过该通信接口输出处理结果。该通信接口可以是输入输出接口。
可选的,上述的处理器与存储器可以是物理上相互独立的单元,或者,存储器也可以和处理器集成在一起。
实施本申请实施例,可以在LTE或NR的接入层引入网络编码的场景下,进行超时丢包处理,比如,丢弃已经QoS失效的数据包,减少QoS失效的数据包在空口上传输或者存储造成的资源浪费。
附图说明
为了更清楚地说明本申请实施例的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍。
图1是本申请实施例提供的通信系统的架构示意图;
图2是NR系统中gNB-CU和gNB-DU分离的网络架构示意图;
图3a是gNB采用CU-DU分离架构下的控制面协议栈示意图;
图3b是gNB采用CU-DU分离架构下的用户面协议栈示意图;
图4是本申请实施例提供的UE和基站的简化结构示意图;
图5a是发送端的一种可能网络编码流程示意图;
图5b是发送端的另一种可能网络编码流程示意图;
图6是MBMS引入网络编码的架构示意图;
图7是NR PDCP层的超时丢包机制示意图;
图8是PDCP层引入NC后PDCP SDU与PDCP PDU之间的关系示意图;
图9a是本申请实施例提供的网络编码功能位于PDCP层内的协议层架构示意图;
图9b是本申请实施例提供的NC层在PDCP层之下的协议层架构示意图;
图9c是本申请实施例提供的NC层在RLC层之上的协议层架构示意图;
图10是本申请实施例提供的网络编码场景下的超时丢包方法的第一种示意流程图;
图11a是本申请实施例提供的UE侧超时丢包示意图一;
图11b是本申请实施例提供的gNB侧NC层位于PDCP层之下的超时丢包示意图一;
图11c是本申请实施例提供的gNB侧NC层位于RLC层之上的超时丢包示意图一;
图12是本申请实施例提供的网络编码场景下的超时丢包方法的第二种示意流程图;
图13a是本申请实施例提供的UE侧超时丢包示意图二;
图13b是本申请实施例提供的gNB侧NC层位于PDCP层之下的超时丢包示意图二;
图13c是本申请实施例提供的gNB侧NC层位于RLC层之上的超时丢包示意图二;
图14是本申请实施例提供的网络编码场景下的超时丢包方法的第三种示意流程图;
图15是本申请实施例提供的网络编码场景下的超时丢包方法的第四种示意流程图;
图16是本申请实施例提供的gNB侧NC层位于PDCP层之下的超时丢包示意图三;
图17是本申请实施例提供的gNB侧NC层位于RLC层之上的超时丢包示意图三;
图18是本申请实施例提供的通信装置的一结构示意图;
图19是本申请实施例提供的通信装置的另一结构示意图;
图20是本申请实施例提供的发送PDCP实体的结构示意图;
图21是本申请实施例提供的通信装置1000的结构示意图。
具体实施方式
下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述。
本申请实施例中,“至少一个”是指一个或者多个,“多个”是指两个或两个以上。“和/或”,描述关联对象的关联关系,表示可以存在三种关系,例如,A和/或B,可以表示:单独存在A,同时存在A和B,单独存在B的情况,其中A,B可以是单数或者复数。字符“/”一般表示前后关联对象是一种“或”的关系。“以下至少一项(个)”或其类似表达,是指的这些项中的任意组合,包括单项(个)或复数项(个)的任意组合。例如,a,b,或c中的至少一项(个),可以表示:a,b,c;a和b;a和c;b和c;或a和b和c。其中a,b,c可以是单个,也可以是多个。
应理解,在本申请中,“当…时”、“若”以及“如果”均指在某种客观情况下装置会做出相应的处理,并非是限定时间,且也不要求装置实现时一定要有判断的动作,也不意味着存在其它限定。
本申请中的“同时”可以理解为在相同的时间点,也可以理解为在一段时间段内,还可以理解为在同一个周期内,具体可以结合上下文进行理解。
本申请中对于使用单数表示的元素旨在用于表示“一个或多个”,而并非表示“一个且仅一个”,除非有特别说明。
另外,本文中术语“系统”和“网络”可互换替换使用。
应理解,在本申请各实施例中,“与A对应的B”表示B与A相关联,根据A可以确定B。但还应理解,根据A确定B并不意味着仅仅根据A确定B,还可以根据A和/或其它信息确定B。
本申请实施例的技术方案可以应用于各种通信系统中,例如:LTE系统,全球互联微波接入(worldwide interoperability for microwave access,WiMAX)通信系统,第五代(5th Generation,5G)系统,如新一代无线接入技术(new radio access technology,NR),多种系统融合的网络,物联网系统,车联网系统,以及未来的通信系统,如6G系统等。
应理解,本申请实施例描述的网络架构是为了更加清楚的说明本申请实施例的技术方案,并不构成对于本申请实施例提供的技术方案的限定,本领域普通技术人员可知,随着网络架构的演变,本申请实施例提供的技术方案对于类似的技术问题,同样适用。
本申请实施例中部分场景以无线通信网络中NR网络的场景为例进行说明,应理解,本申请实施例中的方案还可以应用于其他无线通信网络中,相应的名称也可以用其他无线通信网络中的对应功能的名称进行替代。
参见图1,图1是本申请实施例提供的通信系统的架构示意图。如图1所示,该通信系统包括一个或多个网络设备(如图1中的基站)和一个或多个终端设备(如图1中的UE)。其中,终端设备与网络设备之间可以进行无线通信,一个终端设备可以与一个网络设备或同时与多个网络设备进行通信,一个网络设备也可以与一个终端设备或同时与多个终端设备进行通信。终端设备可配置一个或多个天线,用于收发数据/信息。同理,网络设备也可配置一个或多个天线,用于收发数据/信息。应理解,网络设备和终端设备还可包括与数据/信息发送和接收相关的多个部件(例如,处理器、调制器、复用器、解调器或解复用器等)。还应理解,图1仅是示意图,该通信系统中还可以包括其它设备,如还可以包括核心网设备、无线中继设备和/或无线回传设备等,在图1中未画出。
可选的,本申请实施例中的终端设备还可以称为终端、用户设备(userequipment,UE)、移动台(mobile station,MS)、移动终端(mobile terminal,MT)等,其可以是用户侧的一种用于接收或发射信号的实体,如手机;其可以部署在陆地上,包括室内或室外、手持或车载;也可以部署在水面上(如轮船等);还可以部署在空中(例如飞机、气球和卫星上等)。UE包括具有无线通信功能的手持式设备、车载设备、可穿戴设备或计算设备。示例性地,UE可以是手机(mobile phone)、平板电脑或带无线收发功能的电脑。终端设备还可以是虚拟现实(virtual reality,VR)终端设备、增强现实(augmented reality,AR)终端设备、工业控制中的无线终端、无人驾驶中的无线终端、远程医疗中的无线终端、智能电网中的无线终端、智慧城市(smart city)中的无线终端、智慧家庭(smart home)中的无线终端等等。本申请实施例中,用于实现终端的功能的装置可以是终端;也可以是能够支持终端实现该功能的装置,例如芯片系统、或通信模块、或调制解调器等,该装置可以被安装在终端中。本申请实施例中,芯片系统可以由芯片构成,也可以包括芯片和其他分立器件。本申请实施例提供的技术方案中,以用于实现终端的功能的装置是终端,以终端是UE为例,描述本申请实施例提供的技术方案。本申请的实施例对终端设备所采用的具体技术和具体设备形态不做限定。
可选的,UE也可以用于充当基站。例如,UE可以充当调度实体,其在车辆外联(vehicle-to-everything,V2X)、设备到设备(device-to-device,D2D)或点对点(peer topeer,P2P)等中的UE之间提供侧行链路信号。
可选的,UE也可以用于充当中继节点。例如:UE可以充当中继设备(relay),或者接入回传一体化(integrated access and backhaul,IAB)节点,用于为终端设备提供无线回传服务。
可选的,本申请实施例中的网络设备包括接入网设备,例如基站(base station,BS),BS可以是网络侧的一种用于发射或接收信号的实体,也是一种部署在无线接入网中能够和终端进行无线通信的设备。基站(BS)可以是固定的,也可以是移动的。其中,基站可能有多种形式,比如宏基站、微基站、中继站和接入点等。示例性地,本申请实施例涉及到的基站可以是5G中的基站或LTE中演进的基站(Evolved Node B,eNB)。其中,5G中的基站还可以称为发送接收点(transmission reception point,TRP)或5G基站(Next-Generation NodeB,gNB)。基站还可以与如下名称进行替换,比如:无线访问点、节点B(NodeB)、发射点(transmitting point,TP)、主站MeNB、辅站SeNB、多制式无线(MSR)节点、家庭基站、网络控制器、接入节点、无线节点、传输节点、收发节点、基带单元(baseband unit,BBU)、射频拉远单元(remote radio unit,RRU)、有源天线单元(AAU)、射频头(RRH)、集中式单元(centralized unit,CU)、分布式单元(distributed unit,DU)、定位节点、IAB宿主(IABdonor)等。本申请实施例中,用于实现网络设备的功能的装置可以是网络设备;也可以是能够支持网络设备实现该功能的装置,例如芯片系统、或通信模块、或调制解调器等,该装置可以被安装在网络设备中。在本申请实施例提供的技术方案中,以用于实现网络设备的功能的装置是网络设备,以网络设备是基站为例,描述本申请实施例提供的技术方案。基站可以支持相同或不同接入技术的网络。本申请的实施例对网络设备所采用的具体技术和具体设备形态不做限定。
在一些部署中,gNB是为用户设备(user equipment,UE)提供NR用户面和控制面传输的节点,其可以支持一个或多个小区。gNB通过NG接口连接到5G核心网,并通过Xn接口与其他gNB相连。其中,Xn-C接口用于两个gNB之间控制面信令的传输,Xn-U接口用于两个gNB之间用户面数据的传输。gNB与UE之间通过Uu接口连接。
在另一些部署中,接入网设备(例如:gNB)可以包括集中式单元(central unit,CU)和分布式单元(distributed unit,DU)。也就是说,gNB可以采用CU-DU分离架构,即gNB包含一个gNB-CU和一个或多个gNB-DU。gNB还可以包括射频单元(radio unit,RU)。CU和DU可以理解为是对基站从逻辑功能角度的划分,CU和DU在物理上可以分离,也可以部署在一起。其中,gNB-CU和gNB-DU都是逻辑节点,一个gNB-CU可以连接一个或者多个gNB-DU,一个gNB-DU仅能连接一个gNB-CU,gNB-CU与gNB-DU之间通过F1接口相连。一个gNB-DU可以支持一个或者多个小区,但一个小区只属于一个gNB-DU。示例性的,参见图2,图2是NR系统中gNB-CU和gNB-DU分离的网络架构示意图。如图2所示,5G核心网(5G core,5GC)与5G无线接入网(next generation radio access network,NG-RAN)互连通信,两者通过NG接口相连。NG-RAN中的gNB既可以采用CU-DU分离架构,也可以采用非CU-DU分离架构。NG-RAN中两个gNB通过Xn接口相连。gNB采用CU-DU分离架构时,多个gNB-DU可连接到一个gNB-CU。应理解,虽然图2所示网络结构应用于NR通信系统,但也可以与LTE系统共享一个或多个部件或资源。
如果gNB采用CU-DU分离架构,UE可通过gNB-DU连接到gNB-CU。可选的,gNB可以将协议层拆分开,部分协议层的功能放在gNB-CU集中控制,剩下部分或全部协议层的功能分布在gNB-DU中,由gNB-CU集中控制gNB-DU。作为一种实现方式,与UE对等的无线链路控制(radio link control,RLC)层,媒体接入控制(medium access control,MAC)层,以及物理层(physical layer,PHY)部署在gNB-DU上,与UE对等的无线资源控制(radio resourcecontrol,RRC)层,分组数据汇聚协议(packet data convergence protocol,PDCP)层,以及业务数据适应协议(service data adaptation protocol,SDAP)层部署在gNB-CU上。从而,gNB-CU具有RRC层、PDCP层以及SDAP层的处理能力。gNB-DU具有RLC层、MAC层以及PHY层的处理能力。可以理解的是,上述功能的划分仅为一个示例,不构成对gNB-CU和gNB-DU的限定。
示例性的,参见图3a,图3a是gNB采用CU-DU分离架构下的控制面协议栈示意图。如图3a所示,对于控制面而言,上行(uplink,UL)方向,gNB-DU将UE生成的RRC消息封装在F1接口的F1应用层协议(F1 application protocol,F1AP)消息中通过控制面的F1接口(F1-control,F1-C)发送到gNB-CU。下行(downlink,DL)方向,gNB-CU将RRC消息封装在F1AP消息中发送到gNB-DU,gNB-DU从F1AP消息中提取出RRC消息映射到Uu接口对应的信令无线承载(signalling radio bearer,SRB)如SRB0/SRB1/SRB2上发送给UE。具体的,对UL方向,gNB-DU将该F1AP消息依次经过流控制传输协议(stream control transmission protocol,SCTP)层、以太网协议(Internet Protocol,IP)层、层2(Layer 2,L2)和层1(Layer 1,L1)的处理后发送到gNB-CU。对DL方向,gNB-CU将该F1AP消息依次经过SCTP层、IP层、L2层和L1层的处理后发送到gNB-DU。参见图3b,图3b是gNB采用CU-DU分离架构下的用户面协议栈示意图。如图3b所示,对于用户面而言,UL方向,gNB-DU将从Uu接口对应的数据无线承载(dataradio bearer,DRB)上收到的UE数据包映射到对应的通用分组无线业务(general packetradio service,GPRS)隧道协议(GPRS tunneling protocol,GTP)隧道中通过用户面的F1接口(F1-user,F1-U)发送给gNB-CU。DL方向,gNB-CU将UE数据包映射到对应的GTP隧道中发送给gNB-DU,gNB-DU从GTP隧道中提取出UE数据包,并将该UE数据包映射到Uu接口对应的DRB上发送给UE。具体的,对UL方向,gNB-DU将UE的数据包映射到对应的GTP隧道后,再依次经过用户数据报协议(user datagram protocol,UDP)层、IP层、L2层和L1层的处理后发送到gNB-CU。对DL方向,gNB-CU将UE的数据包映射到对应的GTP隧道后,再依次经过UDP层、IP层、L2层和L1层的处理后发送到gNB-DU。应理解,本申请实施例主要涉及用户面协议栈。
在本申请实施例中,术语“无线通信”还可以简称为“通信”,术语“通信”还可以描述为“数据传输”、“信息传输”或“传输”。
参见图4,图4是本申请实施例提供的UE和基站的简化结构示意图。为简单起见,图4仅示出了基站110和UE 120中的主要部件,实际应用中,基站和UE的结构可多于图4所示部件,也可少于图4所示部件,还可只包含图4所示部件。应理解,图4所示基站既可以采用CU-DU分离架构,也可以采用非CU-DU分离架构。下面分别对图4中的各个组成部分进行简单介绍。
基站110包括接口111和处理器112。处理器112可选地可以存储程序114。基站110可选地包括存储器113。存储器113可选地可以存储程序115。UE 120包括接口121和处理器122。处理器122可选地可以存储程序124。UE 120可选地包括存储器123。存储器123可选地可以存储程序125。这些组件一起工作,以提供本申请中描述的各种功能。例如,处理器112和接口111一起工作以提供基站110与UE 120之间的无线连接。处理器122和接口121共同作用,实现UE 120的下行传输和/或上行传输。
处理器(例如,处理器112和/或处理器122)可包括一个或多个处理器并实现为计算设备的组合。处理器(例如,处理器112和/或处理器122)可分别包括以下一种或多种:微处理器、微控制器、数字信号处理器(DSP)、数字信号处理设备(DSPD)、专用集成电路(ASIC)、现场可编程门阵列(FPGA)、可编程逻辑器件(PLD)、选通逻辑、晶体管逻辑、分立硬件电路、处理电路或其它合适的硬件、固件和/或硬件和软件的组合,用于执行本申请中所描述的各种功能。处理器(例如,处理器112和/或处理器122)可以是通用处理器或专用处理器。例如,处理器112和/或处理器122可以是基带处理器或中央处理器。基带处理器可用于处理通信协议和通信数据。中央处理器可用于使基站110和/或UE 120执行软件程序,并处理软件程序中的数据。
接口(例如,接口111和/或121)可包括用于实现与一个或多个计算机设备(例如,UE、BS和/或网络节点)之间的通信。在一些实施例中,接口可以包括用于耦合有线连接的电线、或用于耦合无线收发器的管脚、或用于无线连接的芯片和/或管脚。在一些实施例中,接口可以包括发射器、接收器、收发器和/或天线。接口可以被配置为使用任何可用的协议(例如3GPP标准)。
本申请中的程序在广义上用于表示软件。软件的非限制性示例是程序代码、程序、子程序、指令、指令集、代码、代码段、软件模块、应用程序、软件应用程序等。程序可以在处理器和/或计算机中运行,以使基站110和/或UE 120执行本申请中描述的各种功能和/或过程。
内存(例如存储器113和/或存储器123)可存储由处理器112、122在执行软件时操纵的数据。存储器113、123可以使用任何存储技术实现。例如,存储器可以是处理器和/或计算机能够访问的任何可用存储介质。存储介质的非限制性示例包括:RAM、ROM、EEPROM、CD-ROM、可移动介质、光盘存储器、磁盘存储介质、磁存储设备、闪存、寄存器、状态存储器、远程挂载存储器、本地或远程存储器组件,或能够携带或存储软件、数据或信息并可由处理器/计算机访问的任何其它介质。
内存(例如存储器113和/或存储器123)和处理器(例如处理器112和/或处理器122)可以分开设置或集成在一起。存储器可以用于与处理器连接,使得处理器能够从存储器中读取信息,在存储器中存储和/或写入信息。存储器113可以集成在处理器112中。存储器123可以集成在处理器122中。处理器(例如处理器112和/或处理器122)和存储器(例如存储器113和/或存储器123)可以设置在集成电路中(例如,该集成电路可以设置在UE或基站或其他网络节点中)。
上述内容简要阐述了本申请实施例的网络架构,为更好地理解本申请实施例的技术方案,下面将简要介绍与本申请相关的几个内容。
一、网络编码(network coding,NC)功能
本申请中的网络编码功能包括对原数据包进行网络编码和添加编码包包头。其中,网络编码可以通过编码器来实现,编码器的输入为K个原数据包,编码器的输出为N个编码数据包(简称为编码包),其中,N和K均为正整数,且N大于K。编码包包括N-K(N减K)个冗余包和K个系统包,或者,编码包包括N个冗余包(即编码包均为冗余包,不包括系统包)。其中,系统包的包体的内容和原数据包的内容一致(也就是说,系统包由编码包包头和原数据包构成),系统包可以通过对原数据包直接加包头得到,也可以通过前述编码器编码后加包头得到,系统包的编码系数为单位向量。冗余包的编码系数为非单位向量。通过冗余包的内容和生成该冗余包的原数据包的内容之间的关联,接收设备(可简称收端)可以通过冗余包和成功接收(或接收正确)的原数据包或系统包一起译码,恢复未成功接收(或接收错误)的原数据包。基于网络编码的特点,原数据包的包大小相等。应理解,本文中“编码系数”,“系数因子”,“编码系数因子”三者可相互替换使用。还应理解,本文中的“原数据包”还可以称为“原始数据包”或“原包”等,本申请对其名称不做具体限定。
进一步的,本申请中的网络编码功能还可以包括对原始数据单元,比如服务数据单元(service data unit,SDU)或协议数据单元(protocol data unit,PDU)进行处理获得大小相等的原数据包的过程,该处理可以包括分割,级联,或,加填充(padding)中的一种或多种。发送设备(可简称为发端)的网络编码功能对应接收设备的网络译码功能。接收设备通过对成功接收的至少K个编码包一起进行译码可以恢复出K个原数据包。具有网络编码功能或网络编码对应的译码功能的协议层称为网络编/译码层,本申请中将网络编/译码层简称为网络编码层,即,上述具有网络编码的协议层称为网络编码层。
网络编码层可以是无线资源控制(radio resource control,RRC)层,业务数据适配协议(service data adaptation protocol,SDAP),分组数据汇聚层协议(packet dataconvergence protocol,PDCP)层,回传适配协议(backhaul adaptation protocol,BAP)层,无线链路控制(radio link control,RLC)层,媒体接入控制(medium access control,MAC)层,或物理层(physical layer,PHY)等协议层。网络编码层也可以是除PHY层,MAC层,RLC层,BAP层,PDCP层,SDAP层以及RRC层之外的一个新的协议层,可以为在PDCP层之上增加网络编码层(例如:5G NR中,在PDCP层和SDAP层之间增加网络编码层),或者,在BAP层之上增加网络编码层,或者,在PDCP层和RLC层之间增加网络编码层,或者,在RLC层和MAC层之间增加网络编码层,或者,在MAC层和PHY层之间增加网络编码层。
常用的网络编码方案包括分组码和卷积码两大类,其中,分组码的方案包括随机线性网络编码(random linear network coding,RLNC)、确定线性网络编码(deterministic linear network coding,DLNC)、分批稀疏码(batch sparse code,BATScode)、纠删码(erasure code)、喷泉码(fountain code)、最大距离可分码(maximumdistance separable code,MDS code)、卢比变换码(luby transform,LT)码、快速旋风(rapid tornado)码、RaptorQ码、无速率(rateless)码和里德-所罗门(Reed-Solomon,RS)码等中的一项或多项,卷积码的方案包括卷积网络编码(convolutional network coding,CNC)、流编码(streaming code)和滑动窗口网络编码(sliding window network coding)等中的一项或多项。
下面对发送设备(简称为发端)网络编码功能的两种可能的网络编码流程进行介绍。
第一种可能的网络编码流程:
先获取原始数据(PDU或者SDU),以PDU为例,通过对一个或多个PDU进行分割,级联,或,加padding等处理中的一项或多项获得等大小的原数据包。其中,原数据包携带每个原数据包和该原数据包对应的一个或多个PDU之间的对应关系。该携带可以是显式的携带,比如,携带每个原数据包和该原数据包对应的一个或多个PDU之间的位置映射关系,该携带也可以是隐式的携带,比如,每个原数据包和该原数据包对应的一个或多个PDU之间的对应关系是默认的。这样接收设备(简称为收端)可以基于所述对应关系从原数据包恢复出PDU。
可选的,每个原数据包的包头携带该原数据包和该原数据包对应的一个或多个PDU之间的对应关系。这种情况下,一种可能的实现是:先对PDU进行前述的分割,级联,或加padding等处理中的一项或多项获得原数据,再对原数据添加包头获得等大小的原数据包。
可选的,所述对应关系可以通过所述一个或多个PDU的分割和/或级联的情况进行指示。
可以理解的是,若原始数据本身就是等大小的话,那么就可以跳过上述通过对一个或多个PDU或者SDU进行分割,级联或加padding等处理中的一项或多项获得等大小的原数据包这个步骤,即,PDU或者SDU就是等大小的原数据包。
参见图5a,图5a是发送端的一种可能网络编码流程示意图;参见图5b,图5b是发送端的另一种可能网络编码流程示意图。
图5a和图5b以PDU大小不等以及通过包头携带上述对应关系为例,先对PDU1~PDU4进行处理得到原数据Data1~Data4,这里对PDU的处理可以是分割,级联或加padding等操作中的一项或多项。原数据的大小可以相等也可以不等。再对该组原数据进行加包头的操作,得到K个原数据包,即图5a和图5b中的Pkt1~Pkt4,原数据包可以理解为是未经过编码的数据包,且原数据包的大小相等。
再对多个等大小的原数据包进行编码。
具体的,对多个等大小的原数据包进行编码可以采取以下三种方式中的任意一种。
方式1如图5a所示,通过对K个原数据包进行编码,并添加编码包包头,可以得到N-K个编码包,这里的编码包可以称为校验包或者冗余包,即图5a所示的EPkt1~EPkt2。其中,K为正整数,N为不小于K的正整数。
通过上述操作,发端最终发送K个原数据包和N-K个冗余包。
方式2和方式3如图5b所示,通过对K个原数据包进行处理得到N个编码包,如图5b中EPkt1~EPkt6,编码包可以分为系统包和校验包,系统包也可以称为系统数据包,校验包可以称为冗余包。其中,编码包包头可以包括系数因子字段,该系数因子字段指示获得该编码包的编码系数。系统包(EPkt1~EPkt4)由编码包包头以及包体构成,包体的内容和原数据包的内容一致,包头包括的系数因子字段为单位向量。因此,对原数据包进行处理获得系统包的过程可以包括方式2和方式3两种,其中,K为正整数,N为不小于K的正整数。
其中方式2中,由原数据包直接添加编码包包头生成系统包,即不经过编码处理。
其中方式3中,原数据包经过编码处理,即经过为单位向量的系数因子编码后,并添加编码包包头生成系统包。
方式2和方式3中的校验包的生成方式相同,均为对原数据包编码且添加编码包包头而生成。如图5b中所示,N-K个校验包(如EPkt5~EPkt6)由K个原数据包(如Pkt1~Pkt4)通过编码并添加编码包包头生成,其包体部分(EData1~EData1)是K个原数据包和系数因子相乘再相加作用的结果,其中系数因子为非单位向量。
通过上述操作,发端最终发送N个编码包。
相应的,仍以图5a为例,对于收端,针对方式1,收端收到至少K个数据包,且该K个数据包线性无关,即对应的系数矩阵的秩等于K,这样,收端通过译码可以恢复出K个原数据包,继而恢复出相应的PDU。其中,该至少K个数据包可以全部为冗余包,或,部分为原数据包及部分为冗余包,在此不予限定。可以理解的是,如果收端收到的是K个原数据包,那么可以不进行译码。
针对方式2和方式3,仍以图5b为例,收端收到至少K个数据包,且该K个数据包线性无关,即对应的系数矩阵的秩等于K,这样,收端通过译码可以恢复出K个原数据包,继而恢复出相应的PDU。该至少K个数据包可以全部为冗余包,或,部分为系统包及部分为冗余包,在此不予限定。可以理解的是,如果收端收到的是K个系统包,那么可以不进行译码,进行去编码包包头处理即可。
在上述的网络编码功能中,通过对一个或多个原始数据进行分割,级联,或加padding等处理中的一项或多项获得等大小的原数据包,其中,原数据包携带每个原数据包和该原数据包对应的一个或多个原始数据之间的对应关系。
第二种可能的网络编码流程:
在第二种可能的网络编码流程中,可以采用虚拟分割,级联或加padding的处理中的一项或多项的方式获得等大小的原数据包。在这种方式中,先将原始数据和每个原始数据的头信息映射到缓存中,该缓存可以是真实缓存也可以是虚拟缓存,每个原始数据的头信息指示每个原始数据映射在缓存中的位置。再从缓存中获得多个等大小的原数据包。进而对多个等大小的原数据包进行编码获得编码包。其中,从缓存中获得多个等大小的原数据包的方式可以是预先设定的,或者,由发端指示给收端,或者,由数据传输的双方中处于控制地位的一方确定后指示给另一方。这种方式中,原数据包没有包头,但考虑和第一种方式中的描述对齐,仍将本方案中从缓存中获得的等大小的数据段称为原数据包。可以理解的是,本方案中的原数据包也可以称为原数据段。
其中,对多个等大小的原数据包进行编码获得编码包的方式和第一种可能的实现流程中的方式1类似,其与方式1的不同在于,编码后,发端发送一个或多个原始数据及该一个或多个原始数据的头信息,以及,编码获得的冗余包中的一个或多个。
可以理解的是,网络编码层的输入可以为一个或多个原始的数据单元,如原始数据,网络编码层的输出可以为一个或多个PDU,该一个或多个PDU可以包括前述的原数据包和冗余包,或者,前述的系统包和冗余包。其中,输出该一个或多个PDU可理解为通过通信接口在终端设备内或网络设备内将该一个或多个PDU输出给后续处理该一个或多个PDU的模块。可以理解,本申请中涉及的输出可以是指在空口上发送信号,也可以指在装置(例如,终端设备或网络设备)内通过通信接口将信号输出给该装置内的其他模块。具体过程在应用场景中具体描述,在此不予赘述。
具体的编码操作以RLNC为例进行简要说明。RLNC方案以一个编码块(block),为一个编码单元,一个编码块中包括多个大小相同的原数据包,通过构建编码系数矩阵对原数据包进行编码可以得到一组编码包。通常,编码系数矩阵中的系数在有限域,如伽罗华域(Galois field,GF)中随机选取。应理解,RLNC方案中,各个编码块之间没有关联,其中,对一个包含W个原数据包的编码块进行网络编码得到的W+R个编码数据,W和R均是正整数,即编码操作对每个独立的编码块进行,每个编码块的冗余(码率)可以相同,也可以不相同。编码端/发送设备将W个原数据包和生成的W+R个编码数据统一加包头信息后发送,译码端/接收设备接收到至少W个正确且编码系数向量线性无关的编码包时,或者,接收到至少W个正确的编码包且接收到的编码包对应的编码系数矩阵的秩为W时,即可正确译码并恢复出W个原数据包。这是因为编码包融合了若干个原数据包的信息,所以接收设备可以用编码包来恢复原数据包。
下面对本申请涉及的一些术语进行介绍。
系统包:由原数据包乘以为单位向量的编码系数生成的编码数据加编码包包头,或是,原数据包直接加编码包包头得到。
冗余包:由对原数据包进行网络编码生成,冗余包的编码系数为非单位向量。在本申请实施例中,术语“冗余包”还可以简称为“校验包”,两者可替换使用。
本申请中,系统包和冗余包可以统称为编码包,本申请下文所涉及编码包均包括系统包和冗余包。
编码系数因子:用于与原数据包相乘生成系统包或冗余包的向量,该向量的标识,即,编码系数因子的标识,也可以称为该向量的索引,即,编码系数因子的索引。
网络编码分组:分组码相关的术语,分组码中网络编码分组是包含了多个原数据包的集合。例如,将每W个原数据包分为一个网络编码分组进行独立网络编码可以得到与该网络编码分组对应的编码数据。在本申请实施例中,术语“网络编码分组”还可以称为“网络编码块”,“编码分组”,或“编码块”。
编码块的标识:也称为“网络编码分组标识”,“网络编码块标识”,或“编码分组标识”等,用于标识一个编码块的标识。比如,块标识(block ID)。
有限域:也称伽罗华域,是仅含有限个元素的域,可进行加法、减法、乘法和除法运算,且加、减、乘和除运算结果不会超出域的集合。
网络编码层:网络编码层是指具有网络编码功能的协议层,网络编码层可以是具有网络编码功能的RRC层,SDAP层,PDCP层,BAP层,RLC层,MAC层,或PHY层等协议层中的一项或多项。具体是哪层在本申请中不予限定。网络编码层也可以是除上述协议层以外的一个新协议层,例如,该新协议层可以在PDCP层之上,在BAP层之上,在PDCP层和RLC层之间,在RLC层和MAC层之间,或者在MAC层和PHY层之间,新协议层的位置在本申请中可以不予限定。在本申请实施例中,术语“网络编码层”也可以称为“编解码层”,“编译码层”,“网络编解码层”,“网络编译码层”,“网络编/解码层”,“网络编/译码层”或者其它名称,在本申请中不进行限定。
对应于网络编码的译码:网络编码的译码是网络编码的逆过程,利用接收到的编码数据,通过对编码数据对应矩阵的逆矩阵与编码数据相乘可以恢复出原数据包。
协议数据单元(protocol data unit,PDU):协议实体之间传递的数据单元,PDU包含来自上层的信息和当前层的实体附加的信息,这个PDU会被传送到下一较低的层。
服务数据单元(service data unit,SDU):协议层之间传递的数据单元,是来自上层的数据或者要传给上层的数据。
二、网络编码在多媒体广播/组播业务(multimedia broadcast/multicastservice,MBMS)中的应用
为了提升MBMS业务传输的可靠性,第三代合作伙伴项目(3rd generationpartnership project,3GPP)提出在MBMS业务传输过程中引入前向纠错码(网络编码是一种前向纠错码,其通过对原始数据进行编码并预先增加冗余来对抗传输过程中的数据包出错或性能损失等问题),比如Raptor码(属于喷泉码)。参见图6,图6是MBMS引入网络编码的架构示意图。如图6所示,MBMS接收机通过UTRAN(通用地面无线接入网;第三代移动通信系统)或E-UTRAN(演进的UTRAN)接入核心网,核心网的MBMS GW(MBMS网关,MBMS gate way)通过SGmb或SGi-mb接口与BM-SC(Broadcast-Multicast-Service Centre,广播/组播业务中心)通信,BM-SC通过xMB接口与内容提供者(content provider)通信,其具体通信过程可参考LTE或NR中关于MBMS的相关描述,此处不展开说明。其中,在MBMS引入了网络编码技术,主要是在UE和BM-SC(Broadcast-Multicast-Service Centre,广播/组播业务中心)上实现的网络编码技术,即在应用层上实现,没有考虑空口无线链路质量的影响,其对无线接入网(RAN)侧协议无影响。具体的,BM-SC对UE的MBMS业务进行网络编码后,将生成的编码包通过核心网设备和接入网设备发送给UE,对UE而言只要收到足够多的编码包就可以成功译码从而恢复出MBMS业务。
三、NR PDCP层的超时丢包机制
因为网络中某些业务具有时延要求,如果这些业务的数据包传输到PDCP层已超过时延要求或即将超过时延要求,也就没有传到下一层处理的必要,所以在PDCP层就可以删除收到的这些数据包,从而节省空口资源。因此,NR协议在PDCP层引入了基于丢弃定时器(discardTimer)的超时丢包机制。
为便于描述,本申请将实现PDCP层功能的实体称为PDCP实体,将发送端的PDCP实体称为用于发送的PDCP实体,可简称为发送PDCP实体(the transmitting PDCP entity),接收端的PDCP实体称为用于接收的PDCP实体,可简称为接收PDCP实体。换句话说,本申请中“发送端的PDCP实体”、“用于发送的PDCP实体”、以及“发送PDCP实体”可以相互替换使用。
参见图7,图7是NR PDCP层的超时丢包机制示意图。如图7所示,NR PDCP层的超时丢包可以通过discardTimer(丢弃定时器)来实现,具体过程如下:(1)发送PDCP实体从上层收到一个PDCP服务数据单元(service data unit,SDU)时,发送PDCP实体为该PDCP SDU关联一个discardTimer,并开启该discardTimer。(2)若该discardTimer超时,说明该PDCPSDU已经QoS失效,该发送PDCP实体丢弃该PDCP SDU以及该PDCP SDU对应的PDCP PDU,其中一个PDCP SDU对应一个PDCP PDU,一个PDCP PDU是一个PDCP SDU经过头压缩、加密/完整性保护和加PDCP头等操作后得到。(3)若该发送PDCP实体已经将该PDCP PDU发送到RLC层,则发送PDCP实体需要指示RLC层丢弃该PDCP PDU。一种实现方式中,在CU-DU分离架构下,PDCP层位于CU上,RLC层位于DU上,因此CU需要指示DU丢弃该PDCP PDU,该指示携带在F1接口的下行用户数据(DL User Data)中发送。
现有3GPP标准中,由上述第二点(即网络编码在MBMS中的应用)可知,网络编码是在应用层实现的,未考虑在接入层引入网络编码。相对于在应用层引入网络编码,接入层(例如:PDCP层,或PDCP层与RLC层之间新定义的协议层)引入网络编码可充分利用空口的链路质量,减少传输时延(这是因为基于网络编码层的反馈来调整冗余包的发送个数,确保接收端收到足够多的编码包以成功译码恢复出原始数据。NC部署越靠近UE,反馈越快),提高频谱效率。又因为网络编码技术需要保证待编码的多个原始数据包的大小相等,而NR协议中任何一层对应的SDU或者PDU的大小都无法保证是相等的。所以需要对SDU/PDU进行级联和/或分段操作(比如将一个SDU/PDU分成多段,和/或将多个SDU/PDU级联成一个),以使待编码的多个原始数据包的大小相等。
由此可知,本申请考虑在接入层引入网络编码,将会对PDCP层的discardTimer超时丢包产生影响。具体地,主要存在两方面的影响。一方面,如果在PDCP层引入NC,由于网络编码功能包括分段和/或级联操作,将导致PDCP SDU和PDCP PDU不再是一一对应的关系,所以如果PDCP SDU关联的discardTimer超时,发送PDCP实体如何丢弃已经QoS失效的PDCPSDU和PDCP PDU?
参见图8,图8是PDCP层引入NC后PDCP SDU与PDCP PDU之间的关系示意图。如图8所示,以发送PDCP实体将PDCP SDU0、SDU1以及SDU2进行网络编码功能的处理后生成编码包为例进行说明(即图5b示意的方案,编码包包括系统包和冗余包),发送PDCP实体为编码包加PDCP头后生成PDCP PDU。其中,PDCP PDU0(即图8中SN=0的PDCP PDU)包含系统包1,即:PDCP PDU0包含PDCP SDU0和部分的PDCP SDU1。PDCP PDU1(即图8中SN=1的PDCP PDU)包含系统包2,即:PDCP PDU1包含剩余部分的PDCP SDU1和PDCP SDU2。PDCP PDU2(即图8中SN=2的PDCP PDU)和PDCP PDU3(即图8中SN=3的PDCP PDU)均包含冗余包,即:PDCP PDU2和PDCPPDU3均包含PDCP SDU0、PDCP SDU1以及PDCP SDU2的内容。所以,PDCP SDU和PDCP PDU不再一一对应。应理解,图8中“SN=数值(0,1,2,3)”表示序列号(sequence number,SN)为0,1,2,3。图8仅是示意图,其示出的系统包和冗余包未画出其包头,但实际应用中,系统包和冗余包均包括包头信息。
另一方面,如果在PDCP层和RLC层之间引入NC,由于PDCP PDU封装在编码包内,将导致RLC层无法直接看到PDCP PDU。如果与PDCP SDU关联的discardTimer超时,RLC层将无法根据PDCP层的指示丢弃对应的PDCP PDU,则RLC层上已经QoS失效的这些PDCP PDU将如何丢弃?
本申请实施例提供一种网络编码场景下的超时丢包方法,可以在LTE或NR的接入层引入网络编码的场景下,解决PDCP SDU和PDCP PDU不再是一一对应时,如何丢弃已经QoS失效的PDCP SDU和PDCP PDU的问题,和/或解决RLC层上如何丢弃从上层收到的已经QoS失效的PDCP PDU的问题。从而本申请实施例可以进行超时丢包处理,比如,丢弃已经QoS失效的数据包,减少QoS失效的数据包在空口上传输或者存储造成的资源浪费,还可以提高空口传输的效率。
下面将结合更多的附图对本申请提供的技术方案进行详细说明。
因为本申请中的网络编码功能的处理既可以生成原数据包和冗余包(即图5a示意的方案),也可以生成系统包和冗余包(即图5b示意的方案)。所以,为了便于描述和理解,本申请下文中的各个实施例以原始数据(即PDCP SDU/PDU)进行网络编码功能的处理后生成系统包和冗余包(即图5b示意的方案)为例进行介绍说明。应理解,本申请下文描述的各个实施例仍然适用于对原始数据(即PDCP SDU/PDU)进行网络编码功能的处理后生成原数据包和冗余包(即图5a示意的方案)的场景。
本申请提供的技术方案可以通过多个实施例来详细说明,包括实施例一至实施例四。其中,实施例一阐述通过取消当前一个PDCP SDU关联一个discardTimer的机制,重新为一组待编码的原始数据(例如:多个PDCP SDU)关联一个discardTimer,来解决在接入层引入网络编码后导致的PDCP SDU和PDCP PDU不再是一一对应时,如何丢弃已经QoS失效的SDU和PDU的问题。实施例二阐述通过取消当前一个PDCP SDU关联一个discardTimer的机制,重新为一个编码包关联一个discardTimer,来解决在接入层引入网络编码后导致的PDCP SDU和PDCP PDU不再是一一对应时,如何丢弃已经QoS失效的SDU和PDU的问题。应理解,在实施例二中,如果网络编码功能处理生成的是原数据包和冗余包(即图5a示意的方案),则分别为一个原数据包和一个冗余包关联一个discardTimer。实施例三阐述网络编码(NC)功能位于PDCP层内,沿用一个PDCP SDU关联一个discardTimer的机制,并且PDCP PDU只有当其包含的所有PDCP SDU关联的discardTimer都超时才被丢弃。实施例四阐述网络编码(NC)功能位于PDCP层内,沿用一个PDCP SDU关联一个discardTimer的机制,当某个PDCP SDU关联的discardTimer超时后,不仅丢弃这个PDCP SDU,还丢弃这个PDCP SDU对应的所有PDCP PDU。可理解的,本申请实施例一至实施例四所描述的技术方案可以任一组合形成新的实施例且所涉及概念或方案相同或相似的部分可以相互参考或组合。下面分别对各个实施例进行详细说明。
可选的,在介绍本申请实施例之前,先介绍本申请实施例主要涉及的三种协议层架构或应用场景。其中基站可以采用gNB-CU和gNB-DU分离的架构。参见图9a,图9a是本申请实施例提供的网络编码功能位于PDCP层内的协议层架构示意图。如图9a所示,网络编码功能位于UE和gNB-CU的PDCP层内,也就是说在PDCP层内实现网络编码功能。参见图9b,图9b是本申请实施例提供的NC层在PDCP层之下的协议层架构示意图,也就是说在NC层内实现网络编码功能。如图9b所示,NC层分别位于UE和gNB-CU的PDCP层之下。从gNB-CU的角度而言,NC层位于PDCP层和GTP层之间;从UE的角度而言,NC层位于PDCP层和RLC层之间。参见图9c,图9c是本申请实施例提供的NC层在RLC层之上的协议层架构示意图。如图9c所示,NC层分别位于UE和gNB-DU的RLC层之上。从gNB-DU的角度而言,NC层位于RLC层之上;从UE的角度而言,NC层位于PDCP层和RLC层之间。
应理解,本申请提供的技术方案还可以应用于非CU-DU分离的架构,当基站为非CU-DU分离的架构时,其基站内的协议层架构与UE的协议层架构相同,此处不再赘述。
可选的,本申请涉及的通信装置既可以是终端设备,如图1中的UE或图4中的UE120,也可以是网络设备,如图1的基站或图4中的基站110。如果通信装置为基站,该通信装置可采用图2中gNB-CU和gNB-DU分离的架构。
实施例一
本申请实施例一主要介绍通过取消当前一个PDCP SDU关联一个discardTimer的机制,重新为一组待编码的原始数据(例如:多个PDCP SDU)关联一个discardTimer,来解决在接入层引入网络编码后导致的PDCP SDU和PDCP PDU不再是一一对应时,如何丢弃已经QoS失效的SDU和PDU的问题。本申请实施例一还介绍在PDCP层外(即PDCP层之下或RLC层之上)引入网络编码后,RLC层如何丢弃从上层收到的已经QoS失效的PDCP PDU。
可选的,为了便于理解,本申请实施例一以原始数据(即PDCP SDU/PDU)进行网络编码功能的处理后生成系统包和冗余包(即图5b示意的方案)为例进行介绍说明。应理解,本申请实施例一描述的技术方案仍然适用于对原始数据(即PDCP SDU/PDU)进行网络编码功能的处理后生成原数据包和冗余包(即图5a示意的方案)的场景。
参见图10,图10是本申请实施例提供的网络编码场景下的超时丢包方法的第一种示意流程图。如图10所示,该网络编码场景下的超时丢包方法包括但不限于以下步骤:
S101,通信装置获取一组原始数据,该一组原始数据关联一个定时器,该一组原始数据用于一起进行网络编码功能的处理生成多个第一数据包。
S102,若该一组原始数据关联的定时器超时,通信装置丢弃以下中的至少一项:该一组原始数据,该一组原始数据进行网络编码功能的处理生成的该多个第一数据包。
可选的,上述多个第一数据包包括系统包和冗余包,或者,上述多个第一数据包包括原数据包和冗余包。本申请实施例以多个第一数据包包括系统包和冗余包(本文中统称为编码包)为例进行说明。
可选的,本申请实施例适用于前述图9a至图9c中任一种协议层架构。下面结合具体的协议层架构进行详细说明。其中,本申请实施例中的通信装置至少包括PDCP层和RLC层,可选的还包括NC层。
可选的,上述原始数据可以是从上层接收到的PDCP SDU或PDCP PDU,或者上述原始数据还可以是PDCP SDU/PDU经过分割,级联,加填充(padding)等处理中的一项或多项后,再添加包头得到原数据包。也就是说,本申请实施例既可以是为从上层接收到的一组PDCP SDU/PDU关联一个定时器,也可以是为一组原数据包关联一个定时器。为便于描述,下面以原始数据是从上层接收到的PDCP SDU或PDCP PDU为例进行说明。
1、网络编码功能位于PDCP层内
可选的,网络编码功能位于PDCP层内,即前述图9a所示的协议层架构,上述原始数据为PDCP SDU。通信装置的PDCP层从上层(如SDAP层)接收到多个PDCP SDU,并取消/关闭每个PDCP SDU关联一个discardTimer的机制,或者说关闭每个PDCP SDU与一个discardTimer的关联功能。该通信装置的PDCP层确定待进行网络编码功能处理的一组原始数据,例如:将收到的多个PDCP SDU作为一组原始数据,或者,将收到的多个PDCP SDU中的前N个PDCP SDU作为一组原始数据,N为正整数,并为该组PDCP SDU(即该组原始数据)关联一个定时器。该通信装置的PDCP层将该组PDCP SDU一起/联合/共同进行网络编码功能的处理生成多个编码包,具体的网络编码功能的处理可参考前述图5b所示,此处不再赘述。如果该组PDCP SDU(即该组原始数据)关联的定时器超时,说明该组PDCP SDU已经QoS失效,则该通信装置的PDCP层丢弃该组PDCP SDU(即该组原始数据),和该组PDCP SDU(即该组原始数据)进行网络编码功能处理生成的全部编码包。
可选的,通信装置的PDCP层获得上述编码包后,可以针对每个编码包加PDCP头得到一个PDCP PDU。也就是说,一个编码包与一个PDCP PDU对应。因此,如果该组PDCP SDU关联的定时器超时,说明该组PDCP SDU已经QoS失效,则通信装置的PDCP层不仅丢弃该组PDCPSDU和该组PDCP SDU进行网络编码功能处理生成的全部编码包之外,还丢弃该组PDCP SDU对应的PDCP PDU(即:丢弃该组PDCP SDU进行网络编码功能处理生成的每个编码包对应的PDCP PDU)。应理解,这里的通信装置还可以称为发送PDCP实体,即发送端的PDCP实体或用于发送的PDCP实体。
简言之,网络编码功能位于PDCP层内,发送PDCP实体从上层收到一个PDCP SDU,取消该PDCP SDU与一个discardTimer的关联,改为发送PDCP实体将从上层收到的一组PDCPSDU关联一个discardTimer,一旦该discardTimer超时,则丢弃这一组PDCP SDU、该组PDCPSDU对应的编码包、以及对应的PDCP PDU。
可见,本申请实施例在定时器超时后,不仅丢弃与该定时器关联的一组PDCP SDU,还丢弃相应的编码包和PDCP PDU,可以减少已经QoS失效的PDCP PDU传输至下一层的概率,从而节省空口资源。
示例性的,以前述图8为例,发送PDCP实体接收到PDCP SDU0、PDCP SDU1和PDCPSDU2后,将这三个PDCP SDU作为一组原始数据,与一个discardTimer关联。然后,再将这一组原始数据(即PDCP SDU0~PDCP SDU2)进行网络编码功能的处理生成编码包,对每个编码包加PDCP头后生成PDCP PDU。因此,一旦一组原始数据(即PDCP SDU0~PDCP SDU2)关联的discardTimer超时,则发送PDCP实体将丢弃PDCP SDU0、PDCP SDU1、PDCP SDU2,和(PDCPSDU0、PDCP SDU1、PDCP SDU2分别)对应的编码包,以及对应的PDCP PDU0、PDCP PDU1、PDCPPDU2和PDCP PDU3。可选的,如果发送PDCP实体已经将PDCP PDU0~PDCP PDU3中的一个或多个发送到RLC层,则发送PDCP实体需要指示RLC层丢弃相应的PDCP PDU。应理解,PDCP PDU传输至RLC层时,会被RLC层认为是RLC SDU,因此,发送RLC层实体(本申请将实现RLC层功能的实体称为RLC层实体,将发送端的RLC层实体称为用于发送的RLC层实体,简称为发送RLC层实体)丢弃相应的PDCP PDU,可以理解为发送RLC层实体丢弃相应的RLC SDU。
应理解,这里的通信装置既可以是终端设备,如UE;也可以是网络设备,如基站。还应理解,如果通信装置是基站,可以采用CU-DU分离的架构,该通信装置具体为gNB-CU。也就是说,下行(DL)方向,发送PDCP实体位于gNB-CU上;上行(UL)方向,发送PDCP实体位于UE上。
2、网络编码功能位于PDCP层之下
可选的,网络编码功能位于PDCP层之下,PDCP层之下引入一个新的NC层,网络编码功能位于NC层,即前述图9b所示的协议层架构,上述原始数据为PDCP PDU。可选的,通信装置的PDCP层取消/关闭一个PDCP SDU关联一个discardTimer的机制,或者说,通信装置关闭PDCP层中PDCP SDU与discardTimer的关联功能。
通信装置的NC层从上层(如PDCP层)接收到多个PDCP PDU,并确定待进行网络编码功能处理的一组原始数据,例如:将收到的多个PDCP PDU作为一组原始数据,或者,将收到的多个PDCP PDU中的前N个PDCP PDU作为一组原始数据,N为正整数,将该组PDCP PDU(即该组原始数据)关联一个定时器。通信装置的NC层将该组PDCP PDU一起/联合/共同进行网络编码功能的处理生成多个编码包,具体的网络编码功能的处理可参考前述图5b所示,此处不再赘述。如果该组PDCP PDU(即该组原始数据)关联的定时器超时,说明该组PDCP PDU已经QoS失效,则通信装置丢弃该组PDCP PDU(即该组原始数据),和该组PDCP PDU(即该组原始数据)进行网络编码功能的处理生成的全部编码包。
可选的,通信装置的PDCP层从上层(如SDAP层)接收到一个PDCP SDU,就对该PDCPSDU执行头压缩、加密/完整性保护和加PDCP头后得到一个PDCP PDU,并将该PDPC PDU传输至下层(如NC层)。也就是说,一个PDCP PDU与一个PDCP SDU对应。如果该组PDCP PDU关联的定时器超时,通信装置也可以丢弃该组PDCP PDU分别对应的PDCP SDU。
简言之,NC层位于PDCP层之下,可选的,通信装置的PDCP层从上层收到一个PDCPSDU,取消该PDCP SDU与一个discardTimer的关联。通信装置的PDCP层对该PDCP SDU执行头压缩、加密/完整性保护后添加PDCP头得到一个PDCP PDU发送至下层(如NC层)。当通信装置的NC层从上层(即PDCP层)收到多个PDCP PDU后,确定待进行网络编码功能处理的一组原始数据(即:原始数据为PDCP PDU),例如:将收到的多个PDCP PDU作为一组原始数据,或者,将收到的多个PDCP PDU中的前N个PDCP PDU作为一组原始数据,N为正整数,将该组PDCP PDU关联一个discardTimer,一旦该discardTimer定时器超时,则丢弃这一组PDCP PDU、该组PDCP PDU对应的编码包、以及对应的PDCP SDU。
应理解,这里的通信装置既可以是终端设备,如UE;也可以是网络设备,如基站。还应理解,如果通信装置是基站,可以采用CU-DU分离的架构,该通信装置具体为gNB-CU。
可选的,如果上述通信装置是终端设备(如UE),则NC层位于PDCP层之下,也就是UE的NC层位于UE的PDCP层和RLC层之间。UE的NC层将上述一组PDCP PDU一起进行网络编码功能处理生成的全部或部分编码包传输至UE的RLC层后,如果UE上与这一组PDCP PDU关联的定时器超时,则UE的NC层可以指示UE的RLC层丢弃传输至RLC层的该编码包。换句话说,如果UE的NC层已经将这一组PDCP PDU进行网络编码处理生成的编码包发送至RLC层,且与这一组PDCP PDU关联的定时器超时,则UE的NC层还需要指示UE的RLC层删除这些编码包。相应地,UE的RLC层丢弃从UE的NC层接收到的该编码包。应理解,如果UE的NC层已经将这一组PDCP PDU进行网络编码处理生成的部分编码包发送至RLC层,则UE的NC层可以指示RLC层删除发送至该RLC层的这部分编码包,也就是说未发送至RLC层的编码包不需要NC层指示RLC层删除。同理,如果UE的NC层已经将这一组PDCP PDU进行网络编码处理生成的全部编码包发送至RLC层,则UE的NC层需要指示RLC层删除该全部编码包。其中,因为UE的PDCP层、NC层以及RLC层都在UE上实现,所以UE上各层之间的交互可以通过原语来实现,也就是说UE的NC层对RLC层的指示可通过原语实现。
示例性的,参见图11a,图11a是本申请实施例提供的UE侧超时丢包示意图一。如图11a所示,UE的PDCP层从上层收到一个PDCP SDU,可选的,取消该PDCP SDU与一个discardTimer的关联。UE的PDCP层对该PDCP SDU执行头压缩、加密/完整性保护后添加PDCP头得到一个PDCP PDU发送至NC层。UE的NC层从PDCP层接收到PDCP PDU0(即图11a中SN=0的PDCP PDU)、PDCP PDU1(即图11a中SN=1的PDCP PDU)和PDCP PDU2(即图11a中SN=2的PDCPPDU)后,将这三个PDCP PDU作为一组原始数据,与一个discardTimer关联。然后,UE的NC层将这一组原始数据(即PDCP PDU0~PDCP PDU2)一起进行网络编码的处理后生成编码包(如图11a所示的编码包0~3,其中编码包0和编码包1是系统包,编码包2和编码包3是冗余包)。一旦这一组原始数据(即PDCP PDU0~PDCP PDU2)关联的discardTimer超时,则UE将丢弃PDCP PDU0~PDCP PDU2,和编码包0~3,可选的还可以丢弃PDCP PDU0~PDCP PDU2分别对应的PDCP SDU0~PDCP SDU2。如图11a所示,如果UE的NC层将编码包0(即图11a中数据包标识(packet ID)为0的编码包)和编码包1(即图11a中packet ID为1的编码包)发送至UE的RLC层后,一旦与PDCP PDU0~PDCP PDU2关联的discardTimer超时,则UE的NC层指示UE的RLC层丢弃传输至RLC层的编码包0和编码包1。应理解,如果与PDCP PDU0~PDCP PDU2关联的discardTimer超时,UE的NC层尚未将任一编码包发送至UE的RLC层,则UE的NC层直接丢弃编码包0~3。
应理解,因为本申请实施例不涉及(或不关心)系统包和冗余包的包头设计,所以上述图11a示出的系统包和冗余包未画出其包头,但实际应用中,系统包和冗余包均包括包头信息。还应理解,图11a中数据包上打叉“×”,表示discardTimer超时后,丢弃该数据包。
可选的,如果上述通信装置是基站,且采用CU-DU分离的架构,则该通信装置具体为gNB-CU,也就是说NC层位于gNB-CU上且处于PDCP层之下。gNB-CU在对一组PDCP PDU进行网络编码的处理生成编码包后,可以将生成的该编码包发送至gNB-DU。gNB-CU将这一组PDCP PDU进行网络编码处理生成的全部或部分编码包发送至gNB-DU后,如果gNB-CU上与这一组PDCP PDU关联的定时器超时,则gNB-CU可以向gNB-DU发送指示信息,用于指示gNB-DU丢弃从gNB-CU接收到的由这一组PDCP PDU进行网络编码处理生成的全部或部分编码包。其中,该指示信息中包括以下中的一种:发送至gNB-DU的一个或多个编码包各自的标识,比如数据包标识(packet ID);该一个或多个编码包的标识所属范围(即标识的最大值至最小值这个范围),比如packet ID范围,通过packet ID的最大值和最小值来指示;该一个或多个编码包所属编码块的标识,比如编码块标识(block ID);该一个或多个编码包各自对应的编码系数因子标识(或编码系数索引),比如:编码系数因子标识Coeff ID。相应地,gNB-DU接收到该指示信息后,可以根据该指示信息的指示,丢弃该指示信息指示的编码包。换句话说,如果gNB-CU已经将这一组PDCP PDU进行网络编码处理生成的编码包发送至gNB-DU,则gNB-CU需要指示gNB-DU删除这些编码包。比如,gNB-CU向gNB-DU发送需要丢弃的编码包的编号(如packet ID),指示gNB-DU丢弃该编号所标识的编码包。也就是说,如果gNB-CU已经将部分编码包发送至gNB-DU,则上述指示信息中需要携带这部分编码包的标识(如packetID)。或者,gNB-CU向gNB-DU发送用于指示这部分编码包所属的编码块的标识(如blockID),指示gNB-DU丢弃编码包中block ID字段与该block ID相同的编码包,因为编码包中会携带生成该编码包所属编码块的信息。或者,gNB-CU向gNB-DU发送用于指示这部分编码包对应的编码系数因子标识(如Coeff ID),指示gNB-DU丢弃编码包中Coeff ID字段与该Coeff ID相同的编码包,因为编码包中会携带生成该编码包所使用的编码系数因子的信息。其中,上述指示信息可以携带在DL User Data中,还可以是新定义的一个信令,本申请实施例对此不做限定。
应理解,如果gNB-CU将某个编码包发送至gNB-DU后,gNB-CU的存储空间(比如缓存)中就不存在该编码包了,则gNB-CU上与生成该编码包的一组PDCP PDU关联的定时器超时且该编码包已经被发送至gNB-DU后,gNB-CU无需自己执行丢弃该编码包的操作,可以通过指示信息指示gNB-DU去丢弃这个编码包。反之,如果gNB-CU将某个编码包发送至gNB-DU后,gNB-CU的存储空间(比如缓存)中仍然存在这个编码包,则该编码包被发送至gNB-DU后,如果与生成该编码包的一组PDCP PDU关联的定时器超时,则gNB-CU不仅丢弃该编码包,还可通过指示信息指示gNB-DU也丢弃该编码包。
示例性的,参见图11b,图11b是本申请实施例提供的gNB侧NC层位于PDCP层之下的超时丢包示意图一。如图11b所示,gNB-CU的PDCP层从上层收到一个PDCP SDU,可选的,取消该PDCP SDU与一个discardTimer的关联。gNB-CU的PDCP层对该PDCP SDU执行头压缩、加密/完整性保护后添加PDCP头得到一个PDCP PDU发送至NC层。gNB-CU的NC层从PDCP层接收到PDCP PDU0(即图11b中SN=0的PDCP PDU)、PDCP PDU1(即图11b中SN=1的PDCP PDU)和PDCPPDU2(即图11b中SN=2的PDCP PDU)后,将这三个PDCP PDU作为一组原始数据,与一个discardTimer关联。然后,gNB-CU的NC层将这一组原始数据(即PDCP PDU0~PDCP PDU2)一起进行网络编码功能处理后生成编码包(如图11b所示的编码包0~3,其中编码包0和编码包1是系统包,编码包2和编码包3是冗余包)。一旦这一组原始数据(即PDCP PDU0~PDCPPDU2)关联的discardTimer超时,则gNB-CU将丢弃PDCP PDU0~PDCP PDU2,和编码包0~3,可选的还可以丢弃PDCP PDU0~PDCP PDU2分别对应的PDCP SDU0~PDCP SDU2。如图11b所示,如果gNB-CU将编码包0(即图11b中packet ID为0的编码包)和编码包1(即图11b中packet ID为1的编码包)发送至gNB-DU后,与PDCP PDU0~PDCP PDU2关联的discardTimer超时,则gNB-CU向gNB-DU发送指示信息,该指示信息可携带编码包0和编码包1的packetID,用于指示gNB-DU丢弃从gNB-CU接收到的编码包0和编码包1。gNB-DU接收到该指示信息后,根据指示信息丢弃编码包0和编码包1。应理解,如果与PDCP PDU0~PDCP PDU2关联的discardTimer超时,gNB-CU尚未将任一编码包发送至gNB-DU,则gNB-CU直接丢弃编码包0~3。
应理解,上述图11b示出的系统包和冗余包未画出其包头,但实际应用中,系统包和冗余包均包括包头信息。还应理解,图11b中数据包上打叉“×”,表示discardTimer超时后,丢弃该数据包。
可见,当NC层位于UE和gNB-CU的PDCP层之下时,由于PDCP PDU封装在编码包内,导致RLC层无法直接看到PDCP PDU,从而无法沿用现有机制来丢弃已经QoS失效的数据包;本申请实施例通过层间交互(原语)或指示信息来指示RLC层丢弃已经QoS失效的编码包,从而可以减少QoS失效的数据在空口发送造成的资源浪费。
3、网络编码功能位于RLC层之上
可选的,网络编码层功能位于RLC层之上,RLC层之上引入一个新的NC层,网络编码功能位于NC层,即前述图9c所示的协议层架构,上述原始数据为PDCP PDU。应理解,对于终端设备(如UE)而言,因为NC层位于RLC层之上,且NC层位于PDCP层之下,UE侧的协议层架构与图9b完全相同,因此NC层位于RLC层之上时UE的处理流程可以沿用本申请实施例前述NC层位于PDCP层之下时UE的处理流程,此处不再赘述。
对于采用CU-DU分离架构的基站而言,NC层位于RLC层之上(前述图9b所示的gNB侧协议层架构),与NC层位于PDCP层之下(前述图9c所示的gNB侧协议层架构)的不同之处在于:NC层位于RLC层之上时,通信装置是gNB-DU,也就是说NC层位于gNB-DU上且处于RLC层之上。此种情况下,gNB-CU向gNB-DU发送的是PDCP PDU。可选的,gNB-CU可以取消/关闭一个PDCP SDU关联一个discardTimer的机制。gNB-DU从gNB-CU接收到多个PDCP PDU,并确定待进行网络编码功能处理的一组原始数据,例如:将收到的多个PDCP PDU作为一组原始数据,或者,将收到的多个PDCP PDU中的前N个PDCP PDU作为一组原始数据,N为正整数,并为该组PDCP PDU(即该组原始数据)关联一个定时器。gNB-DU将该组PDCP PDU一起/联合/共同进行网络编码功能处理生成多个编码包,具体的网络编码功能处理可参考前述图5b所示,此处不再赘述。如果该组PDCP PDU(即该组原始数据)关联的定时器超时,说明该组PDCP PDU已经QoS失效,则gNB-DU可以丢弃该组PDCP PDU(即该组原始数据),和该组PDCP PDU(即该组原始数据)进行网络编码功能处理生成的全部编码包。
可选的,gNB-DU的NC层将上述一组PDCP PDU一起进行网络编码功能处理生成的全部或部分编码包传输至gNB-DU的RLC层后,如果与这一组PDCP PDU关联的定时器超时,则gNB-DU的NC层可以指示gNB-DU的RLC层丢弃传输至该RLC层的该编码包。换句话说,如果gNB-DU的NC层已经将这一组PDCP PDU进行网络编码功能处理生成的编码包发送至RLC层,则gNB-DU的NC层还需要指示gNB-DU的RLC层删除这些编码包。相应地,gNB-DU的RLC层丢弃从gNB-DU的NC层接收到的该编码包。其中,gNB-DU上各层之间的交互可以通过原语来实现,也就是说gNB-DU的NC层对RLC层的指示可通过原语实现。
示例性的,参见图11c,图11c是本申请实施例提供的gNB侧NC层位于RLC层之上的超时丢包示意图一。如图11c所示,gNB-CU的PDCP层从上层收到一个PDCP SDU,可选的,取消该PDCP SDU与一个discardTimer的关联。gNB-CU的PDCP层对该PDCP SDU执行头压缩、加密/完整性保护后添加PDCP头得到PDCP PDU发送至gNB-DU。gNB-DU的NC层从gNB-CU接收到PDCPPDU0(即图11c中SN=0的PDCP PDU)、PDCP PDU1(即图11c中SN=1的PDCP PDU)和PDCP PDU2(即图11c中SN=2的PDCP PDU)后,将这三个PDCP PDU作为一组原始数据,与一个discardTimer关联。然后,gNB-DU的NC层将这一组原始数据(即PDCP PDU0~PDCP PDU2)一起进行网络编码功能处理后生成编码包(如图11c所示的编码包0~3,其中编码包0和编码包1是系统包,编码包2和编码包3是冗余包)。一旦这一组原始数据(即PDCP PDU0~PDCPPDU2)关联的discardTimer超时,则gNB-DU将丢弃PDCP PDU0~PDCP PDU2,和编码包0~3。如图11c所示,如果gNB-DU的NC层将编码包0(即图11c中packet ID为0的编码包)和编码包1(即图11c中packet ID为1的编码包)发送至gNB-DU的RLC层后,与PDCP PDU0~PDCP PDU2关联的discardTimer超时,则gNB-DU的NC层指示gNB-DU的RLC层丢弃传输至RLC层的编码包0和编码包1。应理解,如果与PDCP PDU0~PDCP PDU2关联的discardTimer超时,gNB-DU的NC层尚未将任一编码包发送至gNB-DU的RLC层,则gNB-DU的NC层直接丢弃编码包0~3。
应理解,上述图11c示出的系统包和冗余包未画出其包头,但实际应用中,系统包和冗余包均包括包头信息。还应理解,图11c中数据包上打叉“×”,表示discardTimer超时后,丢弃该数据包。
可见,当NC层位于UE和gNB-DU的RLC层之上时,由于PDCP PDU封装在编码包内,导致RLC层无法直接看到PDCP PDU,从而无法沿用现有机制来丢弃已经QoS失效的数据包;本申请实施例通过层间交互(原语)来指示RLC层丢弃已经QoS失效的编码包,从而可以减少QoS失效的数据在空口发送造成的资源浪费,提升空口传输的效率。
应理解,对于NC层位于PDCP层之下和NC层位于RLC层之上这两种情况,本申请实施例以gNB采用CU-DU分离架构为例进行说明的,但本申请实施例仍然适用于gNB采用非CU-DU分离架构的场景,即:在下行(DL)方向,PDCP层、NC层以及RLC层都位于gNB上。当gNB采用非CU-DU分离架构时,所有层间交互都在gNB上实现(也就是说需要新增gNB内各层间的交互),其处理流程可参考UE侧的处理流程,此处不再赘述。
本实施例以原数据包生成编码包(包括系统包和冗余包)为例进行说明(即图5b示意的方案),同理,本实施例同样适应于原数据包生成冗余包的场景(即图5a示例的方案),只需要将上述方案中的编码包替换为冗余包,将系统包替换为原数据包即可。
可见,本申请实施例,一方面通过取消一个PDCP SDU关联一个discardTimer的机制,重新为一组待编码的原始数据关联一个discardTimer,当该discardTimer超时后,丢弃这一组待编码的原始数据以及这一组待编码的原始数据经过网络编码功能处理生成的编码包;可以解决在接入层引入网络编码后导致的PDCP SDU和PDCP PDU不再一一对应时,如何丢弃已经QoS失效的SDU和PDU的问题,从而可以减少QoS失效的数据在空口发送造成的资源浪费,提升空口传输的效率。本申请实施例,另一方面通过层间交互(原语)或指示信息来指示RLC层丢弃已经QoS失效的编码包,可以解决由于PDCP PDU封装在编码包内导致的RLC层无法直接看到PDCP PDU,从而无法沿用现有机制来丢弃已经QoS失效的数据包的问题,进一步减少资源浪费,提升空口传输的效率。
实施例二
本申请实施例二主要介绍通过取消当前一个PDCP SDU关联一个discardTimer的机制,重新为一个编码包关联一个discardTimer,来解决在接入层引入网络编码后导致的PDCP SDU和PDCP PDU不再是一一对应时,如何丢弃已经QoS失效的SDU和PDU的问题。本申请实施例二还介绍当在PDCP层外(即PDCP层之下或RLC层之上)引入网络编码后,RLC层如何丢弃从上层收到的已经QoS失效的PDCP PDU。
应理解,在本申请实施例二中,如果网络编码功能处理生成的是原数据包和冗余包(即图5a示意的方案),则分别为一个原数据包和一个冗余包关联一个discardTimer。
本实施例以原数据包生成编码包(包括系统包和冗余包)为例进行说明(即图5b示意的方案)。
参见图12,图12是本申请实施例提供的网络编码场景下的超时丢包方法的第二种示意流程图。如图12所示,该网络编码场景下的超时丢包方法包括但不限于以下步骤:
S201,通信装置对原始数据进行网络编码功能的处理生成多个第一数据包,一个该第一数据包关联一个定时器,该多个第一数据包包括系统包和冗余包,或者,该多个第一数据包包括原数据包和冗余包。
S202,若该多个第一数据包中的第一数据包i关联的定时器超时,通信装置丢弃该第一数据包i。
可选的,上述多个第一数据包包括系统包和冗余包,或者,上述多个第一数据包包括原数据包和冗余包。本申请实施例以多个第一数据包包括系统包和冗余包(本文中统称为编码包)为例进行说明。
可选的,本申请实施例适用于前述图9a至图9c中任一种协议层架构。下面结合具体的协议层架构进行详细说明。其中,本申请实施例中的通信装置至少包括PDCP层和RLC层,可选的还包括NC层。
1、网络编码功能位于PDCP层内
可选的,网络编码功能位于PDCP层内,即前述图9a所示的协议层架构,上述原始数据包括一个或多个PDCP SDU。通信装置的PDCP层从上层(如SDAP层)接收到一个或多个PDCPSDU(即原始数据),并取消/关闭每个PDCP SDU关联一个discardTimer的机制,或者说关闭每个PDCP SDU与一个discardTimer的关联功能。通信装置的PDCP层将该一个或多个PDCPSDU一起/联合/共同进行网络编码功能的处理生成多个编码包,具体的网络编码功能处理可参考前述图5b所示,此处不再赘述。通信装置的PDCP层每得到一个编码包,为该编码包关联一个定时器。如果与某个编码包关联的定时器超时,说明这个编码包已经QoS失效,则通信装置的PDCP层丢弃该编码包。
可选的,通信装置的PDCP层每获得一个编码包,可以对这个编码包加PDCP头得到一个PDCP PDU。也就是说,一个编码包与一个PDCP PDU对应。如果与某个编码包关联的定时器超时,说明这个编码包已经QoS失效,则通信装置的PDCP层不仅可以丢弃该编码包,还可以丢弃该编码包对应的PDCP PDU。
可选的,因为系统包中包体的内容与PDCP SDU一致,而冗余包是原始数据(即一个或多个PDCP SDU)和编码系数相乘再相加作用的结果;所以一个编码包对应一个或多个PDCP SDU。如果与某个编码包关联的定时器超时,说明这个编码包已经QoS失效,则通信装置的PDCP层不仅可以丢弃该编码包,还可以丢弃该编码包对应的PDCP SDU。
应理解,这里的通信装置还可以称为发送PDCP实体,即发送端的PDCP实体或用于发送的PDCP实体。
简言之,网络编码功能位于PDCP层内,发送PDCP实体从上层收到一个PDCP SDU,取消该PDCP SDU与一个discardTimer的关联,改为发送PDCP实体从上层收到一个或多个PDCPSDU后,对这一个或多个PDCP SDU进行网络编码功能的处理后生成多个编码包,并为每个编码包关联一个discardTimer。由于编码包与PDCP PDU一一对应,所以,一旦一个编码包关联的discardTimer超时,则发送PDCP实体将丢弃该编码包以及该编码包对应的PDCP PDU和/或PDCP SDU。
可见,本申请实施例在定时器超时后,不仅丢弃相应的编码包,还丢弃该编码包对应的PDCP PDU(因为编码包已经QoS失效,由该编码包加PDCP头得到的PDCP PDU同样已经QoS失效)和/或PDCP SDU(因为编码包已经QoS失效,生成该编码包的PDCP SDU也即将/已经QoS失效),可以减少已经QoS失效的PDCP PDU传输至下一层的概率,从而节省空口资源,提升空口传输的效率。
示例性的,以前述图8为例,发送PDCP实体接收到PDCP SDU0、PDCP SDU1和PDCPSDU2后,将这三个PDCP SDU进行网络编码功能的处理后生成编码包,并为每个编码包关联一个discardTimer,对每个编码包加PDCP头后生成PDCP PDU。假设与第一个编码包关联的discardTimer超时,则发送PDCP实体将丢弃该第一个编码包、该第一个编码包对应的PDCPPDU0,和/或PDCP SDU0和PDCP SDU1。可选的,如果发送PDCP实体已经将PDCP PDU0发送到RLC层,则发送PDCP实体需要指示RLC层丢弃PDCP PDU0。
应理解,这里的通信装置既可以是终端设备,如UE;也可以是网络设备,如基站。还应理解,如果通信装置是基站,可以采用CU-DU分离的架构,该通信装置具体为gNB-CU。也就是说,下行(DL)方向,发送PDCP实体位于gNB-CU上;上行(UL)方向,发送PDCP实体位于UE上。
2、网络编码功能位于PDCP层之下
可选的,网络编码功能位于PDCP层之下,PDCP层之上引入一个新的NC层,网络编码功能位于NC层,即前述图9b所示的协议层架构,上述原始数据包括一个或多个PDCP PDU。可选的,通信装置的PDCP层取消/关闭一个PDCP SDU关联一个discardTimer的机制,或者说关闭PDCP SDU与discardTimer的关联功能。通信装置的NC层从上层(如PDCP层)接收到一个或多个PDCP PDU(即原始数据),再将该一个或多个PDCP PDU一起/联合/共同进行网络编码功能的处理生成多个编码包,具体的网络编码功能处理可参考前述图5b所示,此处不再赘述。通信装置的NC层每得到一个编码包,为该编码包关联一个定时器。如果与某个编码包关联的定时器超时,说明这个编码包已经QoS失效,则通信装置丢弃该编码包。可选的,因为系统包中包体的内容与PDCP PDU一致,而冗余包是原始数据(即一个或多个PDCP PDU)和编码系数相乘再相加作用的结果;所以一个编码包对应一个或多个PDCP PDU。因此,如果与某个编码包关联的定时器超时,说明这个编码包已经QoS失效,则通信装置不仅可以丢弃该编码包,还可以丢弃该编码包对应的PDCP PDU。
简言之,NC层位于PDCP层之下,通信装置的PDCP层从上层收到一个PDCP SDU,可选的,取消该PDCP SDU与一个discardTimer的关联。通信装置的PDCP层对该PDCP SDU执行头压缩、加密/完整性保护后添加PDCP头得到一个PDCP PDU发送至下层(如NC层)。当通信装置的NC层从上层(即PDCP层)收到一个或多个PDCP PDU后,对这一个或多个PDCP PDU进行网络编码功能的处理后生成编码包,并为每个编码包关联一个discardTimer。一旦一个编码包关联的discardTimer超时,则通信装置将丢弃该编码包以及该编码包对应的PDCP PDU。
应理解,这里的通信装置既可以是终端设备,如UE;也可以是网络设备,如基站。还应理解,如果通信装置是基站,可以采用CU-DU分离的架构,该通信装置具体为gNB-CU。
可选的,如果上述通信装置是终端设备(如UE),则NC层位于PDCP层之下,也就是UE的NC层位于UE的PDCP层和RLC层之间。UE的NC层将某个编码包传输至UE的RLC层后,如果与这个编码包关联的定时器超时,则UE的NC层可以指示UE的RLC层丢弃传输至RLC层的该编码包。换句话说,如果UE的NC层已经将该编码包发送至RLC层,且与该编码包关联的定时器超时,则UE的NC层可以指示RLC层删除发送至该RLC层的这个编码包。相应地,UE的RLC层丢弃从UE的NC层接收到的该编码包。其中,UE上各层之间的交互可以通过原语来实现,也就是说UE的NC层对RLC层的指示可通过原语实现。
示例性的,参见图13a,图13a是本申请实施例提供的UE侧超时丢包示意图二。如图13a所示,UE的PDCP层从上层收到一个PDCP SDU,可选的,取消该PDCP SDU与一个discardTimer的关联。UE的PDCP层对该PDCP SDU执行头压缩、加密/完整性保护后添加PDCP头得到一个PDCP PDU发送至NC层。UE的NC层从PDCP层接收到PDCP PDU0(即图13a中SN=0的PDCP PDU)、PDCP PDU1(即图13a中SN=1的PDCP PDU)和PDCP PDU2(即图13a中SN=2的PDCPPDU)后,将这三个PDCP PDU(即PDCP PDU0~PDCP PDU2)一起进行网络编码功能的处理后生成编码包0~3(如图13a所示编码包0和编码包1是系统包,编码包2和编码包3是冗余包),再为每个编码包关联一个discardTimer。一旦一个编码包关联的discardTimer超时,则UE将丢弃该编码包,可选的还丢弃该编码包对应的PDCP PDU。如图13a所示,如果UE的NC层将编码包0(即图13a中packet ID为0的编码包)传输至UE的RLC层后,与编码包0关联的discardTimer 1超时,则UE的NC层丢弃编码包0对应的PDCP PDU0和PDCP PDU1,并指示UE的RLC层丢弃传输至RLC层的编码包0。应理解,如果与编码包0关联的discardTimer 1超时,UE的NC层尚未将编码包0发送至UE的RLC层,则UE的NC层直接丢弃编码包0。
应理解,因为本申请实施例不涉及(或不关心)系统包和冗余包的包头设计,所以上述图13a示出的系统包和冗余包未画出其包头,但实际应用中,系统包和冗余包均包括包头信息。还应理解,图13a中数据包上打叉“×”,表示discardTimer 1超时后,丢弃该数据包。
可选的,如果上述通信装置是基站,且采用CU-DU分离的架构,则该通信装置具体为gNB-CU,也就是说NC层位于gNB-CU上且处于PDCP层之下。gNB-CU在对一个或多个PDCPPDU进行网络编码功能的处理生成编码包后,可以将生成的编码包发送至gNB-DU。如果gNB-CU已经将某个编码包发送至gNB-DU,且gNB-CU上与这个编码包关联的定时器超时,则gNB-CU可以向gNB-DU发送指示信息,用于指示gNB-DU丢弃这个编码包。其中,该指示信息中包括编码包的标识,比如数据包标识(packet ID)或,该指示信息中包括编码包对应的编码系数因子标识(或编码系数索引),比如,编码系数因子标识Coeff ID。相应地,gNB-DU接收到该指示信息后,可以根据该指示信息的指示,丢弃该指示信息指示的编码包。
应理解,如果gNB-CU将某个编码包发送至gNB-DU后,gNB-CU的存储空间(比如缓存)中就不存在该编码包了,则gNB-CU上与该编码包关联的定时器超时且该编码包已经被发送至gNB-DU后,gNB-CU无需自己执行丢弃该编码包的操作,而是通过指示信息指示gNB-DU去丢弃该编码包。反之,如果gNB-CU将某个编码包发送至gNB-DU后,gNB-CU的存储空间(比如缓存)中仍然存在这个编码包,则该编码包被发送至gNB-DU后,如果与该编码包关联的定时器超时,则gNB-CU不仅丢弃该编码包,还可通过指示信息指示gNB-DU也去丢弃该编码包。
示例性的,参见图13b,图13b是本申请实施例提供的gNB侧NC层位于PDCP层之下的超时丢包示意图二。如图13b所示,gNB-CU的PDCP层从上层收到一个PDCP SDU,可选的,取消该PDCP SDU与一个discardTimer的关联。gNB-CU的PDCP层对该PDCP SDU执行头压缩、加密/完整性保护后添加PDCP头得到一个PDCP PDU发送至NC层。gNB-CU的NC层从PDCP层接收到PDCP PDU0(即图13b中SN=0的PDCP PDU)、PDCP PDU1(即图13b中SN=1的PDCP PDU)和PDCPPDU2(即图13b中SN=2的PDCP PDU)后,将这三个PDCP PDU(即PDCP PDU0~PDCP PDU2)一起进行网络编码功能的处理后生成编码包0~3(如图13b所示编码包0和编码包1是系统包,编码包2和编码包3是冗余包),再为每个编码包关联一个discardTimer。一旦一个编码包关联的discardTimer超时,则gNB-CU将丢弃该编码包,可选的还丢弃该编码包对应的PDCP PDU。如图13b所示,如果gNB-CU将编码包0(即图13b中packet ID为0的编码包)发送至gNB-DU后,与编码包0关联的discardTimer1超时,则gNB-CU丢弃编码包0对应的PDCP PDU0和PDCPPDU1,并向gNB-DU发送指示信息,该指示信息可携带编码包0的packet ID,用于指示gNB-DU丢弃从gNB-CU接收到的编码包0。应理解,如果与编码包0关联的discardTimer 1超时,gNB-CU尚未将编码包0发送至gNB-DU,则gNB-CU直接丢弃编码包0。
应理解,上述图13b示出的系统包和冗余包未画出其包头,但实际应用中,系统包和冗余包均包括包头信息。还应理解,图13b中数据包上打叉“×”,表示discardTimer 1超时后,丢弃该数据包。
可见,当NC层位于UE和gNB-CU的PDPC层之下时,本申请实施例为一个编码包关联一个定时器,在与某个编码包关联的定时器超时后,通过层间交互(原语)或指示信息来指示RLC层丢弃已传输至该RLC层的该编码包,可以减少RLC层再将该编码包传输至下一层导致的空口资源浪费,提升空口传输的效率。
3、网络编码功能位于RLC层之上
可选的,网络编码功能位于RLC层之上,RLC层之上引入一个新的NC层,网络编码功能位于NC层,即前述图9c所示的协议层架构,上述原始数据包括一个或多个PDCP PDU。应理解,对于终端设备(如UE)而言,因为NC层位于RLC层之上,和NC层位于PDCP层之下,UE侧的协议层架构与图9b完全相同,因此NC层位于RLC层之上时UE的处理流程可以沿用本申请实施例前述NC层位于PDCP层之下时UE的处理流程,此处不再赘述。
对于采用CU-DU分离架构的基站而言,NC层位于RLC层之上(前述图9b所示的gNB侧协议层架构),与NC层位于PDCP层之下(前述图9c所示的gNB侧协议层架构)的不同之处在于:NC层位于RLC层之上时,通信装置是gNB-DU,也就是说NC层位于gNB-DU上且处于RLC层之上。此种情况下,gNB-CU向gNB-DU发送的是PDCP PDU。可选的,gNB-CU可以取消/关闭一个PDCP SDU关联一个discardTimer的机制。gNB-DU从gNB-CU接收到一个或多个PDCP PDU(即原始数据)后,将该一个或多个PDCP PDU一起/联合/共同进行网络编码功能的处理生成多个编码包,具体的网络编码功能处理可参考前述图5b所示,此处不再赘述。gNB-DU每得到一个编码包,为该编码包关联一个定时器。如果与某个编码包关联的定时器超时,说明这个编码包已经QoS失效,则gNB-DU可以丢弃这个编码包。本申请实施例中的编码包包括系统包和冗余包中至少一种。
可选的,gNB-DU的NC层将某个编码包传输至gNB-DU的RLC层后,如果与这个编码包关联的定时器超时,则gNB-DU的NC层可以指示gNB-DU的RLC层丢弃传输至RLC层的这个编码包。相应地,gNB-DU的RLC层丢弃从gNB-DU的NC层接收到的这个编码包。其中,gNB-DU上各层之间的交互可以通过原语来实现,也就是说gNB-DU的NC层对RLC层的指示可通过原语实现。
示例性的,参见图13c,图13c是本申请实施例提供的gNB侧NC层位于RLC层之上的超时丢包示意图二。如图13c所示,gNB-CU的PDCP层从上层收到一个PDCP SDU,可选的,取消该PDCP SDU与一个discardTimer的关联。gNB-CU的PDCP层对该PDCP SDU执行头压缩、加密/完整性保护后添加PDCP头得到一个PDCP PDU发送至gNB-DU。gNB-DU的NC层从gNB-CU接收到PDCP PDU0(即图13c中SN=0的PDCP PDU)、PDCP PDU1(即图13c中SN=1的PDCP PDU)和PDCPPDU2(即图13c中SN=2的PDCP PDU)后,将这三个PDCP PDU(即PDCP PDU0~PDCP PDU2)一起进行网络编码功能的处理后生成编码包0~3(如图13c所示编码包0和编码包1是系统包,编码包2和编码包3是冗余包),再为每个编码包关联一个discardTimer。一旦一个编码包关联的discardTimer超时,则gNB-DU将丢弃该编码包,可选的还丢弃该编码包对应的PDCP PDU。如图13c所示,如果gNB-DU的NC层将编码包0(即图13c中packet ID为0的编码包)传输至gNB-DU的RLC层后,与编码包0关联的discardTimer 1超时,则gNB-DU的NC层丢弃编码包0对应的PDCP PDU0和PDCP PDU1,并指示gNB-DU的RLC层丢弃传输至RLC层的编码包0。应理解,如果与编码包0关联的discardTimer 1超时,gNB-DU的NC层尚未将编码包0发送至gNB-DU的RLC层,则gNB-DU的NC层直接丢弃编码包0。
上述图13c示出的系统包和冗余包未画出其包头,但实际应用中,系统包和冗余包均包括包头信息。应理解,图13c中数据包上打叉“×”,表示discardTimer 1超时后,丢弃该数据包。
应理解,对于NC层位于PDCP层之下和NC层位于RLC层之上这两种情况,本申请实施例以gNB采用CU-DU分离架构为例进行说明的,但本申请实施例仍然适用于gNB采用非CU-DU分离架构的场景,即:在下行(DL)方向,PDCP层、NC层以及RLC层都位于gNB上。当gNB采用非CU-DU分离架构时,所有层间交互都在gNB上实现(也就是说需要新增gNB内各层间的交互),其处理流程可参考UE侧的处理流程,此处不再赘述。
本实施例以原数据包生成编码包(包括系统包和冗余包)为例进行说明(即图5b示意的方案),同理,本实施例同样适应于原数据包生成冗余包的场景(即图5a示例的方案),只需要将上述方案中的编码包替换为冗余包,将系统包替换为原数据包即可。
可见,本申请实施例,一方面通过取消一个PDCP SDU关联一个discardTimer的机制,重新为一个编码包关联一个discardTimer,当该discardTimer超时后,丢弃这个编码包以及该编码包对应的PDCP PDU;不仅可以解决PDCP SDU和PDCP PDU不再一一对应时,如何丢弃已经QoS失效的SDU和PDU的问题,从而减少QoS失效的数据在空口发送造成的资源浪费,提升空口传输的效率,还可以精确丢包(因为一个编码包关联一个discardTimer),减少误丢包的情况。本申请实施例,另一方面通过层间交互(原语)或指示信息来指示RLC层丢弃已经QoS失效的编码包,可以解决由于PDCP PDU封装在编码包内导致的RLC层无法直接看到PDCP PDU,从而无法沿用现有机制来丢弃已经QoS失效的数据包的问题,进一步减少资源浪费,提升空口传输的效率。
实施例三
本申请实施例三主要介绍网络编码功能位于PDCP层内,即PDCP SDU和PDCP PDU不再是一一对应的情况下,沿用一个PDCP SDU关联一个discardTimer的机制,发送PDCP实体如何丢弃已经QoS失效的PDCP SDU和PDCP PDU。
可选的,本申请实施例三中用于发送的PDCP实体是指发送端的PDCP实体,简称为发送PDCP实体。其中,发送端既可以是终端设备,如图1中的UE或图4中的UE 120;也可以是网络设备,如图1的基站或图4中的基站110。换句话说,如果发送端是UE,则用于发送的PDCP实体可以位于UE上;如果发送端是基站,且基站采用CU-DU分离的结构,则用于发送的PDCP实体可以位于gNB-CU上。
本实施例以原数据包生成编码包(包括系统包和冗余包)为例进行说明(即图5b示意的方案)。
参见图14,图14是本申请实施例提供的网络编码场景下的超时丢包方法的第三种示意流程图。如图14所示,该网络编码场景下的超时丢包方法包括但不限于以下步骤:
S301,若PDCP SDU关联的定时器超时,发送PDCP实体丢弃该PDCP SDU,其中,一个PDCP SDU关联一个定时器。
S302,发送PDCP实体对一个或多个PDCP SDU进行网络编码功能的处理生成多个第一数据包,该多个第一数据包包括系统包和冗余包,或者,该多个第一数据包包括原数据包和冗余包,一个该第一数据包对应一个PDCP PDU,一个PDCP PDU包括一个第一数据包和PDCP头。
S303,若一个PDCP PDU对应的N个PDCP SDU关联的N个定时器中的K个定时器超时,则发送PDCP实体丢弃该PDCP PDU。
可选的,本申请实施例中步骤S301和步骤S302的执行顺序不做限定,可能步骤S301在步骤S302之前,也可能步骤S301在步骤S302之后,还可能步骤S301和步骤S302同时执行。
可选的,上述多个第一数据包包括系统包和冗余包,或者,上述多个第一数据包包括原数据包和冗余包。本申请实施例以多个第一数据包包括系统包和冗余包(本文中统称为编码包)为例进行说明。
可选的,本申请实施例中网络编码功能位于PDCP层内,也就是说网络编码功能是PDCP层的一个子功能。
可选的,发送PDCP实体在接收到来自上层(如SDAP层)的一个PDCP SDU时,发送PDCP实体为该PDCP SDU关联一个discardTimer,并开启该discardTimer。如果与该PDCPSDU关联的discardTimer超时,说明该PDCP SDU已经QoS失效(这是因为某些业务具有时延要求,如果这些业务的数据包传输到PDCP层时已超过时延要求或即将超过时延要求,也就没有传到下一层的必要,因此在PDCP层就可以删除这些数据包,从而节省空口资源),则该发送PDCP实体丢弃该PDCP SDU。当发送PDCP实体从上层(如SDAP层)接收到一个或多个PDCPSDU(即一组待编码的原始数据)后,发送PDCP实体可以对这一个或多个PDCP SDU一起/共同/联合进行网络编码功能的处理生成多个编码包,具体的网络编码功能处理可参考前述图5b所示,此处不再赘述。发送PDCP实体每得到一个编码包,可以对该编码包添加PDCP头得到一个PDCP PDU。也就是说,一个编码包与一个PDCP PDU对应。因为系统包中包体的内容与PDCP SDU一致,而冗余包是这一个或多个PDCP SDU和编码系数相乘再相加作用的结果;所以,一个编码包对应至少一个PDCP SDU,或者说一个编码包携带至少一个PDCP SDU的信息(应理解,如果这个编码包是系统包,其携带的可能是一个PDCP SDU的全部或部分信息),换句话说,一个PDCP PDU对应至少一个PDCP SDU。因此,如果某个PDCP PDU对应的全部或部分PDCP SDU关联的discardTimer均超时,则发送PDCP实体丢弃该这个PDCP PDU。换句话说,一旦一个PDCP SDU关联的discardTimer超时,则发送PDCP实体将丢弃该PDCP SDU,而PDCPPDU只有当其包含的所有PDCP SDU关联的discardTimer都超时才能被丢弃,即K等于N。或者,一旦一个PDCP SDU关联的discardTimer超时,则发送PDCP实体将丢弃该PDCP SDU,当某个PDCP PDU包含的部分PDCP SDU(这里的“部分”可以是正整数,比如超过一半的PDCP SDU)关联的discardTimer均超时才能被丢弃,即预设阈值为N/2,K是大于N/2的正整数。
其中,上述一个PDCP PDU对应的N个PDCP SDU包括:一个PDCP PDU包括的第一数据包是系统包或原数据包,则这个PDCP PDU包括的第一数据包的数据来自这N个PDCP SDU中的每个PDCP SDU;或,一个PDCP PDU包括的第一数据包是冗余包,则这个PDCP PDU包括的与第一数据包满足网络编码关系的原数据包来自这N个PDCP SDU中的每个PDCP SDU。
示例性的,以前述图8为例,如果与PDCP SDU0关联的discardTimer超时,则发送PDCP实体丢弃PDCP SDU0。发送PDCP实体将PDCP SDU0、PDCP SDU1以及PDCP SDU2一起进行网络编码功能的处理后生成编码包(包括2个系统包,2个冗余包),其中,编码包0为系统包0,包含PDCP SDU0和部分的PDCP SDU1,编码包1为系统包1,包含剩余部分的PDCP SDU1和PDCP SDU2,编码包2和编码包3为冗余包,包含PDCP SDU0、PDCP SDU1和PDCP SDU2的内容。再对每个编码包加PDCP头得到PDCP PDU0~3。因此,PDCP SDU0的信息在PDCP PDU0,PDCPPDU2和PDCP PDU3中都有携带。由于PDCP PDU0除了包含PDCP SDU0之外,还包含PDCP SDU1的部分信息。所以,如果PDCP PDU0对应的PDCP SDU0和PDCP SDU1所关联的discardTimer都超时,发送PDCP实体丢弃PDCP PDU0。或者,如果PDCP PDU0对应的所有PDCP SDU中超过一半的PDCP SDU关联的discardTimer均超时,则发送PDCP实体丢弃PDCP PDU0。由于PDCP PDU2和PDCP PDU3中包含PDCP SDU0、PDCP SDU1以及PDCP SDU2的信息,所以,如果PDCP SDU0,PDCP SDU1,以及PDCP SDU2分别关联的discardTimer都超时,发送PDCP实体丢弃PDCP PDU2和PDCP PDU3。或者,如果PDCP PDU2和PDCP PDU3对应的所有PDCP SDU中超过一半的PDCPSDU关联的discardTimer均超时,则发送PDCP实体丢弃PDCP PDU2和PDCP PDU3。即,如果PDCP SDU0关联的discardTimer、PDCP SDU1关联的discardTimer,以及PDCP SDU2关联的discardTimer中至少2个discardTimer超时,则发送PDCP实体丢弃PDCP PDU2和PDCP PDU3。
可选的,发送PDCP实体对接收到的一个或多个PDCP SDU进行网络编码功能的处理后生成的编码包包括系统包和冗余包。因为网络编码功能位于PDCP层,所以PDCP层除了缓存有PDCP SDU和PDCP PDU之外,还缓存有编码包。因此,如果与某个PDCP SDU关联的discardTimer超时,则发送PDCP实体除了丢弃该PDCP SDU外,还可以丢弃该PDCP SDU对应的多个编码包中的全部或部分。这里,一个PDCP SDU对应多个编码包(因为既有系统包又有冗余包)。例如,如果与某个PDCP SDU关联的discardTimer超时,发送PDCP实体丢弃该PDCPSDU,以及该PDCP SDU对应的系统包或冗余包,即发送PDCP实体丢弃该PDCP SDU对应的多个编码包中的部分。或者,如果与某个PDCP SDU关联的discardTimer超时,发送PDCP实体丢弃该PDCP SDU,以及该PDCP SDU对应的系统包和冗余包,即发送PDCP实体丢弃该PDCP SDU对应的全部编码包。
示例性的,以前述图8为例,PDCP SDU0、PDCP SDU1以及PDCP SDU2一起进行网络编码功能的处理后生成编码包,其包括2个系统包和2个冗余包。如果与PDCP SDU0关联的discardTimer超时,则发送PDCP实体除了丢弃PDCP SDU0外,还丢弃PDCP SDU0对应的系统包(即第一个编码包),或者,丢弃PDCP SDU0对应的系统包(即第一个编码包)和冗余包(即第三个和第四个编码包)。
可选的,发送PDCP实体将某个PDCP PDU发送到RLC层后,如果这个PDCP PDU对应的全部或部分PDCP SDU关联的discardTimer均超时,则发送PDCP实体需要指示RLC层丢弃该PDCP PDU。相应地,发送RLC层实体(本申请将实现RLC层功能的实体称为RLC层实体,将发送端的RLC层实体称为用于发送的RLC层实体,简称为发送RLC层实体)丢弃从上层(如PDCP层)接收到的该PDCP PDU。其中,PDCP PDU传输至RLC层后,会被RLC层认为是RLC SDU,因此,RLC层实体丢弃PDCP PDU,可以理解为RLC层实体丢弃PDCP PDU对应的RLC SDU。
应理解,如果发送PDCP实体将PDCP PDU发送至RLC层后,发送PDCP实体的存储空间(比如缓存)中就不存在该PDCP PDU了,则当该PDCP PDU对应的全部或部分PDCP SDU关联的discardTimer均超时后,发送PDCP实体无需自己执行丢弃该PDCP PDU的操作,而是指示RLC层去丢弃该PDCP PDU。同理,如果发送PDCP实体将PDCP PDU发送至RLC层后,且发送PDCP实体还缓存有该PDCP PDU,则发送PDCP实体不仅需要指示RLC层丢弃该PDCP PDU,还需丢弃自己缓存中的该PDCP PDU。
可选的,发送PDCP实体位于gNB-CU上。如果gNB-CU已经将某个PDCP PDU通过GTP隧道发送给gNB-DU,且这个PDCP PDU对应的全部或部分PDCP SDU关联的discardTimer均超时,则gNB-CU需要指示gNB-DU丢弃该PDCP PDU。相应地,gNB-DU接收到来自gNB-CU的指示后,按照该指示丢弃接收到的该PDCP PDU。其中,该指示携带在F1接口的DL User Data中发送。
本实施例以原数据包生成编码包(包括系统包和冗余包)为例进行说明(即图5b示意的方案),同理,本实施例同样适应于原数据包生成冗余包的场景(即图5a示例的方案),只需要将上述方案中的编码包替换为冗余包,将系统包替换为原数据包即可。
可见,本申请实施例通过在网络编码场景下复用NR PDCP层的超时丢包机制并在此基础上修改丢弃PDCP PDU的原则,即复用一个PDCP SDU关联一个discardTimer,当该discardTimer超时,则丢弃该PDCP SDU,而PDCP PDU只有当其包含的所有或部分PDCP SDU关联的discardTimer都超时才能被丢弃,不仅可以减少对NR PDCP层的超时丢包机制的改动,还可以在网络编码场景下丢弃已经QoS失效的数据包,减少QoS失效的数据包在空口上传输造成的资源浪费且可以减少误丢包的情况,提升空口传输的效率。
实施例四
本申请实施例四主要介绍网络编码功能位于PDCP层内,即PDCP SDU和PDCP PDU不再是一一对应的情况下,沿用一个PDCP SDU关联一个discardTimer的机制,当某个PDCPSDU关联的discardTimer超时后,丢弃这个PDCP SDU,以及如何丢弃已经QoS失效的PDCPPDU。
可选的,本申请实施例四中用于发送的PDCP实体是指发送端的PDCP实体,简称为发送PDCP实体。其中,发送端既可以是终端设备,如图1中的UE或图4中的UE 120;也可以是网络设备,如图1的基站或图4中的基站110。换句话说,如果发送端是UE,则用于发送的PDCP实体可以位于UE上;如果发送端是基站,且基站采用CU-DU分离的结构,则用于发送的PDCP实体可以位于gNB-CU上。
本实施例以原数据包生成编码包(包括系统包和冗余包)为例进行说明(即图5b示意的方案)。
参见图15,图15是本申请实施例提供的网络编码场景下的超时丢包方法的第四种示意流程图。如图15所示,该网络编码场景下的超时丢包方法包括但不限于以下步骤:
S401,发送PDCP实体对一个或多个PDCP SDU进行网络编码功能的处理生成多个第一数据包,该多个第一数据包包括系统包和冗余包,或者,该多个第一数据包包括原数据包和冗余包,该一个或多个PDCP SDU对应该多个第一数据包,一个该第一数据包对应一个PDCP PDU,一个PDCP PDU包括一个第一数据包和PDCP头,一个PDCP SDU对应多个PDCP PDU,该一个或多个PDCP SDU中的一个PDCP SDU关联一个定时器。
S402,若一个或多个PDCP SDU中的第一PDCP SDU关联的定时器超时,发送PDCP实体丢弃以下中的至少一项:该第一PDCP SDU,该第一PDCP SDU对应的多个PDCP PDU。
可选的,上述多个第一数据包包括系统包和冗余包,或者,上述多个第一数据包包括原数据包和冗余包。本申请实施例以多个第一数据包包括系统包和冗余包(本文中统称为编码包)为例进行说明。
可选的,本申请实施例中网络编码功能位于PDCP层内,也就是说网络编码功能是PDCP层的一个子功能。
可选的,发送PDCP实体在接收到来自上层(如SDAP层)的一个PDCP SDU时,发送PDCP实体为该PDCP SDU关联一个discardTimer,并开启该discardTimer。当发送PDCP实体从上层(如SDAP层)接收到一个或多个PDCP SDU(即一组待编码的原始数据)后,发送PDCP实体可以对这一个或多个PDCP SDU一起/共同/联合进行网络编码功能的处理生成多个编码包,具体的网络编码功能处理可参考前述图5b所示,此处不再赘述。发送PDCP实体每得到一个编码包,可以对该编码包添加PDCP头得到一个PDCP PDU。也就是说,一个编码包与一个PDCP PDU对应。因为系统包中包体的内容与PDCP SDU一致,而冗余包是这一个或多个PDCPSDU和编码系数相乘再相加作用的结果;所以,一个PDCP SDU对应多个编码包,或者说一个PDCP SDU的信息携带在多个编码包中,换句话说,一个PDCP SDU对应多个PDCP PDU。因此,如果与某个PDCP SDU(即上述第一PDCP SDU)关联的discardTimer超时,说明该第一PDCPSDU已经QoS失效,该发送PDCP实体丢弃该第一PDCP SDU以及该第一PDCP SDU对应的多个PDCP PDU。换句话说,一旦一个PDCP SDU关联的discardTimer超时,则发送PDCP实体将丢弃该PDCP SDU,以及该PDCP SDU对应的所有PDCP PDU。
示例性的,以前述图8为例,PDCP SDU0、PDCP SDU1以及PDCP SDU2一起进行网络编码功能的处理后生成编码包(包括2个系统包,2个冗余包),其中,编码包0为系统包0,包含PDCP SDU0和部分的PDCP SDU1,编码包1为系统包1,包含剩余部分的PDCP SDU1和PDCPSDU2,编码包2和编码包3为冗余包,包含PDCP SDU0、PDCP SDU1和PDCP SDU2的内容。再对每个编码包加PDCP头得到PDCP PDU0~3。因为PDCP SDU0的信息在PDCP PDU0,PDCP PDU2和PDCP PDU3中都有携带。所以,如果与PDCP SDU0关联的discardTimer超时,则发送PDCP实体将丢弃PDCP SDU0,以及对应的PDCP PDU0,PDCP PDU2和PDCP PDU3。
其中,因为PDCP PDU2和PDCP PDU3均包含冗余包,每个冗余包中均包含PDCPSDU0、PDCP SDU1以及PDCP SDU2的内容,可用于接收端对PDCP SDU0、PDCP SDU1以及PDCPSDU2之中任何一个PDCP SDU的恢复。因此,一旦PDCP SDU0关联的discardTimer定时器超时,则发送PDCP实体除了丢弃PDCP SDU0之外,还需要把所有包含PDCP SDU0内容的PDCPPDU0、PDCP PDU2和PDCP PDU3都丢弃。否则,如果发送PDCP实体仅丢弃PDCP SDU0和PDCPPDU0,因为接收端能够正确接收到PDCP PDU2和/或PDCP PDU3,所以接收端还是能成功把PDCP SDU0恢复出来,将会导致接收端收到一个无效的PDCP SDU0。
可选的,因为网络编码功能位于PDCP层,所以PDCP层除了缓存有PDCP SDU和PDCPPDU之外,还缓存有编码包。因此,如果与上述第一PDCP SDU关联的discardTimer超时,则发送PDCP实体不仅可以丢弃该第一PDCP SDU和该第一PDCP SDU对应的多个PDCP PDU,还可以丢弃该第一PDCP SDU对应的多个编码包中的全部或部分。例如,如果与某个PDCP SDU(即上述第一PDCP SDU)关联的discardTimer超时,发送PDCP实体丢弃该第一PDCP SDU,以及该第一PDCP SDU对应的系统包或冗余包。或者,如果与该第一PDCP SDU关联的discardTimer超时,发送PDCP实体丢弃该第一PDCP SDU,以及该第一PDCP SDU对应的系统包和冗余包。
可选的,发送PDCP实体将上述第一PDCP SDU对应的全部PDCP PDU或部分PDCP PDU发送到RLC层后,如果与该第一PDCP SDU关联的discardTimer超时,则发送PDCP实体需要指示RLC层丢弃传输至该RLC层的这些PDCP PDU。相应地,发送RLC层实体丢弃从上层(如PDCP层)接收到的这些PDCP PDU。
应理解,如果发送PDCP实体已经将上述第一PDCP SDU对应的部分PDCP PDU发送至RLC层,则发送PDCP层实体可以指示RLC层丢弃发送至该RLC层的这部分PDCP PDU,也就是说未发送至RLC层的PDCP PDU不需要发送PDCP实体指示RLC层丢弃,可以由发送PDCP层实体直接丢弃。同理,如果发送PDCP实体已经将上述第一PDCP SDU对应的全部PDCP PDU发送至RLC层,则发送PDCP层实体需要指示RLC层丢弃该全部PDCP PDU,发送PDCP实体无需自己执行丢弃上述第一PDCP SDU对应的多个PDCP PDU的操作。
可选的,发送PDCP实体位于gNB-CU上。如果gNB-CU已经将上述第一PDCP SDU对应的某个PDCP PDU通过GTP隧道发送给gNB-DU,且该第一PDCP SDU关联的discardTimer超时,则gNB-CU需要指示gNB-DU丢弃该第一PDCP SDU对应的该PDCP PDU。相应地,gNB-DU接收到来自gNB-CU的指示后,按照该指示丢弃接收到的该PDCP PDU。其中,该指示携带在F1接口的DL User Data中发送。
本实施例以原数据包生成编码包(包括系统包和冗余包)为例进行说明(即图5b示意的方案),同理,本实施例同样适应于原数据包生成冗余包的场景(即图5a示例的方案),只需要将上述方案中的编码包替换为冗余包,将系统包替换为原数据包即可。
可见,本申请实施例通过在网络编码场景下复用NR PDCP层的超时丢包机制,当一个PDCP SDU关联的一个discardTimer超时后,丢弃该PDCP SDU以及该PDCP SDU对应的所有PDCP PDU,不仅可以减少对NR PDCP层的超时丢包机制的改动,还可以在网络编码场景下丢弃已经QoS失效的数据包,减少QoS失效的数据包在空口上传输造成的资源浪费以及减少接收端恢复出无效数据包的概率,提升空口的传输效率。
一个可选实施例中,通信装置对一组PDCP PDU进行网络编码功能的处理生成多个第一数据包,该多个第一数据包包括系统包和冗余包,或者,该多个第一数据包包括原数据包和冗余包。该一组PDCP PDU包括一个或多个PDCP PDU,一个PDCP PDU对应至少一个第一数据包。若某个PDCP SDU关联的定时器超时,通信装置丢弃该PDCP SDU和该PDCP SDU对应的PDCP PDU,并丢弃该PDCP PDU对应的多个第一数据包,其中一个PDCP SDU关联一个定时器,一个PDCP PDU包括一个PDCP SDU和PDCP头。本申请实施例中的通信装置包括PDCP层、RLC层以及NC层,且NC层位于PDCP层之下。
具体地,以一组PDCP PDU进行网络编码功能的处理生成系统包和冗余包(统称为编码包)为例:如果上述通信装置是UE,UE的PDCP层从上层接收到一个PDCP SDU,为该PDCPSDU关联一个discardTimer,并对该PDCP SDU执行头压缩、加密/完整性保护后加PDCP头得到一个PDCP PDU传输至下层(如NC层)。当UE的NC层从上层(即PDCP层)收到一组PDCP PDU(即一个或多个PDCP PDU)后,将这一组PDCP PDU一起进行网络编码功能的处理生成多个编码包,该多个编码包包括系统包和冗余包,一个PDCP PDU对应多个编码包。然后,UE的NC层可以将生成的多个编码包发送至RLC层。如果与某个PDCP SDU关联的discardTimer超时,则UE的PDCP层丢弃该PDCP SDU以及该PDCP SDU对应的PDCP PDU。由于该PDCP SDU和对应的PDCP PDU已经QoS失效,如果UE的NC层已经将该PDCP PDU对应的编码包发送至RLC层,则UE的NC层需要指示UE的RLC层丢弃该PDCP PDU对应的编码包。相应地,UE的RLC层丢弃该PDCPPDU对应的编码包。
如果上述通信装置是gNB且采用CU-DU分离架构,gNB-CU的PDCP层从上层接收到一个PDCP SDU,为该PDCP SDU关联一个discardTimer,并对该PDCP SDU执行头压缩、加密/完整性保护后加PDCP头得到一个PDCP PDU传输至下层(如NC层)。当gNB-CU的NC层从上层(即PDCP层)收到一组PDCP PDU(即一个或多个PDCP PDU)后,将这一组PDCP PDU一起进行网络编码操作生成多个编码包,该多个编码包包括系统包和冗余包,一个PDCP PDU对应多个编码包。然后,gNB-CU可以将生成的多个编码包发送至gNB-DU。如果与某个PDCP SDU关联的discardTimer超时,则gNB-CU的PDCP层丢弃该PDCP SDU以及该PDCP SDU对应的PDCP PDU。由于该PDCP SDU和对应的PDCP PDU已经QoS失效,如果gNB-CU已经将该PDCP PDU对应的编码包发送至gNB-DU,则gNB-CU可以向gNB-DU发送指示信息,该指示信息中包括该PDCP PDU对应的编码包的标识或生成该编码包对应的编码系数因子标识,用于指示gNB-DU丢弃该PDCP PDU对应的编码包。相应地,gNB-DU接收到该指示信息后,按照该指示信息的指示丢弃该PDCP PDU对应的编码包。
示例性的,参见图16,图16是本申请实施例提供的gNB侧NC层位于PDCP层之下的超时丢包示意图三。如图16所示,如果PDCP SDU0关联的discardTimer 1超时,则gNB-CU的PDCP层将丢弃PDCP SDU0和PDCP PDU0(即图16中SN=0的PDCP PDU)。因为PDCP PDU0,PDCPPDU1和PDCP PDU2进行网络编码功能的处理后生成编码包,其中编码包0为系统包0,包含PDCP PDU0和部分的PDCP PDU1,编码包1为系统包1,包含剩余部分的PDCP PDU1和PDCPPDU2,编码包2和编码包3为冗余包,包含PDCP PDU0、PDCP PDU1和PDCP PDU2的内容。所以,编码包0(即图16中packet ID为0的编码包/系统包)、编码包2(即图16中packet ID为2的编码包/冗余包)和编码包3(即图16中packet ID为3的编码包/冗余包)中都包含了PDCP PDU0的内容,也就是说,PDCP PDU0与编码包0、编码包2和编码包3都对应,因此编码包0、编码包2和编码包3也都需要丢弃。故gNB-CU需要指示gNB-DU丢弃编码包0、编码包2和编码包3。
上述图16示出的系统包和冗余包未画出其包头,但实际应用中,系统包和冗余包均包括包头信息。应理解,图16中数据包上打叉“×”,表示discardTimer 1超时后,丢弃该数据包。
可见,本申请实施例沿用NR PDCP层的超时丢包机制,当一个PDCP SDU关联的一个discardTimer超时后,丢弃该PDCP SDU以及该PDCP SDU对应的一个PDCP PDU,并在通信装置将一组PDCP PDU一起进行网络编码操作生成的编码包发送至RLC层后,通过层间交互或指示信息来指示RLC层删除相应的编码包,可以解决因为PDCP PDU封装在编码包内导致的RLC层无法直接看到PDCP PDU,从而无法沿用现有机制来丢弃已经QoS失效的数据包的问题,从而可以减少QoS失效的数据在空口发送造成的资源浪费,提升空口传输的效率。
本实施例以原数据包生成编码包(包括系统包和冗余包)为例进行说明(即图5b示意的方案),同理,本实施例同样适应于原数据包生成冗余包的场景(即图5a示例的方案),只需要将上述方案中的编码包替换为冗余包,将系统包替换为原数据包即可。
另一个可选实施例中,若PDCP SDU关联的定时器超时,通信装置丢弃该PDCP SDU和该PDCP SDU对应的PDCP PDU,其中一个PDCP SDU关联一个定时器,一个PDCP PDU是一个PDCP SDU执行头压缩、加密/完整性保护后加PDCP头后得到。通信装置对一组PDCP PDU进行网络编码功能的处理生成多个编码包,该多个编码包包括系统包和冗余包,该一组PDCPPDU包括一个或多个PDCP PDU,一个编码包中携带至少一个PDCP PDU的(部分/全部)信息。如果某个编码包对应的所有PDCP PDU分别对应的PDCP SDU所关联的定时器都超时,则通信装置丢弃该编码包。本申请实施例中的通信装置包括PDCP层、RLC层以及NC层,且NC层位于PDCP层之下。
可选的,如果通信装置将某个编码包传输至下层后,这个编码包对应的所有PDCPPDU分别对应的PDCP SDU所关联的定时器都超时,则通信装置需要指示下层丢弃这个编码包。其中,如果通信装置是UE,则这里可通过原语来指示。如果通信装置是gNB且采用CU-DU分离架构,则这里可通过信令(指示信息)来指示。
示例性的,以前述图16为例,PDCP SDU0关联的discardTimer超时,则gNB-CU的PDCP层将丢弃PDCP SDU0和PDCP PDU0(即图16中SN=0的PDCP PDU)。因为PDCP PDU0,PDCPPDU1和PDCP PDU2进行网络编码功能的处理后生成编码包,其中编码包0为系统包0,包含PDCP PDU0和部分的PDCP PDU1,编码包1为系统包1,包含剩余部分的PDCP PDU1和PDCPPDU2,编码包2和编码包3为冗余包,包含PDCP PDU0、PDCP PDU1和PDCP PDU2的内容。所以,编码包0(即图16中packet ID为0的编码包/系统包)不仅包含PDCP PDU0的内容,还包含PDCP PDU1的部分内容,所以如果PDCP SDU0和PDCP SDU1各自关联的discardTimer都超时,则gNB-CU指示gNB-DU丢弃编码包0。
可见,本申请实施例可以解决因为PDCP PDU封装在编码包内导致的RLC层无法直接看到PDCP PDU,从而无法沿用现有机制来丢弃已经QoS失效的数据包的问题,从而可以减少QoS失效的数据在空口发送造成的资源浪费,并且可以减少误丢包的情况,提升空口传输的效率。
本实施例以原数据包生成编码包(包括系统包和冗余包)为例进行说明(即图5b示意的方案),同理,本实施例同样适应于原数据包生成冗余包的场景(即图5a示例的方案),只需要将上述方案中的编码包替换为冗余包,将系统包替换为原数据包即可。
又一个可选实施例中,若PDCP SDU关联的定时器超时,gNB-CU丢弃该PDCP SDU和/或该PDCP SDU对应的PDCP PDU,一个PDCP SDU关联一个定时器,一个PDCP PDU是一个PDCPSDU执行头压缩、加密/完整性保护后加PDCP头后得到。若gNB-CU已经将该PDCP SDU对应的PDCP PDU发送至gNB-DU,gNB-CU可以沿用现有机制指示gNB-DU丢弃对应的PDCP PDU。本申请实施例中NC层位于RLC层之上,也就是说,NC层在gNB-DU上。gNB-DU对从gNB-CU收到的一组PDCP PDU进行网络编码功能的处理生成多个编码包。当gNB-DU收到gNB-CU指示丢弃该PDCP SDU对应的PDCP PDU的指示信息后,gNB-DU还可以丢弃该PDCP PDU对应的所有编码包(包括系统包和冗余包),或者,当某个编码包对应的所有PDCP PDU都被指示丢弃时,gNB-DU才丢弃该编码包。
示例性的,参见图17,图17是本申请实施例提供的gNB侧NC层位于RLC层之上的超时丢包示意图三。如图17所示,gNB-CU向gNB-DU发送PDCP PDU0(即图17中SN=0的PDCPPDU)、PDCP PDU1(即图17中SN=1的PDCP PDU)和PDCP PDU2(即图17中SN=2的PDCP PDU)。gNB-DU将收到的PDCP PDU0、PDCP PDU1和PDCP PDU2作为一个编码块进行网络编码功能的处理后生成编码包。一旦PDCP SDU0关联的discardTimer 1超时,则gNB-CU将丢弃该PDCPSDU0和PDCP PDU0,沿用现有机制,gNB-CU指示gNB-DU丢弃PDCP PDU0。其中编码包0为系统包0,包含PDCP PDU0和部分的PDCP PDU1,编码包1为系统包1,包含剩余部分的PDCP PDU1和PDCP PDU2,编码包2和编码包3为冗余包,包含PDCP PDU0、PDCP PDU1和PDCP PDU2的内容。所以,编码包0(即图17中packet ID为0的编码包/系统包)、编码包2(即图17中packet ID为2的编码包/冗余包)和编码包3(即图17中packet ID为3的编码包/冗余包)中都包含了PDCPPDU0的内容。因此,一旦gNB-CU指示gNB-DU丢弃PDCP PDU0,则gNB-DU除了丢弃PDCP PDU0之外,还将丢弃编码包0、编码包2和编码包3。或者,一旦gNB-CU指示gNB-DU丢弃PDCP PDU0,则gNB-DU只丢弃PDCP PDU0。只有当gNB-CU指示gNB-DU丢弃PDCP PDU0和PDCP PDU1时,gNB-DU除了丢弃PDCP PDU0和PDCP PDU1之外,还将丢弃编码包0。
上述图17示出的系统包和冗余包未画出其包头,但实际应用中,系统包和冗余包均包括包头信息。应理解,图17中数据包上打叉“×”,表示discardTimer 1超时后,丢弃该数据包。
可见,本申请实施例可以解决在PDCP层和RLC层之间引入NC层后,引起的RLC层无法沿用现有机制进行丢包的问题,并且RLC层根据上层的指示信息来丢弃已经QoS失效的数据包,减少失效数据包在空口的发送造成的资源浪费。
本实施例以原数据包生成编码包(包括系统包和冗余包)为例进行说明(即图5b示意的方案),同理,本实施例同样适应于原数据包生成冗余包的场景(即图5a示例的方案),只需要将上述方案中的编码包替换为冗余包,将系统包替换为原数据包即可。
上述内容详细阐述了本申请的方法,为便于更好地实施本申请实施例的上述方案,本申请实施例还提供了相应的装置或设备。
本申请实施例可以根据上述方法示例对通信装置和发送PDCP实体进行功能模块的划分,例如,可以对应各个功能划分各个功能模块,也可以将两个或两个以上的功能集成在一个处理模块中。上述集成的模块既可以采用硬件的形式实现,也可以采用软件功能模块的形式实现。需要说明的是,本申请实施例中对模块的划分是示意性的,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式。下面将结合图18至图21详细描述本申请实施例的通信装置。
在采用集成的单元的情况下,参见图18,图18是本申请实施例提供的通信装置的一结构示意图。该通信装置可以为终端设备或者设置于终端设备中的芯片或电路;该通信装置还可以是网络设备或设置于网络设备中的芯片或电路。如图18所示,该通信装置包括:获取模块11和丢弃模块12。
获取模块11,用于获取一组原始数据,该一组原始数据关联一个定时器,该一组原始数据用于一起进行网络编码功能的处理生成多个第一数据包,该多个第一数据包包括系统包和冗余包,或者,该多个第一数据包包括原数据包和冗余包;丢弃模块12,用于若该一组原始数据关联的定时器超时,丢弃以下中的至少一项:该一组原始数据,该一组原始数据进行网络编码功能的处理生成的该多个第一数据包。
可选的,上述原始数据为PDCP SDU。
可选的,上述一组PDCP SDU对应上述多个第一数据包,一个第一数据包对应一个PDCP PDU,一个PDCP PDU包括一个第一数据包和PDCP头。上述丢弃模块12,还用于丢弃该一组PDCP SDU对应的多个PDCP PDU。
可选的,上述原始数据为PDCP PDU。
可选的,上述丢弃模块12,还用于丢弃该一组PDCP PDU对应的PDCP SDU,其中一个PDCP PDU对应一个PDCP SDU。
可选的,上述通信装置还包括收发模块13。该收发模块13,用于向分布式单元发送指示信息,该指示信息用于指示该分布式单元丢弃该一组原始数据进行网络编码功能的处理生成的该多个第一数据包。其中,该指示信息包括以下中的一项:该多个第一数据包各自的标识,该多个第一数据包的标识所属的范围,该多个第一数据包所属的编码块的标识,该多个第一数据包各自对应的编码系数因子的标识。
可选的,上述通信装置是分布式单元或用于分布式单元的芯片。
可选的,上述通信装置是终端设备或用于终端设备的芯片。上述通信装置包括PDCP层、NC层、以及RLC层,该NC层位于该PDCP层和RLC层之间。上述通信装置还包括关联模块14。该关联模块14,用于为上述一组PDCP PDU关联一个定时器;上述丢弃模块12,具体用于若该一组PDCP PDU关联的定时器超时,丢弃以下中的至少一项:该一组PDCP PDU,该一组PDCP PDU进行网络编码功能的处理生成的该多个第一数据包。
可选的,上述通信装置是终端设备或用于终端设备的芯片。上述通信装置包括PDCP层、NC层、以及RLC层,该NC层位于该PDCP层和RLC层之间。上述通信装置还包括指示模块15。该指示模块15,用于将该一组PDCP PDU进行网络编码功能的处理生成的全部或部分第一数据包传输至该RLC层后,指示该RLC层丢弃传输至该RLC层的该第一数据包;上述丢弃模块12,还用于丢弃从该NC层接收到的该第一数据包。
可选的,上述通信装置包括PDCP层。上述通信装置还包括关闭模块16。该关闭模块16,用于关闭该PDCP层中PDCP SDU与丢弃定时器的关联功能。
其中,上述获取模块11,上述丢弃模块12,上述关联模块14,上述指示模块15,以及上述关闭模块16中的至少两个模块可以集成为一个模块,例如处理模块。
应理解,该通信装置可对应执行前述实施例一,并且该通信装置中的各个单元的上述操作或功能分别为了实现前述实施例一中通信装置的相应操作,其技术效果参见前述实施例一中的技术效果,为了简洁,在此不再赘述。
参见图19,图19是本申请实施例提供的通信装置的另一结构示意图。该通信装置可以为终端设备或者设置于终端设备中的芯片或电路;该通信装置还可以是网络设备或设置于网络设备中的芯片或电路。如图19所示,该通信装置包括:编码模块21和丢弃模块22。
编码模块21,用于对原始数据进行网络编码功能的处理生成多个第一数据包,一个该第一数据包关联一个定时器,该多个第一数据包包括系统包和冗余包,或者,该多个第一数据包包括原数据包和冗余包;丢弃模块22,用于若该多个第一数据包中的第一数据包i关联的定时器超时,丢弃该第一数据包i。
可选的,上述原始数据包括一个或者多个PDCP SDU,一个该第一数据包对应一个PDCP PDU,一个PDCP PDU包括一个第一数据包和PDCP头。上述丢弃模块22,还用于丢弃该第一数据包i对应的PDCP PDU。
可选的,上述丢弃模块22,还用于丢弃该第一数据包i对应的PDCP SDU,其中一个该第一数据包包对应一个或多个PDCP SDU。
可选的,上述原始数据包括一个或者多个PDCP PDU。
可选的,上述通信装置还包括收发模块23。该收发模块23,用于向分布式单元发送指示信息,该指示信息用于指示该分布式单元丢弃该第一数据包i。其中,该指示信息中包括该第一数据包i的标识;或者包括该第一数据包i对应的编码系数因子的标识。
可选的,上述通信装置是分布式单元或用于分布式单元的芯片。
可选的,上述通信装置是终端设备或用于终端设备的芯片。上述通信装置包括PDCP层、NC层、以及RLC层,该NC层位于该PDCP层和RLC层之间。上述通信装置还包括指示模块24。该指示模块24,用于将该第一数据包i传输至该RLC层后,指示该RLC层丢弃该编码包;上述丢弃模块22,还用于丢弃从该NC层接收到的该第一数据包i。
可选的,上述通信装置包括PDCP层。上述通信装置还包括关闭模块25。该关闭模块25,用于关闭该PDCP层中PDCP SDU与丢弃定时器的关联功能。
其中,上述编码模块21,上述丢弃模块22,上述指示模块24,以及上述关闭模块25中的至少两个模块可以集成为一个模块,例如处理模块。
应理解,该通信装置可对应执行前述实施例二,并且该通信装置中的各个单元的上述操作或功能分别为了实现前述实施例二中通信装置的相应操作,其技术效果参见前述实施例二中的技术效果,为了简洁,在此不再赘述。
参见图20,图20是本申请实施例提供的发送PDCP实体的结构示意图。该发送PDCP实体可以为用于终端设备或者设置于终端设备中的芯片或电路。该发送PDCP实体还可以为用于网络设备或者设置于网络设备中的芯片或电路。如图20所示,该发送PDCP实体包括:丢弃模块31和编码模块32。
一种设计中,丢弃模块31,用于若PDCP SDU关联的定时器超时,丢弃该PDCP SDU,其中一个PDCP SDU关联一个定时器;编码模块32,用于对一个或多个PDCP SDU进行网络编码功能的处理生成多个第一数据包,该多个第一数据包包括系统包和冗余包,或者,该多个第一数据包包括原数据包和冗余包,一个该第一数据包对应一个PDCP PDU,一个PDCP PDU包括一个第一数据包和PDCP头;该丢弃模块31,还用于若一个PDCP PDU对应的N个PDCP SDU关联的N个定时器中的K个定时器超时,丢弃该PDCP PDU。其中,K为小于或等于N的正整数,且K大于预设阈值。一个PDCP PDU对应的N个PDCP SDU包括:该一个PDCP PDU包括的第一数据包是系统包或原数据包,则该一个PDCP PDU包括的第一数据包的数据来自该N个PDCPSDU中的每个PDCP SDU;或该一个PDCP PDU包括的第一数据包是冗余包,则该一个PDCP PDU包括的与第一数据包满足网络编码关系的原数据包来自该N个PDCP SDU中的每个PDCPSDU。
可选的,上述丢弃模块31,还用于丢弃该一个或多个PDCP SDU对应的多个第一数据包中的全部或部分。
应理解,该种设计中发送PDCP实体可对应执行前述实施例三,并且该发送PDCP实体中的各个单元的上述操作或功能分别为了实现前述实施例三中发送PDCP实体的相应操作,其技术效果参见前述实施例三中的技术效果,为了简洁,在此不再赘述。
另一种设计中,编码模块32,用于对一个或多个PDCP SDU进行网络编码功能的处理生成多个第一数据包,该多个第一数据包包括系统包和冗余包,或者,该多个第一数据包包括原数据包和冗余包,该一个或多个PDCP SDU对应该多个第一数据包,一个该第一数据包对应一个PDCP PDU,一个PDCP PDU包括一个第一数据包和PDCP头,一个PDCP SDU对应多个PDCP PDU,该一个或多个PDCP SDU中的一个PDCP SDU关联一个定时器;丢弃模块31,用于若该一个或多个PDCP SDU中的第一PDCP SDU关联的定时器超时,丢弃以下中的至少一项:该第一PDCP SDU,该第一PDCP SDU对应的多个PDCP PDU。
可选的,上述丢弃模块31,还用于丢弃该第一PDCP SDU对应的多个第一数据包中的全部或部分。
应理解,该种设计中的发送PDCP实体可对应执行前述实施例四,并且该发送PDCP实体中的各个单元的上述操作或功能分别为了实现前述实施例四中发送PDCP实体的相应操作,其技术效果参见前述实施例四中的技术效果,为了简洁,在此不再赘述。
其中,上述两种设计中的上述丢弃模块31和上述编码模块32可以集成为一个模块,例如处理模块。
参见图21,图21是本申请实施例提供的通信装置1000的结构示意图。如图21所示,本申请实施例提供的通信装置1000可用于实现上述方法实施例中描述的方法,可以参见上述方法实施例中的说明。该通信装置1000可以是前述通信装置和前述发送PDCP实体中的任意一种。
通信装置1000包括一个或多个处理器1001。处理器1001可以是通用处理器或者专用处理器等。例如可以是基带处理器、或中央处理器。基带处理器可以用于对通信协议以及通信数据进行处理,中央处理器可以用于对装置(如,UE、基站或芯片等)进行控制,执行软件程序,处理软件程序的数据。该装置可以包括收发单元,用以实现信号的输入(接收)和输出(发送)。例如,装置可以为芯片,该收发单元可以是芯片的输入和/或输出电路,或者通信接口。该芯片可以用于终端设备(如UE)或接入网设备(比如基站)。又如,装置可以为终端设备(比如UE)或接入网设备(比如基站),该收发单元可以为收发器,射频芯片等。
通信装置1000包括一个或多个处理器1001,该一个或多个处理器1001可实现前述实施例一或二中通信装置的方法、或实现前述实施例三或四中发送PDCP实体的方法。
可选的,处理器1001除了实现前述任一实施例的方法,还可以实现其他功能。
可选的,一种设计中,处理器1001也可以包括指令1003,所述指令可以在所述处理器上被运行,使得通信装置1000执行上述任一方法实施例中描述的方法。
在又一种可能的设计中,通信装置1000也可以包括电路,所述电路可以实现前述实施例一或二中通信装置的功能、或实现前述实施例三或四中发送PDCP实体的功能。
在又一种可能的设计中,通信装置1000中可以包括一个或多个存储器1002,其上存有指令1004,所述指令可在所述处理器上被运行,使得通信装置1000执行上述任一方法实施例中描述的方法。可选的,所述存储器中还可以存储有数据。可选的处理器中也可以存储指令和/或数据。例如,所述一个或多个存储器1002可以存储上述实施例中所描述的编码包,或者上述实施例中所涉及的其他信息。所述处理器和存储器可以单独设置,也可以集成在一起。
在又一种可能的设计中,通信装置1000还可以包括收发单元1005以及天线1006,或者,包括通信接口。收发单元1005可以称为收发机、收发电路、或者收发器等,用于通过天线1006实现装置的收发功能。所述通信接口(图中未示出),可以用于核心网设备和接入网设备,或是,接入网设备和接入网设备之间的通信。可选的,该通信接口可以为有线通信的接口,比如光纤通信的接口。
处理器1001可以称为处理单元,对装置(比如通信设备)进行控制。
应理解,在本申请实施例中的处理器可以是中央处理单元(central processingunit,CPU),该处理器还可以是其他通用处理器、数字信号处理器(digital signalprocessor,DSP)、专用集成电路(application specific integrated circuit,ASIC)、现成可编程门阵列(field programmable gate array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
还应理解,本申请实施例中的存储器可以是易失性存储器或非易失性存储器,或可包括易失性和非易失性存储器两者。其中,非易失性存储器可以是只读存储器(read-only memory,ROM)、可编程只读存储器(programmable ROM,PROM)、可擦除可编程只读存储器(erasable PROM,EPROM)、电可擦除可编程只读存储器(electrically EPROM,EEPROM)或闪存。易失性存储器可以是随机存取存储器(random access memory,RAM),其用作外部高速缓存。通过示例性但不是限制性说明,许多形式的随机存取存储器(random accessmemory,RAM)可用,例如静态随机存取存储器(static RAM,SRAM)、动态随机存取存储器(DRAM)、同步动态随机存取存储器(synchronous DRAM,SDRAM)、双倍数据速率同步动态随机存取存储器(double data rate SDRAM,DDR SDRAM)、增强型同步动态随机存取存储器(enhanced SDRAM,ESDRAM)、同步连接动态随机存取存储器(synchlink DRAM,SLDRAM)和直接内存总线随机存取存储器(direct rambus RAM,DR RAM)。
上述实施例,可以全部或部分地通过软件、硬件(如电路)、固件或其他任意组合来实现。当使用软件实现时,上述实施例可以全部或部分地以计算机程序产品的形式实现。所述计算机程序产品包括一个或多个计算机指令或计算机程序。在计算机上加载或执行所述计算机指令或计算机程序时,全部或部分地产生按照本申请实施例所述的流程或功能。所述计算机可以为通用计算机、专用计算机、计算机网络、或者其他可编程装置。所述计算机指令可以存储在计算机可读存储介质中,或者从一个计算机可读存储介质向另一个计算机可读存储介质传输,例如,所述计算机指令可以从一个网站站点、计算机、服务器或数据中心通过有线,例如光纤,或是无线,例如红外、无线、微波等,方式向另一个网站站点、计算机、服务器或数据中心进行传输。所述计算机可读存储介质可以是计算机能够存取的任何可用介质或者是包含一个或多个可用介质集合的服务器、数据中心等数据存储设备。所述可用介质可以是磁性介质(例如,软盘、硬盘、磁带)、光介质(例如,DVD)、或者半导体介质。半导体介质可以是固态硬盘。
本申请实施例还提供一种计算机程序产品,该计算机程序产品包括计算机程序代码,当该计算机程序代码在计算机上运行时,使得该计算机执行前述实施例一或二所描述的通信装置的方法步骤;或者当该计算机程序代码在计算机上运行时,使得该计算机执行前述实施例三或四所描述的发送PDCP实体的方法步骤。
本申请实施例还提供一种计算机可读存储介质,该计算机可读存储介质上存储有程序指令,当其在计算机上运行时,使得该计算机执行前述实施例一或二所描述的通信装置的方法步骤;或者当该计算机程序代码在计算机上运行时,使得该计算机执行前述实施例三或四所描述的发送PDCP实体的方法步骤。
本申请实施例还提供一种装置,该装置可以为芯片。该芯片包括处理器。该处理器用于读取并执行存储器中存储的计算机程序,以执行前述任一实施例的任意可能的实现方式中的方法。可选的,该芯片还包括存储器,该存储器与该处理器通过电路或电线连接。进一步可选的,该芯片还包括通信接口,该处理器与该通信接口连接。该通信接口用于接收待处理的数据和/或信号,该处理器从该通信接口获取该数据和/或信号,并对该数据和/或信号进行处理,并通过该通信接口输出处理结果。该通信接口可以是输入输出接口。
可选的,上述的处理器与存储器可以是物理上相互独立的单元,或者,存储器也可以和处理器集成在一起。
本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,该流程可以由计算机程序来指令相关的硬件完成,该程序可存储于计算机可读取存储介质中,该程序在执行时,可包括如上述各方法实施例的流程。而前述的存储介质包括:ROM或随机存储记忆体RAM、磁碟或者光盘等各种可存储程序代码的介质。
以上所述,仅为本申请的具体实施方式,但本申请的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本申请揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本申请的保护范围之内。因此,本申请的保护范围应以所述权利要求的保护范围为准。

Claims (28)

1.一种网络编码场景下的超时丢包方法,其特征在于,包括:
通信装置获取一组原始数据,所述一组原始数据关联一个定时器,所述一组原始数据用于一起进行网络编码功能的处理生成多个第一数据包,所述多个第一数据包包括系统包和冗余包,或者,所述多个第一数据包包括原数据包和冗余包;
若所述一组原始数据关联的定时器超时,所述通信装置丢弃以下中的至少一项:所述一组原始数据,所述一组原始数据进行网络编码功能的处理生成的所述多个第一数据包。
2.根据权利要求1所述的方法,其特征在于,所述原始数据为分组数据汇聚协议PDCP服务数据单元SDU。
3.根据权利要求2所述的方法,其特征在于,所述一组PDCP SDU对应所述多个第一数据包,一个所述第一数据包对应一个PDCP协议数据单元PDU,一个PDCP PDU包括一个所述第一数据包和PDCP头;
所述方法还包括:
所述通信装置丢弃所述一组PDCP SDU对应的多个PDCP协议数据单元PDU。
4.根据权利要求1所述的方法,其特征在于,所述原始数据为PDCP PDU。
5.根据权利要求4所述的方法,其特征在于,所述方法还包括:
所述通信装置丢弃所述一组PDCP PDU对应的PDCP SDU,其中一个PDCP PDU对应一个PDCP SDU。
6.根据权利要求4或5所述的方法,其特征在于,所述通信装置为集中式单元或用于所述集中式单元的芯片;
所述方法还包括:
所述通信装置向分布式单元发送指示信息,所述指示信息用于指示所述分布式单元丢弃所述一组原始数据进行网络编码功能的处理生成的所述多个第一数据包。
7.根据权利要求6所述的方法,其特征在于,所述指示信息包括以下中的一项:所述多个第一数据包各自的标识,所述多个第一数据包的标识所属的范围,所述多个第一数据包所属的编码块的标识,所述多个第一数据包各自对应的编码系数因子的标识。
8.根据权利要求4或5所述的方法,其特征在于,所述通信装置为分布式单元或用于所述分布式单元的芯片。
9.根据权利要求4或5所述的方法,其特征在于,所述通信装置为终端设备或用于所述终端设备的芯片,所述通信装置包括分组数据汇聚协议PDCP层、网络编码NC层、以及无线链路控制RLC层,所述通信装置的NC层位于所述通信装置的PDCP层和RLC层之间;
所述通信装置获取一组原始数据之后,所述方法还包括:
所述通信装置的NC层为所述一组PDCP PDU关联一个定时器;
所述若所述一组原始数据关联的定时器超时,所述通信装置丢弃以下中的至少一项:所述一组原始数据,所述一组原始数据进行网络编码功能的处理生成的所述多个第一数据包,包括:
若所述一组PDCP PDU关联的定时器超时,所述通信装置的NC层丢弃以下中的至少一项:所述一组PDCP PDU,所述一组PDCP PDU进行网络编码功能的处理生成的所述多个第一数据包。
10.根据权利要求4、5、9中任一项所述的方法,其特征在于,所述通信装置为终端设备或用于所述终端设备的芯片,所述通信装置包括PDCP层、NC层、以及RLC层,所述通信装置的NC层位于所述通信装置的PDCP层和RLC层之间;
所述方法还包括:
所述通信装置将所述一组PDCP PDU进行网络编码功能的处理生成的全部或部分第一数据包传输至所述通信装置的RLC层后,所述通信装置的NC层指示所述通信装置的RLC层丢弃传输至所述RLC层的所述第一数据包;
所述通信装置的RLC层丢弃从所述通信装置的NC层接收到的所述第一数据包。
11.根据权利要求1-10中任一项所述的方法,其特征在于,所述通信装置包括PDCP层,所述方法还包括:
所述通信装置关闭所述通信装置的PDCP层中PDCP SDU与丢弃定时器的关联功能。
12.一种网络编码场景下的超时丢包方法,其特征在于,包括:
通信装置对原始数据进行网络编码功能的处理生成多个第一数据包,一个所述第一数据包关联一个定时器,所述多个第一数据包包括系统包和冗余包,或者,所述多个第一数据包包括原数据包和冗余包;
若所述多个第一数据包中的第一数据包i关联的定时器超时,所述通信装置丢弃所述第一数据包i。
13.根据权利要求12所述的方法,其特征在于,所述原始数据包括一个或者多个PDCPSDU,一个所述第一数据包对应一个PDCP PDU,一个PDCP PDU包括一个第一数据包和PDCP头;
所述方法还包括:
所述通信装置丢弃所述第一数据包i对应的PDCP PDU。
14.根据权利要求13所述的方法,其特征在于,所述方法还包括:
所述通信装置丢弃所述第一数据包i对应的PDCP SDU,其中一个所述第一数据包对应一个或多个PDCP SDU。
15.根据权利要求12所述的方法,其特征在于,所述原始数据包括一个或者多个PDCPPDU。
16.根据权利要求15所述的方法,其特征在于,所述通信装置为集中式单元或用于所述集中式单元的芯片;
所述方法还包括:
所述通信装置向分布式单元发送指示信息,所述指示信息用于指示所述分布式单元丢弃所述第一数据包i。
17.根据权利要求16所述的方法,其特征在于,所述指示信息中包括所述第一数据包i的标识或包括所述第一数据包i对应的编码系数因子的标识。
18.根据权利要求15所述的方法,其特征在于,所述通信装置为分布式单元或用于所述分布式单元的芯片。
19.根据权利要求15所述的方法,其特征在于,所述通信装置为终端设备或用于所述终端设备的芯片,所述通信装置包括PDCP层、NC层以及RLC层,所述通信装置的NC层位于所述通信装置的PDCP层和RLC层之间;
所述方法还包括:
所述通信装置的NC层将所述第一数据包i传输至所述通信装置的RLC层后,所述通信装置的NC层指示所述通信装置的RLC层丢弃所述第一数据包i;
所述通信装置的RLC层丢弃从所述通信装置的NC层接收到的所述第一数据包i。
20.根据权利要求12-19中任一项所述的方法,其特征在于,所述通信装置包括PDCP层,所述方法还包括:
所述通信装置关闭所述通信装置的PDCP层中PDCP SDU与丢弃定时器的关联功能。
21.一种网络编码场景下的超时丢包方法,其特征在于,包括:
若PDCP SDU关联的定时器超时,发送PDCP实体丢弃所述PDCP SDU,其中一个PDCP SDU关联一个定时器;
所述发送PDCP实体对一个或多个PDCP SDU进行网络编码功能的处理生成多个第一数据包,所述多个第一数据包包括系统包和冗余包,或者,所述多个第一数据包包括原数据包和冗余包,一个所述第一数据包对应一个PDCP PDU,一个PDCP PDU包括一个第一数据包和PDCP头;
若所述一个PDCP PDU对应的N个PDCP SDU关联的N个定时器中的K个定时器超时,所述发送PDCP实体丢弃所述PDCP PDU,所述K为小于或等于N的正整数,且所述K大于预设阈值;
其中所述一个PDCP PDU对应的N个PDCP SDU包括:
所述一个PDCP PDU包括的第一数据包是系统包或原数据包,则所述一个PDCP PDU包括的第一数据包的数据来自所述N个PDCP SDU中的每个PDCP SDU;或
所述一个PDCP PDU包括的第一数据包是冗余包,则所述一个PDCP PDU包括的与第一数据包满足网络编码关系的原数据包来自所述N个PDCP SDU中的每个PDCP SDU。
22.根据权利要求21所述的方法,其特征在于,所述发送PDCP实体对一个或多个PDCPSDU进行网络编码功能的处理生成多个第一数据包之后,所述方法还包括:
所述发送PDCP实体丢弃所述一个或多个PDCP SDU对应的多个第一数据包中的全部或部分。
23.一种网络编码场景下的超时丢包方法,其特征在于,包括:
发送PDCP实体对一个或多个PDCP SDU进行网络编码功能的处理生成多个第一数据包,所述多个第一数据包包括系统包和冗余包,或者,所述多个第一数据包包括原数据包和冗余包,所述一个或多个PDCP SDU对应所述多个第一数据包,一个所述第一数据包对应一个PDCP PDU,一个PDCP PDU包括一个第一数据包和PDCP头,一个PDCP SDU对应多个PDCP PDU,所述一个或多个PDCP SDU中的一个PDCP SDU关联一个定时器;
若所述一个或多个PDCP SDU中的第一PDCP SDU关联的定时器超时,所述发送PDCP实体丢弃以下中的至少一项:所述第一PDCP SDU,所述第一PDCP SDU对应的多个PDCP PDU。
24.根据权利要求23所述的方法,其特征在于,所述方法还包括:
所述发送PDCP实体丢弃所述第一PDCP SDU对应的多个第一数据包中的全部或部分。
25.一种通信装置,其特征在于,包括用于执行权利要求1-20中任一项所述方法的模块或单元。
26.一种发送PDCP实体,其特征在于,包括用于执行权利要求21-24中任一项所述方法的模块或单元。
27.一种通信装置,其特征在于,包括:
一个或多个处理器,所述一个或多个处理器与一个或多个存储器耦合;
其中,所述一个或多个存储器用于存储计算机程序,所述一个或多个处理器用于执行存储于所述一个或多个存储器中的计算机程序,以使得所述通信装置执行如权利要求1-24中任一项所述的方法。
28.一种可读存储介质,其特征在于,用于存储程序,所述程序被一个或多个处理器执行,使得包括所述一个或多个处理器的装置执行如权利要求1-24中任一项所述的方法。
CN202110874205.2A 2021-07-30 2021-07-30 网络编码场景下的超时丢包方法、装置及可读存储介质 Pending CN115696435A (zh)

Priority Applications (2)

Application Number Priority Date Filing Date Title
CN202110874205.2A CN115696435A (zh) 2021-07-30 2021-07-30 网络编码场景下的超时丢包方法、装置及可读存储介质
PCT/CN2022/107865 WO2023005909A1 (zh) 2021-07-30 2022-07-26 网络编码场景下的超时丢包方法、装置及可读存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202110874205.2A CN115696435A (zh) 2021-07-30 2021-07-30 网络编码场景下的超时丢包方法、装置及可读存储介质

Publications (1)

Publication Number Publication Date
CN115696435A true CN115696435A (zh) 2023-02-03

Family

ID=85057921

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202110874205.2A Pending CN115696435A (zh) 2021-07-30 2021-07-30 网络编码场景下的超时丢包方法、装置及可读存储介质

Country Status (2)

Country Link
CN (1) CN115696435A (zh)
WO (1) WO2023005909A1 (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2024087585A1 (en) * 2023-05-12 2024-05-02 Lenovo (Beijing) Limited Method and apparatus of data transmission using protocol data unit set discard timers

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20200034484A (ko) * 2018-09-21 2020-03-31 삼성전자주식회사 무선 통신 시스템에서 데이터를 송수신하는 방법 및 장치

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2024087585A1 (en) * 2023-05-12 2024-05-02 Lenovo (Beijing) Limited Method and apparatus of data transmission using protocol data unit set discard timers

Also Published As

Publication number Publication date
WO2023005909A1 (zh) 2023-02-02

Similar Documents

Publication Publication Date Title
KR101216100B1 (ko) 단편화 패킹 확장헤더를 수반하는 mac pdu를 전송하는 방법 및 장치
WO2017101972A1 (en) Data retransmission
US20230139754A1 (en) Coding method and apparatus
US20220368494A1 (en) Uplink re-transmission with compact memory usage
US11990919B2 (en) Method and device in UE and base station for channel coding
WO2023005909A1 (zh) 网络编码场景下的超时丢包方法、装置及可读存储介质
WO2018103637A1 (zh) 数据处理的方法、发送设备和接收设备
WO2022228467A1 (zh) 数据传输方法、装置及可读存储介质
TWI826994B (zh) 一種實體層控制資訊的傳輸方法和裝置
WO2021259042A1 (zh) 通信系统中数据处理方法和装置
WO2021169732A1 (zh) 一种切换方法及通信装置
CN113316922B (zh) 用于传输数据分组的设备、方法、装置以及计算机可读存储介质
CN110708723B (zh) 一种数据传输方法及装置
KR102661184B1 (ko) 무선 통신 시스템, 송수신 방법, 프로그램, 무선 통신 기지국 장치, 제어 회로 및 제어 방법
US20240154724A1 (en) Configuration method for network coding function and related apparatus
WO2023005885A1 (zh) 一种切换场景的数据转发方法及装置
WO2023016506A1 (zh) 传输数据的方法及通信装置
WO2023273973A1 (zh) 一种通信方法及通信装置
WO2023046029A1 (zh) 数据传输方法、装置及可读存储介质
WO2023123515A1 (zh) 数据处理方法、终端设备和网络设备
CN116418452A (zh) 一种通信方法及装置
CN118216103A (zh) 通信方法和设备

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination