CN101136859B - 控制光纤信道通信中的信息单元的方法和系统 - Google Patents
控制光纤信道通信中的信息单元的方法和系统 Download PDFInfo
- Publication number
- CN101136859B CN101136859B CN200710127303XA CN200710127303A CN101136859B CN 101136859 B CN101136859 B CN 101136859B CN 200710127303X A CN200710127303X A CN 200710127303XA CN 200710127303 A CN200710127303 A CN 200710127303A CN 101136859 B CN101136859 B CN 101136859B
- Authority
- CN
- China
- Prior art keywords
- control unit
- main memory
- memory control
- information unit
- command word
- 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.)
- Expired - Fee Related
Links
- 238000000034 method Methods 0.000 title claims abstract description 20
- 239000000835 fiber Substances 0.000 title claims description 41
- 238000004891 communication Methods 0.000 title claims description 13
- 230000004044 response Effects 0.000 claims abstract description 36
- 239000013307 optical fiber Substances 0.000 claims abstract description 11
- 230000008569 process Effects 0.000 claims description 5
- 230000005540 biological transmission Effects 0.000 description 16
- 230000006870 function Effects 0.000 description 7
- 238000013461 design Methods 0.000 description 5
- 238000010586 diagram Methods 0.000 description 5
- 230000000712 assembly Effects 0.000 description 4
- 238000000429 assembly Methods 0.000 description 4
- 230000008859 change Effects 0.000 description 3
- 238000005516 engineering process Methods 0.000 description 3
- 230000003287 optical effect Effects 0.000 description 3
- 238000012546 transfer Methods 0.000 description 3
- 238000004422 calculation algorithm Methods 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 238000004088 simulation Methods 0.000 description 2
- RYGMFSIKBFXOCR-UHFFFAOYSA-N Copper Chemical compound [Cu] RYGMFSIKBFXOCR-UHFFFAOYSA-N 0.000 description 1
- 239000004606 Fillers/Extenders Substances 0.000 description 1
- 238000004590 computer program Methods 0.000 description 1
- 239000010949 copper Substances 0.000 description 1
- 229910052802 copper Inorganic materials 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 230000007717 exclusion Effects 0.000 description 1
- 238000012423 maintenance Methods 0.000 description 1
- 238000013507 mapping Methods 0.000 description 1
- 230000007246 mechanism Effects 0.000 description 1
- 238000012545 processing Methods 0.000 description 1
- 230000001902 propagating effect Effects 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 230000003068 static effect Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04B—TRANSMISSION
- H04B10/00—Transmission systems employing electromagnetic waves other than radio-waves, e.g. infrared, visible or ultraviolet light, or employing corpuscular radiation, e.g. quantum communication
- H04B10/25—Arrangements specific to fibre transmission
-
- 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/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0655—Vertical data movement, i.e. input-output transfer; data movement between one or more hosts and one or more storage devices
- G06F3/0659—Command handling arrangements, e.g. command buffers, queues, command scheduling
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F15/00—Digital computers in general; Data processing equipment in general
- G06F15/16—Combinations of two or more digital computers each having at least an arithmetic unit, a program unit and a register, e.g. for a simultaneous processing of several programs
-
- 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/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/061—Improving I/O performance
- G06F3/0611—Improving I/O performance in relation to response time
-
- 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/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/067—Distributed or networked storage systems, e.g. storage area networks [SAN], network attached storage [NAS]
-
- 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/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0646—Horizontal data movement in storage systems, i.e. moving data in between storage devices or systems
- G06F3/065—Replication mechanisms
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Human Computer Interaction (AREA)
- Computer Hardware Design (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Electromagnetism (AREA)
- Software Systems (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
- Computer And Data Communications (AREA)
- Optical Communication System (AREA)
- Selective Calling Equipment (AREA)
Abstract
所提供的是一种方法、系统和产品,其中主存储控制单元通过光纤信道连接从远程主机接收信息单元。主存储控制单元调整包括在从主存储控制单元向远程主机发送的响应内的信息单元调步参数,其中所述信息单元调步参数指出允许远程主机无需等待来自主存储控制单元的任何其他响应便可向主存储控制单元发送的信息单元的个数。
Description
技术领域
本发明涉及控制光纤信道通信中的信息单元的方法、系统和产品。
背景技术
光纤信道(Fibre Channel)是指由美国国家标准协会制定的一整套数据传送体系结构标准。光纤连接(FICON)是光纤信道体系结构的协议,正式名称也可以叫FC-SB3。FC-SB3的更详细资料可参见美国信息技术国家标准在2003年3月26日出版的“FIBRE CHANNELSingle-Byte Command Code Sets-3 Mapping Protocol(FC-SB-3)”,Rev.1.6)。
信道是通信设备之间的直接或经转接的点对点连接。在光纤信道体系结构中,FICON信道可以执行由FC-SB3规定的功能,以通过控制单元或仿真控制单元提供对输入/输出(I/O)设备的访问。FICON信道可以依赖于在通信设备之间传送数据的分组交换。
信道命令字(CCW)是包括I/O请求的控制块,可以指规定要执行的命令以及参数的专用系统体系结构的结构。信道程序是相继执行的一个或多个信道命令字的序列,用来控制信道操作的具体顺序。FICON信道可以为任何写操作每次发送多到16个信道命令字以及相关联的数据,在这种情况下信道命令字可以称为“信息单元”。如果在一个信道程序中存在16个以上的信息单元,则在发送了最初的16个信息单元后可以按8个一组地成组发送剩下的信息单元,直至完成信道程序。
扩展远程拷贝(Extended Remote Copy,XRC)是z/OS*和OS/390*操作系统可用的拷贝功能。XRC远地异步维护数据拷贝,可 以在长距离(例如超过一百公里)的范围内实现。XRC可以用于IBM企业存储服务器*(ESS)。XRC的更详细的资料可以参见国际商用机器公司在2004年7月出版的“IBM TotaiStorage Enterprise StorageServer:Implementing ESS Copy Services with IBM eServer zSeries”。
发明内容
所提供的是一种方法、系统和产品,其中主存储控制单元通过光纤信道连接从远程主机接收信息单元。主存储控制单元调整包括在从主存储控制单元向远程主机发送的响应内的信息单元调步(pacing)参数,该信息单元调步参数指出允许远程主机不用等待来自主存储控制单元的任何其他响应就可向主存储控制单元发送的信息单元的个数。
在另一些实施例中,将信息单元调步参数设置为一个大于16的数。
在其他一些实施例中,信息单元是光纤连接协议中的信道命令字,所接收的信道命令字开始一个信道命令字链。确定信道命令字是否包括定义扩展远程拷贝操作的子系统操作的定义子系统操作命令。确定与定义子系统操作命令关联的读记录集命令(read record setcommand)的个数,其中读记录集命令与读请求相对应。信息单元调步参数的值被设置为大到足以允许远程主机发送剩下的信息单元而不需要来自主存储控制单元的其他响应。
在又一些实施例中,信息单元是光纤连接协议中的信道命令字,所接收的信道命令字开始一个信道命令字链。确定信道命令字是否包括定义扩展远程拷贝操作的子系统操作的定义子系统操作命令。响应于信道命令字不包括定义子系统操作命令的确定结果,将信息单元调步参数设置为零,其中通过将信息单元调步参数设置为零,在用于在远程主机与主存储控制单元之间进行通信的光纤信道连接协议中使用默认的信息单元调步信用值(credit)。
在又一些实施例中,远程主机执行从主存储控制单元到远程存储控制单元的数据的扩展远程拷贝,其中远程主机与主存储控制单元地理上相隔超过一百公里的距离。
附图说明
下面将对同样的标号标注的是相应部分的附图进行说明,在这些附图中:
图1例示了按照特定实施例设计的计算环境的方框图;
图2例示了按照特定实施例设计的与光纤连接关联的数据结构;
图3例示了按照特定实施例设计的与扩展远程拷贝关联的数据结构;
图4例示了方框图,所述方框图示出按照特定实施例在远程主机与主存储控制器之间进行的通信;
图5例示了流程图,所述流程图示出按照特定实施例控制光纤信道通信中的信息单元的操作;以及
图6例示了计算系统的体系结构,在特定实施例中可以按照该计算系统的体系结构实现图1的计算环境内的各个组成部分。
具体实施方式
在以下说明中,将参考形成本发明的一部分的例示本发明的特定实施例的附图。可以理解,也可以应用其他实现方式,在结构上和操作上都可以加以改变。
在FICON体系结构中称为“信息单元调步”的流控制方法可以将FICON信道限制成在任何时间点在传输中(in flight)最多具有16个信息单元。信道程序可以通过将第八个信息单元内的命令响应请求(CRR)比特置位来请求命令响应信息单元。在信道程序从控制单元接收到命令响应信息单元时,就再发送另8个信息单元。这可能导致在长距离(例如超过一百公里)上数据率下降,因为按照FICON调步协议控制单元必须接收到第一组16个信息单元后再请求另外的信息单元,因此增添了信道与控制单元端口之间的通信的附加往返行程。 往返行程数取决于信道命令字链的大小。如果在信道命令字链中有150个信道命令字,就可以有多到17个往返行程。在长距离上,例如超过一百公里,可能要增加不少用于这些附加的通信往返行程的开销。
特定实施例允许主存储控制单元修改FICON体系结构内的信息单元的流,使得在任何时间点在传输中可以有16个以上的信息单元。在使用光纤信道网络中的FICON实现扩展距离(extended distance)远程拷贝中,远程主机可以执行扩展距离远程拷贝操作以将数据从主存储控制单元拷贝给远程存储控制单元。通过允许在给定的时间点在传输中有16个以上的信息单元,与将信道限制为在任何时间点在传输中不超过16个信息单元的情况相比,特定实施例可以减少执行扩展远程拷贝的时间。
图1例示了利用与主存储控制单元104和远程存储控制单元106耦接的远程主机102的计算环境100的方框图。虽然图1示出了只有一个远程主机102、一个主存储控制单元104和一个远程存储控制单元106,但在特定的可供选择的实施例中可以有多个远程主机与多个主存储控制单元和多个远程存储控制单元耦接。
远程主机102可以通过数据接口信道,例如光纤信道108或在该技术领域所知的任何其他数据接口机制,与主存储控制单元104连接。远程主机102可以是在该技术领域内当前所知的任何适当的计算设备,诸如个人计算机、工作站、服务器、大型机、手持式计算机、电话设备、网络设备之类。远程主机102可以包括在该技术领域内所知的任何操作系统,例如IBM OS/390或z/OS操作系统。
主存储控制单元104和远程存储控制单元106可以包括多个逻辑卷。主存储控制单元104和远程存储控制单元106可以控制多个各可以包括一个或多个物理卷的物理存储装置。
远程主机102可以包括主机应用110,而主存储控制单元104可以包括控制器应用112。主机应用110与控制器应用112对接,以从主存储控制单元104读取数据和将数据存储在远程存储控制单元106内。主机应用110和控制器应用112通过光纤信道108进行通信。在 特定实施例中,主机应用110用扩展远程拷贝通过光纤信道108将数据从主存储控制单元104拷贝给远程存储控制单元106。
远程主机102与主存储控制单元104之间通过光纤信道108的通信可以由包含在远程主机102内的光纤信道适配器114和包含在主存储控制单元104内的光纤信道适配器116实施。包含在远程主机102内的光纤信道适配器114包括端口118,包含在主存储控制单元104内的光纤信道适配器116包括端口120,端口118和120在光纤信道术语中都可以称为N端口。可以在远程主机102的端口118与主存储控制单元104的端口120之间执行用FICON协议进行的基于光纤信道的通信。
因此,图1例示了主机应用110使用扩展远程拷贝操作用FICON协议将数据从主存储控制单元104拷贝给远程存储控制单元106的计算环境100。在特定实施例中,通过使用光纤信道扩展解决方案,远程主机102与主存储控制单元104之间的距离可以超过光纤信道体系结构所支持的最大距离。
图2例示了按照特定实施例设计的与在计算环境100的光纤信道108上实现的光纤连接关联的数据结构。图2所示的数据结构称为FICON数据结构200。
FICON数据结构200包括一个或多个信道命令字202、信息单元调步信用值204、具有信息单元调步参数208的命令响应信息单元206,其中信息单元调步参数208也称为IU调步参数,而信息单元调步信用值204可以称为IU调步信用值。
信道命令字202是包括I/O请求的控制块。例如,在特定实施例中,信道命令字202可以包括从主机应用110到控制器应用112的读请求,读请求是读主存储控制单元104所存储的数据的请求。信道命令字202也可以称为信息单元。
用于远程主机102与主存储控制单元104之间的光纤信道通信的每个信道提供IU调步信用值204,IU调步信用值204在每个信道程序开始时或者在继续执行信道程序的重新连接期间初始化。IU调步信 用值204是远程主机102从主存储控制单元104接收到命令响应信息单元206前可以向主存储控制单元104发送的信息单元的最多的个数。
命令响应信息单元206是响应于特定的条件从主存储控制单元104向远程主机102发送的信息单元。例如,响应于特定的信道命令字202可以将命令响应信息单元206从主存储控制单元104发送给远程主机102。与命令响应信息单元206关联的IU调步参数208可以从主存储控制单元104的端口120发送,以指出远程主机102在从主存储控制单元104接收到新的命令响应信息单元前可以通过信道发送的信息单元的最多个数。IU调步参数208为零表示主存储控制单元104倾向于保留IU调步信用值204的缺省值不变。
因此,图2例示了主存储控制单元104设置IU调步参数208来控制从远程主机102到主存储控制单元104的信道命令字202的流。
图3例示了按照特定实施例设计的与在计算环境100内实现的扩展远程拷贝关联的数据结构。图3所示的数据结构称为XRC数据结构300。
XRC数据结构可以包括定义子系统操作(DSO)命令302,它定义了子系统操作,给出要在当前命令链中执行若干个读记录集(RRS)信道命令字的意图。在扩展远程拷贝操作期间,DSO命令302可以定义在远程主机102与主存储控制单元104之间进行通信期间的子系统操作。RRS命令304,如果与DSO命令302关联,就向主存储控制单元104指出远程主机102在发送读请求。
扩展距离XRC配置可以在远程主机102与主存储控制单元104之间使用光纤信道扩展技术。远程主机102可以用扩展光纤信道来从主存储控制单元104读取数据和将数据存储在远程存储控制单元106的存储装置内。在特定实施例中,将从主存储器104读取的数据作为备份数据存储在远程存储控制单元106内。
在特定实施例中,远程主机102向主存储控制单元104发出命令链,该命令链包括DSO命令302,继之以一系列读记录集命令304,最后是一些附加命令[例如,执行子系统功能(PSE)命令和读子系统数据(RSSD)命令,如在XRC中所定义的],以确定下一个链的副文件输入项(side-file entry)的个数。在DSO命令参数内标出了对链内RRS命令304的计数,在一些典型的实施例中RRS命令304的计数可以超过150个信道命令字。
因此,图3例示了特定的实施例,其中与DSO命令302关联的读记录集命令304向主存储控制单元104指出远程主机102请求了读操作。这样的DSO命令302在实现扩展远程拷贝的实施例中可以从远程主机102发送给主存储控制单元104。
图4例示了示出按照在计算环境100内实现的本发明的实施例,在远程主机102与主存储器控制器104之间进行通信的方框图。
远程主机102能通过按照FICON协议在远程主机102与主存储控制单元104之间产生的信道按顺序发送一个或多个信道命令字400。主存储控制单元104可以响应于特定的信道命令字400发送命令响应信息单元402。在特定实施例中通过调整包含在命令响应信息单元402内的IU调步参数,如IU调步参数208,主存储控制单元104可以修改在远程主机102与主存储控制单元104之间在传输中可以存在的信道命令字的个数。
图5例示了流程图,所述流程图示出按照特定实施例控制光纤信道通信中的信息单元的操作。图5中所例示的操作有些可以在主存储控制单元104内实现。
控制在方框500启动,其中在远程主机102与主存储控制单元104之间在光纤信道108上形成的信道处在空闲状态,并且信道命令字链开始(标注数字502)。
控制进至方框504,其中控制器应用112确定第一个接收到的命令控制字是否包括定义子系统操作命令302。如果是,控制器应用112就确定在该定义子系统操作命令302的参数中是否指出了一个或多个读记录集命令304。读记录集命令304的个数可以表示在扩展远程拷贝操作期间从远程主机102到主存储控制单元104随后的读请求的个数。存在读记录集命令304还可以表示已经在光纤信道108上实现扩展距离远程拷贝。
如果控制器应用112确定(在方框504)在定义子系统操作命令302的参数内包括一个或多个读记录集命令304,在特定实施例中控制器应用112就将下一个命令响应信息单元206的IU调步参数208设置(在方框508)为比定义子系统操作命令302内所指出的读记录集命令304的个数大2。比读记录集命令304的个数大2被包括在IU调步参数内,这是因为在该实施例的一些扩展远程拷贝实现中,在来自远程主机102的命令链的最后可以包括一些诸如执行子系统功能命令和读子系统数据命令之类的附加命令。在特定的可替代的实施例中,控制器应用112可以将IU调步参数208设置为任何其他数值,以便控制FICON协议内信道命令字的流。
控制器应用112发送(在方框510)带有该IU调步参数208的命令响应信息单元206。根据主机应用110接收到的IU调步参数208的数值,通过将IU调步信用值204设置为IU调步参数208的值来调整在光纤信道108上在传输中的信道命令字的个数。控制进至方框500,在发送了由IU调步信用值204所指示的这些个数的信道命令字后信道重新处于空闲状态,并且下一个控制字链开始(标注数字502)。
如果在方框504控制器应用112确定第一个命令控制字不包括定义子系统操作命令302,则控制器应用112将下一个命令响应信息单元的IU调步参数208设置(在方框512)为零,以表示将使用默认的IU调步信用值204。控制器应用112发送(在方框510)带有IU调步参数208的命令响应信息单元206。在这种情况下,任何时候可在光纤信道108上在传输中的信道命令字不超过16个。
如果在方框506控制器应用112确定定义子系统操作命令302没有指出一个或多个读记录集命令,则控制器应用112将下一个命令响应信息单元的IU调步参数208设置(在方框512)为零,以表示将使用默认的IU调步信用值204。控制器应用112发送(在方框510)带有该IU调步参数208的命令响应信息单元206。在这种情况下,任何时候可在光纤信道108上在传输中的信道命令字不超过16个。
因此,图5例示了这样一些实施例,其中可由主存储控制单元104动态地改变IU调步参数208,以修改FICON体系结构内的信息单元的流,使得在扩展远程拷贝期间在任何时间点上在从远程主机102向主存储控制单元104的传输中可以有16个以上的信息单元。特定实施例避免了由于在特定的默认FICON实现中超过例如100公里的远距离通信所需的额外往返行程所导致的数据率下降。此外,特定实施例不需要使用具有仿真能力的信道扩展器来避免数据率下降。
其他实施例细节
所揭示的技术可以实现为一种方法、设备或涉及软件、固件、微码、硬件和/或它们的任何组合的产品。所谓“产品”在这里是指以媒体实现的代码或逻辑,这样的媒体可以包括硬件逻辑[例如,集成电路片、可编程门阵列(PGA)、专用集成电路(ASIC)等]或者计算机可读媒体,诸如磁存储媒体(例如,硬盘驱动器、软盘、磁带等)、光存储器(CD-ROM、光盘等)、易失和非易失性存储器[例如,电可擦可编程只读存储器(EEPROM)、只读存储器(ROM)、可编程只读存储器(PROM)、随机存取存储器(RAM)、动态随机存取存储器(DRAM)、静态随机存取存储器(SRAM)、快擦写存储器、固件、可编程序逻辑等]。计算机可读媒体内的代码由处理器接入和执行。编有代码或逻辑的媒体还可以包括通过空间或诸如光纤、铜线之类的传输媒体传播的传输信号。编有代码或逻辑的传输信号可以进一步包括无线信号、卫星传输、无线电波、红外信号、蓝牙等。编有代码或逻辑的传输信号由发射台发送和由接收台接收,而在传输信号内编码的代码或逻辑可以经解码后存储在接收和发射台或设备的硬件或计算机可读媒体内。此外,所述“产品”可以包括一些体现、处理和执行代码的硬件和软件组件的组合。当然,熟悉该技术的人员可以看到,可以在不背离这些实施例的范围的情况下进行许多修改,而产品可以包括任何信息承载媒体。例如,产品包括存有在由机器执行时导致实施一些操作的指令的存储媒体。
特定实施例可以呈现为完全用硬件实施、完全用软件实施或含有 硬件和软件的形式。在一个优选实施例中,本发明用包括(但不局限于)固件、常驻软件、微操作码等的软件实现。
此外,特定实施例可以呈现为从提供供计算机或任何指令执行系统使用或与之配合使用的程序代码的计算机可用或计算机可读媒体得到的计算机程序产品的形式。就此而言,计算机可用或计算机可读媒体可以是任何可以含有、存储、传送、传播或传输供指令执行系统、设备或装置使用的或者与之配合使用的程序的设备。媒体可以是电子、磁、光、电磁、红外或半导体的系统(或设备或装置),也可以是传播媒体。计算机可读媒体的例子有半导体或固态存储器、磁带、计算机活动软盘、随机存取存储器(RAM)、只读存储器(ROM)、硬盘和光盘。当前光盘的例子有只读光盘(CD-ROM)、读/写光盘(CD-R/W)和DVD。
术语“特定实施例”、“一个实施例”、“实施例”、“所述实施例”、“该实施例、“各实施例”、“一个或多个实施例”和“一些实施例”都是意味着一个或多个(但不是所有)实施例,除非另有明确说明。所谓“包括”、“包含”、“具有”意味着“包括但并不局限于”,除非另有明确说明。所列举的项目列表并不意味着任何或所有的项目是互斥的,除非另有明确说明。所谓“一个”和“该”意味着“一个或多个”,除非另有明确说明。
相互通信的设备不必相互连续通信,除非另有明确说明。此外,相互通信的设备可以直接或通过一个或多个中介间接通信。此外,对一个具有一些相互通信的组成部分的实施例的描述并不意味着需要所有这样的组成部分。相反,所以说明各种任选的组成部分是为了例示本发明有各种各样的可能实现方式。
此外,虽然过程步骤、方法步骤、算法之类是以相继次序说明的,但这样一些过程、方法和算法可以按其他次序进行。也就是说,所说明的任何步骤顺序或次序不一定表示这些步骤就要按这个次序执行。在这里所说明的过程的步骤可以按任何切实可行的次序执行。此外,有些步骤可以同时或并行执行。
在这里说明单个设备或项目时,显然也可以用一个以上的设备/项目(无论它们协作与否)来代替单个设备/项目。类似,在这里说明一个以上的设备或项目(无论它们协作与否)时,显然也可以用单个设备/项目来代替一个以上的设备/项目。一个器件的功能和/或特征也可以由一个或多个没有明确表示为具有这样的功能/特征的其他器件体现。因此,其他实现方式不必包括器件本身。
图6例示了典型的计算机系统600,其中在特定实施例中可以按照计算机系统600的计算机体系结构实现图1的计算环境100中的远程主机102、主存储器控制器104和远程存储控制器。计算机系统600也可以称为系统,可以包括电路602,在特定实施例中它可以包括处理器604。系统600还可以包括存储器606(例如,易失性存储器)和存储装置608。在图1中的远程主机102、主存储器控制器104或远程存储控制器106内可以有或没有系统600的一些组成部分。存储装置608可以包括非易失性存储器装置(例如,EEPROM、ROM、PROM、RAM、DRAM、SRAM、快擦写存储器、固件、可编程逻辑等)、磁盘驱动器、光盘驱动器、磁带驱动器等。存储装置608可以包括内部存储装置、外挂存储装置和/或网络可访问的存储装置。系统600可以包括程序逻辑610,它包括可以装入存储器606和由处理器604或电路602执行的代码612。在一些实施例中,包括代码612的程序逻辑610可以存储在存储装置608内。在一些其他实施例中,程序逻辑610可以在电路602内实现。因此,虽然图6将程序逻辑610与其他组成部分分开示出,但程序逻辑610可以在存储器606和/或电路602内实现。
可以将一些实施例用于由人员配置计算指令的方法或将计算机可读代码集成入计算系统的自动化处理,这计算机可读代码与计算系统结合能执行所说明的实施例的操作。
图6中所例示的这些操作中至少有些除了相继执行之外也可以并行执行。在另一些实施例中,特定操作可以按不同的次序执行、加以修改或省去。
而且,为了例示清晰,许多软件和硬件组件都以独立的模块示出。这样的一些组件可以集成为少一些的组件或者分成多一些的组件。此外,一些描述为由一个特定组件执行的操作也可以由其他组件执行。
在图1-6中所示出或提到的数据结构和组件描述为具有特定类型的信息。在另一些实施例中,数据结构和组件可以按不同方式构成,具有比图中所示或提到的少一些、多一些或不同的字段或不同的功能。
因此,以上给出的对这些实施例的说明只是例示性和说明性的,它不是穷举性的,并不是要将本发明局限于所揭示的确切形式。根据以上的教导,许多修改和变动都是可行的。
注:*z/OS、OS/390和Enterprise Storage服务器都是国际商用机器公司的商标或注册商标。
Claims (8)
1.一种为将数据从主存储控制单元复制到远程主机而控制光纤信道通信中的信息单元的方法,包括:
在主存储控制单元处通过光纤信道连接从远程主机接收信息单元;以及
由主存储控制单元调整包括在从主存储控制单元向远程主机发送的响应内的信息单元调步参数,其中所述信息单元调步参数指出允许远程主机无需等待来自主存储控制单元的任何其他响应便可向主存储控制单元发送的信息单元的个数,
其中所述信息单元是光纤连接协议中的信道命令字,其中所接收的信道命令字开始一个信道命令字链,所述方法还包括:
确定信道命令字是否包括定义子系统操作命令,所述定义子系统操作命令定义扩展远程拷贝操作的子系统操作;
确定与定义子系统操作命令关联的读记录集命令的个数,其中读记录集命令与读请求相对应;以及
响应于确定信道命令字包括定义子系统操作命令,将信息单元调步参数设置为比读记录集命令的个数大2的值,以允许远程主机发送剩余信息单元而无需来自主存储控制单元的其他响应。
2.权利要求1的方法,其中所述信息单元调步参数被设置为大于16的数。
3.权利要求1的方法,其中所述信息单元是光纤连接协议中的信道命令字,其中所接收的信道命令字开始一个信道命令字链,所述方法还包括:
确定信道命令字是否包括定义扩展远程拷贝操作的子系统操作的定义子系统操作命令;
响应于确定信道命令字不包括定义子系统操作命令,将信息单元调步参数设置为零,其中通过将信息单元调步参数设置为零,在用于在远程主机与主存储控制单元之间进行通信的光纤信道连接协议中使用默认的信息单元调步信用值。
4.权利要求1的方法,其中所述远程主机执行从主存储控制单元到远程存储控制单元的数据的扩展远程拷贝,其中所述远程主机与主存储控制单元地理上相隔超过一百公里的距离。
5.一种为将数据从主存储控制单元复制到远程主机而控制光纤信道通信中的信息单元的系统,包括:
远程主机;
与远程主机耦接的主存储控制单元;
将主存储控制单元与远程主机耦接的光纤信道连接;
用于通过光纤信道连接从远程主机接收信息单元的装置;以及
调整包括在从主存储控制单元向远程主机发送的响应内的信息单元调步参数的装置,其中所述信息单元调步参数指出允许远程主机无需等待来自主存储控制单元的任何其他响应便可向主存储控制单元发送的信息单元的个数,
其中所述信息单元是光纤连接协议中的信道命令字,其中所接收的信道命令字开始一个信道命令字链,所述系统还包括:
确定信道命令字是否包括定义子系统操作命令的装置,其中所述定义子系统操作命令定义扩展远程拷贝操作的子系统操作;
确定与定义子系统操作命令关联的读记录集命令的个数的装置,其中读记录集命令与读请求相对应;以及
响应于确定信道命令字包括定义子系统操作命令,将信息单元调步参数设置为比读记录集命令的个数大2的值,以允许远程主机发送剩余的信息单元而无需来自主存储控制单元的其他响应的装置。
6.权利要求5的系统,其中所述信息单元调步参数被设置为大于16的数。
7.权利要求5的系统,其中所述信息单元是光纤连接协议中的信道命令字,其中所接收的信道命令字开始一个信道命令字链,所述系统还包括:
确定信道命令字是否包括定义扩展远程拷贝操作的子系统操作的定义子系统操作命令的装置;
响应于确定信道命令字不包括定义子系统操作命令,将信息单元调步参数设置为零的装置,其中通过将信息单元调步参数设置为零,在用于在远程主机与主存储控制单元之间进行通信的光纤信道连接协议中使用默认的信息单元调步信用值。
8.权利要求5的系统,其中所述远程主机执行从主存储控制单元到远程存储控制单元的数据的扩展远程拷贝,其中所述远程主机与主存储控制单元地理上相隔超过一百公里的距离。
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/468,720 US7500030B2 (en) | 2006-08-30 | 2006-08-30 | Control of information units in fibre channel communications |
US11/468,720 | 2006-08-30 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN101136859A CN101136859A (zh) | 2008-03-05 |
CN101136859B true CN101136859B (zh) | 2011-11-23 |
Family
ID=39160700
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN200710127303XA Expired - Fee Related CN101136859B (zh) | 2006-08-30 | 2007-06-27 | 控制光纤信道通信中的信息单元的方法和系统 |
Country Status (4)
Country | Link |
---|---|
US (2) | US7500030B2 (zh) |
KR (1) | KR100992018B1 (zh) |
CN (1) | CN101136859B (zh) |
TW (1) | TWI427479B (zh) |
Families Citing this family (48)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7502873B2 (en) | 2006-10-10 | 2009-03-10 | International Business Machines Corporation | Facilitating access to status and measurement data associated with input/output processing |
US7500023B2 (en) | 2006-10-10 | 2009-03-03 | International Business Machines Corporation | Facilitating input/output processing by using transport control words to reduce input/output communications |
US7668980B2 (en) * | 2007-11-30 | 2010-02-23 | International Business Machines Corporation | Usage of persistent information unit pacing protocol in fibre channel communications |
US7899944B2 (en) | 2008-02-14 | 2011-03-01 | International Business Machines Corporation | Open exchange limiting in an I/O processing system |
US8117347B2 (en) | 2008-02-14 | 2012-02-14 | International Business Machines Corporation | Providing indirect data addressing for a control block at a channel subsystem of an I/O processing system |
US7840717B2 (en) | 2008-02-14 | 2010-11-23 | International Business Machines Corporation | Processing a variable length device command word at a control unit in an I/O processing system |
US8176222B2 (en) * | 2008-02-14 | 2012-05-08 | International Business Machines Corporation | Early termination of an I/O operation in an I/O processing system |
US7890668B2 (en) | 2008-02-14 | 2011-02-15 | International Business Machines Corporation | Providing indirect data addressing in an input/output processing system where the indirect data address list is non-contiguous |
US8001298B2 (en) | 2008-02-14 | 2011-08-16 | International Business Machines Corporation | Providing extended measurement data in an I/O processing system |
US8108570B2 (en) | 2008-02-14 | 2012-01-31 | International Business Machines Corporation | Determining the state of an I/O operation |
US8166206B2 (en) | 2008-02-14 | 2012-04-24 | International Business Machines Corporation | Cancel instruction and command for determining the state of an I/O operation |
US8478915B2 (en) | 2008-02-14 | 2013-07-02 | International Business Machines Corporation | Determining extended capability of a channel path |
US8196149B2 (en) | 2008-02-14 | 2012-06-05 | International Business Machines Corporation | Processing of data to determine compatability in an input/output processing system |
US8214562B2 (en) | 2008-02-14 | 2012-07-03 | International Business Machines Corporation | Processing of data to perform system changes in an input/output processing system |
US7917813B2 (en) | 2008-02-14 | 2011-03-29 | International Business Machines Corporation | Exception condition determination at a control unit in an I/O processing system |
US7937507B2 (en) | 2008-02-14 | 2011-05-03 | International Business Machines Corporation | Extended measurement word determination at a channel subsystem of an I/O processing system |
US7908403B2 (en) * | 2008-02-14 | 2011-03-15 | International Business Machines Corporation | Reserved device access contention reduction |
US8312189B2 (en) | 2008-02-14 | 2012-11-13 | International Business Machines Corporation | Processing of data to monitor input/output operations |
US9052837B2 (en) | 2008-02-14 | 2015-06-09 | International Business Machines Corporation | Processing communication data in a ships passing condition |
US7840718B2 (en) * | 2008-02-14 | 2010-11-23 | International Business Machines Corporation | Processing of data to suspend operations in an input/output processing log-out system |
US7941570B2 (en) | 2008-02-14 | 2011-05-10 | International Business Machines Corporation | Bi-directional data transfer within a single I/O operation |
US8095847B2 (en) | 2008-02-14 | 2012-01-10 | International Business Machines Corporation | Exception condition handling at a channel subsystem in an I/O processing system |
US8082481B2 (en) | 2008-02-14 | 2011-12-20 | International Business Machines Corporation | Multiple CRC insertion in an output data stream |
US7904605B2 (en) | 2008-02-14 | 2011-03-08 | International Business Machines Corporation | Computer command and response for determining the state of an I/O operation |
US9170904B1 (en) * | 2008-06-30 | 2015-10-27 | Emc Corporation | I/O fault injection using simulated computing environments |
US7904606B2 (en) | 2008-07-31 | 2011-03-08 | International Business Machines Corporation | Transport control channel program chain linked branching |
US7937504B2 (en) | 2008-07-31 | 2011-05-03 | International Business Machines Corporation | Transport control channel program message pairing |
US8055807B2 (en) * | 2008-07-31 | 2011-11-08 | International Business Machines Corporation | Transport control channel program chain linking including determining sequence order |
US8005082B2 (en) * | 2008-10-03 | 2011-08-23 | International Business Machines Corporation | Concurrent enablement of persistent information unit pacing |
GB2464129A (en) * | 2008-10-06 | 2010-04-07 | Ibm | Persistent information unit pacing protocol for fibre channel communications |
US8332542B2 (en) | 2009-11-12 | 2012-12-11 | International Business Machines Corporation | Communication with input/output system devices |
CN102169439B (zh) * | 2010-02-26 | 2014-05-07 | 英业达股份有限公司 | 数据传输系统 |
US9015362B2 (en) | 2010-07-16 | 2015-04-21 | International Business Machines Corporation | Monitoring network performance and detecting network faults using round trip transmission times |
US8583988B2 (en) | 2011-06-01 | 2013-11-12 | International Business Machines Corporation | Fibre channel input/output data routing system and method |
US8677027B2 (en) | 2011-06-01 | 2014-03-18 | International Business Machines Corporation | Fibre channel input/output data routing system and method |
US8738811B2 (en) | 2011-06-01 | 2014-05-27 | International Business Machines Corporation | Fibre channel input/output data routing system and method |
US8364853B2 (en) | 2011-06-01 | 2013-01-29 | International Business Machines Corporation | Fibre channel input/output data routing system and method |
US9021155B2 (en) | 2011-06-01 | 2015-04-28 | International Business Machines Corporation | Fibre channel input/output data routing including discarding of data transfer requests in response to error detection |
US8364854B2 (en) | 2011-06-01 | 2013-01-29 | International Business Machines Corporation | Fibre channel input/output data routing system and method |
US8312176B1 (en) | 2011-06-30 | 2012-11-13 | International Business Machines Corporation | Facilitating transport mode input/output operations between a channel subsystem and input/output devices |
US8346978B1 (en) | 2011-06-30 | 2013-01-01 | International Business Machines Corporation | Facilitating transport mode input/output operations between a channel subsystem and input/output devices |
US8549185B2 (en) | 2011-06-30 | 2013-10-01 | International Business Machines Corporation | Facilitating transport mode input/output operations between a channel subsystem and input/output devices |
US8473641B2 (en) | 2011-06-30 | 2013-06-25 | International Business Machines Corporation | Facilitating transport mode input/output operations between a channel subsystem and input/output devices |
US8868994B2 (en) | 2011-10-25 | 2014-10-21 | International Business Machines Corporation | High performance virtual Converged Enhanced Ethernet with persistent state flow control |
US8971176B2 (en) | 2012-09-28 | 2015-03-03 | International Business Machines Corporation | Fibre channel over Ethernet switch implicit logout |
US8918542B2 (en) | 2013-03-15 | 2014-12-23 | International Business Machines Corporation | Facilitating transport mode data transfer between a channel subsystem and input/output devices |
US8990439B2 (en) | 2013-05-29 | 2015-03-24 | International Business Machines Corporation | Transport mode data transfer between a channel subsystem and input/output devices |
US10250516B2 (en) * | 2016-11-22 | 2019-04-02 | International Business Machines Corporation | Adjustment of an information unit pacing credit to increase data transmission rate |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5526484A (en) * | 1992-12-10 | 1996-06-11 | International Business Machines Corporation | Method and system for pipelining the processing of channel command words |
US20050114358A1 (en) * | 2003-11-20 | 2005-05-26 | International Business Machines (Ibm) Corporation | Decreased response time for PPRC write operation |
Family Cites Families (14)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4170038A (en) | 1974-11-05 | 1979-10-02 | Compagnie Honeywell Bull | Apparatus for selective control of information between close and remote stations |
US6470391B2 (en) | 1995-09-08 | 2002-10-22 | Hitachi, Ltd. | Method for transmitting data via a network in a form of divided sub-packets |
US6185631B1 (en) * | 1998-10-14 | 2001-02-06 | International Business Machines Corporation | Program for transferring execution of certain channel functions to a control unit and having means for combining certain commands and data packets in one sequence |
US6240446B1 (en) * | 1998-10-14 | 2001-05-29 | International Business Machines Corporation | Multiplexing of multiple data packets for multiple input/output operations between multiple input/output devices and a channel subsystem having multiple channels |
US6330585B1 (en) * | 1998-10-14 | 2001-12-11 | International Business Machines Corporation | Transfer information using optical fiber connections |
US6920537B2 (en) | 1998-12-31 | 2005-07-19 | Emc Corporation | Apparatus and methods for copying, backing up and restoring logical objects in a computer storage system by transferring blocks out of order or in parallel |
AU5774200A (en) * | 1999-06-28 | 2001-01-31 | Sangate Systems Inc. | Intelligent splitter, system, and methods of use |
US6665738B2 (en) * | 2000-09-29 | 2003-12-16 | Emc Corporation | Method for enabling overlapped input/output requests to a logical device from multiple hosts with explicit allegiances |
US7143176B2 (en) | 2001-11-06 | 2006-11-28 | International Business Machines Corporation | Data communication with a protocol that supports a given logical address range |
US7685128B2 (en) | 2004-06-10 | 2010-03-23 | International Business Machines Corporation | Remote access agent for caching in a SAN file system |
US7711924B2 (en) * | 2004-11-15 | 2010-05-04 | International Business Machines Corporation | Managing volumes in volume groups |
US7647469B2 (en) * | 2005-07-22 | 2010-01-12 | International Business Machines Corporation | Method of assigning virtual import/export element addresses |
US20070027989A1 (en) * | 2005-08-01 | 2007-02-01 | Dot Hill Systems Corp. | Management of storage resource devices |
US8032581B2 (en) * | 2006-08-30 | 2011-10-04 | International Business Machines Corporation | Persistent information unit pacing |
-
2006
- 2006-08-30 US US11/468,720 patent/US7500030B2/en not_active Expired - Fee Related
-
2007
- 2007-06-27 CN CN200710127303XA patent/CN101136859B/zh not_active Expired - Fee Related
- 2007-08-10 TW TW096129760A patent/TWI427479B/zh not_active IP Right Cessation
- 2007-08-17 KR KR1020070082866A patent/KR100992018B1/ko not_active IP Right Cessation
-
2008
- 2008-12-04 US US12/328,437 patent/US7587528B2/en not_active Expired - Fee Related
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5526484A (en) * | 1992-12-10 | 1996-06-11 | International Business Machines Corporation | Method and system for pipelining the processing of channel command words |
US20050114358A1 (en) * | 2003-11-20 | 2005-05-26 | International Business Machines (Ibm) Corporation | Decreased response time for PPRC write operation |
Non-Patent Citations (1)
Title |
---|
全文. |
Also Published As
Publication number | Publication date |
---|---|
US20080123681A1 (en) | 2008-05-29 |
CN101136859A (zh) | 2008-03-05 |
US20090083447A1 (en) | 2009-03-26 |
KR20080020486A (ko) | 2008-03-05 |
TW200817912A (en) | 2008-04-16 |
TWI427479B (zh) | 2014-02-21 |
KR100992018B1 (ko) | 2010-11-05 |
US7587528B2 (en) | 2009-09-08 |
US7500030B2 (en) | 2009-03-03 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN101136859B (zh) | 控制光纤信道通信中的信息单元的方法和系统 | |
EP2316075B1 (en) | Method and apparatus for connecting usb devices to a remote computer | |
EP2453364B1 (en) | A method for deterministic SAS discovery and configuration | |
US6098120A (en) | Peripheral sharing system using a bus bridge to emulate peripherals on a first bus to a host on a second bus | |
US7568053B2 (en) | USB composite device, USB communication system, and USB communication method | |
CN1327368C (zh) | 外部连接设备、主设备及数据通信系统 | |
US7496691B2 (en) | Standard ATA queuing automation in serial ATA interface for creating a frame information structure (FIS) corresponding to command from transport layer | |
US5142624A (en) | Virtual network for personal computers | |
CN101663654A (zh) | 用于连接到主机的存储设备的优化的提示模型和用于存储设备的写优化方案 | |
WO2010010686A1 (ja) | 通信システム、通信装置及び通信方法 | |
CN101310250A (zh) | 选择包括首要和次级群集上的端口的路径以用于将位于首要卷的数据传输到次级卷 | |
US7979897B2 (en) | System and article of manufacture for bidirectional data transfer | |
US7143176B2 (en) | Data communication with a protocol that supports a given logical address range | |
EP2743928B1 (en) | Electronic system including a memory module with configurable input/output ports | |
CN102387184A (zh) | 切换装置和可在切换装置中操作的方法 | |
CN102843435A (zh) | 一种在集群系统中存储介质的访问、响应方法和系统 | |
CN100365600C (zh) | 数据存储系统和用于管理数据存储系统中逻辑路径的方法 | |
US7472211B2 (en) | Blade server switch module using out-of-band signaling to detect the physical location of an active drive enclosure device | |
CN104615558B (zh) | 一种数据传送方法及电子装置 | |
CN101878617B (zh) | 光纤信道通信中持续信息单元定步协议的使用 | |
US4977499A (en) | Method and apparatus for commanding operations on a computer network | |
US20090168806A1 (en) | Tuning of industrial automation system performance based on device operating characteristics | |
CN100356307C (zh) | 用存储接口电路连到主机系统的盘驱动器及接口连接方法 | |
CN100518077C (zh) | 在客户计算机系统中远程禁止网络活动的数据处理系统和方法 | |
US20100211735A1 (en) | Storage system, storage control device, reception control device, and control method |
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 | ||
CF01 | Termination of patent right due to non-payment of annual fee | ||
CF01 | Termination of patent right due to non-payment of annual fee |
Granted publication date: 20111123 |