The present invention relates to communication networks. More specifically, it relates to a method for reducing interference from initializing network devices in a data-over-cable system.
With the explosive growth of the Internet, many customers have desired to use the larger bandwidth of a cable television network to connect to the Internet and other computer networks. Cable modems, such as those provided by 3Com Corporation of Santa Clara, Calif., and others offer customers higher-speed connectivity to the Internet, an intranet, local area networks (“LANs”) and other computer networks via cable television networks. These cable modems currently support a data connection to the Internet and other computer networks via a cable television network with a data rate of up to 30+ Mbps which is a much larger data rate than can be supported by a modem used over a standard telephone line.
The physical plant of the data-over-cable system may be divided into physically isolated branches that distribute digital signals from a cable modem termination system (“CMTS”) to geographically distinct groups of cable modems. Typically, each branch carries the same downstream signal that serves all the cable modems, regardless of which branch they are on. By contrast, in the reverse or upstream direction, the cable modems on any given branch transmit to the CMTS with a set of common transmission parameters, which may differ from the upstream transmission parameters for another branch. Thus the transmissions to the CMTS on each branch are independent of the transmissions on the other branches. Typically, the transmissions on different branches do not interfere with each other because the branches are physically isolated from each other.
When a cable modem is connected to a data-over-cable system, it must first gain access to the system by undergoing an initialization procedure before it is permitted to transmit data. A part of the initialization procedure includes a ranging process to determine the appropriate transmission parameters for its data transfer. This process involves sending a ranging message at an appropriate time interval, referred to as the Initial Maintenance interval.
In data-over-cable systems with more than one branch, the Initial Maintenance intervals for ranging on each branch are typically independent of each other. Unfortunately, this independence may cause ranging messages from one branch to interfere with upstream data transmissions on another branch. This interference occurs because an initializing cable modem may not have sufficient information to identify to which branch it belongs. In the most typical arrangement of cable modem transmission parameters, the cable modems on each branch transmit upstream at a common transmission frequency. The common upstream transmission frequency usually does not present a problem since the branches are physically isolated. When a cable modem initializes, however, it examines the downstream transmissions and determines when an Initial Maintenance interval is scheduled to occur. The problem is that the cable modem may accept the Initial Maintenance interval for another branch and thus send out ranging messages at the wrong time for its branch.
These mistimed ranging messages generally interfere with legitimate upstream data transmissions from the other cable modems on the branch. One solution to this problem is to arrange that the upstream transmission frequency for each branch is different. The CMTS is tuned to receive signals from each branch at the frequency appropriate for that branch. Then incorrect ranging signals are at a different frequency from the legitimate data transmissions, do not interfere with the data transmissions, and are rejected by the CMTS. In practice, however, the limited bandwidth for upstream radio frequency propagation does not permit sufficient number of branches to be tuned to different frequencies.
It is, therefore, desirable to reduce interference between ranging messages from initializing network devices on branches of a data-over-cable system and upstream data transmissions.
One aspect of the invention is a method for reducing interference from initializing network devices. The method includes aligning multiple maintenance intervals. Each of the maintenance intervals is associated with an upstream channel. The initializing network devices are instructed to range during the aligned maintenance intervals.
Another aspect of the invention is a method for aligning the multiple maintenance intervals. The method includes determining a measure of common maintenance start time for the multiple maintenance intervals. A CMTS decides whether the measure of common maintenance start time falls within multiple usage intervals. Each of the multiple usage intervals is associated with an upstream channel. When the measure of common maintenance start time falls within the multiple usage intervals, the CMTS schedules the maintenance intervals to start at the measure of common maintenance start time.
Another aspect of the invention is also a method for aligning the multiple maintenance intervals. The method includes determining a measure of common maintenance start time for the multiple maintenance intervals. The CMTS identifies a longest maintenance interval from the multiple maintenance intervals and calculates a number of maintenance intervals that can occur during the longest maintenance interval for each upstream channel. The CMTS decides whether the measure of common maintenance start time falls within multiple usage intervals. Each of the multiple usage intervals is associated with an upstream channel. When the measure of common maintenance start time falls within the multiple usage intervals, for each upstream channel of the plurality of upstream channels, the CMTS schedules the number of maintenance intervals to start at the measure of common maintenance start time.
The foregoing and other features and advantages of preferred embodiments of the present invention will be more readily apparent from the following detailed description, which proceeds with references to the accompanying drawings in which:
The Internet, a world wide network of interconnected computers, provides multi-media content including audio, video, graphics, and text that customers may best experience over data connections to the Internet that have large bandwidths. But most Internet Service Providers (“ISPs”) typically allow customers to connect to the Internet via an analog serial telephone line from a public switched telephone network at data rates including 14,400 bps, 28,800 bps, 33,600 bps, 56,000 bps, and others, which many customers find to be too slow. Therefore, customers are increasingly turning to other ways of connecting to the Internet that may provide data rates well in excess of those provided by analog telephone lines.
One type of high bandwidth data connection is available from a cable television network. The cable television network can provide data services having data rates from about 10 Mega-bits-per-second (“Mbps”) to 30+ Mbps per channel. Apart from having the advantage of already being installed in most metropolitan areas, the cable television network also serves a large number of subscribers over a large geographical area through a network of coaxial cables or Hybrid Fiber/Coaxial (“HFC”) cables. Cable television networks include those provided by Comcast Cable Communications, Inc., of Philadelphia, Pa., Cox Communications of Atlanta, Ga., AT&T Corporation of New York, N.Y., Time-Warner Cable, of Marietta, Ga., Continental Cablevision, Inc., of Boston, Mass., among others. Data-over-cable systems, also known to those skilled in the art as cable modem systems, typically use the cable television network already in existence in the geographical area.
Background information related to cable modem systems in general is described in the Data-Over-Cable Service Interface Specifications (“DOCSIS”)—Radio Frequency Interface Specifications, Interim Draft, dated Nov. 5, 1999, issued by Cable Television Laboratories, Inc. This document, known to persons working in the art, is incorporated by reference herein.
The head-end 18 includes a cable modem termination system (“CMTS”) 30. The CMTS 30 provides a network side interface to a wide area network, indicated at 32, and a radio frequency (“RF”) interface between the CMTS 30 and the cable network in both the downstream and upstream directions, indicated respectively at 34 and 36. As used in the present document, the term “downstream” refers to transmission in the direction from the head-end 18 or CMTS 30 to the cable modem 28 at the customer premises. The term “upstream” refers to transmission in the direction from the cable modem 28 to the CMTS 30.
For transmission in the downstream direction, the CMTS 30 supplies data received from the computer 10 through the network 12 to a modulation circuit (“MOD”) 37 and then to a combiner 38, which combines the data with video signals for the cable television system. The combined signals are sent to a transmission module 40 where they are imparted onto the fiber network 22. The O/E nodes 24 convert the signals from the fiber network 22 to electrical signals on the coaxial cable network 26. Together, the fiber network 22, O/E nodes 24, and coaxial cable network 26 are often referred to in the art as a Hybrid Fiber Cable (“HFC”) network.
In a typical two-way cable system, also termed a bi-directional cable system, a cable modem 28 will transmit data packets to the CMTS 30 over one or more upstream channels on the cable television network 22 and 26. In the upstream direction, data from the cable modem 28 transmits data from the CPE 14 over the cable network 26 and 22, which is received at a receiver module 42. The receiver module 42 couples the upstream signal to a splitter and filter bank 44 which separates the data signal from video signals for the cable television system and couples the data signal to a demodulation circuit (“DEMOD”) 45 in the CMTS 30. A network termination unit 46 processes the data, sends the data to the switch or router 20, and routes the data onto the network 12 for transmission to the remote computer 10.
A data packet may carry, as its payload, information that is sent from the CPE 14 and destined for the CMTS 30. The cable modem 28 adds overhead to the data packet to maintain the integrity of the payload. Examples of overhead include redundant bits for error correction and preambles. On the cable network 22 and 26 side of the cable modem 28, the cable modem 28 transmits from and receives the data packet and overhead in the form of digitally modulated radio frequency carriers. An exemplary bi-directional data-over-cable system includes customer premises equipment 14 (e.g., a customer computer), a cable modem 28, a CMTS 30, a cable television network 18, 22, 26, and a backbone data network 12 (e.g., the Internet).
The preferred embodiments may be utilized with a bi-directional cable system. Cable modems and cable modem termination systems include those provided by 3Com Corporation of Santa Clara, Calif., Motorola Corporation of Schamburg, Ill., Bay Networks of Santa Clara, Calif., Scientific-Atlanta of Norcross, Ga., and others.
Cable Modem Protocol Stack
For data transmission over a bi-directional data-over-cable system, the cable modem 28 connects to the cable network 26 in a physical layer via a radio frequency (“RF”) interface 52. In an exemplary preferred embodiment of the present invention, the RF interface 52 has an operation frequency range of approximately 50 Mega-Hertz (“MHz”) to 1 Giga-Hertz (“GHz”) and a channel bandwidth of approximately 6 MHz on the downstream channels. In another exemplary preferred embodiment of the present invention, which relates to a bi-directional data-over-cable system, the RF interface 52 has an operation frequency range of approximately 5 MHz to 42 MHz on the upstream channels. Information on such interfaces may be found in DOCSIS. However, other operation frequencies and bandwidths may also be used and the invention is not limited to these frequencies and bandwidths.
The RF interface 52 preferably uses a signal modulation method of Quadrature Amplitude Modulation (“QAM”), although other methods may alternatively be used. As is known in the art, QAM is used as a means of encoding and decoding digital information over radio, wire, or fiber optic transmission links. QAM is a combination of amplitude and phase modulation and is an extension of multiphase phase-shift-keying. QAM can have any number of discrete digital levels typically including 4, 16, 64 or 256 levels.
In one embodiment of the present invention, the RF interface 52 uses QAM-64 for downstream reception. In another embodiment of the present invention, upstream transmission uses QAM-16 or Quadrature Phase-Shift-Keying (“QPSK”). For the upstream embodiment, the symbol rate of upstream transmission may be 160, 320, 640, 1,280, or 2,560 kilo-symbols per second (“ksym/sec”) for 16-QAM, or 160, 320, 640, 1,280, or 2,560 ksym/sec for QPSK. However, other operating frequencies, modulation methods, and symbol rates may alternatively be used. Also, other RF interfaces 52 may be used and the present invention is not limited to interfaces complying with DOCSIS.
Referring again to
Above both the downstream and upstream data-link layers in a network layer is an Internet Protocol (“IP”) layer 58. The IP layer 58, hereinafter IP 58, roughly corresponds to OSI layer 3, the network layer, but is typically not defined as part of the OSI model. As is known in the art, the IP 58 is a routing protocol designed to route traffic within a network or between networks. Additional information on the IP 58 may be found in the Internet Engineering Task Force (“IETF”) standard Request For Comments (“RFC”) 791—Internet Protocol, dated September 1981, which is incorporated herein by reference.
Also within the network layer of the protocol stack 50, an Internet Control Message Protocol (“ICMP”) layer 56 is used for network management. The main functions of the ICMP layer 56, hereinafter ICMP 56, include error reporting, reachability testing (e.g., “pinging”), congestion control, route-change notification, performance, and subnet addressing. Since the IP 58 is an unacknowledged protocol, datagrams may be discarded and the ICMP 56 is used for error reporting. Additional information on the ICMP 56 may be found in IETF standard RFC 792—Internet Control Message Protocol, dated September 1981, which is incorporated herein by reference.
Above the IP 58 and the ICMP 56 is a transport layer with a User Datagram Protocol (“UDP”) layer 60. The UDP layer 60, hereinafter UDP 60, roughly corresponds to OSI layer 4, the transport layer, but is typically not defined as part of the OSI model. As is known in the art, the UDP 60 provides a connectionless mode of communication with datagrams. Additional information on the UDP 60 may be found in IETF standard RFC 768—User Datagram Protocol, dated Aug. 28, 1980, which is incorporated herein by reference.
Above the network layer are a Simple Network Management Protocol (“SNMP”) layer 62, a Trivial File Transfer Protocol (“TFTP”) layer 64, a Dynamic Host Configuration Protocol (“DHCP”) layer 66 and a UDP manager 68. The SNMP layer 62 is used to support network management functions. Additional information on the SNMP layer 62 may be found in IETF standard RFC 1157—A Simple Network Management Protocol (SNMP), dated May 1990, which is incorporated herein by reference. The TFTP layer 64 is a file transfer protocol used to download files and configuration information. Additional information on the TFTP layer 64 may be found in IETF standard RFC 1350—The TFTP Protocol (Revision 2), dated July 1992, which is incorporated herein by reference. The DHCP layer 66 is a protocol for passing configuration information to hosts on an IP 54 network. Additional information on the DHCP layer 66 may be found in IETF standard RFC 2131—Dynamic Host Configuration Protocol, dated March 1997, which is incorporated herein by reference. The UDP manager 68 distinguishes and routes packets to an appropriate service such as a virtual tunnel known to those skilled in the art. More or fewer protocol layers may also be used with a data-over-cable system 16.
An operating environment for the CMTS 30, cable modems 28, and other network devices of the present invention includes a processing system with at least one Central Processing Unit (“CPU”) and a memory system. Preferably, a CPU controls the operations of the CMTS 30. In accordance with the practices of persons skilled in the art of computer programming, the preferred methods are described herein with reference to acts and symbolic representations of operations that are performed by the processing system, unless indicated otherwise.
It will be appreciated that the acts and symbolically represented operations include the manipulation of electrical signals by the CPU. The electrical signals represent data bits that cause a resulting transformation or reduction of the electrical signal representation. The CMTS 30, cable modems 28, and other network devices may maintain data bits at memory locations in their respective memory systems to reconfigure or otherwise alter their CPU's operation, as well as other processing of signals. The memory locations, such as random access memory (“RAM”), are physical locations that have particular electrical, magnetic, or optical properties corresponding to the data bits, depending on the type of memory used.
The data bits may also be maintained on a computer readable medium including magnetic disks, optical disks, organic disks, and any other volatile or non-volatile mass storage system readable by the CPU. The computer readable medium includes cooperating or interconnected computer readable media that exist exclusively on the processing system or are distributed among multiple interconnected processing systems that may be local or remote to the processing system.
Upstream Data Transmission
A cable modem 28 typically transmits on an upstream channel during a transmission mini-slot allocated by the CMTS 30. The upstream channel may be viewed as time-divided into a stream of mini-slots, each of which is a unit of granularity for upstream transmission opportunities. The CMTS 30 also times the mini-slots to prevent collisions between the transmissions from different cable modems by instructing the cable modems 28 to transmit alternately during the mini-slots.
Before transmitting data, however, a cable modem 28 must first request permission to transmit from the CMTS 30. A cable modem 28 that wishes to transmit sends a Request message to the CMTS 30.
The SID 76 is a unique identifier for the cable modem 28 that is requesting permission to transmit. The SID 76 may be assigned by the CMTS 30 when the cable modem 28 initializes and registers with the CMTS 30 as discussed below. The REQ 74 field contains a measure of how much bandwidth, i.e. how many mini-slots, the cable modem 28 requests for the transmission of its data to the CMTS 30.
In response, the CMTS 30 builds an Upstream Bandwidth Allocation Map message 80 (“MAP”) and transmits it via the downstream channel to all cable modems 28. Typically, the CMTS 30 receives requests from a number of cable modems 28 that wish to transmit and may allocate one or more transmission mini-slots to each of the cable modems 28. The MAP message 80 then informs each cable modem 28 of its permitted mini-slot(s) for transmission.
The MAP message 80 informs the cable modems 28 of the allocation of mini-slots for a scheduled upstream usage interval and when to begin the usage interval. In a given upstream usage interval, selections of the cable modems 28 alternately transmit on the upstream channel. As is known in the art, each upstream usage interval is composed of transmission intervals, also referred to as “bursts,” which comprise at least one mini-slot.
The upstream channel identifier field 84 within the MAP message 80 includes an identifier for the upstream channel to which the MAP message 80 applies. As is known to those of ordinary skill in the art, the data-over-cable system 16 may support upstream transmission on more than one upstream channel. For example, a common head-end 18 may serve more than one branch of the HFC network 22-26, and each branch may require a unique upstream channel for reasons of network configuration. In such a case, the Upstream Channel ID 84 may distinguish between the branches. Thus, the MAP message 80 intended for the cable modems 28 served by one branch may be distinguished from the MAP messages 80 for cable modems 28 on other branches by use of the Upstream Channel ID 84.
The MAP Information Elements field 100 designates the order and duration of the transmissions from the cable modems 28 for the upstream channel. As described in DOCSIS, one element may describe each transmission. The Number of Elements field 88 contains the total number of such elements.
The IUCs 102 are values that designate the type of transmission that is permitted in each interval. The cable modems 28 may be capable of several types of transmission. For example, the transmission may be for the purposes of ranging, allowing a cable modem 28 to compensate for delay on the cable network. Additionally, the transmission may be for the purpose of delivering a data packet to the CMTS 30. Two types of data transmissions typically occur: a short data grant or a long data grant. These data grants correspond to IUCs 102 that are described in DOCSIS. For example, a short data grant may be appropriate when the CPE 14 only has a small amount of data to transmit on the upstream channel, such as a few keystrokes or the opening of a hyperlink on a web page. A long data grant may be appropriate when the CPE 14 requests to transfer a file through the backbone network 12. In this manner, the CMTS 30 instructs the cable modem 28 when to transmit, on which upstream channel, and what type of data to transmit.
It should be understood, however, as alternatives to the foregoing, that other field settings for the Request message 70, the MAP message 80, and the MAP Information Elements 100 might be used.
Parameters for Upstream Data Transmission
Additionally, the cable modem 28 may transmit data packets in adjacent mini-slots according to different transmission formats for the RF interface 52. Associated with the formats are parameters for data transmission. In one exemplary preferred embodiment of the present invention, the parameters for upstream data transmission include the symbol rate, the upstream channel frequency, the modulation type, the preamble, and Forward Error Correction (“FEC”) parameters as described in Table 3.
As is known in the art, FEC adds redundant bits to the data packet to detect, locate, and correct transmission errors. The FEC level (“T”) is a measure of the amount of redundant data that must be added to the data packet to allow for error correction; A higher value of T provides a better level of error correction. The FEC data coverage size (“k”) is a measure of the amount of information over which data correction is to be performed; For the same FEC level, an increase in the FEC data coverage size will result in more errors going uncorrected. It should be understood that many more data transmission parameters are possible and that the present invention is not restricted to the parameters described herein.
Because each upstream channel may transmit according to a different transmission format, the cable modems 28 may undergo configuration so that their future transmissions occur according to a particular upstream format. The CMTS 30 may configure the cable modems 28, for example, by issuing an Upstream Channel Descriptor (“UCD”) message.
The upstream channel identifier field 114 typically contains a value that identifies the upstream channel to which the UCD message 110 applies. As with the upstream channel identifier field 84 within a MAP message 80, the upstream channel identifier field 114 may distinguish upstream channels when there is more than one upstream channel.
The CMTS 30 sends the transmission parameters to the cable modems 28 as TLV encoded channel descriptors 122 or as TLV encoded burst descriptors 124. TLV encoding is known to those skilled in the art. A selection of parameters for the overall channel and the bursts are given in Table 3 above. The CMTS 30 encodes these parameters as channel or burst descriptors and incorporates them into a UCD message 110 to reconfigure one or more cable modems 28. In response, a cable modem 28 reads the UCD message 110, determines if there are any changes in the parameters that describe its upstream channel, and determines if there are any changes in the parameters that describe its burst descriptor. The cable modem 28 reconfigures itself to transmit data according to these parameters. However, it should be understood that other field structures and values for the UCD message 110 might be used for the present invention.
When the CMTS 30 changes the data transmission parameters for an upstream channel, it builds a UCD message 110 with channel and/or burst descriptors that correspond to the new parameters. The UCD message 110 is sent on the downstream channel 26 to the cable modems 28. The CMTS 30 also sends out a corresponding MAP message 80. The burst descriptors in the UCD message 110 correspond to the IUC fields 102 of the MAP Information Elements 100 of the MAP message 80. As each cable modem 28 transmits on the upstream channel it may be doing so according to data transmission parameters that are different from other cable modems 28. In this manner, the cable modems 28 within an upstream usage interval may alternately transmit data packets to the CMTS 30 according to independent data transmission parameters.
Cable Plant Architecture
In the opposite transmission direction, the cable modems 28 on each branch transmit RF signals upstream to their associated O/E node 144-148, where the upstream RF signals are separated from the downstream RF signals by high-low pass filters 150-154 and are converted to optical signals. The HFC network maintains the physical separation of the signals on each branch. Each O/E node 144-148 transmits the upstream optical signals through a separate fiber bundle 138-142 to associated optical receivers 156-160 at the head-end 18 of the data-over-cable system 16. The CMTS 30 receives the separated upstream optical signals from the respective optical receivers 156-160 and typically processes each upstream signal independently of the other.
In the most common arrangement, the operator of the data-over-cable system 16 typically configures the upstream signals for different branches to operate on the same frequency. The rationale for using the same frequency is that bandwidth may be restrictive but the signals from different branches are physically isolated from each other on different fiber bundles 138-142. Typically, therefore, the upstream transmission bursts from different branches do not interfere. Because the upstream signals from the separate branches are independent, but all branches are served by the common downstream channel, the branches are distinguished by having different values for the upstream channel identifiers that are placed in the upstream channel identifier fields 84, 114 of the MAP message 80 and the UCD message 110. Each cable modem 28 therefore receives the MAP messages 80 and the UCD messages 110 for all branches from the common downstream channel but responds only to those messages that contain the upstream channel identifier for the branch to which it is connected.
Cable Modem Initialization and Registration
The CMTS 30 schedules and configures cable modem 28 data transmissions as discussed above. However, when a new cable modem 28 joins the data-over-cable system 16, it must undergo initialization and registration procedures before the data-over-cable system 16 permits it to transmit data. An initialization procedure is described in the DOCSIS specification and typically includes: scanning for a downstream channel and establishing synchronization with the CMTS 30; obtaining upstream transmission parameters from a UCD 110 message; ranging; establishing IP 58 connectivity; establishing the time of day; transferring operational parameters; and initializing Baseline Privacy.
As part of the initialization procedure, the cable modem 28 searches for a downstream channel. Typically, the cable modem 28 stored its parameters, such as the frequency of the last accessed downstream channel, in non-volatile memory during its last operation. The cable modem 28 tries to reacquire this downstream channel, but if it fails then the cable modem 28 typically scans the downstream frequency band until it finds a downstream signal with which it may synchronize.
Once it synchronizes with the downstream channel, the cable modem 28 monitors the channel and searches for UCD messages 110. When a cable modem 28 is installed on the network for the first time, however, it has no prior information concerning on which branch it is installed. To determine the branch, the cable modem 28 collects the UCD messages 110 which are sent within the downstream signal. The branches are distinguished by different values in the upstream channel identifier field 114 in the UCD message 110. The cable modem 28 attempts to communicate with the CMTS 30 by transmitting according to each UCD message 110 which it has received.
Each UCD message 110 may contain the data transmission parameters for an upstream channel upon which the cable modem 28 may transmit data to the CMTS 30. Once the cable modem 28 has selected a suitable UCD message 110 and configured itself to transmit on the corresponding upstream channel as identified in the upstream channel identifier field 114, the cable modem 28 enters a ranging phase.
The ranging phase discerns a timing offset such that the cable modem's 28 transmissions are aligned to the appropriate mini-slot boundary. Ranging adjusts each cable modem's 28 timing offset such that data bursts transmitted by the cable modem 28 arrive at the CMTS 30 at the correct instant in time. The cable modem 28 transmits prematurely by an amount equal to the timing offset to ensure that the signal arrives at the CMTS 30 just when it is expected. Other transmission parameters, such as transmitted power from the cable modem 28, are also adjusted during the ranging phase.
First, the cable modem 28 monitors MAP messages 80 and looks for a MAP message 80 whose upstream channel identifier field 84 value is the same as that for the upstream channel identifier field 114 of the selected UCD message 110. As described above in relation to
The cable modem 28 finds a MAP Information Element 100 in the MAP message 80 that has an IUC 102 indicating an Initial Maintenance interval. The CMTS 30 has reserved this time interval for receiving ranging signals from any cable modems 28 that are initializing on this particular upstream channel. The cable modem 28 has also reserved this time interval for starting its ranging phase. The Initial Maintenance interval is a contention interval and many cable modems 28 on the upstream channel may also use this interval to start ranging. During this interval, the SID 76 for the Initial Maintenance interval in the MAP Information Elements 100 is typically a broadcast/multicast SID 76. This SID 76 is acceptable because the cable modems 28 have not yet registered and so the cable modems 28 have not yet been assigned SIDs 76 by the CMTS 30.
When the Initial Maintenance interval occurs for the upstream channel corresponding to the upstream channel identifier in the MAP message 80 and the UCD message 110, the cable modem 28 sends a ranging request (“RNG-REQ”) message upstream to the CMTS 30.
The initialization SID 76 that the cable modem 28 places in the SID 76 field of the RNG-REQ message 170 is typically zero. This indicates to the CMTS 30 that the cable modem 28 has not registered before. If the SID 76 is non-zero, the CMTS 30 assumes that the cable modem 28 has previously undergone initialization but on another upstream channel.
In response to receiving the RNG-REQ message 170 from the cable modem 28, the CMTS 30 transmits a Ranging Response (“RNG-RSP”) message 180.
During the initial ranging, the RNG-RSP message 180 contains a temporary SID 76 for the cable modem 28. This SID 76 identifies the cable modem 28 to the CMTS 30 until it has completed a registration process. The RNG-RSP message 180 also includes information on RF power adjustments, transmission frequency adjustments, and offset timing adjustments that the cable modem 28 should adopt so as to improve communications from the cable modem 28 to the CMTS 30.
In response to the RNG-RSP message 180, the cable modem 28 monitors the downstream channel and again examines the MAP messages 80. In particular, the cable modem 28 looks for a MAP Information Element 100 in the MAP messages 80 for the selected upstream channel that has an IUC 102 indicating a Station Maintenance interval and an associated SID 76 field containing the temporary SID 76 assigned to the cable modem 28. The CMTS 30 has reserved this time interval for receiving ranging signals from only the cable modem 28 associated with the temporary SID 76.
When the appropriate Station Maintenance interval occurs, the cable modem 28 sends another RNG-REQ message 170 upstream to the CMTS 30. In return, the CMTS 30 returns a RNG-RSP message 180 with appropriate corrections to the transmission parameters in the ranging information field 186. The sequence of RNG-REQ 170 and RNG-RSP 180 is repeated until the CMTS 30 sends a RNG-RSP message 180 notifying the cable modem 28 that the ranging is successful.
During the Initial Maintenance interval 200, the cable modem 28 sends a RNG-REQ message 170 upstream to the CMTS 30. The RNG-REQ message 170 may have its SID field 76 set to zero to indicate that the cable modem 28 is initializing. The CMTS 30 receives the RNG-REQ message 170 and selects a temporary SID for the cable modem 28 at step 204. The CMTS 30 sends a RNG-RSP message 180 with this temporary SID to the cable modem 28. The cable modem 28 adopts this temporary SID as its identifier at step 208.
The cable modem 28 waits for another MAP message 80 for the upstream channel that includes a MAP information element 100 for a Station Maintenance interval for the temporary SID at step 212. When this Station Maintenance interval arrives at step 214, the cable modem 28 transmits another RNG-REQ message 170 upstream to the CMTS 30. In response, the CMTS 30 determines adjustments to the cable modem 28 transmission parameters at step 218 and transmits the parameters to the cable modem 28 in a RNG-RSP message 180. The cable modem 28 receives the RNG-RSP message 180 and correspondingly adjusts its transmission parameters at step 222.
Unfortunately, the cable modem's 28 attempts to range may interfere with legitimate upstream transmissions. For example, if the initializing cable modem 28 is on Branch A of
Alignment of Initial Maintenance Intervals
The above problem of an initializing cable modem 28 interfering with legitimate data transmissions from other cable modems 28 due to upstream channel ambiguities may be resolved by scheduling the Initial Maintenance intervals for all upstream channels to occur simultaneously. Thus, if a cable modem 28 on one branch ranges according to the timing for another branch, the RNG-REQ messages 170 will not interfere with data transmissions because no other cable modems 28 have been scheduled to transmit data in this common Initial Maintenance interval. The lack of collisions between ranging messages and data transmissions may result in fewer retransmissions of ranging messages on the one channel and fewer retransmissions of data on the other channel.
Upon receiving the RNG-REQ messages 170, the CMTS 30 typically sends a RNG-RSP message 180 to the cable modem 28. The upstream channel identifier field 184 of the RNG-RSP message 180 contains the identifier for the branch of the HFC network on which the CMTS 30 received the RNG-REQ message 170. The CMTS 30 determines on which branch it received the RNG-REQ message 170 by determining which optical receiver 150-156 received the RNG-REQ message 170. Upon receipt of the RNG-RSP message 180 from the CMTS 30, the cable modem 28 may determine that the upstream channel identifier field 184 contains a different identifier from the content of the upstream channel identifier field 114 of the UCD message 110 and MAP message 80 it originally used for configuration. The cable modem 28 may then cease using the UCD message 110 and MAP message 80 it had erroneously adopted and instead reconfigure itself according to the UCD messages 110 and MAP messages 80 appropriate for the newly received identifier from the RNG-RSP message 180. This procedure may result in a quicker registration time for cable modems 28.
A scheduling program on the CMTS 30 determines a sequence of intervals for transmission on the upstream channels and determines the type of transmissions that may occur during the intervals. In response, the CMTS 30 builds a MAP message 80 for each upstream channel and transmits them downstream to the cable modems 28. The scheduling program may therefore include a routine for aligning the Initial Maintenance intervals for the upstream channels because it determines the MAP messages 80 for all the upstream channels. It should be understood, however, that the preferred embodiments are not limited to aligning Initial Maintenance intervals and that other types of upstream transmissions, such as Station Maintenance intervals or combinations of Station Maintenance and Initial Maintenance intervals, may be aligned to reduce interference from initializing cable modems 28.
In accordance with the DOCSIS standard, the CMTS 30 schedules the Initial Maintenance intervals according to cycles of a system clock. Typically, the CMTS 30 has a 10.24 MHz system clock. The CMTS 30 derives the mini-slots for upstream transmission opportunities by dividing the system clock by a power of two. For example, from the 10.24 MHz system clock, the CMTS 30 may derive mini-slots of duration: 12.5 μs, 25 μs, 50 μs, 100 μs, 200 μs, 400 μs, or 800 μs. Also, the CMTS 30 may count mini-slots by examining upper bits of the system clock. For example, if the system clock is a 32-bit clock that increments at the 10.24 MHz rate, the eighth highest bit cycles every 12.5 μs, the ninth highest bit cycles every 25 μs, and so on down to the fourteenth highest bit, which cycles every 800 μs. Thus a count of mini-slots may be achieved by examining the cycling of one bit of the system clock. It should be understood, however, that the present invention is not limited to counting mini-slots by examination of bits of the system clock, or that the preferred methods are restricted to data-over-cable systems with a system clock. Other methods for counting mini-slots and other configurations of clocks are contemplated.
The CMTS 30 may schedule upstream channel transmissions according to differing mini-slot sizes. For example, with reference to
Alignment When the Symbol Rates and Mini-slot Sizes are Shared
Typically, the CMTS 30 schedules periodic Initial Maintenance intervals. A preferred period for the Initial Maintenance intervals is a basic insertion time, measured in seconds, and is a configurable parameter of the data-over-cable system 16. By dividing by the mini-slot size, measured in seconds, the basic insertion time corresponds to an integral number of TB mini-slots. It should be understood, however, that the period for the Initial Maintenance intervals is not limited to the basic insertion time and that other scheduling periods may be used, such as scheduling an Initial Maintenance interval during every alternate MAP message 80.
The CMTS 30 constructs MAP messages 80 for the upstream channels of the data-over-cable system 16, which designate order, duration, and types of transmissions from the cable modems 28. In general, each MAP message 80 need not designate a series of transmission intervals that jointly occupies a common number of mini-slots; the total number of mini-slots for upstream transmissions, represented by the MAP Information Elements field 100, may vary from MAP message 80 to MAP message 80 and from upstream channel to upstream channel.
To determine whether the CMTS 30 may schedule an aligned Initial Maintenance interval in the MAP messages 80 for each upstream channel, the CMTS 30 calculates that the aligned Initial Maintenance interval should start at a time corresponding to an integral number of TB mini-slots. As the CMTS 30 system clock provides the present time, corresponding to an integral number of TP mini-slots, the CMTS 30 calculates that the aligned Initial Maintenance interval should start at a time as illustrated in Equation (1):
TIM=TP+TB−TPmod(TB) (1)
measured in mini-slots. Equation (1) employs modular arithmetic as is familiar to those of ordinary skill in the art. The CMTS 30 therefore schedules the aligned Initial Maintenance intervals for each upstream channel to start at multiples of TB mini-slots, if such an alignment is possible.
In one embodiment, the units for the time calculations disclosed herein are measured in mini-slots. In an alternative embodiment, the units for the time calculations disclosed herein are measured in seconds. In yet another embodiment, the units for the time calculations disclosed herein are measured in numbers of cycles of the system clock. It should be understood, however, that the units are not limited to measuring time in seconds, numbers of mini-slots for an upstream channel, or numbers of cycles of the system clock, and that other units for measurement of time are possible for each upstream channel.
If the scheduled start of the aligned Initial Maintenance interval falls within the usage interval allocated by the next MAP message 80 for each upstream channel, the CMTS 30 may insert an element corresponding to an Initial Maintenance interval into the MAP Information Elements 100 of the next MAP message 80 for each upstream channel with an appropriate offset 104. To determine whether the element corresponding to an Initial Maintenance interval may be inserted into the next MAP message 80 for a particular upstream channel, the CMTS 30 determines whether the common start time for the Initial Maintenance interval occurs within the upstream channel's usage interval. Thus the CMTS 30 determines whether TIM occurs after the allocation start time 90 of the next MAP message 80, TS mini-slots, but before the end of usage interval allocated by this MAP message 80. Each upstream channel may have a different value for TS and the CMTS 30 may select TS for each upstream channel so that the transmissions allocated by the next MAP message 80 do not overlap remaining transmissions allocated by the previous MAP message 80. The CMTS 30 may insert the element corresponding to the Initial Maintenance interval if the scheduled start time satisfies the expression as illustrated in Equation (2):
TS≦TIM<TS+LMAP (2)
where LMAP is the length in mini-slots of the entire usage interval associated with the MAP message 80 for the upstream channel. Each upstream channel may have a different value for the number of mini-slots of transmission allocated by the MAP message 80, LMAP. If TIM does not satisfy Equation (2) for all the upstream channels, the CMTS 30 schedules intervals for data grants, Station Maintenance, Request messages, and other upstream transmissions, but not Initial Maintenance, according the scheduler program. The CMTS 30 then constructs MAP Information Elements 100 corresponding to the scheduled intervals, and transmits MAP messages 80 for the upstream channels to the cable modems 28.
If the start time of the aligned Initial Maintenance interval falls within the usage interval allocated by the next MAP message 80 for each of the upstream channels according to Equation (2), the CMTS 30 schedules a common, aligned Initial Maintenance interval to commence at time TIM for all upstream channels. The CMTS 30 also schedules the other types of upstream transmissions for each upstream channel to occur before and after their respective Initial Maintenance intervals. In particular, the CMTS 30 schedules (TIM−TS) mini-slots before the Initial Maintenance interval for upstream transmissions on each upstream channel. Provided this number of mini-slots is sufficiently large to accommodate one or more types of upstream transmissions, the CMTS 30 constructs the appropriate MAP Information Elements 100 for each upstream channel corresponding to the scheduled intervals.
Also, the CMTS 30 schedules a certain number of mini-slots after the Initial Maintenance interval for upstream transmissions on each of the upstream channels. If the length of the Initial Maintenance interval in mini-slots is LIM for the upstream channel, the number of mini-slots after the Initial Maintenance interval is given by the expression as illustrated in Equation (3):
max(0, TS+LMAP−[TIM+LIM]) (3)
Each upstream channel may have a different value for the number of mini-slots in an Initial Maintenance interval, LIM. Provided the number of mini-slots after the Initial Maintenance interval is sufficiently large to accommodate one or more types of upstream transmissions, the CMTS 30 constructs the appropriate MAP Information Elements 100 corresponding to the scheduled intervals for each upstream channel. In this manner, the CMTS 30 aligns the Initial Maintenance intervals for the upstream channels, and schedules other types of upstream transmissions on each upstream channel outside of the aligned Initial Maintenance interval common to all the upstream channels but within the usage intervals for each of the upstream channels.
Having aligned the Initial Maintenance intervals for the upstream channels, an initializing cable modem 28 may not interfere with legitimate upstream transmissions from other cable modems 28. An initializing cable modem 28 in the data-over-cable network system 16 may receive a UCD message 110 and a MAP message 80 for an upstream channel that is associated with another branch of the cable plant. After determining the Initial Maintenance interval from the MAP message 80, the initializing cable modem 28 may attempt to range at the wrong time for its branch. As the CMTS 30 has aligned the Initial Maintenance intervals, however, the ranging messages from the initializing cable modem 28 will not collide with other types of messages transmitted upstream on the branch.
Alignment When the Symbol Rates and/or Mini-slot Sizes Vary
Typically, the mini-slot size or the symbol rate may be different for each upstream channel. For example, an upstream channel with a low symbol rate and a large mini-slot size may have an Initial Maintenance interval that lasts much longer than an Initial Maintenance interval for another upstream channel having a high symbol rate and small mini-slot size. In this case, the CMTS 30 may schedule one Initial Maintenance interval for the former upstream channel and simultaneously schedule many consecutive Initial Maintenance intervals for the latter upstream channel.
As was the case above where the mini-slot size and symbol rates were common to all upstream channels, the period for the Initial Maintenance intervals is preferably a basic insertion time, measured in seconds, and is a configurable parameter of the data-over-cable system 16. By dividing by the mini-slot size for each upstream channel, measured in seconds, this basic insertion time corresponds to TB mini-slots in each upstream channel's measure of mini-slots. The number of mini-slots, TB, may vary amongst upstream channels because of the differing mini-slot sizes, but each upstream channel's number of mini-slots corresponds to the same value for the basic insertion time as measured in seconds. It should be understood, however, that the period for the Initial Maintenance intervals is not limited to the basic insertion time and that other scheduling periods may be used, such as scheduling an Initial Maintenance interval during every alternate MAP message 80 for the upstream channel.
To determine whether the CMTS 30 may schedule aligned Initial Maintenance intervals in the MAP messages 80 for each upstream channel, the CMTS 30 calculates that the aligned Initial Maintenance interval for each upstream channel should start at a time corresponding to a number TIM mini-slots in the upstream channel's measure of mini-slots. As the CMTS 30 system clock provides the present time, corresponding to a number TP mini-slots in the upstream channel's measure of mini-slots, the CMTS 30 calculates that the aligned Initial Maintenance interval should start at a time as illustrated in Equation (4):
TIM=TP+TB−TP mod(TB) (4)
for each upstream channel in the upstream channel's measure of mini-slots.
In one embodiment, the units for the time calculations disclosed herein are measured in numbers of mini-slots corresponding to the mini-slot size for each upstream channel. In an alternative embodiment, the units for the time calculations disclosed herein are measured in seconds. In yet another embodiment, the units for the time calculations disclosed herein are measured in numbers of cycles of the system clock. It should be understood, however, that the units are not limited to measuring time in seconds, numbers of mini-slots for an upstream channel, or numbers of cycles of the system clock, and that other units for measurement of time are possible for each upstream channel.
To ensure that a sufficiently long period is set aside for aligned Initial Maintenance on all upstream channels, the CMTS 30 determines which upstream channel's Initial Maintenance interval is longest in duration. For example, the CMTS 30 may multiply the length of the Initial Maintenance interval for an upstream channel, LIM measured in mini-slots for this upstream channel, by the duration of each of the upstream channel's mini-slot to convert the length of the Initial Maintenance interval to seconds. By comparing the length of the Initial Maintenance intervals in seconds, the CMTS 30 may determine which upstream channel has the longest Initial Maintenance interval. The length of the longest Initial Maintenance interval is XIMMAX measured in seconds, which may be converted to a number of mini-slots for each upstream channel by dividing by that upstream channel's mini-slot size.
In the upstream channel that has the longest Initial Maintenance interval, LIMMAX mini-slots as measured in the mini-slot size for that upstream channel, the CMTS 30 may schedule only one Initial Maintenance interval. In each other upstream channel, however, the CMTS 30 may simultaneously schedule one or more Initial Maintenance intervals because the length of the MAX Initial Maintenance interval for the upstream channel, LIM, is less than LIMMAX mini-slots as measured in the mini-slot size for the upstream channel. The number of mini-slots for each channel, LIMMAX, may be different for each upstream channel after converting XIMMAX seconds to the number of mini-slots on the upstream channel by dividing by the mini-slot size for that channel.
The number of Initial Maintenance intervals that may occur on each upstream channel during the longest Initial Maintenance interval is the integer part of the number of that upstream channel's mini-slots for the longest Initial Maintenance interval divided by the number of the upstream channel's mini-slots for its Initial Maintenance interval and is illustrated in Equation (5):
NIM=int(LIMMAX/LIM) (5)
Thus, for example, the CMTS 30 may schedule one Initial Maintenance interval on the upstream channel that has the longest Initial Maintenance interval, and may simultaneously schedule NIM Initial Maintenance intervals for each other upstream channel.
If the scheduled start of the aligned Initial Maintenance interval, TIM for each upstream channel, falls within the usage interval allocated by the next MAP message 80 for the upstream channel, the CMTS 30 may insert elements corresponding to one or more Initial Maintenance intervals into the MAP Information Elements 100 of the next MAP message 80 for each upstream channel with appropriate offsets 104. To determine whether the elements corresponding to Initial Maintenance intervals may be inserted into the next MAP message 80 for a particular upstream channel, the CMTS 30 determines whether the common start time for the Initial Maintenance intervals occurs within each upstream channel's usage interval. Thus the CMTS 30 determines whether TIM occurs after the allocation start time 90 of the next MAP message 80, TS mini-slots, but before the end of usage interval allocated by this MAP message 80. Each upstream channel may have a different value for TS and the CMTS 30 may select TS for each upstream channel so that the transmissions allocated by the next MAP message 80 do not overlap remaining transmissions allocated by the previous MAP message 80. The CMTS 30 may insert the element corresponding to the Initial Maintenance interval if the scheduled start time satisfies the expression as illustrated in Equation (6):
TS≦TIM<TS+LMAP (6)
where LMAP is the length in mini-slots of the entire usage interval allocated by the MAP message 80 for the upstream channel. Each upstream channel may have a different value for the number of mini-slots of transmission allocated by the MAP message 80, LMAP. If TIM does not satisfy Equation (6) for all the upstream channels, the CMTS 30 schedules intervals for data grants, Station Maintenance, Request messages, and other upstream transmissions, but not Initial Maintenance, according to the scheduler program. The CMTS 30 then constructs MAP Information Elements 100 corresponding to the scheduled intervals, and transmits MAP messages 80 for the upstream channels downstream to the cable modems 28.
If the start time of the aligned Initial Maintenance interval falls within the transmission time allocated by the next MAP message 80 for each of the upstream channels according to Equation (6), the CMTS 30 schedules a common, aligned Initial Maintenance interval to commence at time TIM for all upstream channels. For each upstream channel, the CMTS 30 schedules NIM Initial Maintenance intervals to occur consecutively on the upstream channel, and the CMTS 30 constructs the appropriate MAP Information Elements 100 for the upstream channel corresponding to the scheduled intervals.
The CMTS 30 also schedules the other types of upstream transmissions for each upstream channel to occur before and after their respective Initial Maintenance intervals. In particular, the CMTS 30 schedules (TIM−TS) mini-slots before the Initial Maintenance interval for upstream transmissions on each upstream channel. Provided this number of mini-slots is sufficiently large to accommodate one or more types of upstream transmissions, the CMTS 30 constructs the appropriate MAP Information Elements 100 for each upstream channel corresponding to the scheduled intervals.
Also, the CMTS 30 schedules a certain number of mini-slots after the Initial Maintenance intervals for upstream transmissions on each of the upstream channels. As the length of the NIM Initial Maintenance intervals in mini-slots is LIMMAX for the upstream channel, the number of mini-slots after the Initial Maintenance interval is given by the expression as illustrated in Equation (7):
max(0, TS+LMAP−[TIM+LIMMAX]) (7)
Provided the number of mini-slots after the Initial Maintenance interval is sufficiently large to accommodate one or more types of upstream transmissions, the CMTS 30 constructs the appropriate MAP Information Elements 100 corresponding to the scheduled intervals for each upstream channel. In this manner, the CMTS 30 aligns the Initial Maintenance intervals for the upstream channels, and schedules other types of upstream transmissions on each upstream channel outside of the aligned Initial Maintenance interval common to all the upstream channels but within the usage intervals for each of the upstream channels.
Having aligned the Initial Maintenance intervals for the upstream channels, an initializing cable modem 28 may not interfere with legitimate upstream transmissions from other cable modems 28. An initializing cable modem 28 in the data-over-cable network system 16 may receive a UCD message 110 and MAP message 80 for an upstream channel that is associated with another branch of the cable plant. Even though the cable modem 28 transmits with an inappropriate mini-slot size and/or symbol rate, after determining the Initial Maintenance interval from the MAP message 80, the initializing cable modem 28 may attempt to range at the wrong time for its branch. As the CMTS 30 has aligned the Initial Maintenance intervals, however, the ranging messages from the initializing cable modem 28 will not collide with other types of messages transmitted upstream on the branch.
It should be understood that the programs, processes, methods, systems and apparatus described herein are not related or limited to any particular type of computer apparatus (hardware or software), unless indicated otherwise. Various types of general purpose or specialized computer apparatus may be used with or perform operations in accordance with the teachings described herein. Although the network devices that communicate using the data-over-cable system 16 have repeatedly been referred to herein as cable modems 28, it is to be understood that the term “network devices” includes any device that contains the foregoing functionality ascribed to the cable modem 28. Such functionality may be implemented in stand-alone devices, such as the cable modem 28 illustrated in
In view of the wide variety of embodiments to which the principles of the invention can be applied, it should be understood that the illustrated embodiments are exemplary only, and should not be taken as limiting the scope of the present invention. For example, the steps of the flow diagrams may be taken in sequences other than those described, and more or fewer elements or component may be used in the block diagrams.
The claims should not be read as limited to the described order or elements unless stated to that effect. In addition, use of the term “means” in any claim is intended to invoke 35 U.S.C. §112, paragraph 6, and any claim without the word “means” is not so intended. Therefore, all embodiments that come within the scope and spirit of the following claims and equivalents thereto are claimed as the invention.
Number | Name | Date | Kind |
---|---|---|---|
4644533 | Braff et al. | Feb 1987 | A |
4881263 | Herbison et al. | Nov 1989 | A |
4996685 | Farese et al. | Feb 1991 | A |
5014234 | Edwards, Jr. | May 1991 | A |
5138712 | Corbin | Aug 1992 | A |
5301273 | Konishi | Apr 1994 | A |
5347304 | Moura et al. | Sep 1994 | A |
5430727 | Callon | Jul 1995 | A |
5442749 | Northcutt et al. | Aug 1995 | A |
5488412 | Majeti et al. | Jan 1996 | A |
5489897 | Inoue | Feb 1996 | A |
5528595 | Walsh et al. | Jun 1996 | A |
5583931 | Schneider et al. | Dec 1996 | A |
5586121 | Moura et al. | Dec 1996 | A |
5598410 | Stone | Jan 1997 | A |
5600717 | Schneider et al. | Feb 1997 | A |
5606606 | Schneider et al. | Feb 1997 | A |
5608446 | Carr et al. | Mar 1997 | A |
5610910 | Focsaneanu et al. | Mar 1997 | A |
5623542 | Schneider et al. | Apr 1997 | A |
5623601 | Vu | Apr 1997 | A |
5636211 | Newlin et al. | Jun 1997 | A |
5675732 | Majeti et al. | Oct 1997 | A |
5675742 | Jain et al. | Oct 1997 | A |
5708654 | Arndt et al. | Jan 1998 | A |
5710885 | Bondi | Jan 1998 | A |
5724510 | Arndt et al. | Mar 1998 | A |
5761602 | Wagner et al. | Jun 1998 | A |
5778181 | Hidary et al. | Jul 1998 | A |
5784597 | Chiu et al. | Jul 1998 | A |
5790198 | Roop et al. | Aug 1998 | A |
5790548 | Sistanizadeh et al. | Aug 1998 | A |
5790677 | Fox et al. | Aug 1998 | A |
5790770 | McClure et al. | Aug 1998 | A |
5790806 | Koperda | Aug 1998 | A |
5793747 | Kline | Aug 1998 | A |
5799086 | Sudia | Aug 1998 | A |
5805804 | Laursen et al. | Sep 1998 | A |
5809252 | Beighe et al. | Sep 1998 | A |
5812819 | Rodwin et al. | Sep 1998 | A |
5815664 | Asano | Sep 1998 | A |
5818845 | Moura et al. | Oct 1998 | A |
5819028 | Manghirmalani et al. | Oct 1998 | A |
5819042 | Hansen | Oct 1998 | A |
5828655 | Moura et al. | Oct 1998 | A |
5828666 | Focsaneanu et al. | Oct 1998 | A |
5835720 | Nelson et al. | Nov 1998 | A |
5835727 | Wong et al. | Nov 1998 | A |
5841777 | Cohen | Nov 1998 | A |
5852721 | Dillon et al. | Dec 1998 | A |
5854901 | Cole et al. | Dec 1998 | A |
5859852 | Moura et al. | Jan 1999 | A |
5864679 | Kanai et al. | Jan 1999 | A |
5870134 | Laubach et al. | Feb 1999 | A |
5872523 | Dellaverson et al. | Feb 1999 | A |
5884024 | Lim et al. | Mar 1999 | A |
5894479 | Mohammed | Apr 1999 | A |
5903558 | Jones et al. | May 1999 | A |
5909549 | Compliment et al. | Jun 1999 | A |
5913037 | Spofford et al. | Jun 1999 | A |
5915119 | Cone | Jun 1999 | A |
5922049 | Radia et al. | Jul 1999 | A |
5922051 | Sidey | Jul 1999 | A |
5923659 | Curry et al. | Jul 1999 | A |
5926458 | Yin | Jul 1999 | A |
5929850 | Broadwin et al. | Jul 1999 | A |
5941988 | Bhagwat et al. | Aug 1999 | A |
5943604 | Chen et al. | Aug 1999 | A |
5954797 | Sidey | Sep 1999 | A |
5958007 | Lee et al. | Sep 1999 | A |
5960177 | Tanno | Sep 1999 | A |
5974453 | Andersen et al. | Oct 1999 | A |
5982748 | Yin et al. | Nov 1999 | A |
5987524 | Yoshida et al. | Nov 1999 | A |
5991292 | Focsaneanu et al. | Nov 1999 | A |
5991306 | Burns et al. | Nov 1999 | A |
5996076 | Rowney et al. | Nov 1999 | A |
5999536 | Kawafuji et al. | Dec 1999 | A |
6003077 | Bawden et al. | Dec 1999 | A |
6005851 | Craddock et al. | Dec 1999 | A |
6006264 | Colby et al. | Dec 1999 | A |
6009103 | Woundy | Dec 1999 | A |
6012088 | Li et al. | Jan 2000 | A |
6013107 | Blackshear et al. | Jan 2000 | A |
6014545 | Wu et al. | Jan 2000 | A |
6018767 | Fijolek et al. | Jan 2000 | A |
6031841 | Woundy | Feb 2000 | A |
6032019 | Chen et al. | Feb 2000 | A |
6041041 | Ramanathan et al. | Mar 2000 | A |
6046979 | Bauman | Apr 2000 | A |
6049546 | Ramakrishnan | Apr 2000 | A |
6049825 | Yamamoto | Apr 2000 | A |
6049826 | Beser | Apr 2000 | A |
6052724 | Willie et al. | Apr 2000 | A |
6058421 | Fijolek et al. | May 2000 | A |
6061349 | Coile et al. | May 2000 | A |
6064372 | Kahkoska | May 2000 | A |
6065049 | Beser | May 2000 | A |
6070187 | Subramaniam et al. | May 2000 | A |
6070242 | Wong et al. | May 2000 | A |
6070246 | Beser | May 2000 | A |
6073178 | Wong et al. | Jun 2000 | A |
6075787 | Bobeck et al. | Jun 2000 | A |
6091709 | Harrison et al. | Jul 2000 | A |
6094431 | Yamato et al. | Jul 2000 | A |
6104700 | Haddock et al. | Aug 2000 | A |
6112258 | Miller et al. | Aug 2000 | A |
6122254 | Aydemir et al. | Sep 2000 | A |
6128298 | Wootton et al. | Oct 2000 | A |
6130879 | Liu | Oct 2000 | A |
6130880 | Naudus et al. | Oct 2000 | A |
6137792 | Jonas et al. | Oct 2000 | A |
6137793 | Gorman et al. | Oct 2000 | A |
6148410 | Baskey et al. | Nov 2000 | A |
6157965 | Mohammed et al. | Dec 2000 | A |
6170061 | Beser | Jan 2001 | B1 |
6178455 | Schutte et al. | Jan 2001 | B1 |
6185624 | Fijolek et al. | Feb 2001 | B1 |
6189102 | Beser | Feb 2001 | B1 |
6208656 | Hrastar | Mar 2001 | B1 |
6212563 | Beser | Apr 2001 | B1 |
6216171 | Isono et al. | Apr 2001 | B1 |
6223222 | Fijolek et al. | Apr 2001 | B1 |
6230326 | Unger et al. | May 2001 | B1 |
6240464 | Fijolek et al. | May 2001 | B1 |
6243369 | Grimwood et al. | Jun 2001 | B1 |
6260072 | Rodriguez-Moral | Jul 2001 | B1 |
6269099 | Borella et al. | Jul 2001 | B1 |
6272150 | Hrastar et al. | Aug 2001 | B1 |
6275853 | Beser et al. | Aug 2001 | B1 |
6289377 | Lalwaney et al. | Sep 2001 | B1 |
6295554 | Karadogan | Sep 2001 | B1 |
6331987 | Beser | Dec 2001 | B1 |
6332163 | Bowman-Amuah | Dec 2001 | B1 |
6337858 | Petty et al. | Jan 2002 | B1 |
6393478 | Bahlmann | May 2002 | B1 |
6442158 | Beser | Aug 2002 | B1 |
6449291 | Burns et al. | Sep 2002 | B1 |
6453472 | Leano et al. | Sep 2002 | B1 |
6490727 | Nazarathy et al. | Dec 2002 | B1 |
6507592 | Hurvig et al. | Jan 2003 | B1 |
6510162 | Fijolek et al. | Jan 2003 | B1 |
6526070 | Bernath et al. | Feb 2003 | B1 |
6594305 | Roeck et al. | Jul 2003 | B1 |
6650624 | Quigley et al. | Nov 2003 | B1 |
6735221 | Cherubini | May 2004 | B1 |
6741551 | Cherubini | May 2004 | B1 |
6742186 | Roeck | May 2004 | B1 |
20020122050 | Sandberg | Sep 2002 | A1 |
20020136165 | Ady et al. | Sep 2002 | A1 |
20030028891 | Hardt et al. | Feb 2003 | A1 |
Number | Date | Country |
---|---|---|
WO 0067385 | Nov 2000 | WO |
Number | Date | Country | |
---|---|---|---|
20020101883 A1 | Aug 2002 | US |