Method and apparatus for determining loopback capabilities of a communication device

Abstract
A method and apparatus for determining a communication device's loopback capabilities by querying a device driver of the device. The device's loopback capabilities identify locations (e.g., internal modules, protocol layers) in the device, and/or data rates, at which loopback testing may be performed. Instead of embedding those capabilities in a diagnostic application and modifying the application every time a device changes or is upgraded, the application queries the device driver. The device driver sends the application a data structure or message identifying the capabilities, including identifiers. The application specifies a loopback capability to be exercised by returning a corresponding identifier to the driver.
Description


BACKGROUND

[0001] This invention relates to the field of computer systems. More particularly, an apparatus and method are provided for determining the loopback capability or capabilities of a communication device.


[0002] Many communication devices, such as NICs (Network Interface Cards), are able to perform some type of loopback testing to test the device's transmit and receive components or modules. Loopback testing typically involves the routing of predetermined communications (e.g., test patterns) between transmit and receive components. Such testing can determine whether the components are working correctly, without actually attempting to transmit across a network or other external communication link.


[0003] Diagnostic tools (e.g., applications or utilities) operating on a computer system may interact with a communication device or interface, or a corresponding device driver, in order to initiate loopback testing. However, current diagnostic tools must have some information regarding a device's loopback testing capabilities before they can invoke those capabilities. A device's loopback capabilities may indicate the locations, modules or protocol layers within the device at which loopback testing can be performed.


[0004] In some systems, a diagnostic tool and a communication device's driver may be designed or compiled with identifications of the device's loopback capabilities. In particular, one or more constants may be defined and shared between a tool and a device driver (e.g., in header files used by both programs), to represent individual loopback testing capabilities.


[0005] Unfortunately, such tools comprise static definitions of a device's loopback capabilities. As a result, in order to perform loopback testing on a particular communication device, a diagnostic tool specifically configured for the device must be used.


[0006] If the capabilities of a device change, or the device is replaced with one having different capabilities, the tool must be replaced or recompiled. Thus, every time a communication device or its loopback testing capabilities are upgraded, a diagnostic tool for initiating loopback testing on the device must be altered or replaced as well.



SUMMARY

[0007] In one embodiment of the invention, a method and apparatus are provided for determining a communication device's loopback capabilities by querying a device driver of the device. The device's loopback capabilities identify locations (e.g., internal modules, protocol layers) in the device, and/or data rates, at which loopback testing may be performed. Instead of embedding those capabilities in a diagnostic application and modifying the application every time a device changes or is upgraded, the application queries the device driver. The device driver may send the application a data structure or message identifying the capabilities, including identifiers. The application specifies a loopback capability to be exercised by returning a corresponding identifier to the driver.


[0008] The application may request the size of the data structure before requesting the structure itself. The device driver may maintain the loopback capability data structure in storage, or may generate it dynamically from data in the device information data structure corresponding to the communication device.







DESCRIPTION OF THE FIGURES

[0009]
FIG. 1 is a block diagram depicting a communication device whose loopback capabilities may be queried, in accordance with an embodiment of the present invention.


[0010]
FIG. 2 is a flowchart illustrating one method by which a diagnostic application may determine the loopback capabilities of a communication device, in accordance with an embodiment of the invention.


[0011] FIGS. 3A-B. depict a communication device and device driver for applying a non-intrusive method of loopback testing, in accordance with an embodiment of the present invention.


[0012]
FIG. 4 is a flowchart illustrating one method by which a non-intrusive method of loopback testing may be applied to a communication device, in accordance with an embodiment of the invention.







DETAILED DESCRIPTION

[0013] The following description is presented to enable any person skilled in the art to make and use the invention, and is provided in the context of particular applications of the invention and their requirements. Various modifications to the disclosed embodiments will be readily apparent to those skilled in the art and the general principles defined herein may be applied to other embodiments and applications without departing from the scope of the present invention. Thus, the present invention is not intended to be limited to the embodiments shown, but is to be accorded the widest scope consistent with the principles and features disclosed herein.


[0014] The program environment in which a present embodiment of the invention is executed illustratively incorporates a general-purpose computer or a special purpose device such as a hand-held computer. Details of such devices (e.g., processor, memory, data storage, display) may be omitted for the sake of clarity.


[0015] It should also be understood that the techniques of the present invention may be implemented using a variety of technologies. For example, the methods described herein may be implemented in software executing on a computer system, or implemented in hardware utilizing either a combination of microprocessors or other specially designed application specific integrated circuits, programmable logic devices, or various combinations thereof. In particular, the methods described herein may be implemented by a series of computer-executable instructions residing on a suitable computer-readable medium. Suitable computer-readable media may include volatile (e.g., RAM) and/or non-volatile (e.g., ROM, disk) memory, carrier waves and transmission media (e.g., copper wire, coaxial cable, fiber optic media). Exemplary carrier waves may take the form of electrical, electromagnetic or optical signals conveying digital data streams along a local network, a publicly accessible network such as the Internet or some other communication link.


[0016] In an embodiment of the invention, an apparatus and method are provided to allow a communication device's loopback testing capability to be determined by an application (e.g., a diagnostic tool or utility). The device may comprise a communication interface or adapter, such as a NIC (Network Interface Card), or another device capable of electronically transmitting and receiving electronic signals. In this embodiment, the application queries the device (or an associated device driver) and receives information regarding the device's capabilities.


[0017] In another embodiment of the invention, a system and method of non-intrusive loopback testing are provided. In this embodiment, a communication device or device driver blocks or suspends other communication streams, rather than terminating them, when a loopback test or loopback mode of operation is initiated.


[0018] Determining a Communication Device's Loopback Capabilities


[0019]
FIG. 1 depicts a communication device for which an embodiment of the invention may be implemented. In FIG. 1, adapter 102 is a NIC or other communication interface device configured for network (e.g., Ethernet) communications. In other embodiments of the invention, a communication device may be of virtually any type and may be configured for any communication format or protocol (e.g., USB (Universal Serial Bus), IEEE 1394, InfiniBand).


[0020] Adapter 102 includes Bus Interface Module (BIM) 110, which is coupled to a bus (e.g., PCI, ISA) of a computer system. The bus couples the adapter to a processor configured to execute a device driver (not shown) for operating adapter 102, a diagnostic application for testing the adapter, and other programs. Port 120 allows the adapter to be coupled to a suitable communication link (e.g., copper, fiber) for communicating with another entity (e.g., a switch, a router, another computer system). A loopback plug may be connected to port 120.


[0021] Adapter 102 also includes DMA (Direct Memory Access) modules or components for transmitting (element 112a) and receiving (element 112b) signals. The DMA modules facilitate movement of data between the network adapter and other components of the computer system (e.g., a processor, memory). The adapter also includes transmit and receive MAC (Medium Access Control) modules 114a, 114b and PHY (physical layer) modules 116a, 116b. The various modules of adapter 102 may be located on different chips or ASICs (Application-Specific Integrated Circuit), or multiple modules may be colocated on a chip.


[0022] In the illustrated embodiment of the invention, the DMA modules, MAC modules and PHY modules, and the port, represent different loopback capabilities. In this embodiment, a loopback capability refers to a location or point within adapter 102, or a layer of a protocol stack applied to adapter 102, at which loopback testing may be performed. In other embodiments of the invention, a communication device may have any number of loopback capabilities, and may not directly match the capabilities depicted in FIG. 1. For example, communication devices configured for different communication formats may employ different types of components or modules for routing transmit and receive traffic, some or all of which may have loopback abilities. Virtually any communication device capable of transmitting and receiving electronic signals may be able to implement an embodiment of the invention.


[0023] At each point of loopback capability within adapter 102, transmit traffic can be routed to the receive flow of traffic, as indicated by the dashed lines in FIG. 1. Thus, by exercising different loopback capabilities, different layers or modules of the adapter can be tested for correct operation.


[0024] In addition to the various locations or layers at which loopback testing may be performed, different data rates may also be tested. Thus, each loopback capability of adapter 102 (e.g., DMA, MAC, PHY, external port) may be tested at multiple speeds (e.g., 10 Mbps, 100 Mbps, 1000 Mbps, 10000 Mbps).


[0025] In an embodiment of the invention, a request to identify a communication device's loopback capabilities is received from an application, such as a diagnostic tool. The request is received by a device driver corresponding to the device. The driver responds by transmitting to the application a set of information identifying the device's loopback capabilities. The loopback capability information may be stored in a memory of the computer system, may be maintained in a device information data structure controlled by the device driver, or may be generated or assembled in response to a request.


[0026] Illustratively, a loopback capability data structure may include entries for one or more loopback testing capabilities. An entry for a loopback capability may include a type of capability (e.g., internal, external), a character string (e.g., a label or key) describing the capability (e.g., “MAC loopback at 100 Mbps”), a shorter identifier (e.g., a numeric constant), etc. The descriptive string may be used by the application to identify the loopback testing capability (e.g., to offer choices of different tests to a user, to record which test was run). The shorter identifier may be used by the application to identify to the device driver a loopback capability to be exercised.


[0027] A communication interface protocol may be defined for use by a communication device's driver and an application wanting to exercise one or more of the device's loopback capabilities. For example, the protocol may specify how the application queries the device driver to obtain the device's loopback capabilities, how the driver identifies the capabilities to the application, how the application selects and identifies a loopback capability to be tested, etc. Or, an existing protocol may be applied (e.g., DLPI—Data Link Protocol Interface).


[0028] In one embodiment of the invention, a communication device's driver maintains one or more data structures other than a loopback capability data structure. For example, the driver may maintain a per-stream data structure to represent each stream of traffic passing through the device.


[0029] In this embodiment, each stream's structure includes an identifier of the stream's current status. One of the possible statuses may indicate that the stream is in a loopback mode. When a stream is in loopback mode, its outgoing packets are not actually transmitted over an external communication link. Because of the nature of loopback testing, the device may be limited to having only one stream at a time in a loopback mode. Also, other streams through the device may be blocked or suspended while a stream is in loopback mode, until the loopback testing is completed.


[0030] In one embodiment of the invention, a driver for a communication adapter and a program (e.g., an application, a utility) configured to perform loopback testing on the adapter include the following common structures:
1typedef uint32_t lb_info_sz_t; /* Size of loopback cap. structure */typedef enum {  normal,/* Normal operation, allows exit out of loopback */  internal/* Loopback is internal to the adapter or ASIC */  external,/* Requires a wired loopback connector */} lb_type_t;


[0031] In this embodiment, the adapter's loopback capability structure includes three elements filled in by the adapter's driver. Each loopback capability is defined by a different set of values for the three elements. The loopback capability structure may be configured as follows:
2typedef struct_lb_property_t {  lb_type_t lb_type;/* Loopback type (e.g., int, ext, normal) */  char key[16];/* Description of loopback capability */  uint32_t value;/* Loopback capability identifier */} lb_property_t, *p_lb_property_t;


[0032] In the preceding sample loopback capability structure, the “value” is the loopback capability identifier passed between the driver and the program exercising the adapter's loopback testing. The “key” is intended to provide a human-readable string which can be used by the program to identify (e.g., to a user) which loopback is currently underway.


[0033] The definitions below exemplify the variety of loopback capabilities that can be configured for a communication adapter (each enumeration is a possible “value” for the property structure defined above):
3typedef enum {  lb_normal,  lb_ext1000,  lb_ext100,  lb_ext10,  lb_phy,  lb_serdes,  lb_mac1000,  lb_mac} ce_lb_t;


[0034] The following code may be used to initialize the property structure:
4static lb_property_t lb_normal =  {normal, “normal”, lb_normal};static lb_property_t lb_external1000 =  {external, “external1000”, lb_ext1000};static lb_property_t lb_external100 =  {external, “external100”, lb_ext100};static lb_property_t lb_external10 =  {external, “external10”, lb_ext10};static lb_property_t lb_phy =  {internal, “phy”, lb_phy};static lb_property_t lb_mac1000 =  {internal, “mac1000”, lb_mac1000};static lb_property_t lb_mac =  {internal, “mac10/100”, lb_mac};


[0035]
FIG. 2 is a flowchart demonstrating a method of determining a communication device's loopback capabilities, according to one embodiment of the invention. Prior to, or as an initial part of the method depicted in FIG. 2, the communication device is opened by its device driver, the driver is attached to the device, and one or more protocols are bound to the device.


[0036] In operation 202, a diagnostic application or tool sends to the device's driver a request for the size of the device's loopback capability data structure. Because the entire structure will be sent to the application, the application needs to know how much memory to allocate to accommodate the structure.


[0037] In operation 204, the device driver responds by informing the application of the size of the loopback capability data structure. A loopback capability data structure may be any size, depending on the associated device's loopback capabilities.


[0038] In operation 206, the application sends the device driver a message asking for the device's loopback capabilities. In operation 208, the driver responds by sending the device's loopback capability data structure. The data structure may be assembled in response to the request, or may be retrieved from storage.


[0039] If the device driver returns an error in operation 204 or operation 208, this may indicate that the driver is not configured to inform the application of the device's loopback capability. In this case, the ability to initiate loopback testing may depend upon whether the application includes any other knowledge of the device's capabilities. If it can pass to the driver an identifier of a capability, the procedure may advance to operation 210.


[0040] In operation 210, the application selects one or more loopback capabilities or tests. Illustratively, each selection may identify a particular module in the device, a particular layer of its protocol stack, a speed at which to operate, etc. Thus, one test may request loopback at the MAC layer, at 100 Mbps; another may request loopback at the external port (e.g., using a loopback plug) at 1000 Mbps.


[0041] The application informs the device driver of which loopback test (and speed) to exercise, by sending another message to the device. The message may identify the test by a label, tag, constant or string that was included in the loopback capability data structure passed to the application. Illustratively, the application may iteratively select and exercise multiple (e.g., all) loopback capabilities in sequence.


[0042] In another embodiment, one or more tests may be identified together, in which case the tests may be automatically applied one after the other. For example, the application may specify that all internal or external capabilities are to be tested. The device driver may then sequence among the corresponding capabilities.


[0043] In operation 212, the device driver informs the application that link-up is complete. In particular, the driver notifies the application when it is ready to proceed with the loopback test. As part of the link-up process, the driver may suspend one or more other communication streams in favor of the loopback test, instruct the device to enter loopback mode at a specified module or layer, etc.


[0044] The application may specifically query the device driver as to whether link-up is complete, or may wait for a signal from the driver. As yet another alternative, the application may simply wait a period of time (e.g., two seconds) and then proceed to operation 214. In this alternative, only if the transmitted test data are not received correctly will the application examine the link-up status or assume that it failed.


[0045] The driver may also take other action in response to the commencement of loopback testing (e.g., drop any communications received from an external communication link, update per-device and/or per-stream data structures to reflect the testing).


[0046] In operation 214, the application sends the device driver some data (e.g. a test pattern) for loopback testing. The driver implements its transmission process to send the data at a desired data rate.


[0047] In operation 216, the device loops the data from its transmit path to its receive path at the specified location or layer, and forwards the received data to the driver.


[0048] In operation 218, the received data are compared to the transmitted data (e.g., by the application). Test results may be aggregated for multiple iterations and/or separate loopback tests. During and/or after the testing is complete, the application may report the results to a user or store them.


[0049] In operation 220, if another loopback capability is to be exercised, the illustrated method may return to operation 210 so the application can identify a different capability. As described above, the application (or the device driver) may loop through the different testing capabilities.


[0050] Non-Intrusive Loopback Testing


[0051] In another embodiment of the invention, a non-intrusive method of loopback testing allows non-loopback streams, such as IP (Internet Protocol), IPv6 (Internet Protocol, version six), ARP (Address Resolution Protocol), a snoop utility, upper layer protocols and so on, to be suspended at the driver level (e.g., instead of being terminated during the loopback testing). While in loopback mode, the connection states of the other communication streams are maintained, thereby allowing them to easily resume when no longer suspended.


[0052]
FIG. 3 depicts a system in which one implementation of this embodiment of the invention may be applied. In this implementation, device driver 304 controls or manages operation of communication device 302, which may be a NIC, a channel adapter or other device. Communication device 302 couples a computer system to an external communication link (not shown), to facilitate network traffic and/or other communications. In different embodiments of the invention, a communication device may be configured for virtually any type or format of bi-directional communications (e.g., Ethernet, InfiniBand, IEEE 1394).


[0053] In FIG. 3A, multiple communication streams are active through device driver 304 and communication device 302. Thus, IP stream 310 comprises incoming and outgoing IP traffic, and IPv6 stream 312 comprises IPv6 traffic. ARP stream 314 includes address resolution protocol traffic, and snoop utility 316 allows the computer system to observe some or all communications handled by communication device 302.


[0054] In FIG. 3B, streams 310, 312, 314 and 316 are suspended or blocked at the device driver, because diagnostic application 320 has initiated a loopback mode of operation for communication device 302. As described in a previous section, a communication device may have multiple loopback capabilities. Therefore, diagnostic application 320 may be exercising one or more of the loopback capabilities of communication device 302.


[0055] In this embodiment, while a communication stream is suspended and the communication device is in loopback mode, any outgoing communications for that stream received at device driver 304 or communication device 302 are dropped. Similarly, any incoming communications for the stream received at communication device 302 from an external communication link are rejected or dropped.


[0056]
FIG. 4 demonstrates a method of applying non-intrusive loopback testing to a communication device, according to one embodiment of the invention. In this embodiment, communication streams are merely suspended, rather than terminated, while the device is operated in a loopback mode.


[0057] In operation 402, a device driver or communication device receives a request to initiate a loopback mode of operation. The request may be received from a diagnostic utility or application. As described above, the application may learn of the device's loopback capabilities by querying the device or device driver. Alternatively, the application may already possess knowledge of such capabilities. Thus, the application may specify a particular type of loopback mode (e.g., at a specific data rate, at a particular location in the communication device, at a specified layer of the communication protocol stack), or may instruct the driver to engage in a series of loopback operations or tests.


[0058] In operation 404, the device driver (or the application) accesses a list of communication streams; each active communication stream is represented by an entry in the list. Illustratively, the list may be maintained by the communication device's driver, as part of the communication device's information data structure.


[0059] In operation 406, the device driver or the application suspends each stream by updating its entry in the list to indicate a suspended status. This may entail setting (or clearing) a flag or field in the entry. Though suspended, each stream can be easily resumed. While a communication stream is suspended, its corresponding application (e.g., operating in the application layer of the protocol stack) may continue to execute.


[0060] In operation 408, an entry representing the requested loopback mode is added to the list of communication streams. This entry is not placed in a suspended status.


[0061] In operation 410, the communication device is operated in the desired loopback mode. For example, the driver may instruct the device to activate a loopback capability. While operating in loopback mode, a communication (e.g., a test packet) submitted to the device's transmit flow is conveyed to the device's receive flow at the desired location or layer of the device, instead of being transmitted on an external link. When the communication loops back (e.g., to the driver or application), it is compared to what was sent.


[0062] In operation 412, while the device is operated in loopback mode, non-loopback communications received at the device and/or device driver are dropped.


[0063] In operation 414, the loopback operation or testing is completed. Therefore, the device is reconfigured for normal operation and the entry in the communication stream list corresponding to the loopback operation may be deleted.


[0064] In operation 416, the suspended communication streams are resumed or reactivated, by updating their statuses appropriately in the list of communication streams. Because of the short duration of loopback testing, a stream may be able to quickly correct for any packets or other communications that were dropped or lost during the time the stream was suspended.


[0065] The foregoing embodiments of the invention have been presented for purposes of illustration and description only. They are not intended to be exhaustive or to limit the invention to the forms disclosed. Accordingly, the scope of the invention is defined by the appended claims, not the preceding disclosure.


Claims
  • 1. A method of performing loopback testing in a communication device, the method comprising: executing a device driver for a communication device of a computer system; receiving, from an application executing on the computer system, a request to identify loopback capabilities of the communication device; sending to the application a data structure identifying one or more loopback capabilities of the communication device; receiving from the application an identifier of a first loopback capability of the communication device; and testing the first loopback capability.
  • 2. The method of claim 1, further comprising: receiving from the application a request for the size of said data structure.
  • 3. The method of claim 2, further comprising: sending to the application the size of said data structure.
  • 4. The method of claim 1, wherein said request to identify loopback capabilities of the communication device comprises a request for said data structure.
  • 5. The method of claim 1, wherein said data structure comprises: a description of the first loopback capability; and the identifier of the first loopback capability.
  • 6. The method of claim 1, wherein said data structure comprises: an entry for each loopback capability of the communication device, includes the first loopback capability; and each said loopback capability identifies a loopback test the communication device is configured to perform.
  • 7. The method of claim 6, wherein each said loopback capability identifies a location in the transmission process of the communication device at which transmit traffic may be directly routed to the reception process of the communication device.
  • 8. The method of claim 1, wherein the application contains no information identifying loopback capabilities of the communication device prior to said sending.
  • 9. The method of claim 1, wherein the application is usable to test loopback capabilities of multiple different communication devices without being modified.
  • 10. A computer readable storage medium storing instructions that, when executed by a computer, cause the computer to perform a method of performing loopback testing in a communication device, the method comprising: executing a device driver for a communication device of a computer system; receiving, from an application executing on the computer system, a request to identify loopback capabilities of the communication device; sending to the application a data structure identifying one or more loopback capabilities of the communication device; receiving from the application an identifier of a first loopback capability of the communication device; and testing the first loopback capability.
  • 11. A method of determining the loopback capabilities of a communication device within a computer system, the method comprising: opening the communication device; attaching the communication device; binding the communication device; receiving, from an application executing on the computer system, a request for the size of a loopback capability structure of the communication device, wherein said loopback capability structure is configured to identify one or more loopback capabilities of the communication device; identifying the size of said loopback capability structure to the application; receiving from the application a request for said loopback capability structure; sending said loopback capability structure to the application; receiving from the application an identification of a first loopback capability; setting the communication device to a loopback mode; and exercising the first loopback capability.
  • 12. The method of claim 11, wherein said first loopback capability indicates one or more of a level of loopback and a data rate.
  • 13. The method of claim 11, further comprising: assembling said loopback capability structure from a device information data structure maintained by a device driver corresponding to the communication device.
  • 14. A computer readable storage medium storing instructions that, when executed by a computer, cause the computer to perform a method of determining the loopback capabilities of a communication device within a computer system, the method comprising: opening the communication device; attaching the communication device; binding the communication device; receiving, from an application executing on the computer system, a request for the size of a loopback capability structure of the communication device, wherein said loopback capability structure is configured to identify one or more loopback capabilities of the communication device; identifying the size of said loopback capability structure to the application; receiving from the application a request for said loopback capability structure; sending said loopback capability structure to the application; receiving from the application an identification of a first loopback capability; setting the communication device to a loopback mode; and exercising the first loopback capability.
  • 15. A computer readable storage medium containing a data structure configured identify one or more loopback capabilities of a communication device, the data structure comprising, for each said loopback capability: a type; a description; and an identifier.
  • 16. The computer readable storage medium of claim 15, wherein said data structure is transmitted from a device driver for the communication device to an application for performing loopback testing on the communication device.
  • 17. The computer readable storage medium of claim 15, wherein said type is one of: normal, internal and external.
  • 18. The computer readable storage medium of claim 15, wherein said identifier is received by a device driver of the communication device, from an application, to identify said loopback capability to be exercised.
  • 19. An apparatus for performing loopback testing of a communication device, comprising: a communication device configured to enable a computer system to transmit and receive electronic communications; a device driver configured to control operation of the communication device; and an application configured to initiate diagnostic testing of one or more components of the computer system, including said loopback testing on the communication device; wherein the application is configured to request the device driver to send the application a data structure identifying one or more loopback capabilities of the communication device.
  • 20. The apparatus of claim 19, wherein the application is further configured to request the size of said data structure prior to requesting the device driver to send said data structure.
  • 21. The apparatus of claim 19, wherein the application has no knowledge of loopback capabilities of the communication device prior to receiving said data structure.
  • 22. The apparatus of claim 19, wherein the application is configured to initiate loopback testing on multiple different communication devices, including the communication device, without modification.