CN100380349C - 确认序列进阶技术接附规格sata桥接器身份的方法 - Google Patents

确认序列进阶技术接附规格sata桥接器身份的方法 Download PDF

Info

Publication number
CN100380349C
CN100380349C CNB2006100651493A CN200610065149A CN100380349C CN 100380349 C CN100380349 C CN 100380349C CN B2006100651493 A CNB2006100651493 A CN B2006100651493A CN 200610065149 A CN200610065149 A CN 200610065149A CN 100380349 C CN100380349 C CN 100380349C
Authority
CN
China
Prior art keywords
parameter
standard
standard commands
sata
output
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.)
Active
Application number
CNB2006100651493A
Other languages
English (en)
Other versions
CN1821983A (zh
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.)
Via Technologies Inc
Original Assignee
Via Technologies Inc
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 Via Technologies Inc filed Critical Via Technologies Inc
Priority to CNB2006100651493A priority Critical patent/CN100380349C/zh
Publication of CN1821983A publication Critical patent/CN1821983A/zh
Application granted granted Critical
Publication of CN100380349C publication Critical patent/CN100380349C/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Landscapes

  • Stored Programmes (AREA)
  • Communication Control (AREA)

Abstract

本发明是有关于一种确认序列进阶技术接附规格SATA桥接器身份的方法,本发明先藉由软件程式输入一标准命令至一主机控制器,以转换标准命令为一输入讯框资讯结构的格式并传送至一标准介面装置,之后标准介面装置执行标准命令并产生一包含无效输出参数的输出资讯,且传送此输出资讯至SATA桥接器,以供SATA桥接器设定无效输出参数为辨识参数,并转换包含辨识参数的输出资讯为一输出讯框资讯结构的格式,如此软件程式即可读取输出资讯的辨识参数,且判断辨识参数以确认SATA桥接器的身份。

Description

确认序列进阶技术接附规格SATA桥接器身份的方法
技术领域
本发明涉及一种确认方法,特别是涉及一种确认序列进阶技术接附规格(SATA)桥接器身份的方法,其是利用SATA桥接器设定输出资讯的无效输出参数为辨识参数,以供软件程式确认SATA桥接器。
背景技术
现今计算机(即电脑)技术不断的进步,驱使现今计算机系统与硬式磁碟机和光碟机等标准介面装置之间的传输介面格式必须进一步改善,以搭配运算越来越快的计算机系统。现今标准介面装置的传输介面规格大多为进阶技术接附(Advanced Technology Attachment;ATA)与进阶技术接附封包介面(AT Attachment Packet Interface;ATAPI)两种规格。进阶技术接附ATA与进阶技术接附封包介面ATAPI的传输介面规格采用平行(parallel)方式传输资料,理论上,其最大传输速率为每秒100百万位元组(MB/s)和每秒133百万位元组(MB/s)。
然而,随着中央处理单元执行速率逐渐提升,进阶技术接附ATA与进阶技术接附封包介面ATAPI的传输介面规格所能提供的频宽逐渐难以满足现代计算机系统的需求。为此,序列式进阶技术接附工作小组(Serial ATAWorking Group)针对进阶技术接附ATA的标准介面规格的缺失进行研究,进而发展序列式进阶技术接附规格(Serial Advanced TechnologyAttachment;SATA)以扩展进阶技术接附ATA标准介面规格,使资料传输速率的理论值可达到每秒150百万位元组(MB/s)以上,以提升计算机系统的执行效率。
现有习知计算机系统中,标准介面装置与相关装置的耦接,其关系陈述如下:计算机系统中,一主机控制器耦接至一序列进阶技术接附规格SATA桥接器,SATA桥接器耦接至一标准介面装置。若欲驱使标准介面装置动作时,是必须藉由一软件程式输入一标准命令至标准介面装置,软件程式所输入的标准命令会先经过主机控制器,以转换标准命令为一输入讯框资讯结构FIS的格式,之后再传送至SATA桥接器,SATA桥接器会转换输入讯框资讯结构格式的标准命令为标准介面装置可辨识的格式再传送至标准介面装置,以供标准介面装置执行命令。标准介面装置执行标准命令完毕后则产生一输出资讯,且回传此输出资讯至SATA桥接器以转换为一输出讯框资讯结构的格式而传送至主机控制器,最后再经由软件程式从主机控制器读取输出资讯。
一般计算机系统在出厂前皆会进行测试,以确保计算机系统在出厂后可以正常使用,而测试SATA桥接器的方式大都是利用特别设计的软件程式对SATA桥接器进行测试。现今部份业者为了提高测试效率均投入人力研发测试软件程式。然而,总有部分未经授权的业者挪用它厂所设计的软件程式,导致自行研发软件程式的厂商在权益上遭受相当大的损失。另外,有部分业者为了提升桥接器的使用效能,亦会研发设计附带多项功能的软件程式以用于桥接器,但如同前面所述,亦同样存在有遭受盗用的问题。
为了有效杜绝上述的问题,最佳的防止方式是软件程式在执行前先确认SATA桥接器是否被软件程式支援使用,若确认SATA桥接器不被软件程式支援使用时,软件程式则停止执行;若确认SATA桥接器被软件程式支援使用时,软件程式继续执行。如此,藉由软件程式确认SATA桥接器的方式,即可达到保护软件程式不被盗用的目的。然而,SATA规格中仅提供辨识标准介面装置的标准命令,并没有提供辨识SATA桥接器的标准命令,所以软件程式无法在执行时先确认SATA桥接器身份,导致无法防止软件程式被非经原厂授权的业者所使用。
因此,本发明提出一种确认SATA桥接器身份的方法,提供软件程式可确认SATA桥接器身份,避免非经原厂授权的业者盗用软件程式,而可以解决上述问题。
发明内容
本发明的主要目的在于,提供一种新的确认序列进阶技术接附规格(SATA)桥接器身份的方法,所要解决的技术问题是使其是供软件程式被执行时先确认SATA桥接器是否被软件程式支援使用,若否时则软件程式停止动作,因此能够避免软件程式在未经原厂授权使用下遭受盗用,从而更加适于实用。
本发明的另一目的在于,提供一种新的确认序列进阶技术接附规格SATA桥接器身份的方法,所要解决的技术问题是使其是藉由SATA桥接器在转换输出资讯为输出讯框资讯结构的格式时,先设定输出资讯的无效输出参数为辨识参数,如此即可令软件程式读取辨识参数并进行判断,而可以达到确认SATA桥接器身份的目的,从而更加适于实用。
本发明的再一目的在于,提供一种新的确认序列进阶技术接附规格SATA桥接器身份的方法,所要解决的技术问题是使其是藉由设定标准命令的无效输入参数为确认参数与执行参数,让SATA桥接器判断确认参数且确认执行参数为有效参数,而设定输出资讯的无效输出参数为辨识参数,以确认SATA桥接器的身份,如此可以避免SATA桥接器重复设定无效输出参数为辨识参数,进而维持SATA桥接器的使用效能,从而更加适于实用。
本发明的目的及解决其技术问题是采用以下的技术方案来实现的。依据本发明提出的一种确认序列进阶技术接附规格SATA桥接器身份的方法,其包括下列步骤:输入一符合SATA标准介面规格的标准命令至一主机控制器,将该标准命令转换为一输入讯框资讯结构FIS的格式;传送该标准命令至该SATA桥接器,以转换该输入讯框资讯结构格式的该标准命令为一标准介面装置所能辨识的格式;传送该标准命令至该标准介面装置;执行该标准命令并产生一输出资讯至一序列进阶技术接附规格SATA桥接器,该输出资讯包含复数组无效输出参数;设定至少一该无效输出参数为一辨识参数,并且转换该输出资讯为一输出讯框资讯结构的格式;以及藉由判断该辨识参数是否与该SATA桥接器对应,以确认该SATA桥接器的身份。
本发明的目的及解决其技术问题还可采用以下技术措施进一步实现。
前述的方法,其中输入该标准命令至该主机控制器之前,设定该标准命令的复数输入参数,以输入包含该复数输入参数的标准命令至该主机控制器。
前述的方法,其中该标准介面装置依据该复数输入参数执行该标准命令。
前述的方法,其中是在转换该输入讯框资讯结构格式的该标准命令为该标准介面装置所能辨识的格式时,记录该标准命令的命令码,以依据该命令码设定该无效输出参数为该辨识参数。
前述的方法,其中所述的该无效输出参数分别储存于该标准介面装置的复数输出暂存器。
前述的方法,其中是由该SATA桥接器将该无效输出参数设定为该辨识参数。
前述的方法,其中若该SATA桥接器为一软件程式所支援的SATA桥接器,则该SATA桥接器能设定该无效输出参数为该辨识参数。
前述的方法,其中是使用一软件程式对该辨识参数进行判断,若该辨识参数为该软件程式所无法辨别,则该软件程式不继续动作。
前述的方法,其中所述的该辨识参数是为该SATA桥接器内预设的特定值。
前述的方法,其中所述的标准命令是为一28位元标准命令,该无效输出参数为扩充输出参数。
本发明的目的及解决其技术问题还采用以下技术方案来实现。依据本发明提出的一种确认序列进阶技术接附规格SATA桥接器身份的方法,其包括下列步骤:设定一符合SATA标准介面规格的标准命令的一无效输入参数为一执行参数;输入该标准命令至一主机控制器,将该标准命令转换为一输入讯框资讯结构FIS的格式;传送该标准命令至该SATA桥接器,以转换该输入讯框资讯结构格式的该标准命令为一标准介面装置所能辨识的格式,且记录该标准命令的该执行参数;传送该标准命令至该标准介面装置;执行该标准命令并产生一输出资讯至一序列进阶技术接附规格SATA桥接器,该输出资讯包含复数组无效输出参数;依据该执行参数设定至少一该无效输出参数为一辨识参数,且转换该输出资讯为一输出讯框资讯结构的格式;以及藉由判断该辨识参数是否与该SATA桥接器对应,以确认该SATA桥接器的身份。
本发明的目的及解决其技术问题还可采用以下技术措施进一步实现。
前述的方法,其中所述的该等无效输出参数分别储存于该标准介面装置的复数输出暂存器。
前述的方法,其中是由该SATA桥接器将该无效输出参数设定为该辨识参数。
前述的方法,其中若该SATA桥接器为一软件程式所支援的SATA桥接器,则该SATA桥接器能设定该无效输出参数为该辨识参数。
前述的方法,其中是使用一软件程式对该辨识参数进行判断,若该辨识参数为该软件程式所无法辨别,则该软件程式不继续动作。
前述的方法,其中所述的辨识参数是为该SATA桥接器内预设的特定值。
前述的方法,其中是在设定该标准命令的该无效输入参数为该执行参数时,设定该标准命令的另一该无效输入参数为一确认参数,以依据该确认参数与该执行参数设定该无效输出参数为该辨识参数。
前述的方法,其中该确认序列进阶技术接附规格SATA桥接器身份的方法更包括有下列步骤:设定一次要标准命令的至少一无效输入参数为一确认参数;输入该次要标准命令至该主机控制器,以转换为该输入讯框资讯结构的格式;传送该次要标准命令至该SATA桥接器;以及依据该确认参数与该执行参数设定该无效输出参数为该辨识参数。
前述的方法,其中是依据该确认参数与该执行参数,设定该无效输出参数为该辨识参数。
前述的方法,其中所述的次要标准命令为一28位元标准命令,该无效输入参数为扩充输入参数。
前述的方法,其中所述的标准命令是为一28位元标准命令,该无效输入参数为扩充输入参数。
前述的方法,其中所述的该标准命令是为一28位元标准命令,该无效输出参数为扩充输出参数。
本发明与现有技术相比具有明显的优点和有益效果。由以上可知,为了达到上述目的,本发明确认序列进阶技术接附规格SATA桥接器身份的方法,是先藉由软件程式输入一标准命令至一主机控制器以转换标准命令为一输入讯框资讯结构的格式,再传送至SATA桥接器以转换标准命令为标准介面装置所能辨识的格式,接着将此转换后的标准命令传送至标准介面装置供其执行;然后,标准介面装置执行标准命令完毕后则产生一包含无效输出参数的输出资讯;随后,将此包含无效输出参数的输出资讯传送至SATA桥接器,以设定无效输出参数为辨识参数;然后,由SATA桥接器转换包含辨识参数的输出资讯为一输出讯框资讯结构的格式;接着,SATA桥接器将包含有辨识参数的输出资讯传送至主机控制器,如此令软件程式从主机控制器读取辨识参数并进行判断,以可确认SATA桥接器身份。
借由上述技术方案,本发明确认序列进阶技术接附规格SATA桥接器身份的方法至少具有下列优点:
1、本发明确认序列进阶技术接附规格SATA桥接器身份的方法,可供软件程式被执行时先确认SATA桥接器是否被软件程式支援使用,若否时则软件程式停止动作,因此能够避免软件程式在未经原厂授权使用下遭受盗用,从而更加适于实用。
2、本发明确认序列进阶技术接附规格SATA桥接器身份的方法,是藉由SATA桥接器在转换输出资讯为输出讯框资讯结构的格式时,先设定输出资讯的无效输出参数为辨识参数,如此即可令软件程式读取辨识参数并进行判断,而可以达到确认SATA桥接器身份的目的,从而更加适于实用。
3、本发明确认序列进阶技术接附规格SATA桥接器身份的方法,是藉由设定标准命令的无效输入参数为确认参数与执行参数,让SATA桥接器判断确认参数且确认执行参数为有效参数,而设定输出资讯的无效输出参数为辨识参数,以确认SATA桥接器的身份,如此可以避免SATA桥接器重复设定无效输出参数为辨识参数,进而维持SATA桥接器的使用效能,从而更加适于实用。
综上所述,本发明是有关于一种确认序列进阶技术接附规格SATA桥接器身份的方法,本发明是先藉由软件程式输入一标准命令至一主机控制器,以转换标准命令为一输入讯框资讯结构的格式并传送至一标准介面装置,之后标准介面装置执行标准命令并产生一包含无效输出参数的输出资讯,且传送此输出资讯至SATA桥接器,以供SATA桥接器设定无效输出参数为辨识参数,并转换包含辨识参数的输出资讯为一输出讯框资讯结构的格式,如此软件程式即可读取输出资讯的辨识参数,且判断辨识参数而可以确认SATA桥接器的身份,能够避免非经原厂授权的业者盗用软件程式,非常适于实用。本发明具有上述诸多优点及实用价值,其不论在方法上或功能上皆有较大改进,在技术上有较大进步,并产生了好用及实用的效果,从而更加适于实用,并具有产业的广泛利用价值,诚为一新颖、进步、实用的新设计。
上述说明仅是本发明技术方案的概述,为了能够更清楚了解本发明的技术手段,而可依照说明书的内容予以实施,并且为了让本发明的上述和其他目的、特征和优点能够更明显易懂,以下特举较佳实施例,并配合附图,详细说明如下。
附图说明
图1是本发明的标准介面装置耦接计算机系统相关装置的方块图。
图2是本发明一较佳实施例的流程图。
图3是本发明另一较佳实施例的流程图。
图4是本发明再一较佳实施例的流程图。
图5是本发明又一较佳实施例的流程图。
图6是本发明的实施例的流程图。
10:主机控制器          20:SATA桥接器
30:标准介面装置        40:软件程式
具体实施方式
为更进一步阐述本发明为达成预定发明目的所采取的技术手段及功效,以下结合附图及较佳实施例,对依据本发明提出的确认序列进阶技术接附规格(SATA)桥接器身份的方法其具体实施方式、方法、步骤、特征及其功效,详细说明如后。
在标准介面规格中,皆定义有完整的标准命令,以供标准介面装置执行,因此,使用者可藉由软件程式将一标准命令输入至标准介面装置供其执行以进行对应的标准事件。由于SATA标准介面规格延伸于ATA标准介面规格,所以SATA标准命令应符合ATA标准介面规格的规范。
请参阅图1所示,是本发明的标准介面装置与计算机系统相关装置相耦接的方块图。如图所示,标准介面装置30与主机控制器10(HostController)之间设有SATA桥接器20,而此SATA桥接器20用于转换主机控制器10与标准介面装置30之间所传送的命令或资讯的格式,而软件程式40则能输入标准命令至主机控制器10中。
请参阅下列表一所示,是为SATA规格中28位元闲置(IDLE)标准命令的格式表。接下来是以28位元闲置(IDLE)标准命令为例说明SATA标准命令的格式。
表一
如表一所示,其是包含有复数输入参数而分别为一特性(Features)暂存器参数、一磁区计数(Sector Count)暂存器参数、一低位元逻辑区块定址(LBA Low)暂存器参数、一中位元逻辑区块定址(LBA Mid)暂存器参数、一高位元逻辑区块定址(LBA High)暂存器参数以及一装置(Device)暂存器参数,且更包含有一命令(Command)暂存器参数,其是为标准命令的命令码。
当使用者欲藉由软件程式输入28位元的闲置(IDLE)标准命令至标准介面装置以驱使标准介面装置执行时,首先,依序设定闲置(IDLE)标准命令的输入参数,即依序设定一特性(Features)暂存器参数、一磁区计数(Sector Count)暂存器参数、一低位元逻辑区块定址(LBA Low)暂存器参数、一中位元逻辑区块定址(LBA Mid)暂存器参数、一高位元逻辑区块定址(LBA High)暂存器参数以及一装置(Device)暂存器参数,也就是写入上述的输入参数值至主机控制器内部所对应的各输入暂存器中;完成设定之后,即输入命令(Command)暂存器参数(命令码)至主机控制器的命令暂存器中,意即将闲置(IDLE)标准命令的16进制(Hexadecimal)的命令码E3h写入至主机控制器的命令暂存器。写入命令码至命令暂存器时,即表示已输入标准命令。
请参阅下列表二所示,其是为闲置(IDLE)标准命令的输入讯框资讯结构FIS的格式表。
Figure C20061006514900121
表二
在主机控制器侦测出命令暂存器有储存命令(Command)暂存器参数的动作后,立即转换闲置(IDLE)标准命令与对应闲置(IDLE)标准命令的相关输入暂存器的值为本图所示的输入讯框资讯结构(FIS)的格式。此步骤是主机控制器将命令暂存器的命令码与输入暂存器的值分别储存至表二对应的栏位,即命令(Command)暂存器、特性(Features)暂存器、磁区计数(Sector Count)暂存器、低位元逻辑区块定址(LBA Low)暂存器、中位元逻辑区块定址(LBA Mid)暂存器、高位元逻辑区块定址(LBA High)暂存器以及装置(Device)暂存器的值分别储存至表二对应的一命令(Command)栏位、一特性(Features)栏位、一磁区计数(Sector Count)栏位、一低位元逻辑区块定址(LBA Low)栏位、一中位元逻辑区块定址(LBAMid)栏位、一高位元逻辑区块定址(LBA High)栏位以及一装置(Device)栏位内。
此外,一特性扩充(Features(exp))栏位、一磁区计数扩充(SectorCount(exp))栏位、一低位元逻辑区块定址扩充(LBA Low(exp))栏位、一中位元逻辑区块定址扩充(LBA Mid(exp))栏位以及一高位元逻辑区块定址扩充(LBA High(exp))栏位,是用于支援写入48位元的标准命令的扩充输入参数。48位元的标准命令用于支援逻辑区块定址(Logic BlockAddressing;LBA)功能为48位元的标准介面装置。当软件程式输入48位元的标准命令至主机控制器,在设定标准命令的输入参数时,将48位元标准命令的输入参数的第29~48位元的值填入扩充输入暂存器的位址,以储存48位元标准命令的所有输入参数,之后依照输入标准命令至标准介面装置的程序,即可控制此标准介面装置执行标准命令。由上述可知,因为前述的扩充输入参数用于48位元的标准命令,故当输入28位元的标准命令时,前述的扩充输入参数可设为任何数值而成为无效输入参数。另外,其余栏位主机控制器则依据SATA规格的定义写入对应的参数。
当主机控制器将标准命令转成输入讯框资讯结构的格式后,将传送已转换为输入讯框资讯结构格式的标准命令至SATA桥接器,供SATA桥接器转换此标准命令为标准介面装置可辨识的格式,以传送至标准介面装置而储存至所对应的各输入暂存器与命令暂存器,供标准介面装置依据命令暂存器的闲置(IDLE)命令码和其余输入暂存器的输入参数而执行闲置(IDLE)标准命令。
标准介面装置执行标准命令后会产生如下列的表三所示的一输出资讯,输出资讯对应写入于标准介面装置内部的复数输出暂存器中,以供计算机系统或者使用者得知标准介面装置执行命令后的状态。如表三所示,输出资讯包含有复数输出参数分别为一错误(Error)暂存器参数、一磁区计数(Sector Count)暂存器参数、一低位元逻辑区块定址(LBA Low)暂存器参数、一中位元逻辑区块定址(LBA Mid)暂存器参数、一高位元逻辑区块定址(LBA High)暂存器参数、一装置(Device)暂存器参数以及一状态(Status)暂存器参数。
Figure C20061006514900131
表三
当标准介面装置欲回传输出资讯至主机控制器时,先会将输出资讯回传至SATA桥接器以转换为下列表四所示的输出讯框资讯结构的格式,也就是将标准介面装置所有输出暂存器的值储存至表四对应的栏位。其中,表四的一磁区计数扩充(Sector Count(exp))栏位、一低位元逻辑区块定址扩充(LBA Low(exp))栏位、一中位元逻辑区块定址扩充(LBA Mid(exp))栏位与一高位元逻辑区块定址扩充(LBA High(exp))栏位是用于储存各扩充输出参数的值。
Figure C20061006514900141
表四
扩充输出参数即标准介面装置执行48位元的标准命令后,各输出参数的第29至48位元的值则被储存于标准介面装置的各输出暂存器的扩充位址。所以当标准介面装置执行28位元的标准命令之后并产生一输出资讯时,其输出资讯所含的扩充输出参数可设为任何数值,并被储存于所对应的各输出暂存器的扩充位址处,而为无效输出参数。
此外,SATA桥接器会依据SATA规格的定义,在其余栏位写入所对应的参数。SATA桥接器转换输出资讯为输出讯框资讯结构的格式后,会传送此输出资讯至主机控制器,供计算机系统或使用者通过软件程式读取,以得知标准介面装置执行标准命令后的状态。
由上述可知,当软件程式输入28位元标准命令至标准介面装置执行时,标准介面装置产生的扩充输出参数为无效输出参数。因此本发明藉由在软件程式所支援的SATA桥接器内预设至少一组特定值,作为用于辨识SATA桥接器身份的辨识参数,当SATA桥接器在转换输出资讯为输出讯框资讯结构的格式时,依据预设的特定值先设定无效输出参数为特定数值的辨识参数;之后,将输出资讯转换为输出讯框资讯结构的格式而传送至主机控制器;最后,藉由软件程式判断辨识参数即可得知SATA桥接器是否为软件程式所支援的SATA桥接器。换言之,若SATA桥接器不被软件程式支援使用时,即不会在转换输出资讯为输出讯框资讯结构的格式时,先设定无效输出参数为特定数值的辨识参数,所以软件程式无法判断辨识参数以确认SATA桥接器的身份,软件程式于此无法确认的情况下将中断其任何动作以防止盗用。
以下藉由输入28位元闲置(IDLE)标准命令为例,说明本发明确认SATA桥接器身份的方法。请参阅图2所示,是为本发明的一较佳实施例的流程图。首先,进行步骤S11,由软件程式设定28位元闲置(IDLE)标准命令的复数输入参数,其中设定的方式如前述表一的相关说明;之后,进行步骤S12,输入28位元闲置(IDLE)标准命令至主机控制器,以转换闲置(IDLE)标准命令为输入讯框资讯结构的格式并传送至SATA桥接器,其中输入标准命令即输入命令码至主机控制器,其中闲置(IDLE)标准命令的命令码为16进制(Hexadecimal)的E3h;接着,进行步骤S13,SATA桥接器将输入讯框资讯结构格式的闲置(IDLE)标准命令转换为标准介面装置可辨识的格式并记录标准命令的命令码,以得知软件程式下达何种命令,且将转换后的标准命令传送至标准介面装置,标准介面装置会储存标准命令的各输入参数与命令码至对应的各暂存器中。
随后,进行步骤S14,标准介面装置执行所接收的闲置(IDLE)标准命令,当执行完毕后,产生一包含复数组无效输出参数的输出资讯,并将此输出资讯的各输出参数储存至标准介面装置内部各对应的输出暂存器中,且回传此输出资讯至SATA桥接器;之后,进行步骤S15,SATA桥接器依据所记录的命令码得知软件程式输入28位元的闲置(IDLE)标准命令,进而获知标准介面装置所回传的输出资讯含有为无效输出参数的扩充输出参数,因此SATA桥接器设定无效输出参数为特定数值的辨识参数,亦即如下列表五所示,将无效输出参数中的磁区计数扩充(Sector Count(exp))输出参数、低位元逻辑区块定址扩充(LBA Low(exp))输出参数、中位元逻辑区块定址扩充(LBA Mid(exp))输出参数与高位元逻辑区块定址扩充(LBA High(exp))输出参数等扩充输出参数分别设为16进制(Hexadecimal)数值的01h、02h、03h、04h。
Figure C20061006514900151
表五
设定辨识参数完成之后,SATA桥接器将包含辨识参数的输出资讯转换为表五输出讯框资讯结构的格式;接着进行步骤S16,SATA桥接器传送包含辨识参数的输出讯框资讯结构格式的输出资讯至主机控制器,此时主机控制器会将输出资讯的各输出参数分别储存至主机控制器内部所对应的输出暂存器内,其中亦包含储存辨识参数至对应的输出暂存器中。
最后,进行步骤S17,软件程式读取输出资讯的辨识参数,令软件程式判断辨识参数即可确认SATA桥接器的身份。若SATA桥接器不是软件程式支援厂商所制作时,便不会将磁区计数扩充(Sec tor Count(exp))输出参数、低位元逻辑区块定址扩充(LBA Low(exp))输出参数、中位元逻辑区块定址扩充(LBA Mid(exp))输出参数与高位元逻辑区块定址扩充(LBAHigh(exp))输出参数的值分别设定为01h、02h、03h、04h。
所以,当软件程式判断磁区计数扩充(Sector Count(exp))输出参数、低位元逻辑区块定址扩充(LBA Low(exp))输出参数、中位元逻辑区块定址扩充(LBA Mid(exp))输出参数与高位元逻辑区块定址扩充(LBA High(exp))输出参数的值分别为01h、02h、03h、04h时,即表示SATA桥接器为支援厂商所制作,此时软件程式会接续执行;反之,若软件程式判断磁区计数扩充(Sector Count(exp))输出参数、低位元逻辑区块定址扩充LBA Low(exp))输出参数、中位元逻辑区块定址扩充(LBA Mid(exp))输出参数与高位元逻辑区块定址扩充(LBA High(exp))输出参数的值不是01h、02h、03h、04h时,即可得知SATA桥接器不是支援厂商所制作,软件程式即停止执行以避免被非经授权厂商所使用。
综上所述,本发明确认SATA桥接器身份的方法,必须先在所支援的SATA桥接器预设至少一标准命令的命令码,供SATA桥接器与已接收的命令码进行比对,以获知需设定输出资讯的无效输出参数为辨识参数。此外,软件程式在执行时会将一预设标准命令输入至标准介面装置,其中此预设标准命令的命令码同于SATA桥接器预设的命令码,如此当标准介面装置回传输出资讯至SATA桥接器时,完成比对所接收的命令码与SATA桥接器预设的命令码后,便能设定无效输出参数为辨识参数,以供软件程式确认SATA桥接器的身份。
请参阅图3所示,是本发明另一较佳实施例的流程图。如图所示,本实施例与图2所示实施例不同之处在于,图2实施例的SATA桥接器依据标准命令的命令码设定无效输出参数为辨识参数,而本实施例的软件程式在输入标准命令前先设定标准命令的一无效输入参数为一执行参数,提供SATA桥接器依据执行参数设定无效输出参数为辨识参数,在此实施例中SATA桥接器预设有特定的比对值,用以比对执行参数。现将本实施例具体说明陈述如后:首先进行步骤S21,软件程式设定闲置(IDLE)标准命令的复数输入参数并将至少一无效输入参数设为执行参数,在本实施例中是将高位元逻辑区块定址扩充(LBA High(exp))输入参数设为16进制(Hexadecimal)数值的06h,其中高位元逻辑区块定址扩充(LBA High(exp))输入参数为无效输入参数。
之后,进行步骤S22,软件程式输入闲置(IDLE)标准命令至主机控制器,此步骤是输入标准命令的命令码至主机控制器,其中闲置(IDLE)标准命令的命令码为16进制(Hexadecimal)数值的E3h,此时主机控制器将闲置(IDLE)标准命令的各输入参数与命令码转换为下列表六所示的输入讯框资讯结构的格式,例如将高位元逻辑区块定址扩充(LBA High(exp))栏位写入数值06h而为执行参数。之后,主机控制器将转为输入讯框资讯结构格式的闲置(IDLE)标准命令传送至SATA桥接器;接着,进行步骤S23,SATA桥接器将转为输入讯框资讯结构格式的闲置(IDLE)标准命令转换为标准介面装置可读取的格式,同时记录其执行参数,之后再将其传送至标准介面装置。
Figure C20061006514900171
表六
接着,进行步骤S24,标准介面装置执行已接收的闲置(IDLE)标准命令,并在执行完毕后产生包含无效输出参数的输出资讯,再将此输出资讯回传至SATA桥接器;然后,进行步骤S25,根据步骤S23所记录的执行参数,SATA桥接器将输出资讯的无效输出参数设为辨识参数,且转换包含辨识参数的输出资讯为表五所示的输出讯框资讯结构的格式;随后,进行步骤S26,SATA桥接器传送包含辨识参数的输出讯框资讯结构格式的输出资讯至主机控制器;最后,进行步骤S27,软件程式读取输出资讯的辨识参数,令软件程式判断辨识参数,以确认SATA桥接器的身份。
因为无效输入参数为可任意设定的参数值,所以图3的实施例仅设定高位元逻辑区块定址扩充(LBA High(exp))输入参数为06h,容易发生随机设定的值恰巧与执行参数相同,造成SATA桥接器误认欲设定无效输出参数为辨识参数,如此软件程式在确认SATA桥接器身份后,软件程式接续执行并下达命令时,SATA桥接器会因为软件程式乱数产生的无效输入参数的值恰巧与执行参数相同,而重复设定无效输出参数为辨识参数,因而降低SATA桥接器的效能。
为了避免发生上述的情况,本发明藉由图4所示实施例的实施即可解决此一问题,现将其方法说明如下:首先如步骤S31所示,软件程式设定标准命令的复数输入参数并设定无效输入参数分别为确认参数与执行参数。在本实施例中,将低位元逻辑区块定址扩充(LBA Low(exp))输入参数与中位元逻辑区块定址扩充(LBA Mid(exp))输入参数分别设为16进制(Hexadecimal)数值的07h、08h以作为确认参数;将高位元逻辑区块定址扩充(LBA High(exp))输入参数设为16进制(Hexadecimal)数值的06h以作为执行参数。
之后,进行步骤S32,软件程式输入标准命令至主机控制器,此时主机控制器将包含确认参数与执行参数的输入参数和命令码转换为下列表七所示的输入讯框资讯结构的格式,例如将低位元逻辑区块定址扩充(LBA Low(exp))栏位、中位元逻辑区块定址扩充(LBA Mid(exp))栏位与高位元逻辑区块定址扩充(LBA High(exp))栏位分别填入16进制(Hexadecimal)数值的07h、08h、06h。之后,主机控制器再将转为输入讯框资讯结构格式的标准命令传送至SATA桥接器;接着,进行步骤S33,SATA桥接器将已接收的标准命令转换为标准介面装置可读取的格式,同时记录其执行参数与确认参数,之后再将其传送至标准介面装置。在此实施例中SATA桥接器预设有特定的比对值,用以比对确认参数与执行参数。
Figure C20061006514900181
表七
然后,进行步骤S34,标准介面装置执行已接收的标准命令,并在执行完毕后产生包含无效输出参数的输出资讯再将其回传至SATA桥接器;接着,进行步骤S35,根据步骤S33所记录的确认参数与执行参数,决定是否设定无效输出参数为辨识参数,若SATA桥接器判断低位元逻辑区块定址扩充(LBALow(exp))栏位、中位元逻辑区块定址扩充(LBA Mid(exp))栏位的数值分别为07h、08h,且高位元逻辑区块定址扩充(LBA High(exp))栏位的数值为06h时,SATA桥接器即确认06h为有效的执行参数,所以SATA桥接器设定无效输出参数为辨识参数,且将包含有辨识参数的输出资讯转换为表五所示的输出讯框资讯结构的格式;然后,进行步骤S36,SATA桥接器传送包含辨识参数的输出讯框资讯结构格式的输出资讯至主机控制器;最后,进行步骤S37,软件程式读取输出资讯的辨识参数,令软件程式判断辨识参数以确认SATA桥接器的身份。
请参阅图5所示,是本发明又一较佳实施例的流程图。图4所示实施例与本实施例不同之处在于,图4实施例是将一标准命令的不同无效输入参数分别设定为确认参数与执行参数,而本实施例则将标准命令与次要标准命令的无效输入参数分别设为执行参数与确认参数。现将本实施例的说明陈述如后:首先,如步骤S41所示,软件程式设定一次要标准命令的复数输入参数,并将至少一无效输入参数设定为确认参数,在本实施例中是将一闲置(IDLE)标准命令设为此次要标准命令,实际操作上是将闲置(IDLE)标准命令中的低位元逻辑区块定址扩充(LBA Low(exp))输入参数与中位元逻辑区块定址扩充(LBA Mid(exp))输入参数分别设为16进制(Hexadecimal)数值的07h、08h以作为确认参数。
接着,进行步骤S42,软件程式输入次要标准命令至主机控制器,此时主机控制器即会将包含确认参数的次要标准命令转换为如下列表八所示的输入讯框资讯结构的格式,低位元逻辑区块定址扩充(LBA Low(exp))栏位、中位元逻辑区块定址扩充(LBA Mid(exp))栏位的数值分别为07h、08h,接着将次要标准命令传送至SATA桥接器,供SATA桥接器将其转换为标准介面装置可读取的格式并同时记录其所含的确认参数,然后传送转换后的次要标准命令至标准介面装置,以供标准介面装置执行。标准介面装置执行完次要标准命令后,会产生包含无效输出参数的输出资讯,且将其回传至SATA桥接器,此时SATA桥接器并不会设定无效输出参数为辨识参数,仅会将此输出资讯转换为输出讯框资讯结构的格式并传送至主机控制器。
Figure C20061006514900191
表八
然后,进行步骤S43,软件程式设定一标准命令的复数输入参数,并将无效输入参数设定为执行参数,在本实施例中是将另一闲置(IDLE)标准命令设为此标准命令,实作上则是将其所含的高位元逻辑区块定址扩充(LBAHigh(exp))输入参数设为16进制(Hexadecimal)数值的06h以作为执行参数;接着,进行步骤S44,软件程式输入此标准命令至主机控制器,而主机控制器会立即将包含执行参数的标准命令转换为如表六所示的输入讯框资讯结构的格式,并将转为输入讯框资讯结构格式的标准命令传送至SATA桥接器,以供SATA桥接器将其转换为标准介面装置可读取的格式,同时,记录其执行参数,之后再将其传送至标准介面装置。
之后,进行步骤S45,标准介面装置执行标准命令,执行后会产生包含无效输出参数的另一输出资讯,且回传至SATA桥接器;接着,进行步骤S46,SATA桥接器根据所记录的确认参数与执行参数,SATA桥接器断定需设定此输出资讯的无效输出参数为辨识参数,且将包含辨识参数的输出资讯转换为表五所示的输出讯框资讯结构的格式;然后,进行步骤S47,SATA桥接器传送包含辨识参数的输出资讯至主机控制器;最后,进行步骤S48,软件程式读取输出资讯的辨识参数,令软件程式判断辨识参数,以确认SATA桥接器的身份。
综上所述,现以概要说明的方式叙述本发明确认序列进阶技术接附规格(SATA)桥接器身份的方法,请参阅图6所示,现将其流程说明如下:首先,进行步骤S51,输入标准命令并转换标准命令为输入讯框资讯结构的格式;之后,进行步骤S52,传送标准命令至标准介面装置;随后,进行步骤S53,标准介面装置执行标准命令,且产生执行完毕的输出资讯接着,进行步骤S54,SATA桥接器设定输出资讯的无效输出参数为辨识参数并将其转为输出讯框资讯结构的格式;最后,进行步骤S55,软件程式读取输出资讯的辨识参数并进行判断以确认SATA桥接器的身份,若软件程式可辨识SATA桥接器的身份时,即接续执行,若无法辨识时,即停止执行,如此可避免软件程式遭受盗用。
以上所述,仅是本发明的较佳实施例而已,并非对本发明作任何形式上的限制,虽然本发明已以较佳实施例揭露如上,然而并非用以限定本发明,任何熟悉本专业的技术人员,在不脱离本发明技术方案范围内,当可利用上述揭示的技术内容作出些许更动或修饰为等同变化的等效实施例,但凡是未脱离本发明技术方案内容,依据本发明的技术实质对以上实施例所述的形状、构造、特性及精神所作的任何简单修改、等同变化与修饰,均仍属于本发明技术方案的范围内。

Claims (22)

1.一种确认序列进阶技术接附规格SATA桥接器身份的方法,其特征在于其包括下列步骤:
输入一符合SATA标准介面规格的标准命令至一主机控制器,将该标准命令转换为一输入讯框资讯结构FIS的格式;
传送该标准命令至该SATA桥接器,以转换该输入讯框资讯结构格式的该标准命令为一标准介面装置所能辨识的格式;
传送该标准命令至该标准介面装置;
执行该标准命令并产生一输出资讯至一序列进阶技术接附规格SATA桥接器,该输出资讯包含复数组无效输出参数;
设定至少一该无效输出参数为一辨识参数,且转换该输出资讯为一输出讯框资讯结构的格式;以及
藉由判断该辨识参数是否与该SATA桥接器对应,以确认该SATA桥接器的身份。
2.根据权利要求1所述的方法,其特征在于其中输入该标准命令至该主机控制器之前,设定该标准命令的复数输入参数,以输入包含该复数输入参数的标准命令至该主机控制器。
3.根据权利要求2所述的方法,其特征在于其中该标准介面装置依据该复数输入参数执行该标准命令。
4.根据权利要求1所述的方法,其特征在于其中是在转换该输入讯框资讯结构格式的该标准命令为该标准介面装置所能辨识的格式时,记录该标准命令的命令码,以依据该命令码设定该无效输出参数为该辨识参数。
5.根据权利要求1所述的方法,其特征在于其中是由该标准介面装置执行该标准命令。
6.根据权利要求1所述的方法,其特征在于其中所述的该无效输出参数分别储存于该标准介面装置的复数输出暂存器。
7.根据权利要求1所述的方法,其特征在于其中是由该SATA桥接器将该无效输出参数设定为该辨识参数。
8.根据权利要求1所述的方法,其特征在于其中若该SATA桥接器为一软件程式所支援的SATA桥接器,则该SATA桥接器能设定该无效输出参数为该辨识参数。
9.根据权利要求1所述的方法,其特征在于其中是使用一软件程式对该辨识参数进行判断,若该辨识参数为该软件程式所无法辨别,则该软件程式不继续动作。
10.根据权利要求1所述的方法,其特征在于其中所述的该辨识参数是为该SATA桥接器内预设的特定值。
11.根据权利要求1所述的方法,其特征在于其中所述的标准命令是为一28位元标准命令,该无效输出参数为扩充输出参数。
12.一种确认序列进阶技术接附规格SATA桥接器身份的方法,其特征在于其包括下列步骤:
设定一符合SATA标准介面规格的标准命令的一无效输入参数为一执行参数;
输入该标准命令至一主机控制器,将该标准命令转换为一输入讯框资讯结构FIS的格式;
传送该标准命令至该SATA桥接器,以转换该输入讯框资讯结构格式的该标准命令为一标准介面装置所能辨识的格式,且记录该标准命令的该执行参数;
传送该标准命令至该标准介面装置;
执行该标准命令并产生一输出资讯至一序列进阶技术接附规格SATA桥接器,该输出资讯包含复数组无效输出参数;
依据该执行参数设定至少一该无效输出参数为一辨识参数,且转换该输出资讯为一输出讯框资讯结构的格式;以及
藉由判断该辨识参数是否与该SATA桥接器对应,以确认该SATA桥接器的身份。
13.根据权利要求12所述的方法,其特征在于其中所述的该无效输出参数分别储存于该标准介面装置的复数输出暂存器。
14.根据权利要求12所述的方法,其特征在于其中是由该SATA桥接器将该无效输出参数设定为该辨识参数。
15.根据权利要求12所述的方法,其特征在于其中若该SATA桥接器为一软件程式所支援的SATA桥接器,则该SATA桥接器能设定该无效输出参数为该辨识参数。
16.根据权利要求12所述的方法,其特征在于其中是使用一软件程式对该辨识参数进行判断,若该辨识参数为该软件程式所无法辨别,则该软件程式不继续动作。
17.根据权利要求12所述的方法,其特征在于其中所述的辨识参数是为该SATA桥接器内预设的特定值。
18.根据权利要求12所述的方法,其特征在于其中是在设定该标准命令的该无效输入参数为该执行参数时,设定该标准命令的另一无效输入参数为一确认参数,以依据该确认参数与该执行参数设定该无效输出参数为该辨识参数。
19.根据权利要求12所述的方法,其特征在于该确认序列进阶技术接附规格SATA桥接器身份的方法更包括有下列步骤:
设定一次要标准命令的至少一无效输入参数为一确认参数;
输入该次要标准命令至该主机控制器,以转换为该输入讯框资讯结构的格式;
传送该次要标准命令至该SATA桥接器;以及
依据该确认参数与该执行参数设定该无效输出参数为该辨识参数。
20.根据权利要求19所述的方法,其特征在于其中所述的该次要标准命令为一28位元标准命令,该无效输入参数为扩充输入参数。
21.根据权利要求12所述的方法,其特征在于其中所述的该标准命令是为一28位元标准命令,该无效输入参数为扩充输入参数。
22.根据权利要求12所述的方法,其特征在于其中所述的该标准命令是为一28位元标准命令,该无效输出参数为扩充输出参数。
CNB2006100651493A 2006-03-21 2006-03-21 确认序列进阶技术接附规格sata桥接器身份的方法 Active CN100380349C (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CNB2006100651493A CN100380349C (zh) 2006-03-21 2006-03-21 确认序列进阶技术接附规格sata桥接器身份的方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CNB2006100651493A CN100380349C (zh) 2006-03-21 2006-03-21 确认序列进阶技术接附规格sata桥接器身份的方法

Publications (2)

Publication Number Publication Date
CN1821983A CN1821983A (zh) 2006-08-23
CN100380349C true CN100380349C (zh) 2008-04-09

Family

ID=36923353

Family Applications (1)

Application Number Title Priority Date Filing Date
CNB2006100651493A Active CN100380349C (zh) 2006-03-21 2006-03-21 确认序列进阶技术接附规格sata桥接器身份的方法

Country Status (1)

Country Link
CN (1) CN100380349C (zh)

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1032224A2 (en) * 1999-02-22 2000-08-30 Selex Communications LLC. Method and apparatus for providing quasi mobile telephone service
CN1622066A (zh) * 2004-12-13 2005-06-01 威盛电子股份有限公司 驱动标准接口装置执行非标准事件的方法
CN1700197A (zh) * 2005-06-22 2005-11-23 威盛电子股份有限公司 读写标准界面装置内非标准暂存器的方法
CN1725204A (zh) * 2005-06-23 2006-01-25 威盛电子股份有限公司 读写序列进阶技术接附规格装置内非标准暂存器的方法

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1032224A2 (en) * 1999-02-22 2000-08-30 Selex Communications LLC. Method and apparatus for providing quasi mobile telephone service
CN1622066A (zh) * 2004-12-13 2005-06-01 威盛电子股份有限公司 驱动标准接口装置执行非标准事件的方法
CN1700197A (zh) * 2005-06-22 2005-11-23 威盛电子股份有限公司 读写标准界面装置内非标准暂存器的方法
CN1725204A (zh) * 2005-06-23 2006-01-25 威盛电子股份有限公司 读写序列进阶技术接附规格装置内非标准暂存器的方法

Also Published As

Publication number Publication date
CN1821983A (zh) 2006-08-23

Similar Documents

Publication Publication Date Title
CN102291423B (zh) 控制物理层芯片的方法及控制电路
CN101498994B (zh) 一种固态硬盘控制器
CN101685381B (zh) 固态大容量存储装置的数据串流
CN101133404B (zh) 用于与存储器装置通信的系统和方法
CN106095329A (zh) 一种基于NVME接口的Intel SSD硬盘的管理方法
CN101436171B (zh) 模块化通信控制系统
CN100585578C (zh) 系统总线的防死锁方法、装置
CN101488919B (zh) 存储地址分配方法和装置
CN103049224A (zh) 将数据导入物理磁带的方法、装置和系统
CN101421705B (zh) 具有高储存容量的多媒体卡
CN105512052A (zh) 用于处理输入输出操作请求的方法和装置
CN100552613C (zh) 一种scsi数据读写方法、系统和装置
CN104142979B (zh) 一种实现rfid标签存储管理的索引方法
US20070083708A1 (en) Controller of redundant arrays of independent disks and operation method thereof
CN100499557C (zh) 一种寻址控制器件及使用该器件进行寻址的方法
CN100380349C (zh) 确认序列进阶技术接附规格sata桥接器身份的方法
CN109901664A (zh) 提供时钟信号的方法、装置、系统、设备及可读存储介质
CN100377133C (zh) 读写序列进阶技术接附规格装置内非标准暂存器的方法
CN101241478B (zh) 数据传送方法
CN107688435A (zh) Io流调节方法与装置
CN100476782C (zh) 一种存储卡数据传输方法
CN100445970C (zh) 确认桥接器身份的方法
CN105739919A (zh) 资料存取系统及方法
CN101661430A (zh) 一种存储块回收判断装置及存储块管理系统
CN117008843B (zh) 控制页链表构建装置和电子设备

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
C14 Grant of patent or utility model
GR01 Patent grant