This description relates to distributing multicast flows.
Multimedia content may be passed and shared among devices such as cellular phones and computing devices (also referred to as Access Terminals or ATs).
This multimedia content may be implemented to comply with one or more standards such the EV-DO Rev A standard (also written as 1×EV-DO Rev A or 1× Evolution-Data Optimized Revision A), which is herein incorporated by reference. EV-DO Rev A is included in a family of standards that are promoted by the Third Generation Partnership Project 2 (3GPP2), a collaborative Third Generation (3G) telecommunications specification-setting project associated with the development of the next generation Code Division Multiple Access (CDMA) wireless communications.
The 1×EV-DO protocol is an EVolution of the 1×RTT standard for high-speed data-only (DO) services and has been standardized by the Telecommunication Industry Association (TIA) as TIA/EIA/IS-856, “CDMA2000 High Rate Packet Data Air Interface Specification”, 3GPP2 C.S0024-0, Version 4.0, Oct. 25, 2002, which is incorporated herein by reference. Revision A to this specification has been published as TIA/EIA/IS-856, “CDMA2000 High Rate Packet Data Air Interface Specification”, 3GPP2 C.S0024-A, Version 2.0, June 2005, which is also incorporated herein by reference.
When exchanging multimedia content, a series of setup-messages are sent between a user's AT and structures included in a Radio Access Network (RAN). These structures include Radio Nodes (RNs), Radio Network Controllers (RNCs) and Packet Data Serving Nodes (PDSNs), which act as a link between the ATs and content servers (and controllers) that provide the multimedia content.
In some RANs, services provided by RN, RNCs and PDSNs are integrated into a single unit referred to as a Base Station Router (BSR) that reduces space needs and power consumption. However, as multimedia content traffic increases, BSRs (similar to individual RNCs and RNs) are susceptible to overload conditions and potential failure.
In general, in some aspects of the invention, in response to being informed by a controller of a flow for transmission to at least one access terminal in a wireless network, a master base station router assigns the flow to one of a group of slave base station routers to process the flow for transmission to the access terminal. In some arrangements, the controller may be aware or unaware of the slave base station routers. A content provider may provide a flow such as a multicast flow or a unicast flow to the assigned slave base station router. The flow may conform to a published standard such as a standard associated with a Broadcast and Multicast Services (BCMCS) flow.
The master base station router may operate as a radio node, a radio node controller, a packet data serving node or a combination thereof. To assign the flow, the master base station router may determine the processing capacity of each slave base station router. Each slave base station router may send information representative of their processing capacity to the master base station router. This information may be sent in a periodic manner or may be sent based upon a trigger event such as a processing capacity threshold being exceeded.
In response to monitoring a message sent to the master base station router from a backup base station router, flow operations may be transferred from the master base station router to the backup base station router. Operations may also be transferred to the backup base station router if a message acknowledge response is not sent from the master base station router. The backup base station router may send message to other components such as each of the slave base station routers as a flow operations transfer alert. This message may indicate the transfer of operations from the master base station router to the backup base station router. Rather than the master base station router, in response to a failure detection, flow operations may be transferred from a slave base station router to a backup base station router.
In some aspects of the invention, a system includes a controller that initiates a transmission of a flow to at least one access terminal in a wireless network. The system also includes a master base station router that assigns processing of the flow and a group of slave base station routers. One more of slave routers is assigned by the master base station router to process the flow for transmission to the access terminal. In some arrangements, the controller may be aware or unaware of the slave base station routers. A content provider may provide a flow such as a multicast flow or a unicast flow to the assigned slave base station router. The flow may conform to a published standard such as a standard associated with a Broadcast and Multicast Services (BCMCS) flow.
The master base station router may operate as a radio node, a radio node controller, a packet data serving node or a combination thereof. To assign the flow, the master base station router may determine the processing capacity of each slave base station router. Each slave base station router may send information representative of their process capacity to the master base station router. This information may be sent in a periodic manner or may be sent based upon a trigger event such as a processing capacity threshold being.
In response to monitoring a message sent to the master base station router from a backup base station router, flow operations may be transferred from the master base station router to the backup base station router. Operations may also be transferred to the backup base station router if a message acknowledge response is not sent from the master base station router. The backup base station router may send messages to other components such as each of the slave base station routers as a flow operations transfer alert. This message may indicate the transfer of operations from the master base station router to the backup base station router. Rather than the master base station router, in response to a failure detection, flow operations may be transferred from a slave base station router to a backup base station router.
In some aspects of the invention, a medium bears instructions to cause a machine to, in response to being informed by a controller of a flow for transmission to at least one access terminal in a wireless network, assign (by a master base station router) the flow to one of a group of slave base station routers to process the flow for transmission to the access terminal. In some arrangements, the controller may be aware or unaware of the slave base station routers. A content provider may provide a flow such as a multicast flow or a unicast flow to the assigned slave router. The flow may conform to a published standard such as a standard associated with a Broadcast and Multicast Services (BCMCS) flow.
The master base station router may operate as a radio node, a radio node controller, a packet data serving node or a combination thereof. To assign the flow, the master router may determine the processing capacity of each slave base station router. Each slave base station router may send information representative of their processing capacity to the master base station router. This information may be sent in a periodic manner or may be sent based upon a trigger event such as a processing capacity threshold being exceeded.
In response to monitoring a message sent to the master router from a backup base station router, flow operations may be transferred from the master base station router to the backup base station router. Operations may also be transferred to the backup base station router if a message acknowledge response is not sent from the master base station router. The backup base station router may send messages to other components such as each of the slave base station routers as a flow operation transfer alert. This message may indicate the transfer of operations from the master base station router to the backup base station router. Rather than the master base station router, in response to a failure detection, flow operation may be transferred from a slave base station router to a backup base station router.
Among the advantages of the techniques described here are one or more of the following.
Because flow processing is distributed across a group of base station routers, the probability of router overload and failure is reduced. Furthermore, by incorporating backup base station routers, the probability of system failure is further reduced.
Other features and advantages will be apparent from the description and the claims.
Referring to
For example, a cellular phone 102 may be used to share multimedia content with cellular phones 104, 106 and 108. Similarly, cellular phone 110 may be used to share content with a single target cellular phone 112. Cellular phones 102 and 110 (also referred to as the caller ATs), respectively send multimedia content to RAN 100 for delivery to the appropriate one or more target mobile phones (also referred to as target ATs). As can be imagined, while cellular phones are linked via the RAN 100, other types of ATs may be implemented such as personal digital assistants (PDAs), computer systems (e.g., a laptop computer) with wireless modules, or other type of device that supports a protocol such as the 1×EV-DO protocol.
For illustration, a wireless link 114 is established to provide multimedia content from the AT 102 to the RAN 100. Similarly, a wireless link 116 is established to provide multimedia content from the AT 110 to the RAN 100. To provide the multimedia content from AT 102 to multiple target ATs, a multicast flow is placed on a wireless link 118 that is established by the RAN 100 and is accessible by the ATs 104, 106, 108. To provide multimedia content from AT 110 to the one target AT 112, a unicast flow is placed on a wireless link 120 that is received by AT 112. Generally, the term “unicast” refers to any communication technique that enables data to be sent in a point-to-point manner using a dedicated transmission stream. The term “multicast” refers to any communication technique that enables data to be sent in a point-to-multipoint manner to a select group of recipients using a common transmission stream.
Examples of multicast flows that may be established by the RAN 100 include a 3GPP2 Broadcast and Multicast Services (BCMCS) flow. In general, BCMCS is a multicast flow for Code Division Multiple Access (CDMA) (e.g., CDMA2000) networks that implement a flexible common radio channel suitable for point-to-multipoint and broadcast traffic. As with other types of multicast flows, BCMCS provides the benefit of multicast and broadcast in which many ATs can access a common channel. By receiving data from a common channel, data sets do not need to be replicated for transmission over multiple unicast flows (respectively assigned to individual ATs). Compared to a unicast flow, a multicast flow provides more efficient bandwidth management and access flexibility.
Referring to
The RNC functionality (included in each BSR) communicates (e.g., over an Internet Protocol (IP) network referred to as a backhaul network) with the one (or more) associated RN. Each RN may serve multiple geographical areas (e.g., sectors) and communicate with ATs present within the sectors. In some arrangements, an RNC may include one or multiple system controller (SC) cards, of which, one or more may be active during particular time periods. The RNC may also include, e.g., four input/output (I/O) cards such as basic input/output (BIO) cards. The I/O cards may provide connectivity for numerous (e.g., eight) Radio Network Service Module (RNSM) cards, which may implement the 1×EV-DO functionality. However, in other implementations RNC functionality may be may be provided without using a multiple card functional structure (e.g., BIO, RNSM, SC, etc.).
The RAN 100 also includes a BCMCS Controller 222 that may be configured to arrange multicast flows of multimedia content. For example, BCMCS Controller 222 may be used to define program names along with start and end times associated with multicast flows. Bandwidth requirements, addressing information, header compression information, quality of service (QOS)/bit error rate levels, and RN geographical distribution headers may be defined by BCMCS controller 222 along with other parameters. Multicast flow processing such as compression and encryption techniques may be provided by BCMCS controller 222. The BCMCS controller 220 may also provide flow parameters to a content server 224, the BSRs 200, 202 and to other components of RAN 100. Other operations provided by BCMCS controller 200 may include assisting in the authentication of ATs along with providing the ATs with encryption and decryption data (e.g., encryption keys, etc.).
The BSRs 200 and 202 may establish pathways for unicast and multicast flows within the RAN 100 (e.g., assigning pathways for particular multicast flows, initiating broadcast channels at appropriate times, etc.) while the content server 224 may initiate and control content streaming to the BSRs and the time schedules. Additionally, BSRs 200, 202 may provide operations such as preparing content (e.g., attaching Point-to-Point Protocol (PPP) headers, attaching Frame Check Sequence (FCS) trailers, etc.) for transmission to one or more ATs. BSRs 200, 202 may assure that the multicast flows comply with protocols such as the Broadcast Framing Protocol, the Broadcast Security Protocol and the Broadcast MAC Protocol, for example. Furthermore, BSRs 200 and 202 may apply one or more error detecting techniques (e.g., Reed-Solomon Error-detection coding) to the multicast flows and manage the broadcast channels included in the flows.
At an appropriate time (e.g., defined by BCMCS controller 222), the content server 224 initiates content streaming to one or both of the BSRs 200 and 202 via a network 226 such as an Internet Protocol (IP) network. Upon receipt, the BSRs 200 and 202 may perform operations such as multicast framing (e.g., BCMCS framing), error-correction preparation (e.g., addition of error-correction bits, etc.), prior to sending the multicast flow to one or more appropriate antenna systems for transmission, e.g., over a Broadcast Channel. Similarly, BSR 202 may process unicast flows from the content server 224 for transmission. Along with broadcasting the multicast and unicast flow content, periodic overhead messages may be broadcasted over a channel (referred to as a Control Channel). The overhead messages may, for example, include information for granting one or more ATs access to particular types of data such as high-layer data packets.
The BCMCS controller 222 may also provide information to one or more ATs (via the network 226 and a BSR) that is associated with one or more multicast or unicast flows. For example, encryption keys, flow identification data (e.g., flowID data), address data (e.g., multicast address mappings information), compression data (e.g., header compression (ROHC) parameters), decryption data, etc.
By integrating the functionality of one or more RNCs and RNs (and PDSNs) in a single BSR, multicast services and unicast services are provided by a single system component. However, in providing these services, the processing performed by the BSR may become overloaded and thereby slow service execution. To reduce the probability of overload of a single BSR, processing may be distributed across multiple BSRs. Furthermore, one or more load balancing schemes may be implemented to improve flow processing. In addition to reducing component overload, by incorporating one or more layers of BSR redundancy, the probability of system failure due to one or more BSRs failing may be reduced.
Referring to
In this arrangement, the multiple BBSRs include a master BBSR 302 that is in communication with a network (e.g., an IP network) 304 that is connected to a BCMCS controller 306 and a content server 308. In this arrangement, the master BBSR 302 executes such operations as negotiating with the BCMCS controller 306 and distributing flow processing among a group of slave BBSRs 310, 312, 314, 316. The BCMCS controller 306 is unaware of the slave BBSRs present in the system 300 and may assume that the master BBSR 302 is directing operations to prepare the flows for transmission to one or more ATs.
The BSMCS controller 306 provides information such as multicast flow information (e.g., content description, destination information, source information, sector identifiers for local broadcasts, etc.) to the master BBSR 302 to prepare the flow for transmission. The master BBSR 302 also negotiates flow parameters (e.g., flow rates, start and end times, etc.) with the BCMCS controller 304 (e.g., by exchanging messages). Typically, once the flow parameters are set, the BCMCS controller 306 alerts the content server 308 that flows may be sent to the network 304 for transmission (via the BBSRs 302, 310, 312, 314, 316).
To balance the multicast processing load, the master BBSR 302 selects which slave BBSR is to be assigned one or more flows for processing in preparation for transmission. For example, the master BBSR 302 may track the capabilities of each slave BBSR along with their current and scheduled processing loads. From this information, the master BBSR 302 may select a particular slave BBSR to handle one or more flows. The master BBSR 302 may assign an address to the selected slave BBSR and notify the BCMCS controller 306 that the address is to receive a particular flow. The content server 308 is provided this address from the BCMCS controller 306 along with other flow parameters (e.g., flow rate, start time, end time, etc.).
to communicate with the group of slave BBSRs 310, 312, 314, 316, a connection 318 referred to as a backhaul connection connects the slaves to the master BBSR 302. Various signaling techniques may be used with the connection 318, for example, signals complying with protocols such as the Transmission Control Protocol (TCP) or an IP multicast may be implemented. Along with providing assignment information to the slave BBSRs, the master BBSR 302 may also receive status information (e.g., current capacity, current operations being executed, etc.) over the backhaul connection 318 from the slaves. With this information, the master BBSR 302 can track the current state of the slaves and project future flow processing assignments.
Since the controller 306 is not in communication with each individual slave BBSR 310-316, the master BBSR 302 controls the dispensing of multicast flow information to the slave BBSRs. To assign a flow to one of the slave BBSRs 310-316, the master BBSR 302 executes a Flow Manager 320. In some embodiments one or multiple processors may execute instructions to perform the operations of the Flow Manager 320. For example, one or more general processors (e.g., a microprocessor) and/or one or more specialized devices (e.g., an application specific integrated circuit (ASIC), etc.) may execute instructions. One or more of the processors may be implemented in a single integrated circuit as a monolithic structure of in a distributed structure. In some embodiments the instructions that are executed by the processors may reside in a memory (e.g., random access memory (RAM), read-only memory (ROM), static RAM (SRAM), etc.). The instruction may also be stored on one or more mass storage devices (e.g., magnetic, magneto-optical disks, or optical disks, etc.).
One or more of the operations associated with the Flow Manager 320 may be performed by one or more programmable processors (e.g., a microprocessor, an ASIC, etc.) executing a computer program. The execution of one or more computer programs may include operating on input data and generating output. The operations may also be performed by a processor implemented as special purpose logic circuitry (e.g., an FPGA (field programmable gate array), etc.).
Referring to
From this collected information, the master BBSR determines how the scheduled flow are to be assigned among the slave BBSRs and itself by using one or more balancing techniques so that none of the BBSRs are substantially overloaded with flow operations. Upon assignment, the master BBSR determines 406 if one or more of the slave BBSRs is available for their respective assignment. If one or more of the slave BBSRs are not available (e.g., inoperable), the Flow Manager 320 returns to reassess the flow assignments based upon this resource availability information. If an appropriate number of slave BBSRs are available, the master BBSR assigns the scheduled flows to the slave BBSRs. For example, the master BBSR may assign an address (e.g., an IP address) via the backhaul connection 318 to a particular slave BBSR to associated the slave with a flow. Operations of the Flow Manager 320 may also include providing 410 the multicast controller with data that identifies each slave BBSR and associates the slave with an assigned flow. Correspondingly, this information may be provided (e.g., by the multicast controller) to a content server for directing the assigned flow to the proper slave BBSR.
Referring to
Along with negotiating flow parameters, the master BBSR assigns flow to the slave BBSRs. For example, upon determining a particular slave BBSR is available to process a flow, the master BBSR 302 sends a message alerting the slave to its selection to prepare to process a multicast flow. As described below, various methodologies may be utilized to assign an appropriate slave BBSR to a particular flow. In some arrangements, the slave BBSR may send an acknowledge message back to the master BBSR 302 over the backhaul connection 318.
In addition to assigning slave BBSRs to multicast flows, the master BBSR 302 may also change flow assignments among the slave BBSRs. For example, to provide a more balanced flow distribution, the master BBSR 302 may determine to switch a multicast flow from being processed by the slave BBSR 310 to the slave BBSR 312. At a later time, the master BBSR 302 may determine it advantageous to switch the processing of the flow back to the slave BBSR 310 and may or may not assign additional flow processing to the slave BBSR 312.
One or more techniques may be used by Flow Manager 320 to balance the multicast flow processing provided by the BBSRs. For example, each BBSR (e.g., the master BBSR and the slave BBSRs) may be considered to have a predefined processing rate (e.g., quantified in kilo bits per second (kbps)) or other associated metric (e.g., bandwidth, capacity, etc.) for processing flows. Data that represents the processing rate of each slave BBSR may be provided to the master BBSR 302 so that the master may track the amount of processing being consumed by each slave as flows are assigned. As the consumed rate approaches the predefined maximum threshold, the master BBSR 302 may assign fewer flows to that particular slave BBSR until the processing rate consumption decreases (e.g., as flow processing is completed).
Another technique implemented by Flow Manager 320 may dynamically monitor the processing load of each slave BBSR 310-316 along with the master BBSR 302 to determine availability. For example, each slave BBSR may periodically (e.g., every 30 seconds, 30 minutes, etc.) provide data over the backhaul connection 318 to the master BBSR 302 that represents the current processing capacity being consumed by the slave BBSR. Rather than periodic delivery of this data, the processing usage data may also be delivered based upon a particular event. For example, the master BBSR 302 may send a request message to each slave BBSR 310-316 to trigger a status message being sent from each slave over the backhaul connection 318 to the master BBSR. These status messages may include data that represents the current processing capacity being consumed by each respective slave BBSR. Detecting particular events may also trigger the slave BBSRs 310-316 to send status messages to the master BBSR 302. For example, a dramatic increase in flow traffic may be detected and trigger the sending of a status message to the master BBSR 302.
Along with passing information between the master BBSR and the slave BBSRs, data may also be passed between other system components. For example, unicast flows may be individually sent to the BBSRs or in combination with multicast flows for transmission. Similar to multicast processing, to process unicast flows the master BBSR 302 may provide the BCMCS controller 306 one or more addresses respectively assigned to the slave BBSRs to process the unicast flow. The address or addresses may also be provided to a content server (e.g., content server 308) as an alert as to which slave BBSR is responsible for each unicast flow.
Various types of information may be passed among the BBSRs such as Generic Routing Encapsulation (GRE) data (e.g., keys) being passed from the master BBSR 302 to one or more slave BBSRs 310-316 and the content server 308. Along with sending messages to among themselves, the master BBSR 302 and the slave BBSRs 310-316 may send messages to other system components. For example, to join a flow each BBSR may send a message to the network 304 to identify itself to the content server 308. These messages may comply with multicast protocols such as the Internet Group Management Protocol (IGMP) such that the BBSR is identified for joining a unicast or multicast flow that is provided by the content server 308.
The master BBSR 302 may also perform other operations along with flow processing assignment. For example, the master BBSR 302 may map flows being produced into a common channel (referred to as a logical channel). Along with mapping a single flow (e.g., a unicast flow or multicast flow) in a single logical channel, multiple flows may be mapped into a logical channel. Various mapping techniques (e.g., Reed Solomon) may be implemented to produce one or more logical channels.
To combine multiple flow into a single logical channel, techniques such as time division multiplexing may be incorporated by the master BBSR 302. For a finite number of time slots (e.g., 256), the master BBSR 302 may allocate the slots among the flows being placed on the channel. For example, alternating time slots may allow two unicast flows to be interleaved while still providing proper bandwidth. However, multicast flows may need additional bandwidth in order to for interleaving into a channel. By assigning a series of consecutive time slots (e.g., three slots, four slots, etc.) for each interleave period, the bandwidth constraints may be met for a multicast flow. As such, the logical channel contains an interleave of time slot groups are that each assigned to a multicast flow. The master BBSR 302 may also reallocate the time slots along with the flow included in the logical channels. Additionally, the logical channels may be assigned to broadcast channels to satisfy the bandwidth requirements of the logical channels. The master BBSR 302 may also assign a flow rate to each of the slave BBSRs, for example, a rate of approximately one hundred bits per second or higher may be assigned.
Along with controlling the RNC functionality of itself, a BBSR (e.g., the master BBSR 302) may remotely control the same functionally of another BBSR (e.g., the slave BBSRs). As such the master BBSR 302 may be used to control the RN functionality of one or more of the slave BBSRs 310-316. Thus one BBSR may instruct one or more other BBSRs to open, close or modify logical channels. Additionally, the controlling BBSR may initiate the transmission of messages from one or more other BBSRs (along with itself). For example, a message (e.g., a broadcast overhead message) may be sent that conveys information such as identifying when a flow is available in a particular sector, a map that identifies flow interlacing within a logical channel, time slot information or other configuration information. Typically, the broadcast overhead message (BOM) is provided to each of the slave BBSRs 310-316 from the master BBSR 302 via the overhaul connection 318. The message is then broadcast by the BBSRs to the ATs in their respective sectors.
Referring to
Each backup BBSR monitors the functionality (e.g., operation execution, processing capacity, etc.) of the BBSR to which it is connected. For example, backup master BBSR 516 monitors the functionality of the master BBSR 502 while backup slave BBSR 518 monitors the functionality of the slave BBSR 508. To monitor BBSR functionality, one or more techniques may be implemented. For example, a backup BBSR may send a status request signal (referred to as a heartbeat signal) to a corresponding BBSR at designated time intervals (e.g., 30 seconds, 30 minutes, etc.). If an acknowledgement signal is sent back to the backup BBSR from the BBSR being monitored, the functionality of the BBSR is considered to be proper. If the acknowledgement signal is not received, or is not received in a resonable time period, the monitored BBSR is considered to have failed and the backup BBSR assumes the processing load of the failed BBSR.
Along with assuming the responsibility of the failed BBSR, the backup BBSR may also perform other operations such as alerting other system components to the backup BBSR assuming responsibility. For example, upon assuming the responsibility of the master BBSR 502, the backup master BBSR 516 sends a message to the BCMCS controller 504 to assert that it is now operating as the master BBSR. The backup master BBSR 516 also sends a message to the slave BBSRs 508-514 and the other backup BBSRs 518-524. To provide this signaling, a connection 526 allows each backup BBSR 516-524 to communication with each system component.
Absence of a signal being sent may also indicate that a backup BBSR needs to assume the operational responsibility of an associated BBSR. For example, the master BBSR 502 typically sends an acknowledgement signal to the BCMCS controller 504 for each instance of a multicast flow being set up with a slave BBSR (based on receiving a setup acknowledgement signal from the slave BBSR). However, if the BCMCS controller 504 does not receive the acknowledgement signal from the master BBSR 502, the controller assumes that the master BBSR has failed and resends the multicast information to the backup master BBSR 516 (to assure that the multicast flow(s) is properly assigned to the slave BBSR). Thereby, assuming a failure has occurred based upon the absence of the acknowledge signal, the probability that multicast information is not processed or disseminated to the slave BBSRs is reduced.
In this arrangement, the backup master BBSR 516 serves as a dedicated backup to the master BBSR 502, however, other more distributed methodologies may be implemented. For example, upon determining that a BBSR is inoperable or has failed, the backup BBSRS may collectively identify which backup should assume responsibility. Based upon a vote or a group decision (based on current processing capacity), an appropriate backup BBSRs may be identified. Additionally, the backup assignments may be dynamically altered based on current and scheduled processing needs.
To monitor the functionality of a BBSR, a BBSR monitor 528 is executed by a corresponding backup BBSR (e.g., the backup master BBSR 516). Similar to the Flow Manager 320, the BBSR Monitor 528 may be provided by one or more processors (e.g., general processors, specialized devices, etc.) executing instructions to perform operations. The processors may be implemented as a monolithic structure or in a distributed structure. The instructions may reside in a memory (e.g., random access memory (RAM), read-only memory (ROM), static RAM (SRAM), etc.) and be stored on one or more mass storage devices (e.g., magnetic, magneto-optical disks, or optical disks, etc.).
Referring to
Some operations also include sending 604 a status request signal to the BBSR being monitored. Typically, upon receiving the status request signal, a properly functioning BBSR returns an acknowledgement signal to the backup BBSR. If the BBSR being monitored is malfunctioning or has failed, the acknowledgement signal may not be sent. If an acknowledgement signal is not received, or not received within a predefined time period, for example, the BBSR being monitored is considered to be malfunctioning or to have failed. Thereby, operations also include determining 606 if an acknowledgement signal has been properly received. If an acknowledgement signal is received, the BBSR Monitor 528 returns to identify the next instance in which to send another status request signal. If an acknowledgement signal is not received, the BBSR Monitor 528 initiates transferring 608 the operations of the BBSR under monitor to the appropriate backup BBSR.
In some embodiments one or more processors may execute instructions to perform the operations of the BBSR Monitor 528, e.g., represented in flowchart 600. For example, one or more general processors (e.g., a microprocessor) and/or one or more specialized devices (e.g., an application specific integrated circuit (ASIC), etc.) may execute instructions. One or more of the processors may be implemented in a single integrated circuit as a monolithic structure or in a distributed structure. In some embodiments the instructions that are executed by the processors may reside in a memory (e.g., random access memory (RAM), read-only memory (ROM), static RAM (SRAM), etc.). The instructions may also be stored on one or more mass storage devices (e.g., magnetic, magneto-optical disks, or optical disks, etc.)
One or more of the operations associated with the BBSR Monitor 528 may be performed by one or more programmable processors (e.g., a microprocessor, an ASCI, etc.) executing a computer program. The execution of one or more computer programs may include operating on input data (e.g., data provided from a source external to the RAN, etc.) and generating output (e.g., sending data to a destination external to the RAN, etc.). The operations may also be performed by a processor implemented as special purpose logic circuitry (e.g., an FPGA (field programmable gate array), an ASIC (application-specific integrated circuit), etc.).
Operation execution may also be executed by digital electronic circuitry, or in computer hardware, firmware, software, or in combinations of them. The operations described in flowchart 600 (along with other operations of the Flow Manager 320) may be implemented as a computer program product, e.g., a computer program tangibly embodied, e.g., in a machine-readable storage device (e.g., RAM, ROM, hard-drive, CD-ROM, etc.). The computer program product may be executed by or control the operation of, data processing apparatus, e.g., a programmable processor, a computer, or multiple computers. A computer program may be written in one or more forms of programming languages, including compiled or interpreted languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment. A computer program may be deployed to be executed on one computing device (e.g., controller, computer system, etc.) or on multiple computing devices (e.g., multiple controllers) at one site or distributed across multiple sites and interconnected by a communication network.
Although the techniques have been described with respect to a RAN that supports the 1×EV-DO family of standards, the techniques are also applicable to other standards such as the Universal Mobile Telecommunications Systems (UMTS) standard.
Other embodiments are within the scope of the following claims.
Number | Name | Date | Kind |
---|---|---|---|
6711144 | Kim et al. | Mar 2004 | B1 |
6731618 | Chung et al. | May 2004 | B1 |
6741862 | Chung et al. | May 2004 | B2 |
6781999 | Eyuboglu et al. | Aug 2004 | B2 |
7170871 | Eyuboglu et al. | Jan 2007 | B2 |
7200391 | Chung et al. | Apr 2007 | B2 |
7242958 | Chung et al. | Jul 2007 | B2 |
7277446 | Abi-Nassif et al. | Oct 2007 | B1 |
7299278 | Ch'ng | Nov 2007 | B2 |
7489696 | Longoni et al. | Feb 2009 | B2 |
7558356 | Pollman et al. | Jul 2009 | B2 |
7558588 | To et al. | Jul 2009 | B2 |
7603127 | Chung et al. | Oct 2009 | B2 |
20020196749 | Eyuboglu et al. | Dec 2002 | A1 |
20030100311 | Chung et al. | May 2003 | A1 |
20040095881 | Borella et al. | May 2004 | A1 |
20050213555 | Eyuboglu et al. | Sep 2005 | A1 |
20050221825 | Osugi | Oct 2005 | A1 |
20050243749 | Mehrabanzad et al. | Nov 2005 | A1 |
20050245279 | Mehrabanzad et al. | Nov 2005 | A1 |
20060058056 | Das et al. | Mar 2006 | A1 |
20060067422 | Chung | Mar 2006 | A1 |
20060067451 | Pollman et al. | Mar 2006 | A1 |
20060126509 | Abi-Nassif et al. | Jun 2006 | A1 |
20060159045 | Ananthaiyer et al. | Jul 2006 | A1 |
20060240782 | Pollman et al. | Oct 2006 | A1 |
20060291420 | Ng | Dec 2006 | A1 |
20060294241 | Cherian et al. | Dec 2006 | A1 |
20070026884 | Rao | Feb 2007 | A1 |
20070058628 | Palnati et al. | Mar 2007 | A1 |
20070077948 | Sharma et al. | Apr 2007 | A1 |
20070097916 | Eyuboglu et al. | May 2007 | A1 |
20070115896 | To et al. | May 2007 | A1 |
20070140172 | Garg et al. | Jun 2007 | A1 |
20070140184 | Garg et al. | Jun 2007 | A1 |
20070140185 | Garg et al. | Jun 2007 | A1 |
20070140218 | Nair et al. | Jun 2007 | A1 |
20070155329 | Mehrabanzad et al. | Jul 2007 | A1 |
20070220573 | Chiussi et al. | Sep 2007 | A1 |
20070223494 | Hyyrynen et al. | Sep 2007 | A1 |
20070230419 | Raman et al. | Oct 2007 | A1 |
20070238442 | Mate et al. | Oct 2007 | A1 |
20070238476 | Sharma et al. | Oct 2007 | A1 |
20070242648 | Garg et al. | Oct 2007 | A1 |
20070248042 | Harikumar et al. | Oct 2007 | A1 |
20080003988 | Richardson | Jan 2008 | A1 |
20080013488 | Garg et al. | Jan 2008 | A1 |
20080062925 | Mate et al. | Mar 2008 | A1 |
20080065752 | Ch'ng et al. | Mar 2008 | A1 |
20080069020 | Richardson | Mar 2008 | A1 |
20080069028 | Richardson | Mar 2008 | A1 |
20080076398 | Mate et al. | Mar 2008 | A1 |
20080080408 | Gao | Apr 2008 | A1 |
20080117842 | Rao | May 2008 | A1 |
20080119172 | Rao et al. | May 2008 | A1 |
20080120417 | Harikumar et al. | May 2008 | A1 |
20080139203 | Ng et al. | Jun 2008 | A1 |
20080146232 | Knisely | Jun 2008 | A1 |
20080151843 | Valmikam et al. | Jun 2008 | A1 |
20080159236 | Ch'ng et al. | Jul 2008 | A1 |
20080162924 | Chinitz et al. | Jul 2008 | A1 |
20080162926 | Xiong et al. | Jul 2008 | A1 |
20080253550 | Ch'ng et al. | Oct 2008 | A1 |
20080254792 | Ch'ng | Oct 2008 | A1 |
20090034440 | Samar et al. | Feb 2009 | A1 |
20090082020 | Ch'ng et al. | Mar 2009 | A1 |
20090088155 | Kim | Apr 2009 | A1 |
20090116445 | Samar et al. | May 2009 | A1 |
20090154447 | Humblet | Jun 2009 | A1 |
20090156165 | Raghothaman et al. | Jun 2009 | A1 |
20090156195 | Humblet | Jun 2009 | A1 |
20090156218 | Garg et al. | Jun 2009 | A1 |
20090163202 | Humblet et al. | Jun 2009 | A1 |
20090163216 | Hoang et al. | Jun 2009 | A1 |
20090163238 | Rao et al. | Jun 2009 | A1 |
20090164547 | Ch'ng et al. | Jun 2009 | A1 |
20090168766 | Eyuboglu et al. | Jul 2009 | A1 |
20090168788 | Den et al. | Jul 2009 | A1 |
20090170440 | Eyuboglu et al. | Jul 2009 | A1 |
20090170475 | Ch'Ng et al. | Jul 2009 | A1 |
20090170520 | Jones | Jul 2009 | A1 |
20090170547 | Raghothaman et al. | Jul 2009 | A1 |
20090172169 | Ramaswamy et al. | Jul 2009 | A1 |
20090172397 | Kim | Jul 2009 | A1 |
20090186626 | Raghothaman et al. | Jul 2009 | A1 |
Number | Date | Country |
---|---|---|
2452688 | Mar 2009 | GB |
Number | Date | Country | |
---|---|---|---|
20080117842 A1 | May 2008 | US |