US20090028229A1 - Method and Procedure for Detecting Cable Length in a Storage Subsystem with Wide Ports - Google Patents
Method and Procedure for Detecting Cable Length in a Storage Subsystem with Wide Ports Download PDFInfo
- Publication number
- US20090028229A1 US20090028229A1 US11/828,667 US82866707A US2009028229A1 US 20090028229 A1 US20090028229 A1 US 20090028229A1 US 82866707 A US82866707 A US 82866707A US 2009028229 A1 US2009028229 A1 US 2009028229A1
- Authority
- US
- United States
- Prior art keywords
- transmitter
- parameter
- receiver
- error rate
- computing device
- 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.)
- Granted
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/38—Information transfer, e.g. on bus
- G06F13/40—Bus structure
- G06F13/4063—Device-to-bus coupling
- G06F13/4068—Electrical coupling
Definitions
- the present application relates generally to an improved data processing system and method. More specifically, the present application is directed to a method and procedure for detecting cable length in a storage subsystem with wide ports.
- serially attached SCSI (SAS) switch may be used to interconnect the server blades to external storage, such as a typical storage enclosure.
- the server blades may be directly connected to the SAS switch via an internal high speed fabric.
- the SAS switch is connected to the external storage via external SAS cables.
- the initial release of the first BladeCenter® storage product may require a “short” cable, such as three meters, and a “long” cable, such as eleven meters. Soon thereafter, the storage product may require longer cables, such as twenty meters.
- a wide port consists of multiple lanes or physical transceiver elements (PHYs).
- PHYs physical transceiver elements
- SFPs are designed for a single port. It is quite impractical to provide a wide SFP for optical ports. For example, a four-wide port would require four laser transmitters and four receivers. Using a wide SFP for copper cabling would be more likely, but a significant cost adder would be required. It should be noted that SFPs, whether optical or copper, require an out-of-band interface, something that is heretofore not standardized or implemented.
- a generally accepted bit error rate (BER) for high speed serial interfaces is 1 ⁇ 10 ⁇ 12 (one error occurrence for every 10 12 bits that are transferred).
- Some things that can affect high speed signaling include impedance variation caused by unexpected electrical discontinuities along the transmission path, high speed driver/receiver circuit defects, improper mating contacts caused by bent or damaged connector pins, incomplete connector mating caused by mechanical or installation problems, and signal coupling between adjacent signal paths. Individual components are tested to a performance range, but tolerance buildup can cause attenuation beyond nominal design targets. Often, performance parameters are guaranteed by the manufacturing process controls and not 100% tested. Therefore, there is an exposure to maverick defects.
- the parametric variance from the nominal case may cause a communication failure across the high speed interface.
- Aggravating factors may include customer data pattern, printed circuit variations and parasitics, connector parasitics, cable length or cable discontinuities, and system environment.
- the system may try to retransmit the data or may employ error correction schemes.
- the price for transmission recovery may be realized in lost performance.
- Performance degradation may be measured in bit error rate (BER).
- the illustrative embodiments recognize the disadvantages of the prior art and provide a mechanism and procedure for detecting cable length in a storage subsystem with wide ports.
- the mechanism may use in-situ bidirectional cable wrapping for determining different cable lengths.
- the mechanism under-margins transmitter output to failure for each external port and even for each PHY within a wide port. Based on the transition point from “good” wrap to “bad” wrap, the cable length may be determined. This assumes that there are a fixed number of predetermined cable lengths, such as “long” and “short.” The transition point identifies if the cable is long or short, at which point the optimum tuning parameters can accordingly be set.
- the illustrative embodiments further provide a mechanism to calibrate the high speed transmitter/receiver pair characteristics, and, thus, to optimize the transmission performance between subsystems.
- the mechanism mitigates the need for frequent error correction and does not incur the performance degradation associated with error correction techniques.
- a computer program product comprises a computer useable medium having a computer readable program.
- the computer readable program when executed on a computing device, causes the computing device to set at least one transmitter parameter and at least one receiver parameter in the computing device and recording error rate, adjust the at least one transmitter parameter and the at least one receiver parameter and record the error rate until the at least one transmitter parameter and the at least one receiver parameter are margined from a minimum to a maximum, compare the recorded error rates to error rates for known cable lengths, and determine a cable length based on the comparison.
- the computing device is a switch module connected to an end device by an external cable.
- a transmitter/receiver pair at the end device is configured for diagnostic loopback.
- the computing device comprises a plurality of transmitter/receiver pairs and is a switch module connected to an end device by a wide port cable.
- setting the at least one transmitter parameter and the at least one receiver parameter and recording error rate comprises establishing a command transmitter/receiver pair within the plurality of transmitter/receiver pairs for communication across the wide port cable.
- the end device comprises a plurality of transmitter/receiver pairs.
- the computer readable program when executed on the computing device, further causes the computing device to use the command transmitter/receiver pair to configure a next transmitter/receiver pair within the plurality of transmitter/receiver pairs at the end device for diagnostic loopback.
- adjusting the at least one transmitter parameter and the at least one receiver parameter comprises repeatedly adjusting the at least one transmitter parameter and the at least one receiver parameter for a next transmitter/receiver pair until the at least one transmitter parameter and the at least one receiver parameter for all transmitter/receiver pairs within the plurality of transmitter/receiver pairs are margined from a minimum to a maximum.
- repeatedly adjusting the at least one transmitter parameter and the at least one receiver parameter comprises setting a transmitter parameter to a minimum value, setting a receiver parameter to a nominal value, calculating an error rate, logging the calculated error rate, and repeatedly incrementing the transmitter parameter, calculating the error rate, and logging the calculated error rate until the transmitter parameter reaches a maximum value.
- adjusting the at least one transmitter parameter and the at least one receiver parameter further comprises setting a transmitter parameter to a nominal value, setting a receiver parameter to a minimum value, calculating an error rate, logging the calculated error rate, and repeatedly incrementing the receiver parameter, calculating the error rate, and logging the calculated error rate until the receiver parameter reaches a maximum value.
- the computer readable program when executed on the computing device, further causes the computing device to average error rate for the plurality of transmitter/receiver pairs.
- a computing device comprises at least one transmitter/receiver pair and a processor.
- the processor is configured to set at least one transmitter parameter and at least one receiver parameter in the computing device and recording error rate, adjust the at least one transmitter parameter and the at least one receiver parameter and record the error rate until the at least one transmitter parameter and the at least one receiver parameter are margined from a minimum to a maximum, compare the recorded error rates to error rates for known cable lengths, and determine a cable length based on the comparison.
- the computing device is a switch module connected to an end device by an external cable.
- a transmitter/receiver pair at the end device is configured for diagnostic loopback.
- the at least one transmitter/receiver pair comprises a plurality of transmitter/receiver pairs and is a switch module connected to an end device by a wide port cable.
- setting the at least one transmitter parameter and the at least one receiver parameter and recording error rate comprises establishing a command transmitter/receiver pair within the plurality of transmitter/receiver pairs for communication across the wide port cable.
- the end device comprises a plurality of transmitter/receiver pairs.
- the processor is configured to use the command transmitter/receiver pair to configure a next transmitter/receiver pair within the plurality of transmitter/receiver pairs at the end device for diagnostic loopback.
- adjusting the at least one transmitter parameter and the at least one receiver parameter comprises repeatedly adjusting the at least one transmitter parameter and the at least one receiver parameter for a next transmitter/receiver pair until the at least one transmitter parameter and the at least one receiver parameter for all transmitter/receiver pairs within the plurality of transmitter/receiver pairs are margined from a minimum to a maximum.
- repeatedly adjusting the at least one transmitter parameter and the at least one receiver parameter comprises setting a transmitter parameter to a minimum value, setting a receiver parameter to a nominal value, calculating an error rate, logging the calculated error rate, and repeatedly incrementing the transmitter parameter, calculating the error rate, and logging the calculated error rate until the transmitter parameter reaches a maximum value.
- repeatedly adjusting the at least one transmitter parameter and the at least one receiver parameter further comprises setting a transmitter parameter to a nominal value, setting a receiver parameter to a minimum value, calculating an error rate, logging the calculated error rate, and repeatedly incrementing the receiver parameter, calculating the error rate, and logging the calculated error rate until the receiver parameter reaches a maximum value.
- comparing the recorded error rates to error rates for known cable lengths comprises averaging the recorded error rates for the plurality of transmitter/receiver pairs.
- FIGS. 1A-1C are block diagrams of a narrow port in a storage network in accordance with one illustrative embodiment
- FIGS. 2A-2C are block diagrams of a wide port in a storage network in accordance with one illustrative embodiment
- FIG. 3 is a flowchart illustrating operation of a mechanism for detecting cable length in a storage subsystem with wide ports in accordance with an illustrative embodiment
- FIG. 4 is a block diagram illustrating an example system environment in which aspects of the illustrative embodiments may be implemented
- FIG. 5 is a block diagram illustrating a subsystem interface environment in which aspects of the illustrative embodiments may be implemented
- FIG. 6 is a block diagram that illustrates a high speed point-to-point calibration procedure in accordance with an illustrative embodiment
- FIG. 7 is a flowchart illustrating operation of a point-to-point calibration mechanism in accordance with an illustrative embodiment.
- FIG. 8 is a flowchart illustrating system calibration in accordance with an illustrative embodiment.
- FIGS. 1A-1C are block diagrams of a narrow port in a storage network in accordance with one illustrative embodiment. More particularly with reference to FIG. 1A , switch module 110 has processor 112 and switch application specific integrated circuit (ASIC) 114 . Switch ASIC 114 has physical transceiver element (PHY) 116 . A PHY includes a transmitter and receiver pair. End device 120 has processor 122 and end device ASIC 124 . End device ASIC 124 has PHY 126 . PHY 116 is connected to PHY 126 via an external cable for normal data transfer.
- switch module 110 may be a serial attached SCSI (SAS) switch module and end device 120 may be a SAS end device.
- SAS serial attached SCSI
- PHY 116 in switch ASIC 114 and PHY 126 in end device ASIC 124 are configured for diagnostic internal loopback at each end.
- PHY 116 and PHY 126 have the capability to connect the transmitter to the receiver to form an internal loopback.
- FIG. 1B illustrates how the SAS network is configured during diagnostic verification of the external interface. The SAS devices at each end of the cabled interface perform an internal wrap to test out the narrow port of each respective device.
- PHY 126 in end device ASIC 124 is configured for diagnostic loopback at the end device.
- PHY 126 has the capability to connect the transmitter to the receiver to form an external loopback.
- FIG. 1C illustrates a configuration that provides the basis for the cable length detection mechanism and procedure for a narrow port to be described in further detail below.
- FIGS. 2A-2C are block diagrams of a wide port in a storage network in accordance with one illustrative embodiment. More particularly with reference to FIG. 2A , switch module 210 includes switch ASIC 220 , which has switch processor 222 , data processor 224 , switch 226 , and PHYs 0 -N 212 - 216 . Each PHY includes a transmitter and receiver pair. Data processor 224 comprises at least one of a cyclical redundancy check module, a pattern generator/check module, a data buffer, a packet controller, or a protocol controller.
- End device 230 includes end device ASIC 240 , which has target processor 242 , data processor 244 , switch 246 , and PHYs 0 -N 232 - 236 .
- PHYs 212 - 216 are connected to respective ones of PHYs 232 - 236 via a wide port external cable for normal data transfer.
- switch module 210 may be a serial attached SCSI (SAS) switch module and end device 230 may be a SAS end device.
- SAS serial attached SCSI
- PHYs 212 - 216 in switch ASIC 220 and PHYs 232 - 236 in end device ASIC 240 are configured for diagnostic internal loopback at each end.
- PHYs 212 - 216 and PHYs 232 - 236 have the capability to connect the transmitter to the receiver to form an internal loopback.
- FIG. 2B illustrates how the wide port SAS network is configured during diagnostic verification of the external interface. The SAS devices at each end of the cabled interface perform an internal wrap to test out the narrow port of each respective device.
- PHY 212 in switch ASIC 220 and PHY 232 in end device ASIC 240 are configured for normal data transfer.
- PHY 0 212 is a command PHY.
- PHYs 1 -N 234 - 236 in end device ASIC 240 are configured for diagnostic loopback at the end device.
- FIG. 2C illustrates a configuration that provides the basis for the cable length detection mechanism and procedure for a wide port of the illustrative embodiments to be described in further detail below.
- switch module 110 in FIGS. 1A-1C may include more than one narrow port
- switch module 210 in FIGS. 2A-2C may include more than one wide port.
- Other modifications to the storage area network configurations may be made within the spirit and scope of the present invention.
- the depicted examples are not meant to state or imply any architectural limitations with respect to the present invention.
- a mechanism and procedure are provided for detecting cable length in a storage subsystem with wide ports.
- the mechanism may use in-situ bidirectional cable wrapping for determining different cable lengths.
- high speed differential interfaces generally implement transmitter and receiver circuits, also known as serializer/deserializer (SERDES) circuits, which allow for adjustment of the transmitter amplitude as well as receiver equalization.
- SERDES serializer/deserializer
- a mechanism and procedure for adjusting transmitter amplitude and receiver equalization will be described in further detail below with reference to FIGS. 4-8 . During normal operation, it is desired to optimally tune these parameters to provide for the most robust system electrical performance.
- a diagnostic procedure is defined that under-margins the transmitter output and detunes the receiver input to the point that the interface fails, for each external port and even for each PHY within a wide port.
- the cable length can be determined. This assumes that there are a fixed number of predetermined cable lengths, such as “long” cable and “short” cable.
- the transition point may identify the cable as long or short, at which point the optimum tuning parameters can accordingly be determined and programmed during normal operation.
- FIG. 3 is a flowchart illustrating operation of a mechanism for detecting cable length in a storage subsystem with wide ports in accordance with an illustrative embodiment. It will be understood that each block of the flowchart illustrations, and combinations of blocks in the flowchart illustrations, can be implemented by computer program instructions. These computer program instructions may be provided to a processor or other programmable data processing apparatus to produce a machine, such that the instructions which execute on the processor or other programmable data processing apparatus create means for implementing the functions specified in the flowchart block or blocks.
- These computer program instructions may also be stored in a computer-readable memory or storage medium that can direct a processor or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable memory or storage medium produce an article of manufacture including instruction means which implement the functions specified in the flowchart block or blocks.
- blocks of the flowchart illustrations support combinations of means for performing the specified functions, combinations of steps for performing the specified functions and program instruction means for performing the specified functions. It will also be understood that each block of the flowchart illustrations, and combinations of blocks in the flowchart illustrations, can be implemented by special purpose hardware-based computer systems which perform the specified functions or steps, or by combinations of special purpose hardware and computer instructions.
- operation begins when the cable length connected to a wide port is unknown.
- the mechanism invokes the diagnostic cable wrap routine to configure the PHYs on each end for cable length detection (block 302 ). Then, the mechanism establishes a command PHY for communication across the wide port (block 304 ).
- the mechanism wraps the next PHY in the wide port by configuring the PHY to connect the transmitter to the receiver to form an external loopback (block 306 ).
- the mechanism adjusts transmitter and receive parameters to minimum and records the error rate (block 308 ).
- the mechanism then adjusts transmitter and receiver parameters to a next step and records the error rate (block 310 ).
- the mechanism determines whether all adjustments are completed (block 312 ). If all adjustments are not completed, operation returns to block 310 to adjust transmitter and receiver parameters to a next step and record the error rate.
- the mechanism determines whether the last PHY has been tested (block 314 ). If the last PHY has not been tested, operation returns to block 306 to wrap the next PHY in the wide port.
- the mechanism compares the recorded data for each PHY to determine a table of values (block 316 ). The mechanism averages the data for the wrapped PHYs (block 318 ). The mechanism then determines the cable length based on the average of the wrapped PHYs (block 320 ). Thereafter, operation ends.
- FIG. 3 illustrates how the characterization data reflects the range of data points with respect to optimum performance and failure.
- a table of these characterization values may be used during the wrap testing to identify whether a long cable or short cable, or other predetermined lengths, is attached. In other words, error rates may be recorded for known lengths. The mechanism may then compare the recorded values from blocks 308 and 310 , or the average data from block 318 , to the recorded error rates for known lengths.
- high speed serial interfaces used in high frequency applications may be dynamically margined beyond normal limits to determine optimum performance settings.
- the acquired setting represents a system calibration point for each physical path.
- Each system may store the calibration data for the respective point-to-point nodes of the serial interface connection.
- a high speed differential interface may consist of four wires. Two wires are used differentially to represent a single signal, such as a transmit signal. Similarly, two wires are used differentially to represent a second signal, such as a receive signal. In this fashion, transmit and receive signals are implemented.
- a mechanism is provided to optimize the performance of the data transmission between subsystems across the high speed interface.
- the mechanism may vary the parameters of the stimulus and response mechanisms in such a manner as to stress the communication interface transfer function.
- the mechanism may then determine the design/guard band margin of the specific hardware under test.
- the resulting information may then be used as calibration factors for the specific hardware configuration.
- the mechanism may use pre-emphasis/input compensation to test for margins.
- focus is across a communication interface, point-to-point communication from transmitter to receiver. This may cover blade slots, internal high speed fabric, and external cabling, for example.
- a single calibration factor would be used for the system or for a limited set of cable lengths.
- the mechanism of the illustrative embodiment covers an unlimited number of cable lengths and paths (cables of variable width) as a result of the individual point-to-point calibration.
- the mechanism of the illustrative embodiment may also be applied to internalized high speed fabrics as opposed to cabled interfaces. Instead of a nominal set of parameters, the system can be optimized for every path. Many times, the electrical length of a cable or path may not closely correlate to the physical length due to parasitics across the connection. This calibration mechanism may optimize the system for both physical and electrical differences.
- the calibration may be applied for each point-to-point connection, such as a consistent set of subsystems cabled together.
- the calibration may be applied to a changing set of subsystems, such as system reconfiguration, addition or reduction of cabled subsystems, or subsystem degradation due to time or environment.
- Performance calibration may be initiated by power on reset, notification of a hardware change or reconfiguration, or increased error correction rate above a set limit.
- FIG. 4 is a block diagram illustrating an example system environment in which aspects of the illustrative embodiments may be implemented.
- High speed subsystem 410 is connected to high speed subsystem 430 via subsystem external cabling.
- High speed subsystem 410 includes PHY and link layers 412 , which is connected to a transmitter/receiver pair through serialization/de-serialization (SERDES) circuit 416 .
- High speed subsystem 410 also includes PHY and link layers 414 , which is connected to a transmitter/receiver pair through serialization/de-serialization (SERDES) circuit 418 .
- the transmitter/receiver pairs are connected to the subsystem external cabling through connector 420 .
- High speed subsystem 430 includes PHY and link layers 432 , which is connected to a transmitter/receiver pair through serialization/de-serialization (SERDES) circuit 436 .
- High speed subsystem 430 also includes PHY and link layers 434 , which is connected to a transmitter/receiver pair through serialization/de-serialization (SERDES) circuit 438 .
- the transmitter/receiver pairs in high speed subsystem 430 are connected to the subsystem external cabling through connector 440 .
- the PHY and link layers 412 , 414 and SERDES circuits 416 , 418 in high speed subsystem 410 represent stimulus (transmitter) 452 .
- the PHY and link layers 432 , 434 and SERDES circuits 436 , 438 in high speed subsystem 430 represent response (receiver) 456 .
- the transceiver pairs, connectors 420 , 440 , and subsystem external cabling represent a complex interface transfer function 454 .
- the mechanism varies stimulus and response parameters.
- the range of functionality determines a performance margin for a given set of externally cabled subsystems.
- FIG. 5 is a block diagram illustrating a subsystem interface environment in which aspects of the illustrative embodiments may be implemented.
- Host system 510 includes internal application processors 512 - 516 , which are connected to SAS switch 518 at internal ports.
- Storage subsystems 522 - 526 are connected to SAS switch 518 via high speed SAS cables at external ports.
- the mechanism of the illustrative embodiment may margin each point-to-point connection to find the optimum performance setting. The mechanism may then calibrate data stored for each point-to-point connection.
- FIG. 6 is a block diagram that illustrates a high speed point-to-point calibration procedure in accordance with an illustrative embodiment.
- Subsystem 610 includes PHY and link layers 612 , which are connected to a transmit/receiver pair via SERDES 616 .
- Subsystem 630 includes PHY and link layers 632 , which are connected to a transmit/receiver pair via SERDES 636 .
- the transmit/receiver pair of subsystem 610 is connected to the transmit/receiver pair of subsystem 630 by external cable 650 .
- a node-to-node connection includes the output transmitter, printed circuit board paths, connectors, internal high speed fabric, external cables, and the input receiver.
- the calibration mechanism of the illustrative embodiment sets transmit and receiver parameters to nominal design value.
- the mechanism determines the transmit set point for one end of the point-to-point external connection (Node A).
- the mechanism generates self test patterns at the source switch and monitors expected data at the receive switch at the other end of the external connection (Node B).
- the parameter the mechanism measures is bit error rate (BER).
- BER bit error rate
- a unit of BER is one error per megabit of data received.
- the calibration mechanism then margins the transmit settings within a minimum (min) to maximum (max) range.
- the transmit set point for Node A corresponds to the transmit set point that achieved the highest BER at the receiver, Node B.
- the calibration mechanism determines the receiver set point for the other end of the point-to-point external connection (Node B).
- the mechanism generates self test patterns at the source switch and monitors expected data at the receive switch, Node B of the external connection.
- the calibration mechanism margins the receiver settings from min to max range.
- the receiver set point of Node B corresponds to the receiver set point that achieved the highest BER at the receiver.
- the calibration mechanism then repeats the above calibration sequence for external cable Node C and Node D.
- FIG. 7 is a flowchart illustrating operation of a point-to-point calibration mechanism in accordance with an illustrative embodiment. Operation begins and the calibration mechanism sets self test patterns at the transmit side (block 702 ). The calibration mechanism sets the transmit SAS parameters to minimum (block 704 ) and sets receive SAS parameters to nominal (block 706 ).
- the calibration mechanism calculates bit error rate (BER) (block 708 ). The mechanism then determines whether the transmit parameter is equal to the maximum (block 710 ). If the transmit parameter is not equal to the maximum, then the calibration mechanism increments the transmit SAS parameter (block 712 ), and operation returns to block 708 to calculate the BER for the incremented transmit parameter. As the calibration mechanism margins the transmit SAS parameter from minimum to maximum, the mechanism logs BER for each parameter value, as seen in block 714 .
- BER bit error rate
- the calibration mechanism calculates the transmit calculation value (block 716 ).
- the calibration mechanism sets the receive SAS parameter to minimum (block 718 ) and sets the transmit SAS parameter to nominal (block 720 ).
- the calibration mechanism calculates BER (block 722 ). The mechanism then determines whether the receive parameter is equal to the maximum (block 724 ). If the receive parameter is not equal to the maximum, then the calibration mechanism increments the receive SAS parameter (block 726 ), and operation returns to block 722 to calculate the BER for the incremented receive parameter. As the calibration mechanism margins the receive SAS parameter from minimum to maximum, the mechanism logs BER for each parameter value, as seen in block 728 .
- the calibration mechanism calculates the receive calibration value (block 730 ). Thereafter, operation ends.
- FIG. 8 is a flowchart illustrating system calibration in accordance with an illustrative embodiment. Operation begins responsive to one of a plurality of initiating conditions, including power on reset (block 802 ), system reconfiguration (block 804 ), added or reduced cabled subsystems (block 806 ), or SAS bit error rate interface degrading (block 808 ).
- the calibration mechanism in response to an initiating condition, performs point-to-point calibration for the affected high speed interface (block 810 ). Then, the calibration mechanism updates calibration parameters in the system firmware (block 812 ). Thereafter, system calibration is complete (block 814 ), and operation ends.
- the illustrative embodiments solve the disadvantages of the prior art by providing a mechanism and procedure for detecting cable length in a storage subsystem with wide ports.
- the mechanism may use in-situ bidirectional cable wrapping for determining different cable lengths.
- the mechanism under-margins transmitter output to failure for each external port and even for each PHY within a wide port.
- the cable length may be determined. This assumes that there are a fixed number of predetermined cable lengths, such as “long” and “short.”
- the transition point identifies if the cable is long or short, at which point the optimum tuning parameters can accordingly be set.
- the illustrative embodiments further provide a mechanism to calibrate the high speed transmitter/receiver pair characteristics, and, thus, to optimize the transmission performance between subsystems.
- the mechanism mitigates the need for frequent error correction and does not incur the performance degradation associated with error correction techniques.
- the illustrative embodiments may take the form of an entirely hardware embodiment, an entirely software embodiment or an embodiment containing both hardware and software elements.
- the mechanisms of the illustrative embodiments are implemented in software, which includes but is not limited to firmware, resident software, microcode, etc.
- illustrative embodiments may take the form of a computer program product accessible from a computer-usable or computer-readable medium providing program code for use by or in connection with a computer or any instruction execution system.
- a computer-usable or computer-readable medium can be any apparatus that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device.
- the medium may be an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system (or apparatus or device) or a propagation medium.
- Examples of a computer-readable medium include a semiconductor or solid state memory, magnetic tape, a removable computer diskette, a random access memory (RAM), a read-only memory (ROM), a rigid magnetic disk and an optical disk.
- Current examples of optical disks include compact disk-read-only memory (CD-ROM), compact disk-read/write (CD-R/W) and DVD.
- a data processing system suitable for storing and/or executing program code will include at least one processor coupled directly or indirectly to memory elements through a system bus.
- the memory elements can include local memory employed during actual execution of the program code, bulk storage, and cache memories which provide temporary storage of at least some program code in order to reduce the number of times code must be retrieved from bulk storage during execution.
- I/O devices can be coupled to the system either directly or through intervening I/O controllers.
- Network adapters may also be coupled to the system to enable the data processing system to become coupled to other data processing systems or remote printers or storage devices through intervening private or public networks. Modems, cable modems and Ethernet cards are just a few of the currently available types of network adapters.
Landscapes
- Engineering & Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computer Hardware Design (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Maintenance And Management Of Digital Transmission (AREA)
- Communication Control (AREA)
- Detection And Prevention Of Errors In Transmission (AREA)
Abstract
A mechanism detects cable length in a storage subsystem with wide ports. The mechanism uses in-situ bidirectional cable wrapping for determining different cable lengths. The mechanism under-margins transmitter output to failure for each external port and even for each PHY within a wide port. Based on the transition point from “good” wrap to “bad” wrap, the cable length may be determined. The transition point identifies if the cable is long or short, at which point the optimum tuning parameters can accordingly be set. A calibration mechanism calibrates the high speed transmitter/receiver pair characteristics, and, thus, optimizes the transmission performance between subsystems. The calibration mechanism mitigates the need for frequent error correction and does not incur the performance degradation associated with error correction techniques.
Description
- 1. Technical Field
- The present application relates generally to an improved data processing system and method. More specifically, the present application is directed to a method and procedure for detecting cable length in a storage subsystem with wide ports.
- 2. Description of Related Art
- In storage network systems, high speed serial differential interfaces are used to interconnect multiple storage components. For example, in BladeCenter® products from IBM Corporation, a serially attached SCSI (SAS) switch may be used to interconnect the server blades to external storage, such as a typical storage enclosure. The server blades may be directly connected to the SAS switch via an internal high speed fabric. The SAS switch is connected to the external storage via external SAS cables.
- Generally, multiple cable lengths are required for attaching storage at different distances from the SAS switch. The initial release of the first BladeCenter® storage product may require a “short” cable, such as three meters, and a “long” cable, such as eleven meters. Soon thereafter, the storage product may require longer cables, such as twenty meters.
- As the high speed interfaces increase in data rate speed, it becomes necessary to selectively adjust the transmitter/receiver characteristics, such as pre-emphasis and de-emphasis. With significantly disparate cable lengths, it is difficult to optimize the high speed interface for both short and long cables. Therefore, it becomes necessary to determine the cable length attached to each port of the SAS switch. Furthermore, some scenarios may occur in which a short cable is inadvertently, or possibly deliberately, replaced with a long cable.
- To accommodate the different cable lengths, created either by statically preplanned cabling procedures or by dynamically swapping cables in a customer location, it becomes necessary to dynamically determine cable lengths between a SAS switch and external storage. Several methods have been proposed and implemented in the prior art. For example, some fiber channel cables implement an embedded VPD (vital product data) circuit that includes cable length information. This has only been implemented with cables using small form factor pluggable (SFP) connections. Whether the cables are optical or copper, it remains that the necessary cable length information is implemented with some type of cable VPD, which is only accessible via some sort of out-of-band interface embedded within the high speed cable.
- Furthermore, very recent SAS cabling technology employs the notion of a “wide” port. A wide port consists of multiple lanes or physical transceiver elements (PHYs). Today, SFPs are designed for a single port. It is quite impractical to provide a wide SFP for optical ports. For example, a four-wide port would require four laser transmitters and four receivers. Using a wide SFP for copper cabling would be more likely, but a significant cost adder would be required. It should be noted that SFPs, whether optical or copper, require an out-of-band interface, something that is heretofore not standardized or implemented.
- A generally accepted bit error rate (BER) for high speed serial interfaces is 1×10−12 (one error occurrence for every 1012 bits that are transferred). Some things that can affect high speed signaling include impedance variation caused by unexpected electrical discontinuities along the transmission path, high speed driver/receiver circuit defects, improper mating contacts caused by bent or damaged connector pins, incomplete connector mating caused by mechanical or installation problems, and signal coupling between adjacent signal paths. Individual components are tested to a performance range, but tolerance buildup can cause attenuation beyond nominal design targets. Often, performance parameters are guaranteed by the manufacturing process controls and not 100% tested. Therefore, there is an exposure to maverick defects.
- Ideally, all the above problems are tested and verified by interconnect and subsystem manufacturers. However, often this is not the case, and such defects are introduced into the final system integration process. All the low speed circuitry (<1 GHz) can be adequately tested. The high speed circuitry must be carefully verified. A common technique is to wrap the high speed interfaces using a cable or wrap paths external to the subsystem; however, this does not cover the actual interface connections at the time of system integration.
- As subsystem components are integrated into a system, the parametric variance from the nominal case may cause a communication failure across the high speed interface. Aggravating factors may include customer data pattern, printed circuit variations and parasitics, connector parasitics, cable length or cable discontinuities, and system environment. When a communication failure is detected, the system may try to retransmit the data or may employ error correction schemes. The price for transmission recovery may be realized in lost performance. Performance degradation may be measured in bit error rate (BER).
- The illustrative embodiments recognize the disadvantages of the prior art and provide a mechanism and procedure for detecting cable length in a storage subsystem with wide ports. The mechanism may use in-situ bidirectional cable wrapping for determining different cable lengths. The mechanism under-margins transmitter output to failure for each external port and even for each PHY within a wide port. Based on the transition point from “good” wrap to “bad” wrap, the cable length may be determined. This assumes that there are a fixed number of predetermined cable lengths, such as “long” and “short.” The transition point identifies if the cable is long or short, at which point the optimum tuning parameters can accordingly be set.
- The illustrative embodiments further provide a mechanism to calibrate the high speed transmitter/receiver pair characteristics, and, thus, to optimize the transmission performance between subsystems. The mechanism mitigates the need for frequent error correction and does not incur the performance degradation associated with error correction techniques.
- In one illustrative embodiment, a computer program product comprises a computer useable medium having a computer readable program. The computer readable program, when executed on a computing device, causes the computing device to set at least one transmitter parameter and at least one receiver parameter in the computing device and recording error rate, adjust the at least one transmitter parameter and the at least one receiver parameter and record the error rate until the at least one transmitter parameter and the at least one receiver parameter are margined from a minimum to a maximum, compare the recorded error rates to error rates for known cable lengths, and determine a cable length based on the comparison.
- In one exemplary embodiment, the computing device is a switch module connected to an end device by an external cable. In another exemplary embodiment, a transmitter/receiver pair at the end device is configured for diagnostic loopback.
- In yet another exemplary embodiment, the computing device comprises a plurality of transmitter/receiver pairs and is a switch module connected to an end device by a wide port cable. In a further exemplary embodiment, setting the at least one transmitter parameter and the at least one receiver parameter and recording error rate comprises establishing a command transmitter/receiver pair within the plurality of transmitter/receiver pairs for communication across the wide port cable.
- In a still further exemplary embodiment, the end device comprises a plurality of transmitter/receiver pairs. The computer readable program, when executed on the computing device, further causes the computing device to use the command transmitter/receiver pair to configure a next transmitter/receiver pair within the plurality of transmitter/receiver pairs at the end device for diagnostic loopback.
- In a further exemplary embodiment, adjusting the at least one transmitter parameter and the at least one receiver parameter comprises repeatedly adjusting the at least one transmitter parameter and the at least one receiver parameter for a next transmitter/receiver pair until the at least one transmitter parameter and the at least one receiver parameter for all transmitter/receiver pairs within the plurality of transmitter/receiver pairs are margined from a minimum to a maximum.
- In a still further exemplary embodiment, repeatedly adjusting the at least one transmitter parameter and the at least one receiver parameter comprises setting a transmitter parameter to a minimum value, setting a receiver parameter to a nominal value, calculating an error rate, logging the calculated error rate, and repeatedly incrementing the transmitter parameter, calculating the error rate, and logging the calculated error rate until the transmitter parameter reaches a maximum value.
- In a further exemplary embodiment, adjusting the at least one transmitter parameter and the at least one receiver parameter further comprises setting a transmitter parameter to a nominal value, setting a receiver parameter to a minimum value, calculating an error rate, logging the calculated error rate, and repeatedly incrementing the receiver parameter, calculating the error rate, and logging the calculated error rate until the receiver parameter reaches a maximum value.
- In another exemplary embodiment, the computer readable program, when executed on the computing device, further causes the computing device to average error rate for the plurality of transmitter/receiver pairs.
- In another illustrative embodiment, a computing device comprises at least one transmitter/receiver pair and a processor. The processor is configured to set at least one transmitter parameter and at least one receiver parameter in the computing device and recording error rate, adjust the at least one transmitter parameter and the at least one receiver parameter and record the error rate until the at least one transmitter parameter and the at least one receiver parameter are margined from a minimum to a maximum, compare the recorded error rates to error rates for known cable lengths, and determine a cable length based on the comparison.
- In one exemplary embodiment, the computing device is a switch module connected to an end device by an external cable. In another exemplary embodiment, a transmitter/receiver pair at the end device is configured for diagnostic loopback.
- In yet another exemplary embodiment, the at least one transmitter/receiver pair comprises a plurality of transmitter/receiver pairs and is a switch module connected to an end device by a wide port cable. In a further exemplary embodiment, setting the at least one transmitter parameter and the at least one receiver parameter and recording error rate comprises establishing a command transmitter/receiver pair within the plurality of transmitter/receiver pairs for communication across the wide port cable.
- In a further exemplary embodiment, the end device comprises a plurality of transmitter/receiver pairs. The processor is configured to use the command transmitter/receiver pair to configure a next transmitter/receiver pair within the plurality of transmitter/receiver pairs at the end device for diagnostic loopback.
- In a still further exemplary embodiment, adjusting the at least one transmitter parameter and the at least one receiver parameter comprises repeatedly adjusting the at least one transmitter parameter and the at least one receiver parameter for a next transmitter/receiver pair until the at least one transmitter parameter and the at least one receiver parameter for all transmitter/receiver pairs within the plurality of transmitter/receiver pairs are margined from a minimum to a maximum.
- In a further exemplary embodiment, repeatedly adjusting the at least one transmitter parameter and the at least one receiver parameter comprises setting a transmitter parameter to a minimum value, setting a receiver parameter to a nominal value, calculating an error rate, logging the calculated error rate, and repeatedly incrementing the transmitter parameter, calculating the error rate, and logging the calculated error rate until the transmitter parameter reaches a maximum value.
- In another exemplary embodiment, repeatedly adjusting the at least one transmitter parameter and the at least one receiver parameter further comprises setting a transmitter parameter to a nominal value, setting a receiver parameter to a minimum value, calculating an error rate, logging the calculated error rate, and repeatedly incrementing the receiver parameter, calculating the error rate, and logging the calculated error rate until the receiver parameter reaches a maximum value.
- In yet another exemplary embodiment, comparing the recorded error rates to error rates for known cable lengths comprises averaging the recorded error rates for the plurality of transmitter/receiver pairs.
- These and other features and advantages of the present invention will be described in, or will become apparent to those of ordinary skill in the art in view of, the following detailed description of the exemplary embodiments of the present invention.
- The invention, as well as a preferred mode of use and further objectives and advantages thereof, will best be understood by reference to the following detailed description of illustrative embodiments when read in conjunction with the accompanying drawings, wherein:
-
FIGS. 1A-1C are block diagrams of a narrow port in a storage network in accordance with one illustrative embodiment; -
FIGS. 2A-2C are block diagrams of a wide port in a storage network in accordance with one illustrative embodiment; -
FIG. 3 is a flowchart illustrating operation of a mechanism for detecting cable length in a storage subsystem with wide ports in accordance with an illustrative embodiment; -
FIG. 4 is a block diagram illustrating an example system environment in which aspects of the illustrative embodiments may be implemented; -
FIG. 5 is a block diagram illustrating a subsystem interface environment in which aspects of the illustrative embodiments may be implemented; -
FIG. 6 is a block diagram that illustrates a high speed point-to-point calibration procedure in accordance with an illustrative embodiment; -
FIG. 7 is a flowchart illustrating operation of a point-to-point calibration mechanism in accordance with an illustrative embodiment; and -
FIG. 8 is a flowchart illustrating system calibration in accordance with an illustrative embodiment. - Referring to the figures,
FIGS. 1A-1C are block diagrams of a narrow port in a storage network in accordance with one illustrative embodiment. More particularly with reference toFIG. 1A ,switch module 110 hasprocessor 112 and switch application specific integrated circuit (ASIC) 114.Switch ASIC 114 has physical transceiver element (PHY) 116. A PHY includes a transmitter and receiver pair.End device 120 hasprocessor 122 andend device ASIC 124.End device ASIC 124 hasPHY 126.PHY 116 is connected to PHY 126 via an external cable for normal data transfer. In one exemplary embodiment,switch module 110 may be a serial attached SCSI (SAS) switch module andend device 120 may be a SAS end device. - With reference now to
FIG. 1B ,PHY 116 inswitch ASIC 114 andPHY 126 inend device ASIC 124 are configured for diagnostic internal loopback at each end. In accordance with the illustrative embodiment,PHY 116 andPHY 126 have the capability to connect the transmitter to the receiver to form an internal loopback.FIG. 1B illustrates how the SAS network is configured during diagnostic verification of the external interface. The SAS devices at each end of the cabled interface perform an internal wrap to test out the narrow port of each respective device. - Turning to
FIG. 1C ,PHY 126 inend device ASIC 124 is configured for diagnostic loopback at the end device.PHY 126 has the capability to connect the transmitter to the receiver to form an external loopback.FIG. 1C illustrates a configuration that provides the basis for the cable length detection mechanism and procedure for a narrow port to be described in further detail below. -
FIGS. 2A-2C are block diagrams of a wide port in a storage network in accordance with one illustrative embodiment. More particularly with reference toFIG. 2A ,switch module 210 includesswitch ASIC 220, which hasswitch processor 222,data processor 224,switch 226, and PHYs 0-N 212-216. Each PHY includes a transmitter and receiver pair.Data processor 224 comprises at least one of a cyclical redundancy check module, a pattern generator/check module, a data buffer, a packet controller, or a protocol controller.End device 230 includesend device ASIC 240, which hastarget processor 242,data processor 244,switch 246, and PHYs 0-N 232-236. PHYs 212-216 are connected to respective ones of PHYs 232-236 via a wide port external cable for normal data transfer. In one exemplary embodiment,switch module 210 may be a serial attached SCSI (SAS) switch module andend device 230 may be a SAS end device. - With reference now to
FIG. 2B , PHYs 212-216 inswitch ASIC 220 and PHYs 232-236 inend device ASIC 240 are configured for diagnostic internal loopback at each end. In accordance with the illustrative embodiment, PHYs 212-216 and PHYs 232-236 have the capability to connect the transmitter to the receiver to form an internal loopback.FIG. 2B illustrates how the wide port SAS network is configured during diagnostic verification of the external interface. The SAS devices at each end of the cabled interface perform an internal wrap to test out the narrow port of each respective device. - Turning to
FIG. 2C ,PHY 212 inswitch ASIC 220 andPHY 232 inend device ASIC 240 are configured for normal data transfer. In the depicted example, PHY 0 212 is a command PHY. PHYs 1-N 234-236 inend device ASIC 240 are configured for diagnostic loopback at the end device.FIG. 2C illustrates a configuration that provides the basis for the cable length detection mechanism and procedure for a wide port of the illustrative embodiments to be described in further detail below. - Those of ordinary skill in the art will appreciate that the hardware depicted in
FIGS. 1A-1C andFIGS. 2A-2C may vary. For example,switch module 110 inFIGS. 1A-1C may include more than one narrow port, andswitch module 210 inFIGS. 2A-2C may include more than one wide port. Other modifications to the storage area network configurations may be made within the spirit and scope of the present invention. The depicted examples are not meant to state or imply any architectural limitations with respect to the present invention. - In accordance with an illustrative embodiment, a mechanism and procedure are provided for detecting cable length in a storage subsystem with wide ports. The mechanism may use in-situ bidirectional cable wrapping for determining different cable lengths. Note that high speed differential interfaces generally implement transmitter and receiver circuits, also known as serializer/deserializer (SERDES) circuits, which allow for adjustment of the transmitter amplitude as well as receiver equalization. A mechanism and procedure for adjusting transmitter amplitude and receiver equalization will be described in further detail below with reference to
FIGS. 4-8 . During normal operation, it is desired to optimally tune these parameters to provide for the most robust system electrical performance. - To determine the length of any attached cables, a diagnostic procedure is defined that under-margins the transmitter output and detunes the receiver input to the point that the interface fails, for each external port and even for each PHY within a wide port. Based on the transition point from “successful” wrap to “failed” wrap, the cable length can be determined. This assumes that there are a fixed number of predetermined cable lengths, such as “long” cable and “short” cable. The transition point may identify the cable as long or short, at which point the optimum tuning parameters can accordingly be determined and programmed during normal operation.
-
FIG. 3 is a flowchart illustrating operation of a mechanism for detecting cable length in a storage subsystem with wide ports in accordance with an illustrative embodiment. It will be understood that each block of the flowchart illustrations, and combinations of blocks in the flowchart illustrations, can be implemented by computer program instructions. These computer program instructions may be provided to a processor or other programmable data processing apparatus to produce a machine, such that the instructions which execute on the processor or other programmable data processing apparatus create means for implementing the functions specified in the flowchart block or blocks. These computer program instructions may also be stored in a computer-readable memory or storage medium that can direct a processor or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable memory or storage medium produce an article of manufacture including instruction means which implement the functions specified in the flowchart block or blocks. - Accordingly, blocks of the flowchart illustrations support combinations of means for performing the specified functions, combinations of steps for performing the specified functions and program instruction means for performing the specified functions. It will also be understood that each block of the flowchart illustrations, and combinations of blocks in the flowchart illustrations, can be implemented by special purpose hardware-based computer systems which perform the specified functions or steps, or by combinations of special purpose hardware and computer instructions.
- Furthermore, the flowcharts are provided to demonstrate the operations performed within the illustrative embodiments. The flowcharts are not meant to state or imply limitations with regard to the specific operations or, more particularly, the order of the operations. The operations of the flowcharts may be modified to suit a particular implementation without departing from the spirit and scope of the present invention.
- With reference now to
FIG. 3 , operation begins when the cable length connected to a wide port is unknown. The mechanism invokes the diagnostic cable wrap routine to configure the PHYs on each end for cable length detection (block 302). Then, the mechanism establishes a command PHY for communication across the wide port (block 304). - The mechanism wraps the next PHY in the wide port by configuring the PHY to connect the transmitter to the receiver to form an external loopback (block 306). The mechanism adjusts transmitter and receive parameters to minimum and records the error rate (block 308). The mechanism then adjusts transmitter and receiver parameters to a next step and records the error rate (block 310). The mechanism determines whether all adjustments are completed (block 312). If all adjustments are not completed, operation returns to block 310 to adjust transmitter and receiver parameters to a next step and record the error rate.
- If all adjustments are completed for the PHY in
block 312, the mechanism determines whether the last PHY has been tested (block 314). If the last PHY has not been tested, operation returns to block 306 to wrap the next PHY in the wide port. - If, however, the last PHY has been tested in
block 314, the mechanism compares the recorded data for each PHY to determine a table of values (block 316). The mechanism averages the data for the wrapped PHYs (block 318). The mechanism then determines the cable length based on the average of the wrapped PHYs (block 320). Thereafter, operation ends. - During product testing, multiple cable lengths may be attached, whereby each specific cable length is characterized by collecting a set of data points as the wrap is detuned to failure.
FIG. 3 illustrates how the characterization data reflects the range of data points with respect to optimum performance and failure. A table of these characterization values may be used during the wrap testing to identify whether a long cable or short cable, or other predetermined lengths, is attached. In other words, error rates may be recorded for known lengths. The mechanism may then compare the recorded values fromblocks block 318, to the recorded error rates for known lengths. When characterizing wide ports, there are multiple link wraps that are tested. This provides multiple data points for more granular length determination of the attached cable. Note that the flowchart ofFIG. 3 may operate for a single PHY for a narrow port cable. - In accordance with one illustrative embodiment, high speed serial interfaces used in high frequency applications may be dynamically margined beyond normal limits to determine optimum performance settings. The acquired setting represents a system calibration point for each physical path. Each system may store the calibration data for the respective point-to-point nodes of the serial interface connection.
- A high speed differential interface may consist of four wires. Two wires are used differentially to represent a single signal, such as a transmit signal. Similarly, two wires are used differentially to represent a second signal, such as a receive signal. In this fashion, transmit and receive signals are implemented. In accordance with an illustrative embodiment, a mechanism is provided to optimize the performance of the data transmission between subsystems across the high speed interface.
- The mechanism may vary the parameters of the stimulus and response mechanisms in such a manner as to stress the communication interface transfer function. The mechanism may then determine the design/guard band margin of the specific hardware under test. The resulting information may then be used as calibration factors for the specific hardware configuration.
- For high speed SAS switches, the mechanism may use pre-emphasis/input compensation to test for margins. In this case, focus is across a communication interface, point-to-point communication from transmitter to receiver. This may cover blade slots, internal high speed fabric, and external cabling, for example.
- In the past, a single calibration factor would be used for the system or for a limited set of cable lengths. The mechanism of the illustrative embodiment covers an unlimited number of cable lengths and paths (cables of variable width) as a result of the individual point-to-point calibration. Note that the mechanism of the illustrative embodiment may also be applied to internalized high speed fabrics as opposed to cabled interfaces. Instead of a nominal set of parameters, the system can be optimized for every path. Many times, the electrical length of a cable or path may not closely correlate to the physical length due to parasitics across the connection. This calibration mechanism may optimize the system for both physical and electrical differences.
- The calibration may be applied for each point-to-point connection, such as a consistent set of subsystems cabled together. As another example, the calibration may be applied to a changing set of subsystems, such as system reconfiguration, addition or reduction of cabled subsystems, or subsystem degradation due to time or environment. Performance calibration may be initiated by power on reset, notification of a hardware change or reconfiguration, or increased error correction rate above a set limit.
-
FIG. 4 is a block diagram illustrating an example system environment in which aspects of the illustrative embodiments may be implemented.High speed subsystem 410 is connected tohigh speed subsystem 430 via subsystem external cabling.High speed subsystem 410 includes PHY and linklayers 412, which is connected to a transmitter/receiver pair through serialization/de-serialization (SERDES)circuit 416.High speed subsystem 410 also includes PHY and linklayers 414, which is connected to a transmitter/receiver pair through serialization/de-serialization (SERDES)circuit 418. The transmitter/receiver pairs are connected to the subsystem external cabling throughconnector 420.High speed subsystem 430 includes PHY and linklayers 432, which is connected to a transmitter/receiver pair through serialization/de-serialization (SERDES)circuit 436.High speed subsystem 430 also includes PHY and linklayers 434, which is connected to a transmitter/receiver pair through serialization/de-serialization (SERDES)circuit 438. The transmitter/receiver pairs inhigh speed subsystem 430 are connected to the subsystem external cabling throughconnector 440. - In the example depicted in
FIG. 4 , the PHY and linklayers SERDES circuits high speed subsystem 410 represent stimulus (transmitter) 452. The PHY and linklayers SERDES circuits high speed subsystem 430 represent response (receiver) 456. The transceiver pairs,connectors interface transfer function 454. In accordance with the illustrative embodiment, the mechanism varies stimulus and response parameters. The range of functionality determines a performance margin for a given set of externally cabled subsystems. -
FIG. 5 is a block diagram illustrating a subsystem interface environment in which aspects of the illustrative embodiments may be implemented.Host system 510 includes internal application processors 512-516, which are connected toSAS switch 518 at internal ports. Storage subsystems 522-526 are connected toSAS switch 518 via high speed SAS cables at external ports. The mechanism of the illustrative embodiment may margin each point-to-point connection to find the optimum performance setting. The mechanism may then calibrate data stored for each point-to-point connection. -
FIG. 6 is a block diagram that illustrates a high speed point-to-point calibration procedure in accordance with an illustrative embodiment.Subsystem 610 includes PHY and linklayers 612, which are connected to a transmit/receiver pair viaSERDES 616.Subsystem 630 includes PHY and linklayers 632, which are connected to a transmit/receiver pair viaSERDES 636. The transmit/receiver pair ofsubsystem 610 is connected to the transmit/receiver pair ofsubsystem 630 byexternal cable 650. - A node-to-node connection includes the output transmitter, printed circuit board paths, connectors, internal high speed fabric, external cables, and the input receiver. The calibration mechanism of the illustrative embodiment sets transmit and receiver parameters to nominal design value.
- The mechanism then determines the transmit set point for one end of the point-to-point external connection (Node A). The mechanism generates self test patterns at the source switch and monitors expected data at the receive switch at the other end of the external connection (Node B). The parameter the mechanism measures is bit error rate (BER). In one exemplary embodiment, a unit of BER is one error per megabit of data received. The calibration mechanism then margins the transmit settings within a minimum (min) to maximum (max) range. The transmit set point for Node A corresponds to the transmit set point that achieved the highest BER at the receiver, Node B.
- The calibration mechanism then determines the receiver set point for the other end of the point-to-point external connection (Node B). The mechanism generates self test patterns at the source switch and monitors expected data at the receive switch, Node B of the external connection. The calibration mechanism margins the receiver settings from min to max range. The receiver set point of Node B corresponds to the receiver set point that achieved the highest BER at the receiver.
- The calibration mechanism then repeats the above calibration sequence for external cable Node C and Node D.
-
FIG. 7 is a flowchart illustrating operation of a point-to-point calibration mechanism in accordance with an illustrative embodiment. Operation begins and the calibration mechanism sets self test patterns at the transmit side (block 702). The calibration mechanism sets the transmit SAS parameters to minimum (block 704) and sets receive SAS parameters to nominal (block 706). - The calibration mechanism calculates bit error rate (BER) (block 708). The mechanism then determines whether the transmit parameter is equal to the maximum (block 710). If the transmit parameter is not equal to the maximum, then the calibration mechanism increments the transmit SAS parameter (block 712), and operation returns to block 708 to calculate the BER for the incremented transmit parameter. As the calibration mechanism margins the transmit SAS parameter from minimum to maximum, the mechanism logs BER for each parameter value, as seen in
block 714. - If the transmit parameter is equal to the maximum in
block 710, then the calibration mechanism calculates the transmit calculation value (block 716). Next, the calibration mechanism sets the receive SAS parameter to minimum (block 718) and sets the transmit SAS parameter to nominal (block 720). - The calibration mechanism calculates BER (block 722). The mechanism then determines whether the receive parameter is equal to the maximum (block 724). If the receive parameter is not equal to the maximum, then the calibration mechanism increments the receive SAS parameter (block 726), and operation returns to block 722 to calculate the BER for the incremented receive parameter. As the calibration mechanism margins the receive SAS parameter from minimum to maximum, the mechanism logs BER for each parameter value, as seen in
block 728. - If the receive parameter is equal to the maximum in
block 724, then the calibration mechanism calculates the receive calibration value (block 730). Thereafter, operation ends. -
FIG. 8 is a flowchart illustrating system calibration in accordance with an illustrative embodiment. Operation begins responsive to one of a plurality of initiating conditions, including power on reset (block 802), system reconfiguration (block 804), added or reduced cabled subsystems (block 806), or SAS bit error rate interface degrading (block 808). The calibration mechanism, in response to an initiating condition, performs point-to-point calibration for the affected high speed interface (block 810). Then, the calibration mechanism updates calibration parameters in the system firmware (block 812). Thereafter, system calibration is complete (block 814), and operation ends. - Thus, the illustrative embodiments solve the disadvantages of the prior art by providing a mechanism and procedure for detecting cable length in a storage subsystem with wide ports. The mechanism may use in-situ bidirectional cable wrapping for determining different cable lengths. The mechanism under-margins transmitter output to failure for each external port and even for each PHY within a wide port. Based on the transition point from “good” wrap to “bad” wrap, the cable length may be determined. This assumes that there are a fixed number of predetermined cable lengths, such as “long” and “short.” The transition point identifies if the cable is long or short, at which point the optimum tuning parameters can accordingly be set.
- The illustrative embodiments further provide a mechanism to calibrate the high speed transmitter/receiver pair characteristics, and, thus, to optimize the transmission performance between subsystems. The mechanism mitigates the need for frequent error correction and does not incur the performance degradation associated with error correction techniques.
- It should be appreciated that the illustrative embodiments may take the form of an entirely hardware embodiment, an entirely software embodiment or an embodiment containing both hardware and software elements. In one exemplary embodiment, the mechanisms of the illustrative embodiments are implemented in software, which includes but is not limited to firmware, resident software, microcode, etc.
- Furthermore, the illustrative embodiments may take the form of a computer program product accessible from a computer-usable or computer-readable medium providing program code for use by or in connection with a computer or any instruction execution system. For the purposes of this description, a computer-usable or computer-readable medium can be any apparatus that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device.
- The medium may be an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system (or apparatus or device) or a propagation medium. Examples of a computer-readable medium include a semiconductor or solid state memory, magnetic tape, a removable computer diskette, a random access memory (RAM), a read-only memory (ROM), a rigid magnetic disk and an optical disk. Current examples of optical disks include compact disk-read-only memory (CD-ROM), compact disk-read/write (CD-R/W) and DVD.
- A data processing system suitable for storing and/or executing program code will include at least one processor coupled directly or indirectly to memory elements through a system bus. The memory elements can include local memory employed during actual execution of the program code, bulk storage, and cache memories which provide temporary storage of at least some program code in order to reduce the number of times code must be retrieved from bulk storage during execution.
- Input/output or I/O devices (including but not limited to keyboards, displays, pointing devices, etc.) can be coupled to the system either directly or through intervening I/O controllers. Network adapters may also be coupled to the system to enable the data processing system to become coupled to other data processing systems or remote printers or storage devices through intervening private or public networks. Modems, cable modems and Ethernet cards are just a few of the currently available types of network adapters.
- The description of the present invention has been presented for purposes of illustration and description, and is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art. The embodiment was chosen and described in order to best explain the principles of the invention, the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.
Claims (20)
1. A computer program product comprising a computer useable medium having a computer readable program, wherein the computer readable program, when executed on a computing device, causes the computing device to:
set at least one transmitter parameter and at least one receiver parameter in the computing device and recording error rate;
adjust the at least one transmitter parameter and the at least one receiver parameter and recording the error rate until the at least one transmitter parameter and the at least one receiver parameter are margined from a minimum to a maximum;
compare the recorded error rates to error rates for known cable lengths; and
determine a cable length based on the comparison.
2. The computer program product of claim 1 , wherein the computing device is a switch module connected to an end device by an external cable.
3. The computer program product of claim 1 , wherein a transmitter/receiver pair at the end device is configured for diagnostic loopback.
4. The computer program product of claim 1 , wherein the computing device comprises a plurality of transmitter/receiver pairs and is a switch module connected to an end device by a wide port cable.
5. The computer program product of claim 4 , wherein setting the at least one transmitter parameter and the at least one receiver parameter and recording error rate comprises establishing a command transmitter/receiver pair within the plurality of transmitter/receiver pairs for communication across the wide port cable.
6. The computer program product of claim 5 , wherein the end device comprises a plurality of transmitter/receiver pairs, wherein the computer readable program, when executed on the computing device, further causes the computing device to:
use the command transmitter/receiver pair to configure a next transmitter/receiver pair within the plurality of transmitter/receiver pairs at the end device for diagnostic loopback.
7. The computer program product of claim 6 , wherein adjusting the at least one transmitter parameter and the at least one receiver parameter comprises repeatedly adjusting the at least one transmitter parameter and the at least one receiver parameter for a next transmitter/receiver pair until the at least one transmitter parameter and the at least one receiver parameter for all transmitter/receiver pairs within the plurality of transmitter/receiver pairs are margined from a minimum to a maximum.
8. The computer program product of claim 7 , wherein repeatedly adjusting the at least one transmitter parameter and the at least one receiver parameter comprises:
setting a transmitter parameter to a minimum value;
setting a receiver parameter to a nominal value;
calculating an error rate;
logging the calculated error rate; and
repeatedly incrementing the transmitter parameter, calculating the error rate, and logging the calculated error rate until the transmitter parameter reaches a maximum value.
9. The computer program product of claim 8 , wherein repeatedly adjusting the at least one transmitter parameter and the at least one receiver parameter further comprises:
setting a transmitter parameter to a nominal value;
setting a receiver parameter to a minimum value;
calculating an error rate;
logging the calculated error rate; and
repeatedly incrementing the receiver parameter, calculating the error rate, and logging the calculated error rate until the receiver parameter reaches a maximum value.
10. The computer program product of claim 4 , wherein the computer readable program, when executed on the computing device, further causes the computing device to:
average the recorded error rate for the plurality of transmitter/receiver pairs.
11. A computing device, comprising:
at least one transmitter/receiver pair; and
a processor, wherein the processor is configured to:
set at least one transmitter parameter and at least one receiver parameter in the computing device and recording error rate;
adjust the at least one transmitter parameter and the at least one receiver parameter and record the error rate until the at least one transmitter parameter and the at least one receiver parameter are margined from a minimum to a maximum;
compare the recorded error rates to error rates for known cable lengths; and
determine a cable length based on the comparison.
12. The computing device of claim 11 , wherein the computing device is a switch module connected to an end device by an external cable.
13. The computing device of claim 11 , wherein a transmitter/receiver pair at the end device is configured for diagnostic loopback.
14. The computing device of claim 11 , wherein the at least one transmitter/receiver pair comprises a plurality of transmitter/receiver pairs and is a switch module connected to an end device by a wide port cable.
15. The computing device of claim 14 , wherein setting the at least one transmitter parameter and the at least one receiver parameter and recording error rate comprises establishing a command transmitter/receiver pair within the plurality of transmitter/receiver pairs for communication across the wide port cable.
16. The computing device of claim 15 , wherein the end device comprises a plurality of transmitter/receiver pairs, wherein the processor is configured to use the command transmitter/receiver pair to configure a next transmitter/receiver pair within the plurality of transmitter/receiver pairs at the end device for diagnostic loopback.
17. The computing device of claim 16 , wherein adjusting the at least one transmitter parameter and the at least one receiver parameter comprises repeatedly adjusting the at least one transmitter parameter and the at least one receiver parameter for a next transmitter/receiver pair until the at least one transmitter parameter and the at least one receiver parameter for all transmitter/receiver pairs within the plurality of transmitter/receiver pairs are margined from a minimum to a maximum.
18. The computing device of claim 17 , wherein repeatedly adjusting the at least one transmitter parameter and the at least one receiver parameter comprises:
setting a transmitter parameter to a minimum value;
setting a receiver parameter to a nominal value;
calculating an error rate;
logging the calculated error rate; and
repeatedly incrementing the transmitter parameter, calculating the error rate, and logging the calculated error rate until the transmitter parameter reaches a maximum value.
19. The computing device of claim 18 , wherein repeatedly adjusting the at least one transmitter parameter and the at least one receiver parameter further comprises:
setting a transmitter parameter to a nominal value;
setting a receiver parameter to a minimum value;
calculating an error rate;
logging the calculated error rate; and
repeatedly incrementing the receiver parameter, calculating the error rate, and logging the calculated error rate until the receiver parameter reaches a maximum value.
20. The computing device of claim 14 , wherein comparing the recorded error rates to error rates for known cable lengths comprises:
averaging the recorded error rates for the plurality of transmitter/receiver pairs.
Priority Applications (7)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/828,667 US7903746B2 (en) | 2007-07-26 | 2007-07-26 | Calibrating parameters in a storage subsystem with wide ports |
PCT/EP2008/057713 WO2009013081A1 (en) | 2007-07-26 | 2008-06-18 | Apparatus and method for detecting cable length in a storage subsystem with wide ports |
CN2008800255889A CN101802799B (en) | 2007-07-26 | 2008-06-18 | Apparatus and method for detecting cable length in a storage subsystem with wide ports |
JP2010517337A JP4571711B1 (en) | 2007-07-26 | 2008-06-18 | Apparatus and method for detecting cable length in a storage subsystem having a wide port |
KR1020107001418A KR101039172B1 (en) | 2007-07-26 | 2008-06-18 | Apparatus and Method for Detecting Cable Length in Storage Subsystems with Wide Ports |
EP08761166A EP2183675B1 (en) | 2007-07-26 | 2008-06-18 | Apparatus and method for detecting cable length in a storage subsystem with wide ports |
TW97128030A TW200921403A (en) | 2007-07-26 | 2008-07-23 | Method and procedure for detecting cable length in a storage subsystem with wide ports |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/828,667 US7903746B2 (en) | 2007-07-26 | 2007-07-26 | Calibrating parameters in a storage subsystem with wide ports |
Publications (2)
Publication Number | Publication Date |
---|---|
US20090028229A1 true US20090028229A1 (en) | 2009-01-29 |
US7903746B2 US7903746B2 (en) | 2011-03-08 |
Family
ID=39967529
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/828,667 Expired - Fee Related US7903746B2 (en) | 2007-07-26 | 2007-07-26 | Calibrating parameters in a storage subsystem with wide ports |
Country Status (6)
Country | Link |
---|---|
US (1) | US7903746B2 (en) |
EP (1) | EP2183675B1 (en) |
JP (1) | JP4571711B1 (en) |
KR (1) | KR101039172B1 (en) |
CN (1) | CN101802799B (en) |
WO (1) | WO2009013081A1 (en) |
Cited By (36)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20090259893A1 (en) * | 2007-02-07 | 2009-10-15 | Praveen Gopalapuram | 10GBase-T training algorithm |
US20100165983A1 (en) * | 2008-12-29 | 2010-07-01 | Gunes Aybay | System architecture for a scalable and distributed multi-stage switch fabric |
US20100165984A1 (en) * | 2008-12-29 | 2010-07-01 | Gunes Aybay | Methods and apparatus related to a modular switch architecture |
US20100329249A1 (en) * | 2009-06-30 | 2010-12-30 | Sathish Shenoy | Methods and apparatus for dynamic detection of transit times between stages in distributed multi-stage switch fabrics |
US8184933B1 (en) | 2009-09-22 | 2012-05-22 | Juniper Networks, Inc. | Systems and methods for identifying cable connections in a computing system |
US8369321B2 (en) | 2010-04-01 | 2013-02-05 | Juniper Networks, Inc. | Apparatus and methods related to the packaging and cabling infrastructure of a distributed switch fabric |
US8705500B1 (en) | 2009-11-05 | 2014-04-22 | Juniper Networks, Inc. | Methods and apparatus for upgrading a switch fabric |
US20150016498A1 (en) * | 2013-07-09 | 2015-01-15 | Fujitsu Limited | Control device, control method and control system |
US9160498B2 (en) | 2012-09-19 | 2015-10-13 | Fujitsu Limited | Transmission unit and diagnosis method |
US9225666B1 (en) | 2009-03-31 | 2015-12-29 | Juniper Networks, Inc. | Distributed multi-stage switch fabric |
US20160315701A1 (en) * | 2015-04-24 | 2016-10-27 | Fujitsu Limited | Optical transmission device, method for verifying connection, and wavelength selective switch card |
US9734067B1 (en) | 2013-03-15 | 2017-08-15 | Bitmicro Networks, Inc. | Write buffering |
US9842024B1 (en) | 2013-03-15 | 2017-12-12 | Bitmicro Networks, Inc. | Flash electronic disk with RAID controller |
US9858084B2 (en) | 2013-03-15 | 2018-01-02 | Bitmicro Networks, Inc. | Copying of power-on reset sequencer descriptor from nonvolatile memory to random access memory |
US9875205B1 (en) | 2013-03-15 | 2018-01-23 | Bitmicro Networks, Inc. | Network of memory systems |
US9934160B1 (en) | 2013-03-15 | 2018-04-03 | Bitmicro Llc | Bit-mapped DMA and IOC transfer with dependency table comprising plurality of index fields in the cache for DMA transfer |
US9934045B1 (en) | 2013-03-15 | 2018-04-03 | Bitmicro Networks, Inc. | Embedded system boot from a storage device |
US9952991B1 (en) | 2014-04-17 | 2018-04-24 | Bitmicro Networks, Inc. | Systematic method on queuing of descriptors for multiple flash intelligent DMA engine operation |
US9971524B1 (en) | 2013-03-15 | 2018-05-15 | Bitmicro Networks, Inc. | Scatter-gather approach for parallel data transfer in a mass storage system |
US9977077B1 (en) | 2013-03-14 | 2018-05-22 | Bitmicro Llc | Self-test solution for delay locked loops |
US9996419B1 (en) | 2012-05-18 | 2018-06-12 | Bitmicro Llc | Storage system with distributed ECC capability |
US10013373B1 (en) | 2013-03-15 | 2018-07-03 | Bitmicro Networks, Inc. | Multi-level message passing descriptor |
US10025736B1 (en) | 2014-04-17 | 2018-07-17 | Bitmicro Networks, Inc. | Exchange message protocol message transmission between two devices |
US10042792B1 (en) | 2014-04-17 | 2018-08-07 | Bitmicro Networks, Inc. | Method for transferring and receiving frames across PCI express bus for SSD device |
US10042799B1 (en) | 2013-03-15 | 2018-08-07 | Bitmicro, Llc | Bit-mapped DMA transfer with dependency table configured to monitor status so that a processor is not rendered as a bottleneck in a system |
US10055150B1 (en) | 2014-04-17 | 2018-08-21 | Bitmicro Networks, Inc. | Writing volatile scattered memory metadata to flash device |
US10078604B1 (en) | 2014-04-17 | 2018-09-18 | Bitmicro Networks, Inc. | Interrupt coalescing |
US10082966B1 (en) | 2009-09-14 | 2018-09-25 | Bitmicro Llc | Electronic storage device |
US10120586B1 (en) | 2007-11-16 | 2018-11-06 | Bitmicro, Llc | Memory transaction with reduced latency |
US10133686B2 (en) | 2009-09-07 | 2018-11-20 | Bitmicro Llc | Multilevel memory bus system |
US10149399B1 (en) | 2009-09-04 | 2018-12-04 | Bitmicro Llc | Solid state drive with improved enclosure assembly |
US10180887B1 (en) | 2011-10-05 | 2019-01-15 | Bitmicro Llc | Adaptive power cycle sequences for data recovery |
US10210084B1 (en) | 2013-03-15 | 2019-02-19 | Bitmicro Llc | Multi-leveled cache management in a hybrid storage system |
US10423554B1 (en) | 2013-03-15 | 2019-09-24 | Bitmicro Networks, Inc | Bus arbitration with routing and failover mechanism |
US10489318B1 (en) | 2013-03-15 | 2019-11-26 | Bitmicro Networks, Inc. | Scatter-gather approach for parallel data transfer in a mass storage system |
US10552050B1 (en) | 2017-04-07 | 2020-02-04 | Bitmicro Llc | Multi-dimensional computer storage system |
Families Citing this family (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2012164610A1 (en) | 2011-05-31 | 2012-12-06 | Hitachi, Ltd. | Storage apparatus and method of controlling the same |
CN109542367B (en) * | 2018-10-26 | 2022-10-21 | 森大(深圳)技术有限公司 | Rate matching method and device for printer mainboard optical fiber communication and printing system |
US10832536B2 (en) | 2018-12-07 | 2020-11-10 | International Business Machines Corporation | Guided cable management |
Citations (20)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4771230A (en) * | 1986-10-02 | 1988-09-13 | Testamatic Corporation | Electro-luminescent method and testing system for unpopulated printed circuit boards, ceramic substrates, and the like having both electrical and electro-optical read-out |
US5592077A (en) * | 1995-02-13 | 1997-01-07 | Cirrus Logic, Inc. | Circuits, systems and methods for testing ASIC and RAM memory devices |
US5818378A (en) * | 1997-06-10 | 1998-10-06 | Advanced Micro Devices, Inc. | Cable length estimation circuit using data signal edge rate detection and analog to digital conversion |
US5838726A (en) * | 1995-06-29 | 1998-11-17 | Fujitsu Limited | Method of automatically adjusting the output voltage in a transmission system |
US5953384A (en) * | 1997-06-05 | 1999-09-14 | Motorola, Inc. | Automatic measurement of GPS cable delay time |
US20030161630A1 (en) * | 2001-10-12 | 2003-08-28 | Harish Jayaram | System and method of setting thresholds for optical performance parameters |
US20030165340A1 (en) * | 2001-10-12 | 2003-09-04 | Harish Jayaram | System and method for determining a cause of electrical signal degradation based on optical signal degradation |
US6646454B2 (en) * | 2002-01-07 | 2003-11-11 | Test-Um, Inc. | Electronic apparatus and method for measuring length of a communication cable |
US6727712B2 (en) * | 2001-08-10 | 2004-04-27 | James Sabey | Apparatus and methods for testing circuit boards |
US20050066203A1 (en) * | 2003-08-05 | 2005-03-24 | Kabushiki Kaisha Toshiba | Electronic device with serial ATA interface and signal amplitude adjusting method |
US20050125710A1 (en) * | 2003-05-22 | 2005-06-09 | Sanghvi Ashvinkumar J. | Self-learning method and system for detecting abnormalities |
US20050190690A1 (en) * | 2002-10-29 | 2005-09-01 | Broadcom Corporation | Multi-port, gigabit serdes transceiver capable of automatic fail switchover |
US7068044B1 (en) * | 2002-06-07 | 2006-06-27 | Marvell International Ltd. | Cable tester |
US7075283B1 (en) * | 2002-06-07 | 2006-07-11 | Marvell International Ltd. | Cable tester |
US7135873B2 (en) * | 2003-09-05 | 2006-11-14 | Psibor Date Systems, Inc. | Digital time domain reflectometer system |
US20060265191A1 (en) * | 2002-12-27 | 2006-11-23 | Koninklijke Kpn N.V. | System for measuring the effect of an ADSL splitter |
US7302379B2 (en) * | 2003-12-07 | 2007-11-27 | Adaptive Spectrum And Signal Alignment, Inc. | DSL system estimation and parameter recommendation |
US20080034137A1 (en) * | 2006-07-24 | 2008-02-07 | Colin Whitby-Strevens | Apparatus and methods for de-emphasis training on a point-to-point connection |
US20080192814A1 (en) * | 2007-02-09 | 2008-08-14 | Dft Microsystems, Inc. | System and Method for Physical-Layer Testing of High-Speed Serial Links in their Mission Environments |
US20080205501A1 (en) * | 2005-07-10 | 2008-08-28 | Cioffi John M | Dsl System Estimation |
Family Cites Families (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP3446918B2 (en) | 1995-12-15 | 2003-09-16 | ソニー株式会社 | Cable length detection circuit and cable length detection method |
JP2000183938A (en) | 1998-12-15 | 2000-06-30 | Hitachi Cable Ltd | Switching hub |
CN100520418C (en) * | 2002-12-12 | 2009-07-29 | 理想工业公司 | LAN cable line testing system and patchcord length measurement for a LAN tester |
-
2007
- 2007-07-26 US US11/828,667 patent/US7903746B2/en not_active Expired - Fee Related
-
2008
- 2008-06-18 JP JP2010517337A patent/JP4571711B1/en not_active Expired - Fee Related
- 2008-06-18 CN CN2008800255889A patent/CN101802799B/en not_active Expired - Fee Related
- 2008-06-18 KR KR1020107001418A patent/KR101039172B1/en not_active IP Right Cessation
- 2008-06-18 EP EP08761166A patent/EP2183675B1/en active Active
- 2008-06-18 WO PCT/EP2008/057713 patent/WO2009013081A1/en active Application Filing
Patent Citations (21)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4771230A (en) * | 1986-10-02 | 1988-09-13 | Testamatic Corporation | Electro-luminescent method and testing system for unpopulated printed circuit boards, ceramic substrates, and the like having both electrical and electro-optical read-out |
US5592077A (en) * | 1995-02-13 | 1997-01-07 | Cirrus Logic, Inc. | Circuits, systems and methods for testing ASIC and RAM memory devices |
US5838726A (en) * | 1995-06-29 | 1998-11-17 | Fujitsu Limited | Method of automatically adjusting the output voltage in a transmission system |
US5953384A (en) * | 1997-06-05 | 1999-09-14 | Motorola, Inc. | Automatic measurement of GPS cable delay time |
US5818378A (en) * | 1997-06-10 | 1998-10-06 | Advanced Micro Devices, Inc. | Cable length estimation circuit using data signal edge rate detection and analog to digital conversion |
US6727712B2 (en) * | 2001-08-10 | 2004-04-27 | James Sabey | Apparatus and methods for testing circuit boards |
US20030161630A1 (en) * | 2001-10-12 | 2003-08-28 | Harish Jayaram | System and method of setting thresholds for optical performance parameters |
US20030165340A1 (en) * | 2001-10-12 | 2003-09-04 | Harish Jayaram | System and method for determining a cause of electrical signal degradation based on optical signal degradation |
US6646454B2 (en) * | 2002-01-07 | 2003-11-11 | Test-Um, Inc. | Electronic apparatus and method for measuring length of a communication cable |
US7068044B1 (en) * | 2002-06-07 | 2006-06-27 | Marvell International Ltd. | Cable tester |
US7075283B1 (en) * | 2002-06-07 | 2006-07-11 | Marvell International Ltd. | Cable tester |
US20050190690A1 (en) * | 2002-10-29 | 2005-09-01 | Broadcom Corporation | Multi-port, gigabit serdes transceiver capable of automatic fail switchover |
US20060265191A1 (en) * | 2002-12-27 | 2006-11-23 | Koninklijke Kpn N.V. | System for measuring the effect of an ADSL splitter |
US20050125710A1 (en) * | 2003-05-22 | 2005-06-09 | Sanghvi Ashvinkumar J. | Self-learning method and system for detecting abnormalities |
US20050066203A1 (en) * | 2003-08-05 | 2005-03-24 | Kabushiki Kaisha Toshiba | Electronic device with serial ATA interface and signal amplitude adjusting method |
US7135873B2 (en) * | 2003-09-05 | 2006-11-14 | Psibor Date Systems, Inc. | Digital time domain reflectometer system |
US7302379B2 (en) * | 2003-12-07 | 2007-11-27 | Adaptive Spectrum And Signal Alignment, Inc. | DSL system estimation and parameter recommendation |
US20080071516A1 (en) * | 2003-12-07 | 2008-03-20 | Cioffi John M | Dsl system estimation and parameter recommendation |
US20080205501A1 (en) * | 2005-07-10 | 2008-08-28 | Cioffi John M | Dsl System Estimation |
US20080034137A1 (en) * | 2006-07-24 | 2008-02-07 | Colin Whitby-Strevens | Apparatus and methods for de-emphasis training on a point-to-point connection |
US20080192814A1 (en) * | 2007-02-09 | 2008-08-14 | Dft Microsystems, Inc. | System and Method for Physical-Layer Testing of High-Speed Serial Links in their Mission Environments |
Cited By (42)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20090259893A1 (en) * | 2007-02-07 | 2009-10-15 | Praveen Gopalapuram | 10GBase-T training algorithm |
US10120586B1 (en) | 2007-11-16 | 2018-11-06 | Bitmicro, Llc | Memory transaction with reduced latency |
US8804711B2 (en) | 2008-12-29 | 2014-08-12 | Juniper Networks, Inc. | Methods and apparatus related to a modular switch architecture |
US20100165983A1 (en) * | 2008-12-29 | 2010-07-01 | Gunes Aybay | System architecture for a scalable and distributed multi-stage switch fabric |
US20100165984A1 (en) * | 2008-12-29 | 2010-07-01 | Gunes Aybay | Methods and apparatus related to a modular switch architecture |
US8804710B2 (en) | 2008-12-29 | 2014-08-12 | Juniper Networks, Inc. | System architecture for a scalable and distributed multi-stage switch fabric |
US10063494B1 (en) | 2009-03-31 | 2018-08-28 | Juniper Networks, Inc. | Distributed multi-stage switch fabric |
US9225666B1 (en) | 2009-03-31 | 2015-12-29 | Juniper Networks, Inc. | Distributed multi-stage switch fabric |
US8279863B2 (en) | 2009-06-30 | 2012-10-02 | Juniper Networks, Inc. | Methods and apparatus for dynamic detection of transit times between stages in distributed multi-stage switch fabrics |
US20100329249A1 (en) * | 2009-06-30 | 2010-12-30 | Sathish Shenoy | Methods and apparatus for dynamic detection of transit times between stages in distributed multi-stage switch fabrics |
US10149399B1 (en) | 2009-09-04 | 2018-12-04 | Bitmicro Llc | Solid state drive with improved enclosure assembly |
US10133686B2 (en) | 2009-09-07 | 2018-11-20 | Bitmicro Llc | Multilevel memory bus system |
US10082966B1 (en) | 2009-09-14 | 2018-09-25 | Bitmicro Llc | Electronic storage device |
US8351747B1 (en) | 2009-09-22 | 2013-01-08 | Juniper Networks, Inc. | Systems and methods for identifying cable connections in a computing system |
US8184933B1 (en) | 2009-09-22 | 2012-05-22 | Juniper Networks, Inc. | Systems and methods for identifying cable connections in a computing system |
US8705500B1 (en) | 2009-11-05 | 2014-04-22 | Juniper Networks, Inc. | Methods and apparatus for upgrading a switch fabric |
US8369321B2 (en) | 2010-04-01 | 2013-02-05 | Juniper Networks, Inc. | Apparatus and methods related to the packaging and cabling infrastructure of a distributed switch fabric |
US10180887B1 (en) | 2011-10-05 | 2019-01-15 | Bitmicro Llc | Adaptive power cycle sequences for data recovery |
US9996419B1 (en) | 2012-05-18 | 2018-06-12 | Bitmicro Llc | Storage system with distributed ECC capability |
US9160498B2 (en) | 2012-09-19 | 2015-10-13 | Fujitsu Limited | Transmission unit and diagnosis method |
US9977077B1 (en) | 2013-03-14 | 2018-05-22 | Bitmicro Llc | Self-test solution for delay locked loops |
US9734067B1 (en) | 2013-03-15 | 2017-08-15 | Bitmicro Networks, Inc. | Write buffering |
US10120694B2 (en) | 2013-03-15 | 2018-11-06 | Bitmicro Networks, Inc. | Embedded system boot from a storage device |
US10489318B1 (en) | 2013-03-15 | 2019-11-26 | Bitmicro Networks, Inc. | Scatter-gather approach for parallel data transfer in a mass storage system |
US9934045B1 (en) | 2013-03-15 | 2018-04-03 | Bitmicro Networks, Inc. | Embedded system boot from a storage device |
US10013373B1 (en) | 2013-03-15 | 2018-07-03 | Bitmicro Networks, Inc. | Multi-level message passing descriptor |
US10423554B1 (en) | 2013-03-15 | 2019-09-24 | Bitmicro Networks, Inc | Bus arbitration with routing and failover mechanism |
US10210084B1 (en) | 2013-03-15 | 2019-02-19 | Bitmicro Llc | Multi-leveled cache management in a hybrid storage system |
US10042799B1 (en) | 2013-03-15 | 2018-08-07 | Bitmicro, Llc | Bit-mapped DMA transfer with dependency table configured to monitor status so that a processor is not rendered as a bottleneck in a system |
US9971524B1 (en) | 2013-03-15 | 2018-05-15 | Bitmicro Networks, Inc. | Scatter-gather approach for parallel data transfer in a mass storage system |
US9934160B1 (en) | 2013-03-15 | 2018-04-03 | Bitmicro Llc | Bit-mapped DMA and IOC transfer with dependency table comprising plurality of index fields in the cache for DMA transfer |
US9842024B1 (en) | 2013-03-15 | 2017-12-12 | Bitmicro Networks, Inc. | Flash electronic disk with RAID controller |
US9875205B1 (en) | 2013-03-15 | 2018-01-23 | Bitmicro Networks, Inc. | Network of memory systems |
US9858084B2 (en) | 2013-03-15 | 2018-01-02 | Bitmicro Networks, Inc. | Copying of power-on reset sequencer descriptor from nonvolatile memory to random access memory |
US20150016498A1 (en) * | 2013-07-09 | 2015-01-15 | Fujitsu Limited | Control device, control method and control system |
US10078604B1 (en) | 2014-04-17 | 2018-09-18 | Bitmicro Networks, Inc. | Interrupt coalescing |
US10055150B1 (en) | 2014-04-17 | 2018-08-21 | Bitmicro Networks, Inc. | Writing volatile scattered memory metadata to flash device |
US10042792B1 (en) | 2014-04-17 | 2018-08-07 | Bitmicro Networks, Inc. | Method for transferring and receiving frames across PCI express bus for SSD device |
US10025736B1 (en) | 2014-04-17 | 2018-07-17 | Bitmicro Networks, Inc. | Exchange message protocol message transmission between two devices |
US9952991B1 (en) | 2014-04-17 | 2018-04-24 | Bitmicro Networks, Inc. | Systematic method on queuing of descriptors for multiple flash intelligent DMA engine operation |
US20160315701A1 (en) * | 2015-04-24 | 2016-10-27 | Fujitsu Limited | Optical transmission device, method for verifying connection, and wavelength selective switch card |
US10552050B1 (en) | 2017-04-07 | 2020-02-04 | Bitmicro Llc | Multi-dimensional computer storage system |
Also Published As
Publication number | Publication date |
---|---|
KR101039172B1 (en) | 2011-06-03 |
CN101802799A (en) | 2010-08-11 |
EP2183675B1 (en) | 2012-08-22 |
CN101802799B (en) | 2012-07-11 |
KR20100064357A (en) | 2010-06-14 |
JP2010536194A (en) | 2010-11-25 |
US7903746B2 (en) | 2011-03-08 |
WO2009013081A1 (en) | 2009-01-29 |
JP4571711B1 (en) | 2010-10-27 |
EP2183675A1 (en) | 2010-05-12 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7903746B2 (en) | Calibrating parameters in a storage subsystem with wide ports | |
US7949489B2 (en) | Detecting cable length in a storage subsystem with wide ports | |
US20060259278A1 (en) | Systems and methods for analyzing data of a SAS/SATA device | |
US7895366B2 (en) | Information transmission device and information transmission method | |
US8767768B2 (en) | Data path differentiator for pre-emphasis requirement or slot identification | |
US20100118930A1 (en) | Signal transmission apparatus and method | |
US10002101B2 (en) | Methods and apparatus for equalization of a high speed serial bus | |
US9647852B2 (en) | Selective single-ended transmission for high speed serial links | |
KR100756745B1 (en) | A can communication recovery system using termination register | |
CN112448772A (en) | Method and device for automatically adjusting compensation parameters | |
US8483577B2 (en) | Programmable signal emphasis for optical transmitters | |
EP2538626B1 (en) | Transceiver self-diagnostics for electromagnetic interference (EMI) degradation in balanced channels | |
JP5833132B2 (en) | Method for matching signal transmission between two electronic devices and apparatus having a computer system and peripheral devices | |
US6438159B1 (en) | Method and apparatus for margining error rate of multi-drop data buses | |
US20030101020A1 (en) | Devices connected to fiber channels and margin test method for the devices, and method for specifying problems in system having devices connected to fiber channels | |
US7979756B2 (en) | Apparatus, system and method for a go/no go link integrity tester | |
US7493532B2 (en) | Methods and structure for optimizing SAS domain link quality and performance | |
CN113726425B (en) | Wired communication method, device, equipment and readable storage medium | |
US20090031180A1 (en) | Method for Discovering and Isolating Failure of High Speed Traces in a Manufacturing Environment | |
US7394260B2 (en) | Tuning a test trace configured for capacitive coupling to signal traces | |
CN112350785A (en) | Method and system for checking SERDES communication link performance | |
US20090235130A1 (en) | Test pattern customization of high speed sas networks in a manufacturing test system | |
TW200921403A (en) | Method and procedure for detecting cable length in a storage subsystem with wide ports | |
CN113742143A (en) | Single board abnormity detection method, device, terminal, system and storage medium | |
CN118923086A (en) | Link training scheme for high speed serializer/deserializer |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: INTERNATIONAL BUSINESS MACHINES CORPORATION, NEW Y Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:CAGNO, BRIAN JAMES;LUCAS, GREGG STEVEN;TRUMAN, THOMAS STANLEY;REEL/FRAME:019814/0518 Effective date: 20070718 |
|
REMI | Maintenance fee reminder mailed | ||
LAPS | Lapse for failure to pay maintenance fees | ||
STCH | Information on status: patent discontinuation |
Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362 |
|
FP | Lapsed due to failure to pay maintenance fee |
Effective date: 20150308 |