CN116865916A - 数据传输方法、装置、芯片测试机及电子设备 - Google Patents

数据传输方法、装置、芯片测试机及电子设备 Download PDF

Info

Publication number
CN116865916A
CN116865916A CN202310626902.5A CN202310626902A CN116865916A CN 116865916 A CN116865916 A CN 116865916A CN 202310626902 A CN202310626902 A CN 202310626902A CN 116865916 A CN116865916 A CN 116865916A
Authority
CN
China
Prior art keywords
data packet
group
board card
sent
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
CN202310626902.5A
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.)
Hangzhou Changchuan Technology Co Ltd
Original Assignee
Hangzhou Changchuan Technology 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 Hangzhou Changchuan Technology Co Ltd filed Critical Hangzhou Changchuan Technology Co Ltd
Priority to CN202310626902.5A priority Critical patent/CN116865916A/zh
Publication of CN116865916A publication Critical patent/CN116865916A/zh
Pending legal-status Critical Current

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L1/00Arrangements for detecting or preventing errors in the information received
    • H04L1/12Arrangements for detecting or preventing errors in the information received by using return channel
    • H04L1/16Arrangements for detecting or preventing errors in the information received by using return channel in which the return channel carries supervisory signals, e.g. repetition request signals
    • H04L1/18Automatic repetition systems, e.g. Van Duuren systems
    • H04L1/1867Arrangements specially adapted for the transmitter end
    • H04L1/1874Buffer management
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L1/00Arrangements for detecting or preventing errors in the information received
    • H04L1/004Arrangements for detecting or preventing errors in the information received by using forward error control
    • H04L1/0056Systems characterized by the type of code used
    • H04L1/0061Error detection codes
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L1/00Arrangements for detecting or preventing errors in the information received
    • H04L1/12Arrangements for detecting or preventing errors in the information received by using return channel
    • H04L1/16Arrangements for detecting or preventing errors in the information received by using return channel in which the return channel carries supervisory signals, e.g. repetition request signals
    • H04L1/18Automatic repetition systems, e.g. Van Duuren systems
    • H04L1/1829Arrangements specially adapted for the receiver end
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L1/00Arrangements for detecting or preventing errors in the information received
    • H04L1/12Arrangements for detecting or preventing errors in the information received by using return channel
    • H04L1/16Arrangements for detecting or preventing errors in the information received by using return channel in which the return channel carries supervisory signals, e.g. repetition request signals
    • H04L1/18Automatic repetition systems, e.g. Van Duuren systems
    • H04L1/1829Arrangements specially adapted for the receiver end
    • H04L1/1848Time-out mechanisms
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04QSELECTING
    • H04Q9/00Arrangements in telecontrol or telemetry systems for selectively calling a substation from a main station, in which substation desired apparatus is selected for applying a control signal thereto or for obtaining measured values therefrom
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04QSELECTING
    • H04Q2209/00Arrangements in telecontrol or telemetry systems
    • H04Q2209/30Arrangements in telecontrol or telemetry systems using a wired architecture

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Detection And Prevention Of Errors In Transmission (AREA)

Abstract

本申请公开了一种数据传输方法、装置、芯片测试机及电子设备,属于芯片测试技术领域,其中,数据传输方法包括:接收第一组目标数据包,第一组目标数据包中每个目标数据包均为上位机发送的数据包;对第一组目标数据包中的每个目标数据包增加第一包序列号和校验值,得到待发送数据包组,并存储在多个缓存模块;将待发送数据包组发送至业务板卡,以使业务板卡对待发送数据包组中每个数据包进行第一包序列号和校验值计算;当接收到来自业务板卡的否定确认信息时,重新发送多个缓存模块存储的待发送数据包组。该数据传输方法简单实用,并且可以实现在保证通信系统稳定性的同时,也能保证通信效率。

Description

数据传输方法、装置、芯片测试机及电子设备
技术领域
本申请属于芯片测试技术领域,具体涉及一种数据传输方法、装置、芯片测试机及电子设备。
背景技术
芯片测试机用于检测集成电路的功能和性能的完整性,是集成电路生产制造流程中确保集成电路品质的重要设备。芯片测试机最基本的评判指标就是测试效率。而通信效率又是描述芯片测试效率的重要指标之一。
目前,芯片测试机的上位机在下发数据时,在通信板卡与业务板卡之间的通信,通常采用以太网或者AURORA协议。
上述两种协议具有低延迟、高带宽和高度可配置的特性,但是这两种协议数据传输的稳定性较差,在传输数据的过程中会出现错误或丢包的现象。
发明内容
本申请的目的是提供一种数据传输方法、装置、芯片测试机及电子设备以防止芯片测试机在数据传输过程中出现错误或丢失,提高芯片测试机通信系统的稳定性。
根据本申请实施例的第一方面,提供了一种数据传输方法,该方法应用于通信板卡,通信板卡包括多个缓存模块,数据传输方法包括:
接收第一组目标数据包,第一组目标数据包中每个目标数据包均为上位机发送的数据包;
对第一组目标数据包中的每个目标数据包增加第一包序列号和校验值,得到待发送数据包组,并存储在多个缓存模块;
将待发送数据包组发送至业务板卡,以使业务板卡对待发送数据包组中每个数据包进行第一包序列号和校验值计算;
当接收到来自业务板卡的否定确认信息时,重新发送多个缓存模块存储的待发送数据包组;
否定确认信息为业务板卡接收到全部待发送数据包组或超过预设时间未完全接收待发送数据包组时发送的信息,第一组目标数据包中的数据包的数量大于缓存模块数量的一半且小于缓存模块的数量。
在本申请的一些可选实施例中,对第一组目标数据包中的每个目标数据包增加第一包序列号和校验值,得到待发送数据包组的步骤,包括:
识别第一组目标数据包中每个目标数据包的输出通道;
根据输出通道对对应的目标数据包增加第一包序列号,得到带有第一包序列号数据包组;
计算带有第一包序列号数据包组中每个数据包的校验值,并将校验值增加到对应数据包中,形成待发送数据包组。
在本申请的一些可选实施例中,将待发送数据包组发送至业务板卡的步骤,包括:
将待发送数据包组存入多个缓存模块中,并将待发送数据包组通过预设协议发送至业务板卡。
在本申请的一些可选实施例中,在重新发送多个缓存模块存储的待发送数据包组的步骤之后,数据传输方法还包括:
当预设次数的重复发送多个缓存模块存储的待发送数据包组均失败时,向上位机发送传输失败通知。
在本申请的一些可选实施例中,在将待发送数据包组发送至业务板卡的步骤之后,数据传输方法还包括:
当接收到确认信息时,接收第二组目标数据包,并覆盖缓存模块中数据,第二组目标数据包为上位机发送的数据包。
根据本申请实施例的第二方面,提供一种数据传输方法,该方法应用于业务板卡,数据传输方法包括:
接收通信板卡发送的数据包组,并对数据包组中的数据包进行序列号和校验值计算;
当业务板卡全部接收数据包组或超过预设时间未全部接收数据包组时,对数据包组中数据包的序列号和校验值进行校验;
当校验结果为存在异常时,向通信板卡发送否定确认信息,以使通信板卡重新发送数据包组。
在本申请的一些可选实施例中,对数据包组中数据包的序列号和校验值进行校验的步骤,包括:
比较数据包组中数据包的序列号和校验值与通信板卡发送的序列号和校验值是否相同,若至少存在一个不相同则校验结果为存在异常。
在本申请的一些可选实施例中,在对数据包的序列号和校验值进行校验的步骤之后,数据传输方法还包括:
当校验结果中未存在异常时,向通信板卡发送确认信息。
根据本申请实施例的第三方面,提供一种数据传输方法,该方法应用于测试机,测试机包括通信板卡和业务板卡,通信板卡包括多个缓存模块;
通信板卡接收第一组目标数据包,第一组目标数据包中每个目标数据包均为上位机发送的数据包;
通信板卡对第一组目标数据包中的每个目标数据包增加第一包序列号和校验值,得到待发送数据包组,并存储在多个缓存模块;
通信板卡将待发送数据包发送至业务板卡;
业务板卡对接收到的数据包组中的数据包进行序列号和校验值计算;
当业务板卡全部接收数据包组或超过预设时间未全部接收数据包组时,业务板卡对数据包组中数据包的序列号和校验值进行校验;
当业务板卡校验结果为存在异常时,向通信板卡发送否定确认信息;
当通信板卡接收到否定确认信息或业务板卡在预设时间内未完全收到待发送数据包组时,通信板卡重新发送多个缓存模块存储的待发送数据包组,第一组目标数据包中的数据包的数量大于缓存模块数量的一半且小于缓存模块的数量。
根据本申请实施例的第四方面,提供一种数据传输装置,该装置应用于通信板卡,通信板卡包括多个缓存模块,数据传输装置包括:
第一接收模块,与上位机通信连接,用于接收第一组目标数据包,第一组目标数据包中每个目标数据包均为上位机发送的数据包;
第一校验模块,与第一接收模块通信连接,用于对第一组目标数据包中的每个目标数据包增加第一包序列号和校验值,得到待发送数据包组,并存储在多个缓存模块;
第一发送模块,与第一校验模块通信连接,用于将待发送数据包组发送至业务板卡,以使业务板卡对待发送数据包组中每个数据包进行第一包序列号和校验值计算;
第一发送模块,还用于当接收到来自业务板卡的否定确认信息时,重新发送多个缓存模块存储的待发送数据包组;
否定确认信息为业务板卡接收到全部待发送数据包组或超过预设时间未完全接收待发送数据包组时发送的信息,第一组目标数据包中的数据包的数量大于缓存模块数量的一半且小于缓存模块的数量。
在本申请的一些可选实施例中,第一校验模块,包括:
识别单元,用于识别第一组目标数据包中每个目标数据包的输出通道;
增加包序列号单元,用于根据输出通道对对应的目标数据包增加第一包序列号,得到带有第一包序列号数据包组;
计算单元,用于计算带有第一包序列号数据包组中每个数据包的校验值,并将校验值增加到对应数据包中,形成待发送数据包组。
在本申请的一些可选实施例中,第一发送模块,具体用于将待发送数据包组存入多个缓存模块中,并将待发送数据包组通过预设协议发送至业务板卡。
在本申请的一些可选实施例中,数据传输装置还包括:
通知模块,用于当预设次数的重复发送多个缓存模块存储的待发送数据包组均失败时,向上位机发送传输失败通知。
在本申请的一些可选实施例中,第一发送模块,还用于当接收到确认信息时,接收第二组目标数据包,并覆盖缓存模块中数据,第二组目标数据包为上位机发送的数据包。
根据本申请实施例的第五方面,提供一种数据传输装置,该装置应用于业务板卡,数据传输装置包括:
第二接收模块,与通信板卡通信连接,用于接收通信板卡发送的数据包组,并对数据包组中的数据包进行序列号和校验值计算;
第二校验模块,与第二接收模块通信连接,用于当业务板卡全部接收数据包组或超过预设时间未全部接收数据包组时,对数据包组中数据包的序列号和校验值进行校验;
第二发送模块,与第二校验模块通信连接,用于当校验结果为存在异常时,向通信板卡发送否定确认信息,以使通信板卡重新发送数据包组。
在本申请的一些可选实施例中,第二校验模块,具体用于比较数据包组中数据包的序列号和校验值与通信板卡发送的序列号和校验值是否相同,若至少存在一个不相同则校验结果为存在异常。
在本申请的一些可选实施例中,第二发送模块,还用于当校验结果中未存在异常时,向通信板卡发送确认信息。
根据本申请实施例的第六方面,提供一种数据传输装置,该装置可以包括:通信板卡和业务板卡,通信板卡包括多个缓存模块;
通信板卡,与上位机通信连接,用于接收第一组目标数据包,第一组目标数据包中每个目标数据包均为上位机发送的数据包;
通信板卡还用于对第一组目标数据包中的每个目标数据包增加第一包序列号和校验值,得到待发送数据包组,并存储在多个缓存模块;
通信板卡还用于将待发送数据包发送至业务板卡;
业务板卡,与通信板卡通信连接,用于对接收到的数据包组中的数据包进行序列号和校验值计算;
当业务板卡全部接收数据包组或超过预设时间未全部接收数据包组时,业务板卡对数据包组中数据包的序列号和校验值进行校验;
当业务板卡校验结果为存在异常时,业务板卡还用于向通信板卡发送否定确认信息;
当通信板卡接收到否定确认信息时,通信板卡还用于重新发送多个缓存模块存储的待发送数据包组,第一组目标数据包中的数据包的数量大于缓存模块数量的一半且小于缓存模块的数量,或业务板卡在预设时间内未完全收到待发送数据包组。
在本申请的一些可选实施例中,通信板卡包括第一预设数量的第一缓存组,每个第一缓存组均包括第二预设数量的第一缓存模块;业务板卡的个数为第一预设数量,每个业务板卡包括第二预设数量的第二缓存模块,第二预设数量的第二缓存模块形成第二缓存组;
每个第二缓存组与每个第一缓存组一一对应。
根据本申请实施例的第七方面,提供一种芯片测试机,该芯片测试机包括通信板卡和业务板卡,该通信板卡采用如第一方面的任一项实施例中所示的数据传输方法进行数据发送,所述业务板卡采用如第二方面的任一项实施例中所示的数据传输方法进行数据处理。
根据本申请实施例的第八方面,提供一种电子设备,该电子设备可以包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,处理器被配置为执行指令,以实现如第一方面的任一项实施例中所示的数据传输方法或第二方面的任一项实施例中所示的数据传输方法。
本申请的上述技术方案具有如下有益的技术效果:
本申请实施例方法通过先将目标数据包加入包序列号和校验值,并成组的存储在缓存模块中;然后再发送至业务板卡;当业务板卡接收到全部待发送数据包组并校验出错或超过预设时间未完全接收待发送数据包组时,业务板卡向通信板卡发送否定确认信息,以使通信板卡进行数据重传。这样在数据传输错误或者丢包时,通信板卡只需要将缓存模块中的数据进行重传即可,重传数据量少,并且不需要上位机参与。该方法简单实用,并且可以实现在保证通信系统稳定性的同时,也能保证通信效率。
附图说明
图1是本申请一示例性实施例中数据传输方法的流程示意图;
图2是本申请一示例性实施例中通信系统的架构示意图;
图3是本申请一示例性实施例中待发送数据包的结构示意图;
图4是本申请另一示例性实施例中数据传输方法的流程示意图;
图5是本申请又一示例性实施例中数据传输方法的流程示意图;
图6是本申请一示例性实施例中数据传输装置的结构示意图;
图7是本申请另一示例性实施例中数据传输装置的结构示意图;
图8是本申请又一示例性实施例中数据传输装置的结构示意图;
图9是本申请另一示例性实施例中通信系统的架构示意图;
图10是本申请一示例性实施例中芯片测试机的结构示意图;
图11是本申请一示例性实施例中电子设备的硬件结构示意图。
具体实施方式
为使本申请的目的、技术方案和优点更加清楚明了,下面结合具体实施方式并参照附图,对本申请进一步详细说明。应该理解,这些描述只是示例性的,而并非要限制本申请的范围。此外,在以下说明中,省略了对公知结构和技术的描述,以避免不必要地混淆本申请的概念。
在附图中示出了根据本申请实施例的层结构示意图。这些图并非是按比例绘制的,其中为了清楚的目的,放大了某些细节,并且可能省略了某些细节。图中所示出的各种区域、层的形状以及它们之间的相对大小、位置关系仅是示例性的,实际中可能由于制造公差或技术限制而有所偏差,并且本领域技术人员根据实际所需可以另外设计具有不同形状、大小、相对位置的区域/层。
显然,所描述的实施例是本申请一部分实施例,而不是全部的实施例。基于本申请中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本申请保护的范围。
在本申请的描述中,需要说明的是,术语“第一”、“第二”、“第三”仅用于描述目的,而不能理解为指示或暗示相对重要性。
此外,下面所描述的本申请不同实施方式中所涉及的技术特征只要彼此之间未构成冲突就可以相互结合。
下面结合附图,通过具体的实施例及其应用场景对本申请实施例提供的数据传输方法、装置、芯片测试机及电子设备进行详细地说明。
如图1所示,在本申请实施例的第一方面,提供了一种数据传输方法,该方法应用于通信板卡,通信板卡包括多个缓存模块,数据传输方法包括:
步骤S110:接收第一组目标数据包,第一组目标数据包中每个目标数据包均为上位机发送的数据包;
步骤S120:对第一组目标数据包中的每个目标数据包增加第一包序列号和校验值,得到待发送数据包组,并存储在多个缓存模块;
步骤S130:将待发送数据包组发送至业务板卡,以使业务板卡对待发送数据包组中每个数据包进行第一包序列号和校验值计算;
步骤S140:当接收到来自业务板卡的否定确认信息时,重新发送多个缓存模块存储的待发送数据包组;
否定确认信息为业务板卡接收到全部待发送数据包组或超过预设时间未完全接收待发送数据包组时发送的信息,第一组目标数据包中的数据包的数量大于缓存模块数量的一半且小于缓存模块的数量。
本实施例方法在数据传输错误或者丢包时,通信板卡只需要将缓存模块中的数据进行重传即可,重传数据量少,并且不需要上位机参与。方法简单实用,并且可以实现在保证通信系统稳定性的同时,也能保证通信效率。
为了更加清楚的说明,下面对于上述方法步骤分别进行详细介绍:
首先介绍一下芯片测试机的通信系统架构,通信系统的架构,如图2所示,包括:上位机、通信板卡及业务板卡。通信系统运行过程中,上位机通过高速串行计算机扩展总线(PCIE)接口,将目标数据下发至通信板卡,通信板卡的现场可编程逻辑门阵列通过对目标数据进行处理之后再通过高速串行总线(以太网或者aurora协议)转发至业务板卡。其中,目标数据可以是pattern数据或寄存器配置数据等。业务板卡可以是电源板卡、数字板卡或射频板卡等。
接下来介绍的是步骤S110:接收第一组目标数据包,第一组目标数据包中每个目标数据包均为上位机发送的数据包。
本步骤接收的第一组目标数据包可以逐个接收,也可以是成组接收,这里需要注意的是第一组目标数据包中的数据包的数量大于缓存模块数量的一半且小于缓存模块的数量。因这样可以比较充分利用缓存模块,并且也不至于数据溢出。
接下来介绍的是步骤S120:对第一组目标数据包中的每个目标数据包增加第一包序列号和校验值,得到待发送数据包组,并存储在多个缓存模块。
本步骤是为了保证通信系统数据传输的稳定性,可以进行循环冗余校核(crc检测),因此对第一组目标数据包增加包序列号和校验值。并且本步骤并不是直接将第一组目标数据包发送至业务板卡,而是将第一组目标数据包先存入缓存模块之后,再发送至业务板卡。这样一旦出现丢包或者校验错误时,只需要将缓存模块中的第一组目标数据包重发即可,不需要全部数据重发,重传数据量少,并且不需要上位机参与,可以提高数据传输效率。
最后介绍的是步骤S140:当接收到来自业务板卡的否定确认信息时,重新发送多个缓存模块存储的待发送数据包组。
本步骤否定确认信息(Nak)为业务板卡接收到全部待发送数据包组并校验出错或超过预设时间未完全接收待发送数据包组时发送的信息,第一组目标数据包中的数据包的数量大于缓存模块数量的一半且小于缓存模块的数量。
其中,接收到全部待发送数据包组并校验出错证明循环冗余校核失败,需要重传数据;超过预设时间未完全接收待发送数据包组则证明存在丢包的情况,也需要重传数据。预设时间可以根据实际数据传输需求进行设定,也可以根据业务板卡的最大应答命令延时来设定。示例性的,根据业务板卡的最大应答命令延时可以将预设时间设置为20ms。
在一些实施例中,步骤S120对第一组目标数据包中的每个目标数据包增加第一包序列号和校验值,得到待发送数据包组,包括:
步骤S121:识别第一组目标数据包中每个目标数据包的输出通道;
步骤S122:根据输出通道对对应的目标数据包增加第一包序列号,得到带有第一包序列号数据包组;
步骤S123:计算带有第一包序列号数据包组中每个数据包的校验值,并将校验值增加到对应数据包中,形成待发送数据包组。
本实施例的方法步骤执行主体可以是通信板卡中的现场可编程逻辑门阵列(FPGA),现场可编程逻辑门阵列先区分出第一组目标数据包中每个数据包是传输到哪个通道(slot)的,确定通道号;然后在该每个数据包前增加第一包序列号(seq),该包序列号可以是从0开始添加;最后计算每个数据包整包的校验值(CRC),形成待发送数据包,如图3所示。
在一些实施例中,步骤S130将待发送数据包组发送至业务板卡,包括:
步骤S1301:将待发送数据包组存入多个缓存模块中,并将待发送数据包组通过预设协议发送至业务板卡。
本实施例中,预设协议可以是aurora或者10G以太网协议等。具体的,通信板卡的现场可编程逻辑门阵列将待发送数据包组存入多个缓存模块中,并将待发送数据包组通过预设协议发送至业务板卡的现场可编程逻辑门阵列。
在一些实施例中,在步骤S140重新发送多个缓存模块存储的待发送数据包组之后,数据传输方法还包括:
步骤S150:当预设次数的重复发送多个缓存模块存储的待发送数据包组均失败时,向上位机发送传输失败通知。
本实施例中,经过多次重发失败,需要将传输失败的信息通知上位机,此过程可以通过寄存器或者中断的方式通知上位机。
在一些实施例中,在步骤S130将待发送数据包组发送至业务板卡之后,数据传输方法还包括:
步骤S131:当接收到确认信息时,接收第二组目标数据包,并覆盖缓存模块中数据,第二组目标数据包为上位机发送的数据包。
本实施例中收到确认信息(Ack)时,证明第一组数据包发送完成,并通过校验,可以发送第二组数据包。
在收到第二组目标数据包时,同样要对第二组目标数据包中的每个目标数据包增加包序列号和校验值。基于第一组目标数据包,在增加包序列号时如果存在与第一组目标数据包通道相同的数据包,则该数据包号在前一包序列号的基础上增加1。
在发送第二组目标数据包时,同样也是先将第二组目标数据包存储在缓存模块当中,但是由前叙可知,第一组目标数据包中的数据包的数量大于缓存模块数量的一半且小于缓存模块的数量。也就是说缓存模块的空余数量小于第二组目标数据包中数据包的数量,因此需要对一部分第一组目标数据包进行覆盖。
如图4所示,在本申请实施例的第二方面,提供一种数据传输方法,该方法应用于业务板卡,数据传输方法包括:
步骤S410:接收通信板卡发送的数据包组,并对数据包组中的数据包进行序列号和校验值计算;
步骤S420:当业务板卡全部接收数据包组或超过预设时间未全部接收数据包组时,对数据包组中数据包的序列号和校验值进行校验;
步骤S430:当校验结果为存在异常时,向通信板卡发送否定确认信息,以使通信板卡重新发送数据包组。
本实施例方法是应用在业务板卡且与第一方面实施例所述的方法相对应,第一方面实施例所能解决的问题和达到技术效果第二方面实施例也同样可以实现,为了简洁,相同部分不再赘述。
本实施例不同的是本方法的执行主体是业务板卡的现场可编程逻辑门阵列。
在一些实施例中,步骤S410对数据包组中数据包的序列号和校验值进行校验,包括:
步骤S4101:比较数据包组中数据包的序列号和校验值与通信板卡发送的序列号和校验值是否相同,若至少存在一个不相同则校验结果为存在异常。
在一些实施例中,在步骤S420对数据包的序列号和校验值进行校验之后,数据传输方法还包括:
步骤S431:当校验结果中未存在异常时,向通信板卡发送确认信息。
如图5所示,在本申请实施例的第三方面,提供一种数据传输方法,该方法应用于测试机,测试机包括通信板卡和业务板卡,通信板卡包括多个缓存模块;
步骤S510:通信板卡接收第一组目标数据包,第一组目标数据包中每个目标数据包均为上位机发送的数据包;
步骤S520:通信板卡对第一组目标数据包中的每个目标数据包增加第一包序列号和校验值,得到待发送数据包组,并存储在多个缓存模块;
步骤S530:通信板卡将待发送数据包发送至业务板卡;
步骤S540:业务板卡对接收到的数据包组中的数据包进行序列号和校验值计算;
步骤S550:当业务板卡全部接收数据包组或超过预设时间未全部接收数据包组时,业务板卡对数据包组中数据包的序列号和校验值进行校验;
步骤S560:当业务板卡校验结果为存在异常时,向通信板卡发送否定确认信息;
步骤S570:当通信板卡接收到否定确认信息或业务板卡在预设时间内未完全收到待发送数据包组时,通信板卡重新发送多个缓存模块存储的待发送数据包组,第一组目标数据包中的数据包的数量大于缓存模块数量的一半且小于缓存模块的数量。
本实施例方法是通信板卡与业务板卡的交互方法,包括了第一方面实施例方法和第二方面实施例方法,第一方面实施例和第二方面实施例所能解决的问题和达到技术效果第三方面实施例也同样可以实现,为了简洁,相同部分不再赘述。
需要说明的是,本申请实施例提供的数据传输方法,执行主体可以为数据传输装置,或者该数据传输装置中的用于执行数据传输的方法的控制模块。本申请实施例中以数据传输装置执行数据传输的方法为例,说明本申请实施例提供的数据传输的装置。
如图6所示,在本申请实施例的第四方面,提供一种数据传输装置,该装置应用于通信板卡,通信板卡包括多个缓存模块,数据传输装置包括:
第一接收模块610,与上位机通信连接,用于接收第一组目标数据包,第一组目标数据包中每个目标数据包均为上位机发送的数据包;
第一校验模块620,与第一接收模块通信连接,用于对第一组目标数据包中的每个目标数据包增加第一包序列号和校验值,得到待发送数据包组,并存储在多个缓存模块;
第一发送模块630,与第一校验模块通信连接,用于将待发送数据包组发送至业务板卡,以使业务板卡对待发送数据包组中每个数据包进行第一包序列号和校验值计算;
第一发送模块630,还用于当接收到来自业务板卡的否定确认信息时,重新发送多个缓存模块存储的待发送数据包组;
否定确认信息为业务板卡接收到全部待发送数据包组或超过预设时间未完全接收待发送数据包组时发送的信息,第一组目标数据包中的数据包的数量大于缓存模块数量的一半且小于缓存模块的数量。
本实施例装置在数据传输错误或者丢包时,通信板卡只需要将缓存模块中的数据进行重传即可,重传数据量少,并且不需要上位机参与。该装置可以实现在保证通信系统稳定性的同时,也能保证通信效率。
在一些实施例中,第一校验模块620,包括:
识别单元,用于识别第一组目标数据包中每个目标数据包的输出通道;
增加包序列号单元,用于根据输出通道对对应的目标数据包增加第一包序列号,得到带有第一包序列号数据包组;
计算单元,用于计算带有第一包序列号数据包组中每个数据包的校验值,并将校验值增加到对应数据包中,形成待发送数据包组。
在一些实施例中,第一发送模块630,具体用于将待发送数据包组存入多个缓存模块中,并将待发送数据包组通过预设协议发送至业务板卡。
在一些实施例中,数据传输装置还包括:
通知模块,用于当预设次数的重复发送多个缓存模块存储的待发送数据包组均失败时,向上位机发送传输失败通知。
在一些实施例中,第一发送模块630,还用于当接收到确认信息时,接收第二组目标数据包,并覆盖缓存模块中数据,第二组目标数据包为上位机发送的数据包。
如图7所示,在本申请实施例的第五方面,提供一种数据传输装置,该装置应用于业务板卡,数据传输装置包括:
第二接收模块710,与通信板卡通信连接,用于接收通信板卡发送的数据包组,并对数据包组中的数据包进行序列号和校验值计算;
第二校验模块720,与第二接收模块通信连接,用于当业务板卡全部接收数据包组或超过预设时间未全部接收数据包组时,对数据包组中数据包的序列号和校验值进行校验;
第二发送模块730,与第二校验模块通信连接,用于当校验结果为存在异常时,向通信板卡发送否定确认信息,以使通信板卡重新发送数据包组。
本实施例装置在数据传输错误或者丢包时,通信板卡只需要将缓存模块中的数据进行重传即可,重传数据量少,并且不需要上位机参与。该装置可以实现在保证通信系统稳定性的同时,也能保证通信效率。
在一些实施例中,第二校验模块720,具体用于比较数据包组中数据包的序列号和校验值与通信板卡发送的序列号和校验值是否相同,若至少存在一个不相同则校验结果为存在异常。
在一些实施例中,第二发送模块730,还用于当校验结果中未存在异常时,向通信板卡发送确认信息。
如图8所示,在本申请实施例的第六方面,提供一种数据传输装置,该装置可以包括:通信板卡和业务板卡,通信板卡包括多个缓存模块;
通信板卡810,与上位机800通信连接,用于接收第一组目标数据包,第一组目标数据包中每个目标数据包均为上位机800发送的数据包;
通信板卡810还用于对第一组目标数据包中的每个目标数据包增加第一包序列号和校验值,得到待发送数据包组,并存储在多个缓存模块;
通信板卡810还用于将待发送数据包发送至业务板卡820;
业务板卡820,与通信板卡810通信连接,用于对接收到的数据包组中的数据包进行序列号和校验值计算;
当业务板卡820全部接收数据包组或超过预设时间未全部接收数据包组时,业务板卡820对数据包组中数据包的序列号和校验值进行校验;
当业务板卡820校验结果为存在异常时,业务板卡820还用于向通信板卡810发送否定确认信息;
当通信板卡810接收到否定确认信息时,通信板卡810还用于重新发送多个缓存模块存储的待发送数据包组,第一组目标数据包中的数据包的数量大于缓存模块数量的一半且小于缓存模块的数量,或业务板卡820在预设时间内未完全收到待发送数据包组。
本实施例装置在数据传输错误或者丢包时,通信板卡只需要将缓存模块中的数据进行重传即可,重传数据量少,并且不需要上位机参与。该装置可以实现在保证通信系统稳定性的同时,也能保证通信效率。
如图9所示,在一些实施例中,通信板卡包括第一预设数量的第一缓存组,每个第一缓存组均包括第二预设数量的第一缓存模块;业务板卡的个数为第一预设数量,每个业务板卡包括第二预设数量的第二缓存模块,第二预设数量的第二缓存模块形成第二缓存组;
每个第二缓存组与每个第一缓存组一一对应。
从本实施例可以看出,业务板卡的数量是与通信板卡中第一缓存组的数量相等,并且第一缓存组与第二缓存组中缓存模块的数量也是相等的。此种对应设置可以防止通信板卡与业务板卡数据传输过程中出现数据溢出和存储空间浪费。
本申请实施例中的数据传输装置可以是装置,也可以是终端中的部件、集成电路、或芯片。该装置可以是移动电子设备,也可以为非移动电子设备。示例性的,移动电子设备可以为手机、平板电脑、笔记本电脑、掌上电脑、车载电子设备、可穿戴设备、超级移动个人计算机(ultra-mobile personal computer,UMPC)、上网本或者个人数字助理(personaldigital assistant,PDA)等,非移动电子设备可以为服务器、网络附属存储器(NetworkAttached Storage,NAS)、个人计算机(personal computer,PC)、电视机(television,TV)、柜员机或者自助机等,本申请实施例不作具体限定。
本申请实施例中的数据传输装置可以为具有操作系统的装置。该操作系统可以为安卓(Android)操作系统,可以为ios操作系统,还可以为其他可能的操作系统,本申请实施例不作具体限定。
本申请实施例提供的数据传输装置能够实现图1的方法实施例实现的各个过程,为避免重复,这里不再赘述。
可选地,如图10所示,本申请实施例还提供一种电子设备1000,包括处理器1001,存储器1002,存储在存储器1002上并可在所述处理器1001上运行的程序或指令,该程序或指令被处理器1001执行时实现上述数据传输方法实施例的各个过程,且能达到相同的技术效果,为避免重复,这里不再赘述。
需要说明的是,本申请实施例中的电子设备包括上述所述的移动电子设备和非移动电子设备。
图11为实现本申请实施例的一种电子设备的硬件结构示意图。
该电子设备1100包括但不限于:射频单元1101、网络模块1102、音频输出单元1103、输入单元1104、传感器1105、显示单元1106、用户输入单元1107、接口单元1108、存储器1109、以及处理器1110等部件。
本领域技术人员可以理解,电子设备1100还可以包括给各个部件供电的电源(比如电池),电源可以通过电源管理系统与处理器1110逻辑相连,从而通过电源管理系统实现管理充电、放电、以及功耗管理等功能。图11中示出的电子设备结构并不构成对电子设备的限定,电子设备可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置,在此不再赘述。
应理解的是,本申请实施例中,输入单元1104可以包括图形处理器(GraphicsProcessing Unit,GPU)11041和麦克风11042,图形处理器11041对在视频捕获模式或图像捕获模式中由图像捕获装置(如摄像头)获得的静态图片或视频的图像数据进行处理。显示单元1106可包括显示面板11061,可以采用液晶显示器、有机发光二极管等形式来配置显示面板11061。用户输入单元1107包括触控面板11071以及其他输入设备11072。触控面板11071,也称为触摸屏。触控面板11071可包括触摸检测装置和触摸控制器两个部分。其他输入设备11072可以包括但不限于物理键盘、功能键(比如音量控制按键、开关按键等)、轨迹球、鼠标、操作杆,在此不再赘述。存储器1109可用于存储软件程序以及各种数据,包括但不限于应用程序和操作系统。处理器1110可集成应用处理器和调制解调处理器,其中,应用处理器主要处理操作系统、用户界面和应用程序等,调制解调处理器主要处理无线通信。可以理解的是,上述调制解调处理器也可以不集成到处理器1110中。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者装置不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者装置所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者装置中还存在另外的相同要素。此外,需要指出的是,本申请实施方式中的方法和装置的范围不限按示出或讨论的顺序来执行功能,还可包括根据所涉及的功能按基本同时的方式或按相反的顺序来执行功能,例如,可以按不同于所描述的次序来执行所描述的方法,并且还可以添加、省去、或组合各种步骤。另外,参照某些示例所描述的特征可在其他示例中被组合。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本申请的技术方案本质上或者说对现有技术做出贡献的部分可以以计算机软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端(可以是手机,计算机,服务器,或者网络设备等)执行本申请各个实施例所述的方法。
上面结合附图对本申请的实施例进行了描述,但是本申请并不局限于上述的具体实施方式,上述的具体实施方式仅仅是示意性的,而不是限制性的,本领域的普通技术人员在本申请的启示下,在不脱离本申请宗旨和权利要求所保护的范围情况下,还可做出很多形式,均属于本申请的保护之内。

Claims (15)

1.一种数据传输方法,其特征在于,应用于通信板卡,所述通信板卡包括多个缓存模块,所述数据传输方法包括:
接收第一组目标数据包,所述第一组目标数据包中每个目标数据包均为上位机发送的数据包;
对所述第一组目标数据包中的每个目标数据包增加第一包序列号和校验值,得到待发送数据包组,并存储在所述多个缓存模块;
将所述待发送数据包组发送至业务板卡,以使所述业务板卡对所述待发送数据包组中每个数据包进行第一包序列号和校验值计算;
当接收到来自业务板卡的否定确认信息时,重新发送所述多个缓存模块存储的所述待发送数据包组;
所述否定确认信息为所述业务板卡接收到全部所述待发送数据包组或超过预设时间未完全接收所述待发送数据包组时发送的信息,所述第一组目标数据包中的数据包的数量大于所述缓存模块数量的一半且小于所述缓存模块的数量。
2.根据权利要求1所述的数据传输方法,其特征在于,对所述第一组目标数据包中的每个目标数据包增加第一包序列号和校验值,得到待发送数据包组的步骤,包括:
识别所述第一组目标数据包中每个目标数据包的输出通道;
根据所述输出通道对对应的目标数据包增加第一包序列号,得到带有第一包序列号数据包组;
计算所述带有第一包序列号数据包组中每个数据包的校验值,并将所述校验值增加到对应数据包中,形成待发送数据包组。
3.根据权利要求1所述的数据传输方法,其特征在于,所述将所述待发送数据包组发送至业务板卡的步骤,包括:
将所述待发送数据包组存入所述多个缓存模块中,并将所述待发送数据包组通过预设协议发送至业务板卡。
4.根据权利要求1所述的数据传输方法,其特征在于,在所述重新发送所述多个缓存模块存储的所述待发送数据包组的步骤之后,所述数据传输方法还包括:
当预设次数的重复发送所述多个缓存模块存储的所述待发送数据包组均失败时,向所述上位机发送传输失败通知。
5.根据权利要求1-4任一项所述的数据传输方法,其特征在于,在所述将所述待发送数据包组发送至业务板卡的步骤之后,所述数据传输方法还包括:
当接收到确认信息时,接收第二组目标数据包,并覆盖缓存模块中数据,所述第二组目标数据包为所述上位机发送的数据包。
6.一种数据传输方法,其特征在于,应用于业务板卡,所述数据传输方法包括:
接收通信板卡发送的数据包组,并对所述数据包组中的数据包进行序列号和校验值计算;
当所述业务板卡全部接收所述数据包组或超过预设时间未全部接收所述数据包组时,对所述数据包组中数据包的序列号和校验值进行校验;
当校验结果为存在异常时,向所述通信板卡发送否定确认信息,以使通信板卡重新发送所述数据包组。
7.根据权利要求6所述的数据传输方法,其特征在于,所述对所述数据包组中数据包的序列号和校验值进行校验的步骤,包括:
比较所述数据包组中数据包的序列号和校验值与所述通信板卡发送的序列号和校验值是否相同,若至少存在一个不相同则校验结果为存在异常。
8.根据权利要求6-7任一项所述的数据传输方法,其特征在于,在所述对所述数据包的序列号和校验值进行校验的步骤之后,所述数据传输方法还包括:
当校验结果中未存在异常时,向所述通信板卡发送确认信息。
9.一种数据传输方法,其特征在于,应用于测试机,所述测试机包括通信板卡和业务板卡,所述通信板卡包括多个缓存模块;
所述通信板卡接收第一组目标数据包,所述第一组目标数据包中每个目标数据包均为上位机发送的数据包;
所述通信板卡对所述第一组目标数据包中的每个目标数据包增加第一包序列号和校验值,得到待发送数据包组,并存储在所述多个缓存模块;
所述通信板卡将所述待发送数据包发送至业务板卡;
所述业务板卡对接收到的数据包组中的数据包进行序列号和校验值计算;
当所述业务板卡全部接收所述数据包组或超过预设时间未全部接收所述数据包组时,所述业务板卡对所述数据包组中数据包的序列号和校验值进行校验;
当所述业务板卡校验结果为存在异常时,向所述通信板卡发送否定确认信息;
当所述通信板卡接收到所述否定确认信息或所述业务板卡在预设时间内未完全收到所述待发送数据包组时,所述通信板卡重新发送所述多个缓存模块存储的所述待发送数据包组,所述第一组目标数据包中的数据包的数量大于所述缓存模块数量的一半且小于所述缓存模块的数量。
10.一种数据传输装置,其特征在于,应用于通信板卡,所述通信板卡包括多个缓存模块,所述数据传输装置包括:
第一接收模块,与上位机通信连接,用于接收第一组目标数据包,所述第一组目标数据包中每个目标数据包均为所述上位机发送的数据包;
第一校验模块,与所述第一接收模块通信连接,用于对所述第一组目标数据包中的每个目标数据包增加第一包序列号和校验值,得到待发送数据包组,并存储在所述多个缓存模块;
第一发送模块,与所述第一校验模块通信连接,用于将所述待发送数据包组发送至业务板卡,以使所述业务板卡对所述待发送数据包组中每个数据包进行第一包序列号和校验值计算;
所述第一发送模块,还用于当接收到来自业务板卡的否定确认信息时,重新发送所述多个缓存模块存储的所述待发送数据包组;
所述否定确认信息为所述业务板卡接收到全部所述待发送数据包组或超过预设时间未完全接收所述待发送数据包组时发送的信息,所述第一组目标数据包中的数据包的数量大于所述缓存模块数量的一半且小于所述缓存模块的数量。
11.一种数据传输装置,其特征在于,应用于业务板卡,所述数据传输装置包括:
第二接收模块,与通信板卡通信连接,用于接收所述通信板卡发送的数据包组,并对所述数据包组中的数据包进行序列号和校验值计算;
第二校验模块,与所述第二接收模块通信连接,用于当所述业务板卡全部接收所述数据包组或超过预设时间未全部接收所述数据包组时,对所述数据包组中数据包的序列号和校验值进行校验;
第二发送模块,与所述第二校验模块通信连接,用于当校验结果为存在异常时,向所述通信板卡发送否定确认信息,以使通信板卡重新发送所述数据包组。
12.一种数据传输装置,其特征在于,包括:通信板卡和业务板卡,所述通信板卡包括多个缓存模块;
所述通信板卡,与上位机通信连接,用于接收第一组目标数据包,所述第一组目标数据包中每个目标数据包均为所述上位机发送的数据包;
所述通信板卡还用于对所述第一组目标数据包中的每个目标数据包增加第一包序列号和校验值,得到待发送数据包组,并存储在所述多个缓存模块;
所述通信板卡还用于将所述待发送数据包发送至业务板卡;
所述业务板卡,与所述通信板卡通信连接,用于对接收到的数据包组中的数据包进行序列号和校验值计算;
当所述业务板卡全部接收所述数据包组或超过预设时间未全部接收所述数据包组时,所述业务板卡对所述数据包组中数据包的序列号和校验值进行校验;
当所述业务板卡校验结果为存在异常时,所述业务板卡还用于向所述通信板卡发送否定确认信息;
当所述通信板卡接收到所述否定确认信息时,所述通信板卡还用于重新发送所述多个缓存模块存储的所述待发送数据包组,所述第一组目标数据包中的数据包的数量大于所述缓存模块数量的一半且小于所述缓存模块的数量,或所述业务板卡在预设时间内未完全收到所述待发送数据包组。
13.根据权利要求12所述的数据传输装置,其特征在于,所述通信板卡包括第一预设数量的第一缓存组,每个所述第一缓存组均包括第二预设数量的第一缓存模块;所述业务板卡的个数为第一预设数量,每个所述业务板卡包括第二预设数量的第二缓存模块,所述第二预设数量的第二缓存模块形成第二缓存组;
所述每个第二缓存组与所述每个第一缓存组一一对应。
14.一种芯片测试机,其特征在于,所述芯片测试机包括通信板卡和业务板卡,所述通信板卡采用如权利要求1-5任一项所述的数据传输方法进行数据发送,所述业务板卡采用权利要求6-8任一项所述的数据传输方法进行数据处理。
15.一种电子设备,其特征在于,包括:处理器,存储器及存储在所述存储器上并可在所述处理器上运行的程序或指令,所述程序或指令被所述处理器执行时实现如权利要求1-5任一项所述的数据传输方法或权利要求6-8任一项所述的数据传输方法的步骤。
CN202310626902.5A 2023-05-30 2023-05-30 数据传输方法、装置、芯片测试机及电子设备 Pending CN116865916A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202310626902.5A CN116865916A (zh) 2023-05-30 2023-05-30 数据传输方法、装置、芯片测试机及电子设备

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202310626902.5A CN116865916A (zh) 2023-05-30 2023-05-30 数据传输方法、装置、芯片测试机及电子设备

Publications (1)

Publication Number Publication Date
CN116865916A true CN116865916A (zh) 2023-10-10

Family

ID=88229321

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202310626902.5A Pending CN116865916A (zh) 2023-05-30 2023-05-30 数据传输方法、装置、芯片测试机及电子设备

Country Status (1)

Country Link
CN (1) CN116865916A (zh)

Similar Documents

Publication Publication Date Title
JP7008721B2 (ja) フィードバック情報送信方法およびデバイス
US8751708B2 (en) Method for transmitting touch panel data
US9197373B2 (en) Method, apparatus, and system for retransmitting data packet in quick path interconnect system
WO2023093879A1 (zh) 数据传输方法、装置、设备和介质
CN114244780B (zh) 一种数据传输方法、数据传输装置和相关设备
KR20130065619A (ko) 송신 노드로부터 목적지 노드로의 데이터 전송 방법
CN102237983A (zh) 非帧结构通讯系统中文件传输方法、发送装置和接收装置
CN106954276B (zh) 一种重传调度的方法、设备及系统
CN101656595B (zh) 传输系统、设备和方法
EP3493441B1 (en) Data indication method, and related product
EP1788756B1 (en) Apparatus and method for transmitting packets in wireless network
CN103716139A (zh) 一种信息推送处理方法和装置
CN113747503B (zh) 数据传输方法、装置及发送端设备
CN112532359B (zh) 接收端基于数据重传数据进行内容合并的方法及装置
CN116865916A (zh) 数据传输方法、装置、芯片测试机及电子设备
CN116865917A (zh) 数据传输方法、装置、芯片测试机及电子设备
CN111817827B (zh) 旁链路信息的传输方法、终端和控制节点
CN115865281A (zh) 工业仪表通信数据丢包处理方法、系统、设备及存储介质
CN113242318B (zh) 数据传输方法和电子设备
CN114244692B (zh) 一种适用于超大规模互连网络的故障快速定位方法
CN114489718A (zh) 树状连接系统的固件升级方法、装置、设备及存储介质
US9172511B2 (en) Apparatus and method of communicating automatic repeat request (ARQ) feedback in a wireless communication network
CN115412890B (zh) 一种数据传输方法、装置和终端设备
CN110659240A (zh) 一种串口通信方法、装置、存储介质及电子设备
CN105227391A (zh) 应用程序的流量统计功能测试方法和系统

Legal Events

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