CN116541034A - 基于显示端口界面的多流传输模式的固件升级方法及固件升级系统 - Google Patents
基于显示端口界面的多流传输模式的固件升级方法及固件升级系统 Download PDFInfo
- Publication number
- CN116541034A CN116541034A CN202210094060.9A CN202210094060A CN116541034A CN 116541034 A CN116541034 A CN 116541034A CN 202210094060 A CN202210094060 A CN 202210094060A CN 116541034 A CN116541034 A CN 116541034A
- Authority
- CN
- China
- Prior art keywords
- firmware
- data
- upgrading
- display
- upgrade
- 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
Links
- 238000000034 method Methods 0.000 title claims abstract description 46
- 230000005540 biological transmission Effects 0.000 title claims abstract description 15
- 238000012545 processing Methods 0.000 claims description 48
- 230000004044 response Effects 0.000 claims description 28
- 238000004891 communication Methods 0.000 claims description 9
- 239000012634 fragment Substances 0.000 claims description 7
- 238000004806 packaging method and process Methods 0.000 claims 1
- 238000010586 diagram Methods 0.000 description 6
- 230000006870 function Effects 0.000 description 6
- 230000000694 effects Effects 0.000 description 2
- 230000008569 process Effects 0.000 description 2
- 230000002457 bidirectional effect Effects 0.000 description 1
- 230000007547 defect Effects 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 238000012549 training Methods 0.000 description 1
- 230000002618 waking effect Effects 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/60—Software deployment
- G06F8/65—Updates
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/14—Digital output to display device ; Cooperation and interconnection of the display device with other functional units
- G06F3/1423—Digital output to display device ; Cooperation and interconnection of the display device with other functional units controlling a plurality of local displays, e.g. CRT and flat panel display
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/60—Software deployment
- G06F8/61—Installation
-
- G—PHYSICS
- G09—EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
- G09G—ARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
- G09G3/00—Control arrangements or circuits, of interest only in connection with visual indicators other than cathode-ray tubes
- G09G3/20—Control arrangements or circuits, of interest only in connection with visual indicators other than cathode-ray tubes for presentation of an assembly of a number of characters, e.g. a page, by composing the assembly by combination of individual elements arranged in a matrix no fixed position being assigned to or needed to be assigned to the individual characters or partial characters
- G09G3/2092—Details of a display terminals using a flat panel, the details relating to the control arrangement of the display terminal and to the interfaces thereto
- G09G3/2096—Details of the interface to the display terminal specific for a flat panel
-
- G—PHYSICS
- G09—EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
- G09G—ARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
- G09G5/00—Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators
- G09G5/003—Details of a display terminal, the details relating to the control arrangement of the display terminal and to the interfaces thereto
- G09G5/006—Details of the interface to the display terminal
-
- G—PHYSICS
- G09—EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
- G09G—ARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
- G09G2370/00—Aspects of data communication
-
- G—PHYSICS
- G09—EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
- G09G—ARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
- G09G2370/00—Aspects of data communication
- G09G2370/04—Exchange of auxiliary data, i.e. other than image data, between monitor and graphics controller
-
- G—PHYSICS
- G09—EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
- G09G—ARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
- G09G2370/00—Aspects of data communication
- G09G2370/10—Use of a protocol of communication by packets in interfaces along the display data pipeline
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Software Systems (AREA)
- Computer Security & Cryptography (AREA)
- Human Computer Interaction (AREA)
- Computer Hardware Design (AREA)
- Stored Programmes (AREA)
- Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)
- Selective Calling Equipment (AREA)
Abstract
本发明公开一种基于显示端口界面的多流传输模式的固件升级方法及固件升级系统。固件升级方法适用于串接为菊花链拓扑的多个显示器及主机,且包括:配置主机通过显示端口辅助通道获取多个显示器的固件信息,并选择目标显示器进行固件升级;以及执行固件升级程序,包括:配置主机传送开始升级命令及固件升级数据至目标显示器;配置每一个显示器以:接收开始升级命令及固件升级数据,判断是否到达目标显示器,若否,则传给下一个显示器,若是,则依据开始升级命令执行固件升级准备程序,并将固件升级数据写入目标显示器的固件储存装置中。
Description
技术领域
本发明涉及一种固件升级方法及固件升级系统,特别是涉及一种基于显示端口界面的多流传输模式的固件升级方法及固件升级系统。
背景技术
固件升级是指通过专门的升级程序,将硬件中的工作程序或原始程序码进行改进,使其得到相容性、性能或功能上的提高。它是从设备底层进行升级,因此更直接、更有效,性能提高也更可观。这种升级可将设备的性能不断提高,将其潜力不断发挥出来。
现有技术升级显示器固件时,一种使用特殊的硬件转接板从电脑装置传输固件数据到与显示器连接的界面,或者利用电脑的视频传输界面把新固件传输至显示器,来实现固件升级,固件升级过程中设备不能正常工作,而且一次只能升级一台显示装置。对于需要管理大量显示装置的使用者来说操作很不方便。
发明内容
本发明所要解决的技术问题在于,针对现有技术的不足提供一种基于显示端口界面的多流传输模式的固件升级方法及固件升级系统。
为了解决上述的技术问题,本发明所采用的其中一技术方案是提供一种基于显示端口(DisplayPort,DP)界面的多流传输(Multi-Stream Transport,MST)模式的固件升级方法,其适用于串接为一菊花链拓扑的多个显示器及一主机,该固件升级方法包括:配置该主机的一通信模块,通过一主机DP界面的一DP辅助通道获取这些显示器的多组固件信息,并选择这些显示器中的一目标显示器进行固件升级;执行一固件升级程序,包括:配置该主机的一主控固件升级模块传送一开始升级命令及一固件升级数据至该目标显示器;配置这些显示器中的每一个以:通过一接收端电路从一显示器DP界面接收该开始升级命令及该固件升级数据;配置一多数据流处理模块判断该开始升级命令及该固件升级数据是否到达该目标显示器;响应于判断该开始升级命令及该固件升级数据尚未到达该目标显示器,该多数据流处理模块通过传送端电路传给该菊花链拓扑中的下一个该显示器;及响应于判断该开始升级命令及该固件升级数据到达该目标显示器,配置一显示器固件升级模块依据该开始升级命令执行一固件升级准备程序,并将该固件升级数据写入该目标显示器的一固件储存装置中;配置该主机的该主控固件升级模块传送一获取固件升级结果请求至一目标显示器;以及配置这些显示器中的每一个以:通过该接收端电路接收该获取固件升级结果请求;配置该多数据流处理模块判断该获取固件升级结果请求是否到达该目标显示器;响应于判断该获取固件升级结果请求尚未到达该目标显示器,通过传送端电路传给下一个该显示器;及响应于判断该获取固件升级结果请求到达该目标显示器,通过该显示器固件升级模块检查该固件储存装置中的一固件数据,并向该主机传送一升级结果消息。
为了解决上述的技术问题,本发明所采用的另外一技术方案是提供一种基于显示端口(DisplayPort,DP)界面的多流传输(Multi-Stream Transport,MST)模式的固件升级系统,其包括多个显示器及一主机。这些显示器各包括接收端电路、多数据流处理模块、显示器固件升级模块及固件储存装置。接收端电路连接一显示器DP界面。多数据流处理模块,连接该接收端电路。显示器固件升级模块,连接该多数据流处理模块。固件储存装置,用于储存固件。主机与这些显示器串接为菊花链拓扑,该主机包括通信模块及主控固件升级模块。通信模块连接一主机DP界面,经配置以通过一DP辅助通道获取这些显示器的多组固件信息。主控固件升级模块,经配置以选择这些显示器中的一目标显示器进行固件升级。其中,该主机及这些显示器经配置以执行一固件升级程序,包括:配置该主控固件升级模块传送一开始升级命令及一固件升级数据至该目标显示器;配置这些显示器中的每一个以:通过该接收端电路接收该开始升级命令及该固件升级数据;配置该多数据流处理模块判断该开始升级命令及该固件升级数据是否到达该目标显示器;响应于判断该开始升级命令及该固件升级数据尚未到达该目标显示器,该多数据流处理模块通过传送端电路传给该菊花链拓扑中的下一个该显示器;及响应于判断该开始升级命令及该固件升级数据到达该目标显示器,配置一显示器固件升级模块依据该开始升级命令执行一固件升级准备程序,并将该固件升级数据写入该目标显示器的一固件储存装置中;配置该主控固件升级模块传送一获取固件升级结果请求至一目标显示器;以及配置这些显示器中的每一个以:通过该接收端电路接收该获取固件升级结果请求;配置该多数据流处理模块判断该获取固件升级结果请求是否到达该目标显示器;响应于判断该获取固件升级结果请求尚未到达该目标显示器,通过传送端电路传给下一个该显示器;及响应于判断该获取固件升级结果请求到达该目标显示器,通过该显示器固件升级模块检查该固件储存装置中的一固件数据,并向该主机传送一升级结果消息。
本发明的其中一有益效果在于,本发明所提供的固件升级方法及固件升级系统,基于DP标准下的MST功能,通过DP界面的辅助通道的边带消息(Sideband Message)或者主要通道的次数据封包(Secondary Data Packet,SDP),对DP界面的MST链路上的任意一台显示器进行固件升级,或者对链路上所有显示器进行同时固件升级。因此,能降低固件升级成本,提高固件升级效率。
为使能更进一步了解本发明的特征及技术内容,请参阅以下有关本发明的详细说明与附图,但所提供的附图仅用于提供参考与说明,并非用来对本发明加以限制。
附图说明
图1为本发明第一实施例的固件升级系统的功能模块图。
图2为本发明第一实施例的固件储存装置的功能模块图。
图3为本发明第一实施例的固件升级方法的第一流程图。
图4为本发明第一实施例的固件升级方法的第二流程图。
图5为本发明第一实施例的固件升级方法的第三流程图。
图6为本发明第二实施例的固件升级系统的功能模块图。
图7为本发明第二实施例的固件升级方法的第一流程图。
图8为本发明第二实施例的固件升级方法的第二流程图。
图9为本发明第二实施例的固件升级方法的第三流程图。
附图标记说明:
1、1'-固件升级系统 10-主机 12、14-显示器
100-通信模块 102-主控固件升级模块 104-主机DP界面
120、128、140、148-显示器DP界面 121、141:接收端电路 122、142:多数据流处理模块
124、144:显示器固件升级模块 126、146:固件储存装置 1240、1440:固件升级电路
1241、1441:固件存储器 Boot:开机区 Flag:旗标区
User1:第一用户代码区 User2:第二用户代码区
具体实施方式
以下是通过特定的具体实施例来说明本发明所公开有关“基于显示端口界面的多流传输模式的固件升级方法及固件升级系统”的实施方式,本领域技术人员可根据本说明书所公开的内容了解本发明的优点与效果。本发明可通过其他不同的具体实施例加以实施或应用,本说明书中的各项细节也可基于不同观点与应用,在不背离本发明的构思下进行各种修改与变更。另外,本发明的附图仅为简单示意说明,并非依实际尺寸进行描绘,在此事先声明。以下的实施方式将进一步详细说明本发明的相关技术内容,但所公开的内容并非用来限制本发明的保护范围。另外,本文中所使用的术语“或”,应视实际情况可能包括相关联的列出项目中的任一个或者多个的组合。
[第一实施例]
图1为本发明第一实施例的固件升级系统的功能模块图。参阅图1所示,本发明第一实施例提供一种基于显示端口(DisplayPort,DP)界面的多流传输(Multi-StreamTransport,MST)模式的固件升级系统1,其包括多个显示器12、14及主机10。
主机10与显示器12、14串接为菊花链拓扑,主机10包括通信模块100及主控固件升级模块102。通信模块100连接一主机DP界面104,经配置以通过一DP辅助通道获取显示器12、14的多组固件信息。
具体而言,DP界面标准下的MST允许以菊花链方式连接显示器,也就是,将一系列显示器连接到主机10,例如为电脑上。在开启电脑的显卡的MST功能以及显示器的DP功能后,将电脑连接到菊花链拓扑中的第一台显示器上的DP输入端,并将第一台显示器上的DP输出端连接到第二台显示器上的DP输入端,并以此类推。
通信模块100可用于与显示器12、14建立DP界面链接,并获取所有DP界面的辅助通道的控制权及界面参数,并判断菊花链拓扑的具体架构,例如,此拓扑中所有装置的型号、数量及地址。
主控固件升级模块102可依据显示器12、14的多笔固件信息选择显示器12、14的至少其中之一作为目标显示器进行固件升级,且可以通过主机DP界面104,将要升级的固件数据发送给显示器12、14进行固件升级。
需要说明的,主机DP界面104包括数据传输主要通道(Main Link)、辅助通道(AuxChannel)与连接通道(Link Training)。辅助通道为一条独立的双向半双工传输的辅助通道,用来传输设定指令与控制指令。
另一方面,显示器12包括接收端电路121、多数据流处理模块122、显示器固件升级模块124及固件储存装置126,显示器14包括接收端电路141、多数据流处理模块142、显示器固件升级模块144及固件储存装置146,由于显示器12基本上与显示器14具有相同架构,除非必要,否则以下不再赘述。
接收端电路121连接在显示器DP界面120及多数据流处理模块122之间,用于接收通过显示器DP界面120的数据传输主要通道、辅助通道与连接通道传送的数据。接收端电路121可例如为DP接收器,包括有先进先出(First-in First-out,FIFO)缓冲器。
多数据流处理模块122,在本发明第一实施例中的主要用途在于其可以解析DP界面的辅助通道中的边带消息(Sideband Message),并根据边带消息中的总链接计数(Link_Count_Total值,简称LCT)以及剩余链接计数(Link_Count_Remaining值,简称LCR)判断是否把这条消息转到下一级显示器。此外,多数据流处理模块122还可根据边带消息体中的特殊数据片段判断是否需要进行固件升级,以及重组用于指示固件升级成功与否的边带消息,借此通知主机10固件升级是否成功。
显示器固件升级模块124,连接多数据流处理模块122及用于储存固件的固件储存装置126,显示器固件升级模块124可用于将固件数据写入固件储存装置126中。
可参考图2,其为本发明第一实施例的固件储存装置的功能模块图。固件储存装置126主要用于储存固件,其包括开机区Boot、第一用户代码区User1、第二用户代码区User2及旗标区Flag。开机区Boot储存有开机程序A,第一用户代码区User1及第二用户代码区User2各储存有初始固件B1及B2,其中之一作为固件运行区,用来存放正常运行的固件文件,另一个则作为固件备份区,用来备份以及等待固件升级。例如,当第一用户代码区User1作为固件运行区时,固件升级时会把新的固件数据写到作为固件备份区的第二用户代码区User2,升级结束后,显示器重启,从开机区Boot启动,开机程序A会根据旗标区Flag中的信息,让显示器从第二用户代码区User2开始运行,并把第一用户代码区User1设为备份区。
请参考图3,其为本发明第一实施例的固件升级方法的第一流程图。在第一实施例中,主控固件升级模块102可依据显示器12、14的固件信息,选择显示器14作为目标显示器进行固件升级。在此前提下,主机10及显示器12、14经配置以执行固件升级程序。第一流程图示出了在主机端执行的步骤,包括:
步骤S30:配置主控固件升级模块传送开始升级命令至目标显示器。例如,主控固件升级模块102可将开始升级命令包括在一边带消息(Sideband message)中,且通过DP辅助通道传送此边带消息,其目的地为显示器14。边带消息可包括消息标头及消息体,且可例如为通过边带消息类型中的REMOTE_I2C_WRITE Request,其目的在于指示目标显示器开始准备固件升级。消息标头包括前面提到的总链接计数(Link_Count_Total值,简称LCT)以及剩余链接计数(Link_Count_Remaining值,简称LCR),其中,LCT定义是从主机10到目标显示器的路径上,边带消息将会通过的DP链路总数,而LCR定义是到目标显示器的路径上,边带消息经过的DP链路的剩余数量。此外,消息标头还包括描述消息体长度的Sideband_MSG_Body_Length等信息。
步骤S31:配置主控固件升级模块传送固件升级数据至目标显示器。类似的,主控固件升级模块102可将固件升级数据包括在边带消息中,并同样使用REMOTE_I2C_WRITERequest类型的边带消息,向目标显示器发送固件升级数据,且通过DP辅助通道传送此边带消息,其目的地为显示器14。
步骤S32:配置主控固件升级模块传送获取固件升级结果请求至目标显示器。类似地,此步骤是在将固件升级数据传送完毕后,向目标显示器确认固件升级是否完成。因此,在LCT与LCR部分的设定值均与前述步骤相同,不同的是此步骤是通过REMOTE_I2C_READRequest类型的边带消息来获取固件升级是否成功的信息。
请参考图4,其为本发明第一实施例的固件升级方法的第二流程图。此处,第二流程图示出了固件升级程序沿着下行方向在显示器端所执行的步骤。如图4所示,固件升级程序包括配置显示器12、14中的每一个以执行下列步骤:
步骤S40:通过接收端电路接收开始升级命令及固件升级数据。在本实施例中,显示装置12的接收端电路121检测到边带消息后,把数据传输到FIFO缓冲器中,并且将旗标Msg_rcv_finish设定为1,来表示已接收到边带消息。
步骤S41:配置多数据流处理模块判断开始升级命令及固件升级数据是否到达目标显示器。具体而言,若多数据流处理模块122检测到旗标Msg_rcv_finish为1,则从FIFO缓冲器读取数据,并解析边带消息的消息标头中的总链接计数(LCT)及剩余链接计数(LCR),并判断LCR是否为预定数值,也就是0。当判断LCR不为该预定数值(0)时,则判断此边带消息尚未到达目标显示器。
响应于判断开始升级命令及固件升级数据尚未到达目标显示器,固件升级程序进入步骤S42:多数据流处理模块通过传送端电路传给菊花链拓扑中的下一个显示器。例如,多数据流处理模块122可将消息标头中的LCR值修改为LCR-1,再通过传送端电路及显示器DP界面128将重组后的边带消息传送给下一台显示装置14。
响应于判断开始升级命令及固件升级数据到达目标显示器,固件升级程序进入步骤S43:配置显示器固件升级模块依据开始升级命令执行固件升级准备程序,并将固件升级数据写入目标显示器的固件储存装置中。
举例而言,当判断LCR为预定数值(0)时,则判断此边带消息到达目标显示器。例如,到达显示器14时,同样执行上述步骤S40及S41,多数据流处理模块142将判断LCR为0,则进一步解析边带消息的消息体。在先前的步骤中,由于主机10传送边带消息时,使用REMOTE_I2C_WRITE Request类型的边带消息,并分别将开始升级命令及固件升级数据包括在边带消息的消息体中,因此,在步骤S43中,多数据流处理模块142将进一步解析消息体,当解析此消息体发现是REMOTE_I2C_WRITE Request类型的边带消息时,则进一步解析消息体以得到写入识别码,例如,Write_I2C_Device_Identifier,如果此识别码对应的数据片段,例如,字段为经过定义的特定值(例如,0x94),则将消息体中,对应I2C_Data_To_Write的数据传送给显示器固件升级模块144。
接着,显示器固件升级模块经配置以根据数据片段,例如,对应I2C_Data_To_Write的数据中的第一个字节(BYTE)来判断数据片段是对应开始升级命令还是固件升级数据。如果数据片段是对应开始升级命令,则依据开始升级命令执行固件升级准备程序。如果数据片段是对应固件升级数据,则写入目标显示器(例如显示器14)的固件储存装置146中。
步骤S44:通过接收端电路接收获取固件升级结果请求。
步骤S45:配置多数据流处理模块判断获取固件升级结果请求是否到达目标显示器。在此步骤中,获取固件升级结果请求同样通过边带消息来传送,故不再赘述判断是否到达目标显示器的细节。
响应于判断获取固件升级结果请求尚未到达目标显示器,固件升级程序进入步骤S46:通过传送端电路传给下一个显示器。类似地,当判断LCR不为该预定数值(0)时,则判断此边带消息尚未到达目标显示器,多数据流处理模块122可将消息标头中的LCR值修改为LCR-1,再通过传送端电路及显示器DP界面128将重组后的边带消息传送给下一台显示装置14。
响应于判断获取固件升级结果请求到达目标显示器,固件升级程序进入步骤S47:通过显示器固件升级模块检查固件储存装置中的固件数据,并向主机传送升级结果消息。
在此步骤中,若多数据流处理模块142将判断LCR为0,则进一步解析边带消息的消息体。在先前的步骤中,由于主机10传送边带消息时,使用REMOTE_I2C_READ Request类型的边带消息,并分别将获取固件升级结果请求包括在边带消息的消息体中,因此,在步骤S45中,多数据流处理模块142将进一步解析消息体,当解析此消息体发现是REMOTE_I2C_READ Request类型的边带消息时,则进一步解析消息体以得到读取识别码,例如,Read_I2C_Device_Identifier,并进一步解析此识别码对应的数据中的第一个字节(BYTE)来判断数据片段是对应获取固件升级结果请求。
接着,通知显示器固件升级模块144,显示器固件升级模块144则对写入固件储存装置146中的固件数据进行合法性检查,例如,CRC或数字签名认证等方式,并通过REMOTE_I2C_READ Replay消息把升级结果成功或失败的结果返回给主机10。需要说明的是,上行流程与下行流程的概念基本相同,上行流程是将升级结果消息包括在边带消息的消息体中,并以类似的方式设定消息标头中的LCT及LCR,路径中的显示器也会修改LCR后的重组边带消息,直到到达主机10。因此,不再赘述上行流程的细节。
在一些实施例中,如果菊花链拓扑中的所有显示器是相同型号,且所有显示器的固件版本相同,都需要以主机10的固件升级数据进行升级,本发明提供的固件升级方法可以实现对链路上所有显示器同时进行固件升级。
可进一步参考图5,其为本发明第一实施例的固件升级程序的第三流程图。在第一实施例中,若主机10根据固件数据认定目标显示器需要包括所有的显示器,则进一步执行下列步骤:
步骤S50:配置主控固件升级模块以将特定字段插入消息体中,并以菊花链拓扑中的最后一个显示器作为目标显示器。
例如,主控固件升级模块102可采用REMOTE_I2C_WRITE Request类型的消息体,除了将消息体中的Write_I2C_Device_Identifier对应的字段设置为指示固件升级的字段(如0x94),还将消息体中I2C_Data_To_Write对应的数据中的特定字段,例如,第一及第二个字节(BYTE),分别定义为特定的值,例如,0x01及0x00。
步骤S51:多数据流处理模块经配置以解析消息体,在得到特定字段时,直接将写入识别码对应的数据片段传送至显示器固件升级模块。
举例说明,当此边带消息到达显示器12时,多数据流处理模块122首先会判断此边带消息需要继续传向下一台显示器14,因此会将LCR减去1之后的重组边带消息并向下传送,同时,多数据流处理模块122解析此边带消息的消息体时,将会得到消息体中I2C_Data_To_Write对应的数据中,第一及第二个字节(BYTE)为0x01及0x00,则判断要进行固件升级,直接将数据片段传送至显示器固件升级模块124。而与步骤S43类似,如果数据片段是对应开始升级命令,则依据开始升级命令执行固件升级准备程序。如果数据片段是对应固件升级数据,则写入显示器(例如显示器12)的固件储存装置126中。
因此,在第一实施例中,基于DP标准下的MST功能,通过DP界面的辅助通道的边带消息(Sideband Message),对DP界面的MST链路上的任意一台显示器进行固件升级,或者对链路上所有显示器进行同时固件升级。因此,能降低固件升级成本,提供固件升级效率。
[第二实施例]
图6为本发明第二实施例的固件升级系统的功能模块图。在第二实施例中,为了进一步提升固件升级的速度,当需要进行固件升级时,主机10除了采用DP辅助通道传递边带消息之外,还进一步利用DP主要通道将固件升级数据以次数据封包(Secondary DataPacket,SDP)的形式传送给目标显示器。
如图6所示,固件升级系统1'的架构与图1的固件升级系统1的不同之处在于,显示器固件升级模块124包括固件升级电路1240及固件存储器1241,显示器固件升级模块144包括固件升级电路1440及固件存储器1441。
以图6的架构及图3的流程为基础,请进一步参考图7,其为本发明第二实施例的固件升级程序的第一流程图。
在主机端,固件升级方法还包括下列步骤:
步骤S70:将开始升级命令包括在边带消息中,并通过DP辅助通道传送至目标显示器。
步骤S71:将固件升级数据封装在次数据封包中,并通过DP主要通道传送至目标显示器。在DP标准中,次数据封包(Secondary Data Packet,SDP)一般用于传送声源信号,而本发明进一步利用次数据封包来传递固件升级数据。
步骤S72:将获取固件升级结果请求包括在边带消息中,并通过DP辅助通道传送至目标显示器。
以图6的架构及图3的流程为基础,请进一步参考图8,其为本发明第二实施例的固件升级程序的第二流程图。
在显示器端,固件升级程序可包括针对所有的显示器执行下列步骤:
步骤S80:通过接收端电路接收边带消息及次数据封包。关于边带消息的接收方式不再赘述,而针对次数据封包,当第一级的显示器12接收端电路121在收到DP主要通道上的数据后,将接收属于显示器14的数据(包括次数据封包),而将其他数据通过DP主要通道传送给下一级显示器14。
步骤S81:判断边带消息是否到达目标显示器。
响应于判断边带消息到达目标显示器,固件升级程序进入步骤S82:多数据流处理模块将LCR-1,重组边带消息并通过传送端电路传给菊花链拓扑中的下一个显示器。
响应于判断边带消息到达目标显示器,固件升级程序进入步骤S83:配置多数据流处理模块解析消息体以得到开始升级命令,并依据开始升级命令控制固件升级电路执行固件升级准备程序。
步骤S84:配置固件升级电路将具有固件升级数据的次数据封包储存在固件存储器中,并将固件升级数据写入固件储存装置中。
具体而言,当目标显示器,例如,显示器14收到特定的SDP,固件升级电路1440直接把SDP中的固件升级数据存入固件存储器,例如,随机存取内存(Random Access Memory,RAM)中,其可包括有例如2*256个字节(BYTE)的RAM单元来存放数据。当其中一个RAM单元存满256个字节的固件升级数据后,就把固件升级数据写入到固件储存装置中,后续收到的固件升级数据则存放在另一个RAM单元中,两个RAM单元可交替使用,以确保写入不中断。
如果菊花链拓扑中的所有显示器是相同型号,且所有显示器的固件版本相同,都需要以主机10的固件升级数据进行升级,在第二实施例中,固件升级方法也可以实现对链路上所有显示器同时进行固件升级。
请参考图9,其为本发明第二实施例的固件升级方法的第三流程图。如图9所示,当主控固件升级模块判断目标显示器需包括所有的显示器时,固件升级程序还包括下列步骤:
步骤S90:配置主控固件升级模块以将特定字段插入消息体中,并将菊花链拓扑中的最后一个显示器作为目标显示器来传送边带消息。需要说明的是,本实施例中,仅将固件升级命令存放在边带消息来传送,边带消息不包括固件升级数据。
步骤S91:配置主控固件升级模块以通过DP主要通道将包括固件升级数据的SDP传送给这些显示器中的每一个。
步骤S92:配置多数据流处理模块以解析该消息体,获取到特定字段时,直接将写入识别码对应的数据片段传送至显示器固件升级电路。
步骤S93:配置固件升级电路根据该数据片段判断数据片段是对应该开始升级命令,以决定依据开始升级命令执行该固件升级准备程序。此处,步骤S92、S93与步骤S51的相关描述类似,故不再赘述。
响应于该固件升级准备程序已经执行,固件升级程序进入步骤S94:配置固件升级电路将具有固件升级数据的次数据封包储存在固件存储器中,并将固件升级数据写入固件储存装置中。
例如,当多数据流处理模块122解析边带消息的消息体时,将会得到消息体中I2C_Data_To_Write对应的数据中,第一及第二个字节(BYTE)为0x01及0x00,则判断要进行固件升级,直接将数据片段传送至固件升级电路1240,固件升级电路1240判断数据片段是对应开始升级命令,则直接将固件存储器1241中的固件升级数据写入固件储存装置126中。
需要说明的是,在第一实施例及第二实施例中提到的固件升级准备程序可例如为将睡眠状态中的显示器唤醒,以及将工作中的显示器的固件升级模块进行初始化等步骤。然而,依据图2中固件储存装置的配置,显示器仍可在正常工作的情形下执行固件升级程序。
接着,请再参考图8,本发明第二实施例的固件升级程序进入步骤S85。
步骤S85:通过接收端电路接收获取固件升级结果请求。
步骤S86:配置多数据流处理模块判断获取固件升级结果请求是否到达目标显示器。在此步骤中,获取固件升级结果请求同样通过边带消息来传送,故不再赘述判断是否到达目标显示器的细节。
响应于判断获取固件升级结果请求尚未到达目标显示器,固件升级程序进入步骤S87:通过传送端电路传给下一个显示器。
响应于判断获取固件升级结果请求到达目标显示器,固件升级程序进入步骤S88:通过固件升级电路检查固件储存装置中的固件数据,并向主机传送升级结果消息。
[实施例的有益效果]
本发明的其中一有益效果在于,本发明所提供的固件升级方法及固件升级系统,基于DP标准下的MST功能,通过DP界面的辅助通道的边带消息(Sideband Message)或者主要通道的次数据封包(Secondary Data Packet,SDP),对DP界面的MST链路上的任意一台显示器进行固件升级,或者对链路上所有显示器进行同时固件升级。因此,能降低固件升级成本,提高固件升级效率。
以上所公开的内容仅为本发明的优选可行实施例,并非因此局限本发明的申请专利范围,所以凡是根据本发明说明书及附图内容所做的等同技术变化,均包括于本发明的申请专利范围内。
Claims (10)
1.一种基于显示端口界面的多流传输模式的固件升级方法,其适用于串接为一菊花链拓扑的多个显示器及一主机,所述固件升级方法包括:
配置所述主机的一通信模块,通过一主机显示端口界面的一显示端口辅助通道获取所述多个显示器的多组固件信息,并选择所述多个显示器中的一目标显示器进行固件升级;
执行一固件升级程序,包括:
配置所述主机的一主控固件升级模块传送一开始升级命令及一固件升级数据至所述目标显示器;
配置所述多个显示器中的每一个以:
通过一接收端电路从一显示器显示端口界面接收所述开始升级命令及所述固件升级数据;
配置一多数据流处理模块判断所述开始升级命令及所述固件升级数据是否到达所述目标显示器;
响应于判断所述开始升级命令及所述固件升级数据尚未到达所述目标显示器,所述多数据流处理模块通过传送端电路传给所述菊花链拓扑中的下一个所述显示器;及
响应于判断所述开始升级命令及所述固件升级数据到达所述目标显示器,配置一显示器固件升级模块依据所述开始升级命令执行一固件升级准备程序,并以所述固件升级数据写入所述目标显示器的一固件储存装置中;
配置所述主机的所述主控固件升级模块传送一获取固件升级结果请求至一目标显示器;以及
配置所述多个显示器中的每一个以:
通过所述接收端电路接收所述获取固件升级结果请求;
配置所述多数据流处理模块判断所述获取固件升级结果请求是否到达所述目标显示器;
响应于判断所述获取固件升级结果请求尚未到达所述目标显示器,通过传送端电路传给下一个所述显示器;及
响应于判断所述获取固件升级结果请求到达所述目标显示器,通过所述显示器固件升级模块检查所述固件储存装置中的一固件数据,并向所述主机传送一升级结果消息。
2.根据权利要求1所述的固件升级方法,其特征在于,还包括配置所述主机将所述开始升级命令及所述固件升级数据各包括在一边带消息中,且通过所述显示端口辅助通道传送所述边带消息,其包括一消息标头及一消息体。
3.根据权利要求2所述的固件升级方法,其特征在于,判断所述开始升级命令及所述固件升级数据是否到达所述目标显示器的步骤还包括配置所述多数据流处理模块以:
解析所述消息标头以得到一总链接计数及一剩余链接计数,并判断所述剩余链接计数是否为预定数值;
响应于判断所述剩余链接计数并非为预定数值,则判断所述边带消息尚未到达所述目标显示器,将所述剩余链接计数减去1并重组为所述边带消息;以及
响应于判断所述剩余链接计数为预定数值,则判断所述边带消息到达所述目标显示器。
4.根据权利要求3所述的固件升级方法,其特征在于,还包括:
响应于判断所述边带消息到达所述目标显示器,配置所述多数据流处理模块解析所述消息体以得到一写入识别码,并依据所述写入识别码将对应的一数据片段传送至所述显示器固件升级模块;
配置所述显示器固件升级模块根据所述数据片段判断所述数据片段是对应所述开始升级命令或所述固件升级数据,以决定依据所述开始升级命令执行一固件升级准备程序,或将所述固件升级数据写入所述目标显示器的所述固件储存装置中。
5.根据权利要求4所述的固件升级方法,其特征在于,还包括:
响应于所选择的所述目标显示器需要包括所有的所述多个显示器,配置所述主机将一特定字段插入所述消息体中,并以所述菊花链拓扑中的最后一个所述显示器作为所述目标显示器;
配置所述多数据流处理模块以解析所述消息体,在得到所述特定字段时,直接将所述写入识别码对应的所述数据片段传送至所述显示器固件升级模块。
6.根据权利要求1所述的固件升级方法,其特征在于,还包括配置所述主机以:
将所述开始升级命令包括在一边带消息中,并通过所述显示端口辅助通道传送至所述目标显示器,所述边带消息包括一消息标头及一消息体;以及
将所述固件升级数据封装在一次数据封包中,并通过一显示端口主要通道传送给所述目标显示器。
7.根据权利要求6所述的固件升级方法,其特征在于,判断所述开始升级命令及所述固件升级数据是否到达所述目标显示器的步骤还包括配置所述多数据流处理模块以:
解析所述消息标头以得到一总链接计数及一剩余链接计数,并判断所述剩余链接计数是否为预定数值;
响应于判断所述剩余链接计数并非为预定数值,则判断所述边带消息尚未到达所述目标显示器,将所述剩余链接计数参数减去1并重组为所述边带消息,并传送给所述菊花链拓扑中的下一个所述显示器;以及
响应于判断所述剩余链接计数为预定数值,则判断所述边带消息到达所述目标显示器。
8.根据权利要求6所述的固件升级方法,其特征在于,所述显示器固件升级模块包括一固件升级电路及一固件存储器,且固件升级方法还包括:
响应于判断所述边带消息到达所述目标显示器,配置所述多数据流处理模块解析所述消息体以得到所述开始升级命令,并依据所述开始升级命令控制所述固件升级电路执行所述固件升级准备程序;以及
响应于判断所述开始升级命令到达所述目标显示器,配置所述固件升级电路将具有所述固件升级数据的所述次数据封包储存在所述固件存储器中,并将所述固件升级数据写入所述固件储存装置中。
9.根据权利要求8所述的固件升级方法,其特征在于,还包括:
响应于所选择的所述目标显示器需要包括所有的所述多个显示器,配置所述主机将一特定字段插入所述消息体中,并以所述菊花链拓扑中的最后一个所述显示器作为所述目标显示器来传送所述边带消息;
配置所述主机通过所述显示端口主要通道将所述次数据封包传送给所述多个显示器中的每一个;
配置所述多数据流处理模块以解析所述消息体,在得到所述特定字段时,直接将所述写入识别码对应的所述数据片段传送至所述显示器固件升级电路;
配置所述固件升级电路根据所述数据片段判断所述数据片段是对应所述开始升级命令,以决定依据所述开始升级命令执行所述固件升级准备程序;以及
响应于所述固件升级准备程序已经执行,配置所述固件升级电路将具有所述固件升级数据的所述次数据封包储存在所述固件存储器中,并将所述固件升级数据写入所述固件储存装置中。
10.一种基于显示端口界面的多流传输模式的固件升级系统,其包括:
多个显示器,各包括:
一接收端电路,连接一显示器显示端口界面;
一多数据流处理模块,连接所述接收端电路;
一显示器固件升级模块,连接所述多数据流处理模块;及
一固件储存装置,用于储存固件;
一主机,与所述多个显示器串接为一菊花链拓扑,所述主机包括:
一通信模块,连接一主机显示端口界面,经配置以通过一显示端口辅助通道获取所述多个显示器的多组固件信息;
一主控固件升级模块,经配置以选择所述多个显示器中的一目标显示器进行固件升级;
所述主机及所述多个显示器经配置以执行一固件升级程序,包括:
配置所述主控固件升级模块传送一开始升级命令及一固件升级数据至所述目标显示器;
配置所述多个显示器中的每一个以:
通过所述接收端电路接收所述开始升级命令及所述固件升级数据;
配置所述多数据流处理模块判断所述开始升级命令及所述固件升级数据是否到达所述目标显示器;
响应于判断所述开始升级命令及所述固件升级数据尚未到达所述目标显示器,所述多数据流处理模块通过传送端电路传给所述菊花链拓扑中的下一个所述显示器;及
响应于判断所述开始升级命令及所述固件升级数据到达所述目标显示器,配置一显示器固件升级模块依据所述开始升级命令执行一固件升级准备程序,并将所述固件升级数据写入所述目标显示器的一固件储存装置中;
配置所述主控固件升级模块传送一获取固件升级结果请求至一目标显示器;以及
配置所述多个显示器中的每一个以:
通过所述接收端电路接收所述获取固件升级结果请求;
配置所述多数据流处理模块判断所述获取固件升级结果请求是否到达所述目标显示器;
响应于判断所述获取固件升级结果请求尚未到达所述目标显示器,通过传送端电路传给下一个所述显示器;及
响应于判断所述获取固件升级结果请求到达所述目标显示器,通过所述显示器固件升级模块检查所述固件储存装置中的一固件数据,并向所述主机传送一升级结果消息。
Priority Applications (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210094060.9A CN116541034A (zh) | 2022-01-26 | 2022-01-26 | 基于显示端口界面的多流传输模式的固件升级方法及固件升级系统 |
TW111105354A TWI819490B (zh) | 2022-01-26 | 2022-02-15 | 基於顯示埠介面的多串流傳輸模式的韌體升級方法及韌體升級系統 |
US17/741,563 US12112157B2 (en) | 2022-01-26 | 2022-05-11 | Firmware upgrade method and firmware upgrade system based on multi-stream transmission mode of DisplayPort interface |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210094060.9A CN116541034A (zh) | 2022-01-26 | 2022-01-26 | 基于显示端口界面的多流传输模式的固件升级方法及固件升级系统 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN116541034A true CN116541034A (zh) | 2023-08-04 |
Family
ID=87313888
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210094060.9A Pending CN116541034A (zh) | 2022-01-26 | 2022-01-26 | 基于显示端口界面的多流传输模式的固件升级方法及固件升级系统 |
Country Status (3)
Country | Link |
---|---|
US (1) | US12112157B2 (zh) |
CN (1) | CN116541034A (zh) |
TW (1) | TWI819490B (zh) |
Family Cites Families (23)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6633905B1 (en) * | 1998-09-22 | 2003-10-14 | Avocent Huntsville Corporation | System and method for accessing and operating personal computers remotely |
US7010607B1 (en) * | 1999-09-15 | 2006-03-07 | Hewlett-Packard Development Company, L.P. | Method for training a communication link between ports to correct for errors |
US7370322B1 (en) * | 2001-04-11 | 2008-05-06 | Sun Microsystems, Inc. | Method and apparatus for performing online application upgrades in a java platform |
US7146412B2 (en) * | 2001-08-27 | 2006-12-05 | Hewlett-Packard Development Company, L.P. | System and methods for the automatic discovery, notification and installation of firmware upgrades |
EP2247070B1 (en) * | 2003-12-08 | 2013-09-25 | QUALCOMM Incorporated | High data rate interface with improved link synchronization |
US7802246B1 (en) * | 2004-06-21 | 2010-09-21 | Microsoft Corporation | Systems and methods that facilitate software installation customization |
TWI382394B (zh) * | 2007-11-22 | 2013-01-11 | Realtek Semiconductor Corp | 韌體更新之方法與系統 |
US8762977B2 (en) * | 2008-04-10 | 2014-06-24 | Telefonaktiebolaget L M Ericsson (Publ) | Mobile device software management method and apparatus |
US8838084B2 (en) * | 2009-02-27 | 2014-09-16 | Blackberry Limited | System and method for provisioning mobile communication device upgrades |
US8887144B1 (en) * | 2009-09-04 | 2014-11-11 | Amazon Technologies, Inc. | Firmware updates during limited time period |
US9032053B2 (en) * | 2010-10-29 | 2015-05-12 | Nokia Corporation | Method and apparatus for upgrading components of a cluster |
US8527471B2 (en) * | 2010-12-27 | 2013-09-03 | Sap Ag | Shadow system mirroring of an original system during uptime of an upgrade process |
WO2017046789A1 (en) * | 2015-09-15 | 2017-03-23 | Gatekeeper Ltd. | System and method for securely connecting to a peripheral device |
US10289400B2 (en) * | 2016-09-07 | 2019-05-14 | Amplidata N.V. | Outdated resource handling and multiple-version upgrade of cloud software |
US10866798B2 (en) * | 2017-12-28 | 2020-12-15 | Intel Corporation | Firmware upgrade method and apparatus |
US10261775B1 (en) * | 2018-04-17 | 2019-04-16 | Hewlett Packard Enterprise Development Lp | Upgrade orchestrator |
US10521583B1 (en) * | 2018-10-25 | 2019-12-31 | BitSight Technologies, Inc. | Systems and methods for remote detection of software through browser webinjects |
CN111475446B (zh) * | 2019-01-23 | 2021-10-19 | 纬联电子科技(中山)有限公司 | 显示装置及其高显示带宽控制方法 |
CN112150980B (zh) * | 2019-06-28 | 2022-03-04 | 纬联电子科技(中山)有限公司 | 同步调整屏幕设定的方法及多屏幕系统 |
US11956265B2 (en) * | 2019-08-23 | 2024-04-09 | BitSight Technologies, Inc. | Systems and methods for inferring entity relationships via network communications of users or user devices |
CN113377392B (zh) | 2020-03-09 | 2024-03-29 | 瑞昱半导体股份有限公司 | 可后台升级固件的系统及后台升级固件方法 |
CN111459744A (zh) * | 2020-03-20 | 2020-07-28 | 江苏集萃智能集成电路设计技术研究所有限公司 | 视频处理芯片的固件烧录方法和固件调试方法 |
US11467822B2 (en) * | 2021-03-15 | 2022-10-11 | Google Llc | Methods for optics module firmware in-field upgrade |
-
2022
- 2022-01-26 CN CN202210094060.9A patent/CN116541034A/zh active Pending
- 2022-02-15 TW TW111105354A patent/TWI819490B/zh active
- 2022-05-11 US US17/741,563 patent/US12112157B2/en active Active
Also Published As
Publication number | Publication date |
---|---|
TW202331500A (zh) | 2023-08-01 |
US20230236817A1 (en) | 2023-07-27 |
US12112157B2 (en) | 2024-10-08 |
TWI819490B (zh) | 2023-10-21 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10783086B2 (en) | Method and apparatus for increasing a speed of accessing a storage device | |
US9092157B2 (en) | Wireless internet-accessing module, host, communication method thereof, and data card | |
EP2466943A1 (en) | Method and device for monitoring running state of card | |
CN113014510B (zh) | 惯导系统分布式测试中数据缓存方法及装置 | |
CN1322444C (zh) | 传输和处理命令与数据的方法 | |
EP0886410A2 (en) | Data communication method, data communication apparatus, and data communication program recording medium | |
CN116541034A (zh) | 基于显示端口界面的多流传输模式的固件升级方法及固件升级系统 | |
CN111431668B (zh) | 基于多节点uart通讯的波特率切换方法、空调系统及处理器 | |
CN109800202B (zh) | 一种基于pcie的数据传输系统、方法及装置 | |
JP2009182458A (ja) | 通信装置、通信システム、通信方法及びプログラム | |
CN114780120B (zh) | 升级方法、设备及存储介质 | |
CN110764806A (zh) | 一种tws耳机及其升级方法及装置 | |
CN114338270B (zh) | 数据通信方法、装置、电子设备及存储介质 | |
US9078282B2 (en) | Method and apparatus for implementing network device function of wireless communication terminal | |
EP2226728A1 (en) | Communication device, communication system, communication method, and program | |
CN112905206A (zh) | 基于串口的电路升级方法 | |
US12057965B2 (en) | Data communication method and apparatus, electronic device, and storage medium | |
CN109587363B (zh) | 一种调制解调器 | |
CN115086192A (zh) | 一种数据处理方法、装置、系统及监控卡 | |
CN117667138A (zh) | 一种单片机固件升级方法及系统 | |
JP2017123117A (ja) | 通信装置、通信システム、通信方法及びプログラム |
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 |