The subject matter described herein relates to testing network devices. More particularly, the subject matter described herein relates to synchronizing timing among network interface cards in a network equipment test device.
In testing network communications devices, it is desirable to have a consistent clock source among network interfaces so that packet transmit and receipt times can be recorded consistently. For example, one type of test involves a test device sending the packets to a device under test and recording the packet transmission times. The device under test receives the packets, processes the packets, and returns the packets to the test device. The test device receives the packets and records the time of receipt of the packets. If the packet transmit times are generated consistently with the recorded times of receipt, then accurate packet timing statistics can be generated. However, if the packet transmit times are not generated consistently with the recording of the times of receipt, packet timing statistics will be inaccurate.
In order for test device 100 to make accurate measurements of jitter, latency, throughput, or other timing-related parameters, the time recorded by network interface 108 must be consistent with the time recorded by network interface card 104. In some applications, timing consistency on the order of microseconds or even nanoseconds may be required. Although a variety of solutions exist for synchronizing timing among different devices in a network, such solutions are typically not implemented between network interface cards because network interface cards include standard hardware and software and it is desirable to keep the costs of network interface cards low.
Accordingly, there exists a long felt need for methods, systems, and computer readable media for synchronizing timing among network interface cards in a network equipment test device.
Methods, systems, and computer readable media for synchronizing timing among network interface cards in a network equipment test device are disclosed. One method includes generating and sending timing synchronization measurement signals to the management network interface card and a test network interface card in the network equipment test device. The method further includes recording times of receipt of the timing synchronization measurement signals at the management network interface card and the test network interface card. The method further includes adjusting timing of the test network interface card using the times of receipt of the timing synchronization measurement signals.
The subject matter described herein may be implemented in software in combination with hardware and/or firmware. For example, the subject matter described herein may be implemented in software executed by a processor. In one exemplary implementation, the subject matter described herein may be implemented using a non-transitory computer readable medium having stored thereon computer executable instructions that when executed by the processor of a computer control the computer to perform steps. Exemplary computer readable media suitable for implementing the subject matter described herein include non-transitory devices, such as disk memory devices, chip memory devices, programmable logic devices, field-programmable gate arrays, and application specific integrated circuits. In addition, a computer readable medium that implements the subject matter described herein may be located on a single device or computing platform or may be distributed across multiple devices or computing platforms.
As used herein, the term “node” refers to a physical computing platform including one or more processors and memory.
As used herein, the terms “function” or “module” refer to hardware, firmware, or software in combination with hardware and/or firmware for implementing features described herein.
As used herein, the term “message” refers to a packet, a frame, or other units of data, e.g., transferable in a communications network.
The subject matter described herein will now be explained with reference to the accompanying drawings of which:
The subject matter described herein includes methods, systems, and computer readable media for synchronizing timing among network interface cards in a network equipment test device.
Network equipment test device 200 further includes a timing synchronizer 208 for synchronizing timing between management network interface card 206 and test network interface cards 202. In one embodiment, timing synchronizer 208 generates and sends timing synchronization measurement signals to management network interface card 206 and test network interface cards 202. Management network interface card 206 and test network interface cards 202 each record the time of receipt of the timing synchronization measurement signals. The times of receipt can be used to generate a clock frequency adjustment factor and an offset between the timing obtained by management network interface card 206 and test network interface cards 202. An example calculation of the clock frequency adjustment factor and offset will now be provided.
Suppose management network interface card 206 obtains a time of day T1 from and a clock frequency of F1 from an external timing source. To determine the clock frequency adjustment factor, timing synchronizer 208 sends timing synchronization measurement signals at the same time to management network interface card 206 and to test network interface cards 202. Management network interface card 206 records the time of receipt of the timing synchronization measurement signal. Each test network interface card 202 also records its time of receipt of the timing synchronization measurement signal. Timing synchronizer 208 may repeat the process by sending another timing synchronization measurement signal, and management network interface card 206 and test network interface cards 202 may record the times of receipt. If at least two times of receipt are recorded, there is enough information to compute the frequency adjustment factor and the offset. For example, if a given test network interface card 202 records successive times of receipt Ttest1 and Ttest2 and management card 206 records corresponding successive times of receipt Tmgmt1 and Tmgmt2, the frequency adjustment factor can be calculated as follows:
Assuming a linear relationship between the clock obtained by management network interface card 206 and the clocks of test interface cards 202, the following equation can be used to determine any offset between the test network interface card clock and the management card clock.
Clock_Test_Int=Freq_Adj_Factor(Clock_Mgmt_Int)+Offset (2)
In Equation 2, Clock_Test_Int is the measured clock value of the test network interface, Clock_Mgmt_Int is the measured clock value of the management interface, and offset is the offset value between the two clocks. The measured clock values Ttest1, Ttest2, Tmgmt1 and Tmgmt2 referenced above with respect to Equation 1 can also be used to calculate the frequency adjustment factor and offset. For example, if Ttest1=2, Ttest2=4, Tmgmt1=1 and Tmgmt2=2, the frequency adjustment factor can be calculated as follows:
The offset can then be calculated as follows:
Clock_Test_Int=Freq_Adj_Factor(Clock_Mgmt_Int)+Offset
(Ttest1)=(2)(Tmgmt1)+Offset
(2)=(2)(1)+Offset
(2)=2+Offset
Offset=0
Now that the frequency adjustment factor and offset between the test network interface card and the management network interface card are known, the test network interface card can adjust its clock to be equal to the current clock of the management network interface and using a re-arranged version of Equation 2 with the management network interface clock value being the unknown.
Changing the name of the variable Clock_Mgmt_Int in Equation 3 to Desired_Tst_Clk_Val, the equation for the desired clock value on the test network interface card becomes:
Thus, continuing with the example above, if the current value of the test network interface card clock is 3, then the adjusted or desired clock value can be calculated using Equation 4 as follows:
The process of computing the frequency adjustment factor and the offset may be performed for each test network interface card 202 in network equipment test device 200. Once the calculation of these values is performed by each test network interface card 202, each test network interface card 202 may generate and send test packets to device under test 204. Because the clocks of each test network interface card 202 are synchronized with the clock of management network interface 206, transmit and receipt times can be consistently recorded among test network interface cards 202. The consistent recording of packet transmit and receipt times can be used to compute packet timing statistics, such as latency, jitter, throughput, average uplink or downlink bandwidth, etc. The synchronization between the clocks of test network interface cards 202 and management network interface card 206 may be performed on a continual or periodic basis to maintain synchronization between the clocks.
Although the example illustrated in
In step 5, timing synchronizer 208 sends timing synchronization measurement signal #2 to management NIC 206 and test NIC 202. In step 6, management NIC 206 and test NIC 202 record their respective times of receipt of the second timing synchronization measurement signal. In step 7, management NIC 206 and test NIC 202 report their respective times of receipt of the second timing synchronization measurement signal to timing synchronizer 208.
In step 8, timing synchronizer 208 computes the frequency adjustment factor and the offset from the times of receipt reported by management NIC 206 and test NIC 202. The computation may be performed using Equations 1 and 2 above. In step 9, timing synchronizer 208 reports the frequency adjustment factor and the offset to test NIC 202. In step 10, test NIC 202 adjusts its clock based on the frequency adjustment factor and offset. Adjusting the clock may simply include computing desired test clock values using Equation 4 and the local clock of test NIC 202. In step 11, test NIC 202 generates and sends test packets to the device under test, receives test packets from the device under test, and uses the adjusted clock to accurately record timing. In step 12, the test NIC or a separate entity within or external to network equipment test device generates packet timing statistics for the test. As stated above, the timing statistics or measurements may include latency, jitter, throughput, uplink or downlink bandwidth, etc.
As stated above, management NIC 206 may obtain its clock value from an external source.
In order to account for network delay, management NIC 206 sends a delay request message to grand master 500. Grand master 500 returns a delay response. Management NIC computes the roundtrip time for the delay request and the delay response, which in the illustrated example is 4 seconds. Management NIC 206 assumes that the network delay is symmetric and therefore computes that the one way delay is +2. Once the one way network delay is computed, management NIC 206 can compute the delay and offset corrected time. Because the offset is 18 and the network delay is +2, at time 40, the slave computes the delay and offset corrected time to be 60.
In addition to calculating the delay and offset between the master and slave clocks, the management NIC may also determine the frequency adjustment factor between the master and slave clocks. The frequency adjustment factor can be determined by grand master 500 transmitting sync and follow up messages to management NIC 204. In the example illustrated in
In the above-listed equation, the variables Tsync1_master and Tsync2_master are the transmission times of the first and second sync packets recorded in the master's local clock time. The variables Tsync1 slave and Tsync2 slave are the receipt times of the first and second sync packets recorded in the slave's local clock time. Once the frequency adjustment factor, the delay, and the offset are known, the delay, offset, and frequency adjusted time at the slave NIC can be calculated using the equation as follows:
In the above-listed equation, Clock_Slave_Adj is the frequency, offset, and delay adjusted value of the slave clock. Clock_Slave_Unadj is the unadjusted slave clock value for which it is desirable to compute an adjusted slave clock value. Freq_Adj_Factor is the frequency adjustment factor computed above. Offset is the total offset accounting for both network delay and initial phase offset between the master and slave clocks. The value for the frequency adjustment factor is 0.92307, computed as shown in the preceding paragraph. From
Thus, using IEEE 1588, management NIC 206 may obtain a precise time source, which may be distributed among the test NICs using the mechanism described above. However, the subject matter described herein is not limited to using IEEE 1588 to obtain the precise time value at the management NIC. In another example, the management NIC may include its own precise internal clock source or may obtain the precise time from an external source, such as GPS.
Using the synchronization protocols described herein, a plurality of network equipment test devices may be synchronized through a common timing source and may record consistent time when testing one or more devices under test.
Thus, the subject matter described herein improves the technological area of network equipment testing by providing an elegant solution to synchronizing timing between network interface cards in a network equipment test device. Such a solution may be tied to a particular machine or apparatus, such as a network equipment test device. It is understood that a network equipment test device may include a processor for executing the timing synchronizer described above and that each network interface card may include hardware for implementing network protocol stacks. It is also understood that a network equipment test device may include a packet generator executed by its processor to transmit test packets and to and receive test packets from a device under test. The network equipment test device may further include a packet statistics generator that generates packet timing measurements, including any of the measurements described herein.
In step 704, times of receipt of the timing sync signals are recorded. For example, each test NIC 202 and management NIC 206 may record time of receipt of the timing synchronization measurement signals.
In step 706, timing of the test NIC is adjusted using the times of receipt. For example, timing synchronizer 208 may compute the frequency adjustment factor and offset using the mechanism described above. Timing synchronizer 208 may then send these parameters to the test NIC. The test NIC may utilize these parameters to adjust recorded times of receipt of packets, transmits times of packets, and time stamps inserted in packets. Each test NIC 202 may use the synchronized timing to generate consistent packet timing measurements.
As stated above, one packet timing measurement that may be generated by test device 100 is packet latency. Latency is a measure of the amount of time required to process and/or transmit a packet. In one example, test device 200 may measure packet latency by timestamping a packet at a test NIC 202 and transmitting the packet to device under test 204. Device under test 204 may return the packet to test device 200, where the packet is received by another test NIC 202. The packet may include the original timestamp inserted by the transmitting test NIC 202. The receiving test NIC 202 may record the time of receipt using its local clock, which may be synchronized with the clock of the same management NIC 206 as the transmitting test NIC 202, as described above. Returning to
In one example, timing statistics generator 214 may compute the total processing and transmit latency of the packet by subtracting the transmit timestamp value in the packet from the time of receipt. Timing statistics generator 214 may compute packet jitter by calculating latencies for a plurality of packets and then computing jitter as the average difference in latency calculated for the plurality of packets. Timing statistics generator 214 may compute throughput by recording the number of packets transmitted and processed during a time interval multiplied by the size of the packets and divided by the time interval. Timing statistics generator 214 may compute other statistics without departing from the scope of the subject matter described herein.
It will be understood that various details of the subject matter described herein may be changed without departing from the scope of the subject matter described herein. Furthermore, the foregoing description is for the purpose of illustration only, and not for the purpose of limitation, as the subject matter described herein is defined by the claims as set forth hereinafter.
Number | Name | Date | Kind |
---|---|---|---|
6868069 | Knobbe et al. | Mar 2005 | B2 |
7092586 | Vokey et al. | Aug 2006 | B2 |
7881209 | Beliles, Jr. et al. | Feb 2011 | B2 |
8718482 | Roberts | May 2014 | B1 |
8767565 | Dalmau et al. | Jul 2014 | B2 |
9130945 | Smith et al. | Sep 2015 | B2 |
9380070 | Cain et al. | Jun 2016 | B1 |
20030105976 | Copeland, III | Jun 2003 | A1 |
20040190547 | Gordy et al. | Sep 2004 | A1 |
20070268938 | Dowd | Nov 2007 | A1 |
20090231191 | Wu | Sep 2009 | A1 |
20110170534 | York | Jul 2011 | A1 |
20110199133 | Yamada | Aug 2011 | A1 |
20110211473 | Matityahu et al. | Sep 2011 | A1 |
20110268097 | Agrawala et al. | Nov 2011 | A1 |
20120166327 | Amicangioli | Jun 2012 | A1 |
20120275317 | Geva | Nov 2012 | A1 |
20130080817 | Mihelic | Mar 2013 | A1 |
20130094515 | Gura et al. | Apr 2013 | A1 |
20130173778 | Hsy et al. | Jul 2013 | A1 |
20130212439 | Stevens et al. | Aug 2013 | A1 |
20130259049 | Mizrahi | Oct 2013 | A1 |
20130265886 | Leong | Oct 2013 | A1 |
20130278312 | Getzin et al. | Oct 2013 | A1 |
20130329595 | Scholz | Dec 2013 | A1 |
20130343207 | Cook et al. | Dec 2013 | A1 |
20130347103 | Veteikis et al. | Dec 2013 | A1 |
20140006610 | Formby et al. | Jan 2014 | A1 |
20140185632 | Steiner et al. | Jul 2014 | A1 |
20140297852 | Shimizu et al. | Oct 2014 | A1 |
20140317288 | Krueger et al. | Oct 2014 | A1 |
20140321285 | Chew et al. | Oct 2014 | A1 |
20140344930 | Foley | Nov 2014 | A1 |
20150016274 | Holland | Jan 2015 | A1 |
20150023168 | Kotecha et al. | Jan 2015 | A1 |
20150023170 | Kakadia et al. | Jan 2015 | A1 |
20150281025 | Wallbaum et al. | Oct 2015 | A1 |
20160065434 | Janakiraman | Mar 2016 | A1 |
20160110211 | Karnes | Apr 2016 | A1 |
20160285575 | Holmeide | Sep 2016 | A1 |
20160301589 | Rata et al. | Oct 2016 | A1 |
20160301599 | Porfiri et al. | Oct 2016 | A1 |
20160306726 | Regev | Oct 2016 | A1 |
20160315756 | Tenea et al. | Oct 2016 | A1 |
20170041126 | Bergeron | Feb 2017 | A1 |
20170085581 | Jackson | Mar 2017 | A1 |
Number | Date | Country |
---|---|---|
WO 2011144263 | Nov 2011 | WO |
WO 2016168064 | Oct 2016 | WO |
Entry |
---|
Commonly-assigned, co-pending U.S. Appl. No. 14/688,644 for “Methods, Systems, and Computer Readable Media for Emulating Network Devices with Different Clocks,” (Unpublished, filed Apr. 16, 2015). |
Spirent, “Precision Time Protocol (PTP) IEEE 1588,” YouTube “alantalkstech”, https://www.youtube.com/watch?v=yw-gd01aOYg, pp. 1-11 (Dec. 7, 2011). |
Eidson, “IEEE-1588 Standard for a Precision Clock Synchronization Protocol for Networked Measurement and Control Systems—A Tutorial,” Agilent Technologies, pp. 1-94 (Oct. 2005). |
Notification of Transmittal of the International Search Report and the Written Opinion of the International Searching Authority, or the Declaration for International Application No. PCT/US2016/026534 (Jul. 8, 2016). |
Notification of Transmittal of the International Search report and the Written Opinion of the International Searching Authority, or the Declaration for International Application No. PCT/US2016/026533 (Jul. 8, 2016). |
Final Office Action for U.S. Appl. No. 13/933,661, filed Apr. 12, 2016. |
Non-Final Office Action for U.S. Appl. No. 13/933,661, filed Dec. 14, 2015. |
Commonly-assigned, co-pending U.S. Appl. No. 14/860,630 for “Methods, Systems, and Computer Readable Media for Detecting Physical Link Intrusions,” (Unpublished, filed Sep. 21, 2015). |
Commonly-assigned, co-pending U.S. Appl. No. 14/819,337 for “Modeling a Clock,” (Unpublished, filed Aug. 5, 2015). |
“Network Time Protocol,” Wikipedia, https://en.wikipedia.org/wiki/Network—Time—Protocol, pp. 1-7 (Jul. 3, 2015). |
Commonly-assigned, co-pending U.S. Appl. No. 14/685,552 for “Methods, Systems, and Computer Readable Media for One-Way Link Delay Measurement,” (Unpublished, filed Apr. 13, 2015). |
“High Density Modular Fiber Tap,” Ixia, http://www.ixiacom.com/products/net-optics-flex-tap, pp. 1-4 (Jul. 2014). |
“Ixia Anue 3500—Mobile Backhaul Testing Solution,” Ixia Data Sheet, pp. 1-5 (Dec. 2013). |
Arnold, “What Are All of These IEEE 1588 Clock Types,” http://blog.meinbergglobal.com/2013/10/21/ieee1588clocktypes/, News and Tutorials from Meinberg, pp. 1-6 (Oct. 21, 2013). |
“AN-1838 IEEE 1588 Boundary Clock and Transparent Clock Implementation Using the DP83640,” Application Report, Texas Instruments, pp. 1-9 (Apr. 2013). |
Non-Final Office Action for U.S. Appl. No. 14/860,630, filed Dec. 19, 2016. |
Non-Final Office Action for U.S. Appl. No. 14/685,552, filed Oct. 20, 2016. |
Non-Final Office Action for U.S. Appl. No. 13/933,661, filed Sep. 27, 2016. |
Notification of Transmittal of the International Search Report and the Written Opinion of the International Searching Authority, or the Declaration for International Application No. PCT/US2016/040532 (Sep. 12, 2016). |
Commonly-assigned, co-pending International Application No. PCT/US16/40532 for “Methods, Systems, and Computer Readable Media for Detecting Physical Link Intrusions,” (Unpublished, filed Jun. 30, 2016). |
Notice of Allowance and Fee(s) Due for U.S. Appl. No. 13/933,661 (Feb. 17, 2017). |
Non-Final Office Action for U.S. Appl. No. 14/819,337 (Mar. 2, 2017). |
Notice of Allowance and Fee(s) Due for U.S. Appl. No. 14/685,552 (Mar. 1, 2017). |
Number | Date | Country | |
---|---|---|---|
20160309434 A1 | Oct 2016 | US |