Communication protocol for personal computer system human interface devices over a low bandwidth, bi-directional radio frequency link

Information

  • Patent Application
  • 20040203388
  • Publication Number
    20040203388
  • Date Filed
    April 09, 2003
    21 years ago
  • Date Published
    October 14, 2004
    19 years ago
Abstract
A system and method for maintaining communications with a radio frequency (RF) peripheral device such as an RF input device and an RF output device. A computer may search for an RF peripheral device by transmitting a signal request on available channels until a response is received from an RF peripheral device. If the RF channel becomes busy and/or jammed, the RF peripheral device may tune into a predetermined channel while the computer scans for another channel to use. Once the computer finds a better channel, the computer may go to the predetermined channel and broadcast the new channel location to the RF peripheral device. In addition, if an RF signal arrives incomplete or corrupt, the computer may transmit a negative acknowledgement to the RF peripheral device, which may retransmit the previous RF signal.
Description


BACKGROUND OF THE INVENTION

[0001] 1. Field of the Invention


[0002] The present invention relates generally to managing peripheral device usage for a computer system and specifically to maintaining reliable communication between a computer system and peripheral devices.


[0003] 2. Description of the Related Art


[0004] Computer systems may use many different types of peripheral devices. For example, computer systems may receive input from user input devices such as, but not limited to, a pointing device, such as a computer mouse, a keyboard, a microphone, a camera, and a joystick. Because managing wires from different user input devices may be cumbersome, the computer system may use wireless, e.g., radio frequency (RF), signals to communicate with the user input device. For example, an RF peripheral device may transmit an RF signal to a computer system to provide the computer system with a user's inputs (e.g., mouse movements, keyboard keys pressed, etc.). The RF peripheral device may also receive RF signals from the computer system.


[0005] While using the RF signals may allow peripheral devices to communicate with the computer system without requiring wires, RF signals may have disadvantages. For example, computer systems may have trouble detecting or establishing a connection with new RF peripheral devices. RF channels used to transmit RF signals may become busy and/or jammed. In addition, RF signals may be lost, may be incomplete, or may be corrupt when received by the computer system. As a result, computer system programs may be disrupted because of incomplete or missing user inputs. Current computer system software may not be programmed to adjust to intermittent signals from an RF peripheral device, and therefore may require consistent input despite an intermittent RF environment.



SUMMARY OF THE INVENTION

[0006] In one embodiment, a computer may comprise or be coupled to a first radio frequency transmitter/receiver (RFTR). The first RFTR may communicate with a second RFTR coupled to an RF peripheral device. In one embodiment, the first RFTR may establish communications with the second RFTR using a discovery process and, if needed, reestablish communications with the second RFTR using a reunion process


[0007] In one embodiment of the discovery process, the first RFTR may transmit a request for all unassociated RF peripheral devices to respond over a first channel. A micro-controller coupled to the first RFTR may determine if a response from the second RFTR is received over the first channel. If the response from the second RFTR is not received, the first RFTR may transmit the request for all unassociated RF peripheral devices to respond over a second channel and then resume determining if a response is received from the second RFTR over the second channel. In one embodiment, the second RFTR may also tune into one channel after another until a connection is established with the first RFTR.


[0008] If the first RFTR receives a response from the second RFTR, a wireless connection may be established between the first RFTR and the second RFTR. In one embodiment, if the second RFTR responds, a computer may form an association with the RF peripheral devices coupled to the second RFTR, assign the RF peripheral device an address, and enumerate the capabilities of the RF peripheral device.


[0009] Communications between the first RFTR and the second RFTR may be interrupted. In one embodiment, the micro-controller coupled to the computer may determine if an expected data packet (i.e., in a communication from the second RFTR) is not received, an incomplete data packet is received, or a corrupt data packet is received from the second RFTR. The first RFTR may then transmit a negative acknowledgment (NAK) to the second RFTR to indicate that the second RFTR needs to resend the last data packet. In one embodiment, the first RFTR may transmit a request to the second RFTR to have the RF peripheral device resend the last data packet. The second RFTR may then resend the last data packet to the first RFTR.


[0010] In one embodiment of the reunion process, if the current channel being used by the first RFTR and the second RFTR becomes jammed for an extended period of time and communications need to be reestablished, the second RFTR may go to a pre-determined channel and wait for instructions or for a third channel location from the first RFTR. In one embodiment, the second RFTR may have the pre-determined channel location in memory to tune into in case communications with the first RFTR is discontinued on a current channel. In another embodiment, the first RFTR may transmit a channel to the second RFTR to tune into to wait for further instructions.


[0011] In one embodiment, the first RFTR may continue to tune into different channels until a usable channel (e.g., a clear and relatively inactive channel) is found. In one embodiment, when the first RFTR finds a usable channel, the first RFTR may return to the pre-determined channel and transmit the third channel location (i.e., the usable channel location) to the second RFTR. In one embodiment, the first RFTR may not be able to find a clear channel. Instead, the first RFTR may have to determine the best channel available. In one embodiment, the first RFTR may pick a channel that is clearer/more inactive than the previous channel the first RFTR was using.


[0012] In one embodiment, the first RFTR may tune into the third channel after transmitting the third channel location to the second RFTR. The first RFTR may transmit a request for the second RFTR to respond over the third channel. Communications may be established with the second RFTR over the third channel once the second RFTR response has been received over the third channel. In one embodiment, communications may be reestablished with the second RFTR without requesting that the second RFTR respond on the third channel. For example, the first RFTR may assume that the second RFTR tuned into the third channel until the first RFTR gets an indication that the second RFTR has not tuned into the third channel (e.g., a lack of response from the second RFTR).







BRIEF DESCRIPTION OF THE DRAWINGS

[0013] A better understanding of the present invention may be obtained when the following detailed description is considered in conjunction with the following drawings, in which:


[0014]
FIG. 1 illustrates a computer system with an RF peripheral device, according to one embodiment;


[0015]
FIG. 2 illustrates a block diagram of a computer and an RF peripheral device, according to one embodiment;


[0016]
FIG. 3 illustrates a flowchart of a method for discovering an RF peripheral device, according to one embodiment;


[0017]
FIG. 4 illustrates a flowchart of a method for managing interruptions in communication with an RF peripheral device, according to one embodiment; and


[0018]
FIG. 5 illustrates a flowchart of a method for reestablishing a connection with an RF peripheral device, according to one embodiment; and


[0019]
FIG. 6 illustrates a flowchart of a method for reestablishing communications with an RF peripheral device, according to one embodiment.







[0020] While the invention is susceptible to various modifications and alternative forms, specific embodiments thereof are shown by way of example in the drawings and are herein described in detail. It should be understood, however, that the drawings and detailed description thereto are not intended to limit the invention to the particular form disclosed, but on the contrary, the intention is to cover all modifications, equivalents and alternatives falling within the spirit and scope of the present invention as defined by the appended claims.


DETAILED DESCRIPTION OF THE INVENTION


FIG. 1: Computer System With RF Computer Mouse

[0021]
FIG. 1 illustrates an embodiment of a computer system with a computer and an RF peripheral device. In various embodiments, the RF peripheral device may include a wireless input device such as, but not limited to, an RF pointing device, such as an RF computer mouse 105, an RF keyboard 107, an RF camera, an RF joystick, an RF gamepad, an RF touchscreen, or an RF microphone. Embodiments of the RF peripheral devices described herein may also be used with wireless output devices, such as an RF speaker, an RF display 101, and an RF printer. Other RF peripheral devices are also contemplated. In one embodiment, a computer 102 may have a processor/memory housing 103. In one embodiment, the computer 102 may communicate with the RF peripheral device through a peripheral base station 109 coupled to the processor/memory housing 103.


[0022] In one embodiment, RF signals may be transmitted between the computer 102 and the RF peripheral devices communicably coupled to the computer 102. For example, RF computer mouse movements may be transmitted to the computer 102 to control a cursor and keystrokes may be transmitted from the RF keyboard 107 to the computer 102 to provide user typed characters. Other input is also contemplated. As another example, output may be transmitted to the RF display 101 to display an image on the RF display 101. In one embodiment, the computer 102 may communicate with multiple RF peripheral devices on one channel. For example, adjacent computers may each use a separate channel to communicate with the respective computer's RF peripheral devices. Other channel usage is also contemplated. In one embodiment, the RF peripheral device may communicate with the computer 102 through a bit stream relayed half-duplex communication using a frequency shift keying (FSK) RF link. Other communication forms are also contemplated.



FIG. 2: Block Diagram of a Computer System and an RF Peripheral Device

[0023]
FIG. 2 illustrates a block diagram of an embodiment of a computer system with an RF peripheral device. The computer system 215 may comprise a computer 213 coupled to a micro-controller 209 through a universal serial bus (USB) interface 211. In one embodiment, the micro-controller 209 may have a micro-processor and a first memory with instructions executable by the micro-processor. In one embodiment, a processor, such as a central processing unit (CPU), and the first memory, such as, but not limited to, a random access memory (RAM) or hard disk memory, may be used in place of the micro-controller 209. Other processors and other memories are also contemplated. The first memory may have instructions executable by the micro-processor to control a first radio frequency transmitter/receiver (RFTR) such as, but not limited to, a first bulk complementary metal oxide semiconductor (CMOS) transceiver 207. In one embodiment, the first RFTR and the micro-controller 209 may be located in the peripheral base station 109 (see FIG. 1) coupled to the computer 213 and use modulation and demodulation of RF signals for communication. In one embodiment, the first RFTR and the micro-controller 209 may be located in the processor/memory housing 103.


[0024] In one embodiment, the RF peripheral device 217 may have a second RFTR such as, but not limited to, a bulk CMOS transceiver 205 for receiving and transmitting configuration information to the first bulk CMOS transceiver 207 coupled to the computer 213. The second RFTR may be coupled to a micro-controller 203. In one embodiment, the micro-controller 203 may have a micro-processor and a second memory with instructions executable by the micro-processor. The RF peripheral device 217 may use various sensors and switches 201 to gather information from the user for transmitting to the computer 213. For example, an RF computer mouse may have an X direction sensor and a Y direction sensor for detecting user input movement. Other sensors and switches are also contemplated. In addition, while the block diagram shows an embodiment with sensors and switches 201, other sources for inputs and outputs are also contemplated. For example, the computer 213 may send output information to an RF speaker.



FIG. 3: Flowchart for Discovering an RF Peripheral Device

[0025]
FIG. 3 is a flowchart of an embodiment of a method for discovering an RF peripheral device. It should be noted that in various embodiments of the methods described below, one or more of the steps described may be performed concurrently, in a different order than shown, or may be omitted entirely. Other additional steps may also be performed as desired.


[0026] In 301, the first RFTR may transmit a request for the second RFTR to respond over a first channel. For example, the first RFTR may transmit a request for all unassociated RF peripheral devices to respond (e.g., RF peripheral devices currently being used with another computer may not respond) over the first channel. In one embodiment, the first RFTR may send a request for specific RF peripheral devices to respond. For example, the first RFTR transmit a request that all unassociated RF keyboards respond. The first RFTR may then transmit a request that all unassociated computer mouses respond. Other devices and requests are also contemplated.


[0027] In 303, a micro-controller may determine if a response from the second RFTR was received.


[0028] In 305, if the response from the second RFTR was not received over the first channel, the first RFTR may transmit the request for the second RFTR to respond over a second channel. The method may then continue at 303 until a second RFTR response is received. In one embodiment, the second RFTR may also tune into one channel after another until a connection is established. In one embodiment, the second RFTR may tune into clear and inactive channels or may tune into a pre-determined startup channel. Other channels are also contemplated.


[0029] In one embodiment, the first RFTR may send proxy signals to the computer at start-up to represent standard peripheral devices, such as, but not limited to, a computer mouse and a keyboard, regardless of whether the RF peripheral devices have actually been discovered yet. In one embodiment, the computer may be expecting the existence of standard peripheral devices before the micro-controller has actually located the standard peripheral devices. The second RFTR may continue the process at 303 until the standard peripheral devices have been discovered. Sending proxy signals for other RF peripheral devices are also contemplated.


[0030] In 307, if the response is received from the second RFTR, a wireless connection may be established between the first RFTR and the second RFTR. In one embodiment, if an RF peripheral device responds through the second RFTR, the computer may form associations with the responding RF peripheral device, assign the RF peripheral device an address, and enumerate the capabilities of the RF peripheral device. For example, the RF peripheral device may be assigned a device identification (ID) and have a host ID transmitted to it. The RF peripheral device may then become part of a “pico-net” of associated RF peripheral devices and the computer. Other actions by the computer corresponding to the RF peripheral device response are also contemplated.


[0031] In one embodiment, as the RF peripheral device communicates with the computer and vice-versa, the device ID and the host ID may be used by the RF peripheral device and the computer respectively. The computer may only respond to RF peripheral device communications that contain the device ID. Similarly, in one embodiment, the RF peripheral device may only respond to communications from the computer that contains the host ID. In another embodiment, communications between the device may use the ID of the device or computer being communicated with. For example, the RF peripheral device may only respond to communications that contain the RF peripheral devices ID, and the computer may only respond to communications that contain the host ID. In one embodiment, the RF peripheral device and the computer may communicate in a polled fashion. For example, the computer may transmit data to or request data from the RF peripheral device.


[0032] In one embodiment, if multiple RF peripheral devices of a similar type respond, the computer may instruct a user to use the particular RF peripheral device he/she intends to use. For example, if multiple RF keyboards respond, the computer may instruct the user to strike any key on the RF keyboard the user intends to use. The computer may then be able to establish communications with the RF peripheral device that sends input at the time of the request for the user to use the RF peripheral device. Other methods of identifying the correct RF peripheral device to connect to are also within the scope of the invention.


[0033] In one embodiment, because communication with the RF peripheral devices may be intermittent, the micro-controllers for the computer and the RF peripheral device may need to maximize data transmission efficiency. For example, the micro-controllers may minimize overhead (i.e., standard information used to identify transmitted information) in high level protocol of communication data payloads (i.e., containing the information to transmit) used to communicate. The micro-controllers may also minimize overhead of the packet definitions used for information transmitted by the RF peripheral devices. For example, a minimized command (CMD) packet, a minimized OUT packet, a minimized datagram (DGM) packet, and a minimized data (DAT) packet may use a header block, a payload block, and cyclic redundancy code (CRC). A minimized IN packet, a minimized acknowledgement (ACK) packet, a minimized negative acknowledgement (NAK) packet, and a minimized error (ERR) packet may use a header block and CRC. In one embodiment, the header may include blocks including, but not limited to, a three bit packet identifier (Pid) block, a three bit human interface device (HID) address block, a two bit endpoint address (Ndp) block, a one bit sequence toggle (Seq) block, a one bit end of transfer (Eot) block, a four bit payload length (Len) block, and a two bit reserved (Rsrv) block. In one embodiment, the payload may include, but is not limited to, eight bit payload data byte blocks. In one embodiment, the payload may include up to 16 payload data byte blocks. Other payloads, blocks, and block sizes are also contemplated.



FIG. 4: Flowchart for Managing Interruptions in Communication with an RF Peripheral Device

[0034]
FIG. 4 illustrates a flowchart of an embodiment of a method for managing interruptions in communication with an RF peripheral device. It should be noted that in various embodiments of the methods described below, one or more of the steps described may be performed concurrently, in a different order than shown, or may be omitted entirely. Other additional steps may also be performed as desired.


[0035] In 401 and 403, the micro-controller may determine if an expected data packet (i.e., a communication from the second RFTR) is not received, an incomplete data packet is received, or a corrupt data packet is received from the second RFTR. For example, interference on a channel used by the first RFTR and the second RFTR to communicate may occasionally interrupt a data packet sent between the first RFTR and the second RFTR. In 403, if no interruption in communication is detected, the micro-controller may continue displaying at 401.


[0036] In 405, the first RFTR coupled to the computer may transmit a negative acknowledgment (NAK) to the second RFTR to indicate that the second RFTR needs to resend the last data packet. In one embodiment, the first RFTR may transmit a request to the second RFTR to have the RF peripheral device resend the last data packet. Other methods of indicating to the second RFTR to resend the last data packet are also contemplated.


[0037] In 407, the second RFTR may resend the last data packet to the first RFTR. In one embodiment, the first RFTR may send proxy signals to the computer while waiting for the data packet to be resent by the second RFTR. Other uses of proxy signals are also contemplated. Because the computer may receive proxy signals at start-up and may receive proxy signals when communications with the second RFTR are interrupted, the computer may not be aware of interruptions in communications. In other words, the computer may not require additional software to use the RF peripheral devices.



FIG. 5: Flowchart for Reestablishing Communications with an RF Peripheral Device

[0038]
FIG. 5 illustrates a flowchart of an embodiment of a method for reestablishing communications with an RF peripheral device. It should be noted that in various embodiments of the methods described below, one or more of the steps described may be performed concurrently, in a different order than shown, or may be omitted entirely. Other additional steps may also be performed as desired.


[0039] In 501, a first RFTR may transmit a third channel location to the second RFTR. In one embodiment, the second RFTR may have a pre-determined channel location in memory to tune into in case communications with the first RFTR is discontinued on a current channel. For example, if the current channel being used by the first RFTR and the second RFTR becomes jammed (e.g., becomes active with other communications) for an extended period of time, the second RFTR may go to a pre-determined channel and wait for instructions or a third channel location from the first RFTR. In one embodiment, the first RFTR may transmit a channel for the second RFTR to tune into to wait for further instructions. Other instructions for the second RFTR are also contemplated. In one embodiment, the first RFTR may continue to tune into different channels until a clear and relatively inactive channel is found. In one embodiment, when the first RFTR finds a usable channel, the first RFTR may return to the pre-determined channel and transmit the third channel location (i.e., the usable channel location). In one embodiment, the first RFTR may not be able to find a clear channel. The first RFTR may have to determine the best channel available. In one embodiment, the first RFTR may only pick a channel that is clearer/more inactive than the previous channel the first RFTR was using.


[0040] In 503, the first RFTR may tune into the third channel.


[0041] In 505, the first RFTR may transmit a request for the second RFTR to respond over the third channel to insure that the second RFTR made a transition from using the predetermined channel to the third channel.


[0042] In 507, communications may be established with the second RFTR over the third channel once the second RFTR response has been received over the third channel. In one embodiment, communications may be established with the second RFTR without requesting that the second RFTR respond on the third channel. In one embodiment, a micro-controller coupled to the first RFTR may send proxy signals to the computer to represent the RF peripheral device until communications with the RF peripheral device can be reestablished. In one embodiment, the first RFTR may assume that the second RFTR tuned into the third channel until the first RFTR gets an indication that the second RFTR did not tune into the third channel (e.g., a lack of response from the second RFTR).



FIG. 6: Alternate Flowchart for Reestablishing Communications with an RF Peripheral Device

[0043]
FIG. 6 illustrates an alternate flowchart of an embodiment of a method for reestablishing communications with an RF peripheral device. It should be noted that in various embodiments of the methods described below, one or more of the steps described may be performed concurrently, in a different order than shown, or may be omitted entirely. Other additional steps may also be performed as desired.


[0044] In 601, an RF peripheral device may cycle through available channels. In one embodiment, the RF peripheral device may sequence through available channels trying to detect communications from the computer. For example, the RF peripheral device and the computer may be able to communicate over eight available channels. In one embodiment, the RF peripheral device may only be able to communicate over fewer available channels. In one embodiment, the RF peripheral device may recognize communications from the computer because of a host ID in the communications (e.g., a host ID in a packet header).


[0045] In 603, a computer may cycle through available clear channels broadcasting a reunion request. In one embodiment the computer may cycle through available clear channels at substantially the same time as the RF peripheral device sequences through available channels.


[0046] In 605, the RF peripheral device may detect a communication from the computer. For example, the RF peripheral device may detect a communication with a host ID. In one embodiment, the communication from the computer may be the broadcast reunion request.


[0047] In 607, the RF peripheral device may transmit an acknowledgment to the computer.


[0048] In 609, communications between the RF peripheral device and the computer may resume.


[0049] Other embodiments of reestablishing communication are also contemplated. For example, the second RFTR may search for a new channel (i.e., third channel) to use and transmit the new channel location to the first RFTR when the new channel has been found. In one embodiment, the micro-controllers for the RF peripheral device and the computer may be programmed to scan available channels in a particular order. For example, the micro-controllers may switch to a fourth channel for a pre-determined time period and attempt to reestablish communications. If unsuccessful in reestablishing communications, the micro-controllers may switch to a fifth channel for a pre-determined time period, and so on.


[0050] Various embodiments may further include receiving or storing instructions and/or information implemented in accordance with the foregoing description upon a carrier medium. Suitable carrier media may include storage media or memory media such as magnetic or optical media, e.g., disk or CD-ROM, random access memory or other memory, as well as transmission media or RF signals such as electrical, electromagnetic, or digital RF signals, conveyed via a communication medium such as a network and/or a wireless link.


[0051] Further modifications and alternative embodiments of various aspects of the invention may be apparent to those skilled in the art in view of this description. Accordingly, this description is to be construed as illustrative only and is for the purpose of teaching those skilled in the art the general manner of carrying out the invention. It is to be understood that the forms of the invention shown and described herein are to be taken as the presently preferred embodiments. Elements and materials may be substituted for those illustrated and described herein, parts and processes may be reversed, and certain features of the invention may be utilized independently, all as would be apparent to one skilled in the art after having the benefit of this description of the invention. Changes may be made in the elements described herein without departing from the spirit and scope of the invention as described in the following claims.


Claims
  • 1. A computer system, comprising: a processor; a first radio frequency transmitter/receiver (RFTR) coupled to the processor; a peripheral device comprising a second RFTR configured to transmit a radio frequency (RF) signal, wherein the first RFTR and the second RFTR are operable to communicate in a wireless fashion; a memory coupled to the processor and configured to store program instructions executable to: transmit a request using the first RFTR for a second RFTR response over a first channel; and transmit the request using the first RFTR for the second RFTR response over a second channel if the second RFTR response is not received by the first RFTR.
  • 2. The computer system of claim 1, wherein the program instructions are further executable to transmit a signal to the processor on computer start-up to represent the peripheral device before the second RFTR response is received by the first RFTR.
  • 3. The computer system of claim 1, wherein the program instructions are further executable to establish a wireless connection with the second RFTR if the second RFTR response is received.
  • 4. The computer system of claim 1, wherein the second RFTR scans available channels until the second RFTR receives the request for the second RFTR response from the first RFTR.
  • 5. The computer system of claim 1, wherein the peripheral device is a computer mouse, a keyboard, a touchscreen, a gamepad, a joystick, a microphone, or a camera.
  • 6. The computer system of claim 1, wherein the processor is part of a micro-controller coupled to the first RFTR.
  • 7. A computer system, comprising: a processor; a first radio frequency transmitter/receiver (RFTR) coupled to the processor; a peripheral device comprising a second RFTR configured to transmit an RF signal, wherein the first RFTR and the second RFTR are operable to communicate in a wireless fashion; a memory coupled to the processor and configured to store program instructions executable to: transmit a third channel location to the second RFTR; tune into a third channel; and establish communication with the second RFTR over the third channel if the second RFTR response has been received over the third channel.
  • 8. The computer system of claim 7, wherein the program instructions are further executable to transmit a request for the second RFTR response.
  • 9. The computer system of claim 7, wherein the third channel location is transmitted to the second RFTR over a pre-determined channel.
  • 10. The computer system of claim 7, wherein the first RFTR sends signals to a computer, comprising the processor and the memory, through a USB connection without the computer becoming aware of an interruption in RF communication with the peripheral device.
  • 11. The computer system of claim 7, wherein the peripheral device is a computer mouse, a keyboard, a touchscreen, a gamepad, a joystick, a microphone, or a camera.
  • 12. The computer system of claim 7, wherein the processor is part of a micro-controller coupled to the first RFTR.
  • 13. A computer system, comprising: a processor; a first radio frequency transmitter/receiver (RFTR) coupled to the processor; a peripheral device comprising a second RFTR configured to transmit an RF signal, wherein the first RFTR and the second RFTR are operable to communicate in a wireless fashion; a memory coupled to the processor and configured to store program instructions executable to: identify if the first RFTR has not received an expected data packet from the second RFTR, has received a partial data packet from the second RFTR, or has received a corrupt data packet from the second RFTR; and transmit from the second RFTR the expected data packet or an original data packet that was a source of the partial data packet or the corrupt data packet.
  • 14. The computer system of claim 13, wherein the program instructions are further executable to transmit a negative acknowledgement to the second RFTR if the expected data packet is not received from the second RFTR, the partial data packet is received from the second RFTR, or the corrupt data packet is received from the second RFTR.
  • 15. The computer system of claim 13, wherein the program instructions are further executable to transmit a request to the second RFTR to resend the original data packet if the expected data packet is not received from the second RFTR, the partial data packet is received from the second RFTR, or the corrupt data packet is received from the second RFTR.
  • 16. The computer system of claim 13, wherein the first RFTR sends signals to a computer, comprising the processor and the memory, through a USB connection without the computer becoming aware of an interruption in RF communication with the peripheral device.
  • 17. The computer system of claim 13, wherein the peripheral device is a computer mouse, a keyboard, a gamepad, a joystick, a microphone, a touchscreen, or a camera.
  • 18. The computer system of claim 13, wherein the processor is part of a micro-controller coupled to the first RFTR.
  • 19. A method, comprising: transmitting a request for a second RFTR response over a first channel; transmitting the request for the second RFTR response over a second channel if the second RFTR response is not received; and establishing a wireless connection with a second RFTR if the second RFTR response is received.
  • 20. The method of claim 19, further comprising: transmitting a signal to a processor on computer start-up to represent a peripheral device before the second RFTR response is received by a first RFTR.
  • 21. The method of claim 19, further comprising: scanning available channels by the second RFTR until the second RFTR receives the request for the second RFTR response.
  • 22. The method of claim 19, wherein the second RFTR is coupled to a peripheral device.
  • 23. A method, comprising: transmitting a third channel location to a second RFTR; tuning to a third channel; and establishing communications with the second RFTR over the third channel once a second RFTR response has been received over the third channel.
  • 24. The method of claim 23, further comprising: transmitting a request for the second RFTR response over the third channel.
  • 25. A method, comprising: identifying if a first RFTR has not received an expected data packet from a second RFTR, has received a partial data packet from the second RFTR, or has received a corrupt data packet from the second RFTR; and transmitting from the second RFTR the expected data packet or an original data packet that was a source of the partial data packet or the corrupt data packet.
  • 26. The method of claim 25, further comprising: transmitting a negative acknowledgement to the second RFTR if the expected data packet is not received from the second RFTR, the partial data packet is received from the second RFTR, or the corrupt data packet is received from the second RFTR.
  • 27. The method of claim 25, further comprising: transmitting a request to the second RFTR to resend the original data packet if the expected data packet is not received from the second RFTR, the partial data packet is received from the second RFTR, or the corrupt data packet is received from the second RFTR.
  • 28. A computer system, comprising: a processor; a first radio frequency transmitter/receiver (RFTR) coupled to the processor; a peripheral device comprising a second RFTR configured to transmit an RF signal, wherein the first RFTR and the second RFTR are operable to communicate in a wireless fashion; a memory coupled to the processor and configured to store program instructions executable to: cycle the first RFTR through available channels, wherein at each available channel a reunion request is broadcast; receive an acknowledgment from a second RFTR, wherein the second RFTR cycles through available channels at substantially the same time as the first RFTR cycles through available channels and transmits an acknowledgment to the first RFTR when a communication from the first RFTR is detected by the second RFTR.
  • 29. The computer system of claim 28, wherein each available channel is a clear available channel.
  • 30. The computer system of claim 28, wherein the communication from the first RFTR is recognized by the second RFTR because of a host ID in the communication.
  • 31. A method comprising: cycling the first RFTR through available channels, wherein at each available channel a reunion request is broadcast; receiving an acknowledgment from a second RFTR, wherein the second RFTR cycles through available channels at substantially the same time as the first RFTR cycles through available channels and transmits an acknowledgment to the first RFTR when a communication from the first RFTR is detected by the second RFTR.
  • 32. The method of claim 31, wherein each available channel is a clear available channel.
  • 33. The method of claim 31, wherein the communication from the first RFTR is recognized by the second RFTR because of a host ID in the communication.
  • 34. A system, comprising: means for transmitting a request for a second RFTR response over a first channel; means for transmitting the request for the second RFTR response over a second channel if the second RFTR response is not received over the first channel; and means for establishing a wireless connection with a second RFTR once the second RFTR response is received.
  • 35. A system, comprising: a means for transmitting a third channel location to a second RFTR; a means for tuning to a third channel; and a means for establishing communications with the second RFTR over the third channel once a second RFTR response has been received over the third channel.
  • 36. A system, comprising: means for identifying if a first RFTR has not received an expected data packet from a second RFTR, has received a partial data packet from the second RFTR, or has received a corrupt data packet from the second RFTR; and means for transmitting from the second RFTR the expected data packet or an original data packet that was a source of the partial data packet or the corrupt data packet.
  • 37. A system, comprising: means for cycling the first RFTR through available channels, wherein at each available channel a reunion request is broadcast; means for receiving an acknowledgment from a second RFTR, wherein the second RFTR cycles through available channels at substantially the same time as the first RFTR cycles through available channels and transmits an acknowledgment to the first RFTR when a communication from the first RFTR is detected by the second RFTR.
  • 38. A carrier medium comprising program instructions, wherein the program instructions are computer executable to: transmit a request for a second RFTR response over a first channel; transmit the request for the second RFTR response over a second channel if the second RFTR response is not received over the first channel; and establish a wireless connection with a second RFTR once the second RFTR response is received.
  • 39. A carrier medium comprising program instructions, wherein the program instructions are computer executable to: transmit a third channel location to a second RFTR; tune into a third channel; and establish communications with the second RFTR over the third channel once a second RFTR response has been received over the third channel.
  • 40. A carrier medium comprising program instructions, wherein the program instructions are computer executable to: identify if a first RFTR has not received an expected data packet from a second RFTR, has received a partial data packet from the second RFTR, or has received a corrupt data packet from the second RFTR; and transmit from the second RFTR the expected data packet or an original data packet that was a source of the partial data packet or the corrupt data packet.
  • 41. A carrier medium comprising program instructions, wherein the program instructions are computer executable to: cycle the first RFTR through available channels, wherein at each available channel a reunion request is broadcast; receive an acknowledgment from a second RFTR, wherein the second RFTR cycles through available channels at substantially the same time as the first RFTR cycles through available channels and transmits an acknowledgment to the first RFTR when a communication from the first RFTR is detected by the second RFTR.