US20050243059A1 - High-reliability computer interface for wireless input devices - Google Patents

High-reliability computer interface for wireless input devices Download PDF

Info

Publication number
US20050243059A1
US20050243059A1 US11/081,381 US8138105A US2005243059A1 US 20050243059 A1 US20050243059 A1 US 20050243059A1 US 8138105 A US8138105 A US 8138105A US 2005243059 A1 US2005243059 A1 US 2005243059A1
Authority
US
United States
Prior art keywords
message
transceiver
mode
host
ack
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
US11/081,381
Inventor
Martin Morris
Krishnasamy Anandakumar
Suresh Singamsetty
Dennis Chung Kwan
Hock Law
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Jaalaa Inc
Original Assignee
Jaalaa Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Jaalaa Inc filed Critical Jaalaa Inc
Priority to US11/081,381 priority Critical patent/US20050243059A1/en
Assigned to JAALAA, INC. reassignment JAALAA, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: ANANDAKUMAR, KRISHNASAMY, KWAN, DENNIS CHING CHUNG, LAW, HOCK THYE, MORRIS, MARTIN GEORGE, SINGAMSETTY, SURESH KUMAR
Publication of US20050243059A1 publication Critical patent/US20050243059A1/en
Abandoned legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W52/00Power management, e.g. TPC [Transmission Power Control], power saving or power classes
    • H04W52/04TPC
    • H04W52/18TPC being performed according to specific parameters
    • H04W52/28TPC being performed according to specific parameters using user profile, e.g. mobile speed, priority or network state, e.g. standby, idle or non transmission
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode
    • G06F1/3206Monitoring of events, devices or parameters that trigger a change in power modality
    • G06F1/3215Monitoring of peripheral devices
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode
    • G06F1/3234Power saving characterised by the action undertaken
    • G06F1/3237Power saving characterised by the action undertaken by disabling clock generation or distribution
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode
    • G06F1/3234Power saving characterised by the action undertaken
    • G06F1/325Power saving in peripheral device
    • G06F1/3259Power saving in cursor control device, e.g. mouse, joystick, trackball
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode
    • G06F1/3234Power saving characterised by the action undertaken
    • G06F1/325Power saving in peripheral device
    • G06F1/3271Power saving in keyboard
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F13/00Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • G06F13/38Information transfer, e.g. on bus
    • G06F13/382Information transfer, e.g. on bus using universal interface adapter
    • G06F13/385Information transfer, e.g. on bus using universal interface adapter for adaptation of a particular data processing system to different peripheral devices
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/02Input arrangements using manually operated switches, e.g. using keyboards or dials
    • G06F3/023Arrangements for converting discrete items of information into a coded form, e.g. arrangements for interpreting keyboard generated codes as alphanumeric codes, operand codes or instruction codes
    • G06F3/0231Cordless keyboards
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/03Arrangements for converting the position or the displacement of a member into a coded form
    • G06F3/033Pointing devices displaced or positioned by the user, e.g. mice, trackballs, pens or joysticks; Accessories therefor
    • G06F3/0354Pointing devices displaced or positioned by the user, e.g. mice, trackballs, pens or joysticks; Accessories therefor with detection of 2D relative movements between the device, or an operating part thereof, and a plane or surface, e.g. 2D mice, trackballs, pens or pucks
    • G06F3/03543Mice or pucks
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/03Arrangements for converting the position or the displacement of a member into a coded form
    • G06F3/033Pointing devices displaced or positioned by the user, e.g. mice, trackballs, pens or joysticks; Accessories therefor
    • G06F3/038Control and interface arrangements therefor, e.g. drivers or device-embedded control circuitry
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/03Arrangements for converting the position or the displacement of a member into a coded form
    • G06F3/033Pointing devices displaced or positioned by the user, e.g. mice, trackballs, pens or joysticks; Accessories therefor
    • G06F3/038Control and interface arrangements therefor, e.g. drivers or device-embedded control circuitry
    • G06F3/0383Signal control means within the pointing device
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W52/00Power management, e.g. TPC [Transmission Power Control], power saving or power classes
    • H04W52/04TPC
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2213/00Indexing scheme relating to interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • G06F2213/38Universal adapter
    • G06F2213/3814Wireless link with a computer system port
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W52/00Power management, e.g. TPC [Transmission Power Control], power saving or power classes
    • H04W52/04TPC
    • H04W52/18TPC being performed according to specific parameters
    • H04W52/28TPC being performed according to specific parameters using user profile, e.g. mobile speed, priority or network state, e.g. standby, idle or non transmission
    • H04W52/287TPC being performed according to specific parameters using user profile, e.g. mobile speed, priority or network state, e.g. standby, idle or non transmission when the channel is in stand-by
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W52/00Power management, e.g. TPC [Transmission Power Control], power saving or power classes
    • H04W52/04TPC
    • H04W52/38TPC being performed in particular situations
    • H04W52/48TPC being performed in particular situations during retransmission after error or non-acknowledgment
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D10/00Energy efficient computing, e.g. low power processors, power management or thermal management

Definitions

  • Various computers and microprocessor-based devices and systems provide one or more user input devices to allow a user to control certain operations.
  • Such an input device may be separated from the host computer or device and thus a communication link and an interface may be implemented to support proper communications between the input device and the host computer or device.
  • each of the input device and the host computer/device includes appropriate software and hardware, for the communication link and interface.
  • a typical desktop or laptop computer may have a keyboard and a pointing device for a user to input data or commands for controlling or operating the computer.
  • the pointing device for computers include a mouse, a touch pad, a trackball, and a pointing stick (IBM laptops).
  • IBM laptops pointing stick
  • examples of some other user input devices include joysticks and game pads for computers and microprocessor-based game machines, control units for other microprocessor-based devices.
  • a user uses an input button, a control stick, one key or a key combination, or a combination thereof to input data or a command. Circuitry in the input device converts the input data or command into a proper form for transmitting to the computer or device.
  • Such an input device generally uses a particular communication link to transmit the input data or command to the computer or device.
  • An input device may be a wireless input device using a wireless communication link or a wired link using an electrical cable.
  • Input devices with wired links may be implemented based on the PS/2 keyboard interface, the USB 1.0 and USB 2.0 interfaces, and other interfaces.
  • the wireless communication link may be implemented by a radiation transmitter to send the input to a corresponding radiation receiver at the computer or device.
  • Many wireless input devices use RF radiation links based on different radio interfaces such as IEEE 802.5.14 for low speed links and wireless USB 2.0 and IEEE 1394 for relatively high speed links.
  • Some of these wired or wireless input devices may use the Human Interface Device (HID) protocol over wired or wireless USB links or other non-USB communication links.
  • HID Human Interface Device
  • Wireless input devices beneficially increase the flexibility of the interaction between a user and a host computer in that no wired connection is required with the host computer.
  • a wired connection generally provides a source of power for an input device
  • wireless input devices are required to be self-powered (e.g., battery-powered).
  • batteries used to power existing wireless input devices typically last for a period of time significantly less than the useful life of such devices. As a consequence, the convenience and value of such devices are diminished as a consequence of the need for regular battery replacement.
  • FIG. 1 is a diagram of a computer system of the present invention incorporating a wireless input interface
  • FIG. 2 is a diagram of the layered architecture of the present invention for the wireless unit contained in the host computer;
  • FIG. 3 is a block diagram of the wireless unit of the present invention.
  • FIG. 4 is a block diagram of the present invention depicting an exemplary embodiment of the wireless unit
  • FIG. 5 is a block diagram of the present invention depicting an exemplary embodiment of the wireless unit
  • FIG. 6 is an event trace diagram of the present invention for mouse sleep sequence
  • FIG. 7 is an event trace diagram of the present invention for mouse sleep sequence with lost messages
  • FIG. 8 is an event trace diagram of the present invention for enabling of the transmitter/receiver within the RF units
  • FIG. 9 is a state transition diagram of the present invention demonstrating the manner in which the data rate and channel of the wireless unit are changed.
  • FIG. 10 is an event trace diagram of the present invention for normal keyboard sequence
  • FIG. 11 is shown a computer system of the present invention.
  • FIG. 12 is an event trace diagram of the present invention demonstrating the messages exchanged during a pairing operation
  • FIG. 13 is a state transition diagram of the present invention.
  • FIG. 14 is a flowchart of the present invention of a carrier sense/clear channel assessment procedure
  • FIG. 15 is a flowchart of the procedure for dynamically adjusting the CCA threshold level used by the RF unit
  • FIG. 16 is a high-level flow diagram representative of a general approach to interference handling consistent with the present invention.
  • FIG. 17 is a flow diagram of the present invention for the method in which a host transceiver converts between HDR and MDR modes;
  • FIG. 18 is a flow diagram of the present invention for the method in which a device transceiver converts between operations within the HDR and MDR modes;
  • FIG. 19 is a timing diagram of the present invention for the transition of the host transceiver into and out of “awake” and “sleep state” operation;
  • FIG. 20 is a state transition diagram of the present invention for operation of the host transceiver when in Suspend mode
  • FIG. 21 is a state transition diagram of the present invention depicting the modifications to the messaging protocol of the mouse transceiver upon entry of the host transceiver into Suspend mode;
  • FIG. 22 is a high-level diagram of the present invention showing the incorporation of EEPROM in the wireless transceivers
  • FIG. 23 is a flow diagram of the present invention for the inclusion of a patch EEPROM in the wireless transceivers.
  • FIG. 24 is a flow diagram of the present invention for substituting a new function for a default function.
  • a computer system 100 incorporating a wireless input interface in accordance with the invention includes a host computer 102 , a wireless keyboard 104 and a wireless pointing device or “mouse” 106 .
  • the wireless keyboard 104 and the wireless mouse 106 are in communication with the host computer 102 over wireless communication links 108 and 110 , respectively.
  • the host computer 102 includes or is attached to a wireless unit 112 through which the communication links 108 and 110 are respectively established with a wireless unit 114 within the wireless keyboard 114 and a wireless unit 116 of the wireless mouse 106 .
  • the wireless unit 112 may be built into the chassis of the host computer 102 or added as an external peripheral device in the form of, for example, a “dongle”. As an external peripheral device, the wireless unit 112 may either be interfaced to the computer 102 through a wired USB connection or by other available means such as the PS/2 keyboard connector.
  • the wireless keyboard 0 . 104 and the wireless mouse 106 interact with the host computer 102 via wireless communication links 108 and 110 .
  • the wireless unit 112 receives keystroke and other data originating from the wireless keyboard 104 and the wireless mouse 106 over wireless communication links 108 and 110 and passes it to the host computer 102 in such a way that the host computer 102 is unaware of the existence of the wireless links 108 and 110 .
  • the wireless units 112 , 114 and 116 of the present invention are configured to enable the communication links 108 and 110 to exhibit low latency and high reliability relative to conventional approaches employed using wireless peripheral devices.
  • the wireless keyboard 104 and wireless mouse 106 will generally be battery powered devices, minimization of power consumption will typically be a primary design consideration.
  • the wireless units 114 and 116 respectively incorporated within the wireless keyboard 104 and the wireless mouse 106 are disposed to cycle among various power-saving modes so as to conserve battery power and thereby substantially reduce the frequency of required battery replacement operations.
  • FIG. 2 illustratively represents a view of the layered architecture 200 of the wireless unit 112 , it being understood that in the exemplary embodiment the wireless units 114 , 116 are of essentially the same general architecture.
  • the layers depicted in FIG. 2 may be realized in hardware, firmware, or as software instructions stored on a computer-readable medium.
  • the unit 112 is seen to include a physical layer 204 , a media access control (MAC) layer 208 , and a device interface layer 212 .
  • the physical layer 204 interfaces with an antenna element 220 .
  • MAC media access control
  • the device interface layer 212 may be implemented as any known interface permitting the wireless unit 112 to interface with the host computer 102 .
  • a known interface may be designed to support communications between the host computer 102 and the wireless unit 112 in accordance with a standard communications protocol.
  • the device interface 212 may by designed to serve as a USB; PS2 or GPIO interface.
  • the MAC layer 208 serves to control access to the wireless communication links 108 , 110 . That is, MAC layer 208 is responsible for enabling data to be transferred between the device interface 212 and the physical layer 204 , and vice-versa. As shown, a portion of the functions associated with the MAC layer 208 in the exemplary embodiment are carried out by baseband hardware 260 , but this is certainly not required.
  • the physical layer 204 may comprise any structure or collection of elements functioning to transmit and receive bits of data over the wireless communication links 108 , 110 . As shown, the physical layer 204 includes a radio interface portion 250 , which represents the registers and signals that are used to transfer messages between the physical layer 204 and the MAC layer 208 .
  • One potential implementation of the physical layer 204 is described in, for example, the above-referenced provisional application filed on even date herewith.
  • FIG. 3 illustratively represents a block diagram of the wireless unit 112 of FIG. 1 according to an exemplary embodiment of the present invention.
  • the wireless unit 112 (also referred to herein as the host transceiver 112 ) includes a CPU 302 that is coupled via a CPU bus (not shown) to ROM 304 , RAM 306 , a modem 308 , baseband hardware 309 , wake-up logic 310 , USB 312 , and an input/output (I/O) module 316 .
  • the wakeup logic in the host device although it is not generally required in this application, is an integral part of the logic implementation, which is the same in both the computer and peripheral input device.
  • an RF unit 314 which is coupled to an antenna 220 .
  • a power interface portion 330 provides power regulation to both analog and digital components of the host transceiver 112 .
  • the host transceiver 112 is realized as a single system-on-chip IC with protocol stack and application software being integrated in built-in mask ROM, but this is certainly not required.
  • the host transceiver 112 when the host transceiver 112 is transmitting information to one of the wireless devices 114 , 116 , the information is first encrypted, formatted and protected with a cyclical redundancy check (CRC) by the baseband hardware 309 .
  • the modem 308 then receives and encodes (e.g., with differential binary phase shift key (BPSK) encoding) the formatted, encrypted and CRC protected information before it is up-converted for transmission by the RF portion 314 .
  • BPSK differential binary phase shift key
  • the RF unit 314 When receiving a signal from one of the devices 114 , 116 , the RF unit 314 down converts the received signal to an intermediate frequency (IF), and converts the IF frequency signal to a digital IF signal.
  • the modem 308 then decodes the digital IF signal and checks the CRC to regenerate the original encrypted information, which is then decrypted by the baseband hardware 309 .
  • the modem 308 in the exemplary embodiment has four different modes: a high data rate (HDR) mode; a medium data rate (MDR) mode; a low data rate (LDR) mode and a spread mode.
  • the HDR mode is the default mode, which can provide 150 kbps data transmission.
  • the data rates for the MDR, LDR and spread mode are 30 kbps, 10 kbps and 13.64 kbps respectively.
  • spread mode is used when there is interference from similar wireless device(s) (e.g., other host and device transceivers), and MDR is used when there is strong interference (e.g., narrow-band interference) such as from citizen band (CB) radio.
  • CB citizen band
  • the host transceiver 112 is able to detect interference and switch to appropriate modes automatically. As a consequence, the host transceiver 112 provides highly reliable wireless data transfers even in an environment with multiple other wireless users.
  • the LDR mode is for European compliance purposes and may be omitted in transceivers intended for non-European markets.
  • the data transmission rates of the exemplary embodiment i.e., 150 kbps, 30 kbps, 10 kbps and 13.64), are more than sufficient for typical manual input devices (e.g., the keyboard 104 and mouse 106 ), with very little or no perceptible latency.
  • the RF portion 314 in the exemplary embodiment operates to transmit and receive signals in accordance with the operating mode (i.e., the HDR, MDR, LDR and spread mode) of the modem 308 .
  • the RF portion 314 supports multiple selectable transmit frequencies so data may be selectively transmitted over a frequency channel that is substantially free from a strong narrowband interferer such as a citizens band (CB) radio.
  • CB citizens band
  • the I/O unit 316 of the host transceiver 112 is programmable to allow general-purpose I/O pins (not shown) of the host transceiver 112 to be selectively dedicated to a variety of interface communication protocols for communication with the host computer 102 .
  • the UO unit 312 is programmable so as to allow the following five I/O communication protocols to be selectively used with the general-purpose 10 pins: a general purpose input/output (GPIO) 318 , an intelligent interface controller (I 2 C) path 320 , a universal asynchronous receiver/transmitter interface (UART) 322 , a USB interface 324 and a bidirectional synchronous serial interface (PS/2) 326.
  • GPIO general purpose input/output
  • I 2 C intelligent interface controller
  • UART universal asynchronous receiver/transmitter interface
  • PS/2 bidirectional synchronous serial interface
  • the I 2 C interface 320 is a two-wire, bi-directional serial bus which” provides a simple method of data exchange between devices.
  • the I 2 C interface is used for downloading executable programs from external EEPROM to RAM 306 (e.g., to change functionality of certain aspects of the host transceiver), and/or reading configuration parameters that are stored in external EEPROM.
  • the clock speed for the I 2 C interface is software programmable from 200 Hz to 400 KHz (When CPU clock is 12 MHz).
  • the host transceiver 112 may either be selected (e.g., via software) to be a master or a slave device.
  • the UART interconnect 322 provides serial communications between the host transceiver and terminal equipment (e.g., the host computer 102 ).
  • the baud rate is software programmable from 250 bps to 330 Kbps.
  • the universal Serial Bus (USB) interface 324 is a personal computer (PC) interconnect that can support simultaneous attachment of multiple devices.
  • the USB module 312 in the present embodiment is realized by dedicated hardware and includes a USB function controller (not shown) and a full speed (12 Mb/s) USB transceiver (not shown).
  • the PS/2 interface 326 is a two-wire (DATA, CLOCK), bi-directional synchronous serial interface.
  • the PS/2 interface 326 in one embodiment includes two PS/2 interfaces: one for communications with the keyboard 104 and the other for communications with the mouse 106 .
  • dedicated hardware in the host transceiver 112 is associated with one or more of the above described communication protocols. Although it is not necessary to dedicate hardware for I/O communications, latency may be substantially reduced over alternative CPU-driven software implementations.
  • the wireless unit 114 (also referred to herein as the keyboard transceiver 114 ) includes a CPU 402 that is coupled to ROM 404 , RAM 406 , a modem 408 , baseband hardware 409 , RF unit 414 and an I/O module 416 , which in the exemplary embodiment, are substantially the same as the corresponding functional components within the host transceiver 112 . Also shown are wake-up logic portion 410 and a keyboard scan module 412 .
  • exemplary communication protocols are available for the keyboard transceiver 114 to communicate with other devices: a general-purpose input/output (GPIO) 418 , an intelligent interface controller (I 2 C) path 420 , a universal asynchronous receiver/transmitter interface (UART) 422 , and a keyboard interface 424 . These protocols and interfaces are made available to support various design options for the keyboard.
  • GPIO general-purpose input/output
  • I 2 C intelligent interface controller
  • UART universal asynchronous receiver/transmitter interface
  • the keyboard interface 424 in one embodiment is realized with 20 GPIO ports that are dedicated to 20 corresponding columns of a keyboard's bare key switch contacts and 8 GPIO ports that are dedicated to 8 corresponding rows of the keyboard's bare key switch contacts.
  • three optional high-drive open-drain outputs support up to three LED devices on the keyboard.
  • the I/O module 416 is programmed to switch the 28 GPIO ports dedicated to the keyboard to the keyboard scan module 412 .
  • the keyboard scan module 412 detects key presses and releases by receiving inputs from the keyboard interface 424 and performing debouncing and rollover handling. Debouncing is performed by keeping an image of the keyboard state in memory for the last N1 (e.g., three) scan cycles. In the exemplary embodiment, the keyboard scan module 412 does not report a state change until it persists for N1 scan cycles (the scan rate is approximately N2 (e.g., four) milliseconds per scan). As a consequence, the debounce time is approximately N1*N2 milliseconds. In one embodiment, the values of N1 and N2 may be changed via the host transceiver 112 by updating EEPROM of the host transceiver 112 with new values. The host transceiver 112 then sends the updated information to the keyboard transceiver 114 in a configuration message when communication is established with the host transceiver 112 .
  • N1 e.g., three
  • the keyboard scan module 412 does not report a state change until it persists for N
  • the keyboard scan module 412 provides key code (i.e., column and row) information to the CPU 402 , and the CPU 402 generates a message indicating the row and column.
  • the message with row and column information is than transmitted from the keyboard transceiver 114 to the host transceiver 112 .
  • the host transceiver 112 receives the message and then maps the row and column data into key codes, macros, or special functions.
  • the CPU 402 instructs the wake-up logic portion 410 , as described further herein, to place the keyboard transceiver 114 in a sleep mode.
  • the wake-up logic portion 410 in combination with the power interface 430 , then effectively shuts down the CPU 402 by depriving it of a clock signal.
  • a scan oscillator (not shown) in the keyboard scan module 412 is also deactivated so that the keyboard scan module 412 no longer carries out the keyboard scanning described above. Instead, the row inputs to the keyboard scan module 412 are logically ORed together so that any key-press will trigger the keyboard scan module 412 to restart the scanning process.
  • the keyboard scan module 412 When the keyboard scan module 412 (operating in sleep mode) detects a key press, it sends a key press notification signal to the wake-up logic portion 410 , which in combination with the power interface 430 , brings the keyboard transceiver 114 out of sleep mode by reactivating the clock signal to the CPU 402 . Additional details of communications between the keyboard transceiver 114 and the host transceiver 112 when the keyboard transceiver 114 enters and exits sleep mode are described in the above-referenced provisional application filed on even date herewith.
  • the wireless unit 116 (also referred to herein as the mouse transceiver 116 ) includes a CPU 502 that is coupled to ROM 504 , RAM 506 , a modem 508 , baseband hardware 509 , RF unit 514 , and the I/O module 516 , which in the exemplary embodiment, are substantially the same as the corresponding functional components within the keyboard transceiver 114 . Also coupled to the CPU 502 is a wake-up logic portion 510 , which is in communication with a mouse scan module 512 .
  • exemplary communication protocols are available for the mouse transceiver 114 to communicate with other devices: a general-purpose input/output (GPIO) 518 , an intelligent interface controller (I 2 C) path 520 , a universal asynchronous receiver/transmitter interface (UART) 522 , and a mouse interface 524 . These protocols and interfaces are made available to support various design options for the mouse.
  • GPIO general-purpose input/output
  • I 2 C intelligent interface controller
  • UART universal asynchronous receiver/transmitter interface
  • the mouse transceiver 116 receives, via a mouse interface 524 , motion signals from mouse motion transducer 510 , which is configured and positioned within the wireless mouse 106 to convert motion of the wireless mouse 106 into the motion signals.
  • the configuration of the mouse interface 524 in this embodiment is selectable to conform to the communication protocol of the mouse motion transducer 524 , which may vary depending upon the manufacturer and the type of technology (e.g., mechanical or optical position tracking) utilized by the wireless mouse 106 .
  • the I/O module 516 is programmable so that GPIO pins of the mouse transceiver 116 (not shown) are, dedicated for communications in accordance with the protocols utilized by the wireless mouse 106 .
  • the mouse interface 524 is configured to communicate as an optical mouse interface according to a secure digital I/O communication protocol (SDIO), which uses an I 2 C-like read/write sequencing scheme in which the mouse transceiver 116 operates as the master and the wireless mouse 106 as the slave.
  • SDIO secure digital I/O communication protocol
  • This configuration may be used, for example, to communicate with AgilentTM wireless mouse devices with SDIO interface capability including AgilentTM device No. ADNS-2030.
  • the mouse interface 524 is configured to communicate as an optical mouse interface according to serial peripheral interface (SP 1 ) protocols.
  • the mouse interface 524 includes four signals: a clock (CLK), a slave output (SO), a slave input (S 1 ) and a slave select (CS), and the mouse transceiver 116 operates as the master while an optical sensor in the mouse 106 operates as the slave.
  • CLK clock
  • SO slave output
  • S 1 slave input
  • CS slave select
  • the mouse interface 524 includes one pair of quadrature signals for each of the X, Y, and Z axes, wherein the X and Y axes are associated with the translational movement of the wireless mouse 106 and the Z-axis is associated with movement of a roller ball of the wireless mouse 106 .
  • the mouse scan module 512 operates in either a mechanical mode or an optical mode depending upon whether the wireless mouse 106 utilizes mechanical or optical position tracking.
  • a single-axis state machine of a type described in the above-referenced copending patent application is executed by the mouse scan module 512 with respect to each of three perpendicular directional axes (i.e., the X, Y and Z axes).
  • Operation in the mechanical mode also relies upon a button press detector (not shown), which preferably implements “debouncing” in the same manner as was described above with reference to the keyboard scan module 512 .
  • the mouse scan module 512 does not execute state machines during operation in the optical mode. Instead, the mouse scan module 512 sends serial messages to the wireless mouse 106 and receives back position difference information or “deltas”. These position deltas replace the counter values utilized during mechanical mode operation within the mouse position reports generated by the mouse scan module 512 .
  • the MAC layer 208 is responsible for formatting messages conveyed by the MAC layer 208 to and from the device interface 212 and the physical layer 204 .
  • This aspect of the MAC layer 208 may be appreciated with reference to FIGS. 6, 7 and 10 , which are event trace diagrams representative of various messages exchanged between the host wireless unit 112 and the keyboard/mouse wireless units 114 , 116 under the control of their respective MAC layers 208 .
  • an event trace diagram 1000 is provided which depicts the message sequences associated with normal operation of the keyboard/mouse wireless units 114 , 116 .
  • FIG. 10 also illustrates a message sequence between the mouse wireless unit 116 and the host wireless unit 112 in the case in which a message sent by the mouse wireless unit 116 is lost or corrupted and re-transmitted.
  • FIG. 6 there is shown an event trace diagram 600 representative of an event sequence pursuant to which the wireless unit 116 for the wireless mouse 106 transitions into and out of sleep state under the control of its MAC layer 208 .
  • the counters associated with each of the three directional axes are compared against a predefined value (e.g., 2). If none of the counters exceed this threshold, the time-out is restarted and sleep resumed; otherwise, a mouse report message is sent to the host transceiver 112 and these counters are reset to zero.
  • a predefined value e.g. 2
  • FIG. 7 illustrates, in a manner similar to FIG. 6 , an event trace diagram 700 which represents an event sequence pursuant to which the wireless unit 116 for the wireless mouse 106 transitions into and out of sleep state under the control of its MAC layer 208 in the case in which messages are lost between the host wireless unit 112 and the wireless unit 1116 .
  • the MAC layer 208 is also responsible for the overall transfer of data between the device interface 212 and the physical layer 204 and controls the transition of the applicable wireless unit 112 , 114 , 116 into and out of various operative states. Specifically, the MAC layer 208 of a given wireless unit is disposed to govern its transition among sleep, listen, backoff and pending states in the manner described hereinafter.
  • FIG. 13 there is shown a state transition diagram 1300 representative of the manner in which transitions are made between the various states of a state machine executed by the MAC layer * 208 .
  • the wireless units 114 , 116 receives a message containing a long sequence (described below) identifying such unit 114 , 116 , its MAC layer 208 checks the CRC to decide if the message is valid.
  • a message received from the host wireless unit 112 (other than an ACK only) is acknowledged immediately. This acknowledgement may, but need not be, accompanied by data intended for the host wireless unit 112 . If a wireless unit 114 , 116 sends data with or without a “piggyback” acknowledgement, the host wireless unit 112 is disposed to acknowledge the new data.
  • ACK time-out As is indicated by FIG. 13 , if data is sent by a wireless unit 114 , 116 and an acknowledgement is not immediately received following a short “ACK time-out” period, it is retransmitted by the wireless unit 114 , 116 after waiting a “BACKOFF time-out” intended to break deadlocks caused by simultaneous transmissions.
  • the “ACK time-out” period is selected to be roughly equal to the sum of (i) the round trip message transfer time between the applicable device (i.e., the wireless keyboard 104 or wireless mouse 106 ) and the host computer 102 , and (ii) an allowance for processing time. In this regard an ACK time-out period of approximately 1.2 ms has been found to be appropriate for a number of anticipated implementations.
  • time-out values described herein as being associated with the MAC layer 208 are dependent upon the data rate used for the relevant transmission.
  • the values provided herein assume operation in a the HDR mode (i.e., 150 kb/s) discussed above.
  • the provided timeout values should be quintupled.
  • the provided timeout values should be multiplied by a factor of 15 in connection with operation in the LDR mode (i.e., 10 kb/s).
  • the BACKOFF timeout is randomized between wireless units. Such randomization may be effected by, for example, utilizing the device ID of the applicable wireless unit in generating the period of the BACKOFF timeout. If a wireless unit is required to delay for the period of an additional BACKOFF timeout in connection with a given transmission, the duration of the BACKOFF timeout may be increased linearly in accordance with the device ID. Specifically, in an embodiment where N corresponds to the number of consecutive ACK timeouts for a given data packet, and IDMx is the device ID of the transmitting wireless unit, the duration of the BACKOFF timeout is given as BACKOFFmin+(N*f(IDx)). In this embodiment BACKOFFmin is approximately 0.5 ms, and f(IDx) is chosen such that the average extension per consecutive BACKOFF timeout increases by approximately 1 ms.
  • each message preferably contains a one-bit “transmit sequence number” which is incremented (toggled) for each new transmission and maintained the same for a retransmission.
  • a one-bit “receive sequence number” is incremented whenever a new packet is acknowledged by a wireless unit. This bit indicates the sequence number expected in the next packet from the transmitting wireless unit, and thus effectively serves as an acknowledgment of receipt of the prior packet. In other words, if a wireless unit successfully receives a packet numbered “zero”, the receive sequence number is set to “I” in the next packet sent by such wireless unit. This receive sequence number of “1” is repeated in subsequent transmissions from the wireless interface device until it successfully receives another packet, which should have a transmit sequence number of “1”.
  • a first host/device wireless unit sends a packet of sequence “1” which is not received by a second device/host wireless unit
  • the receipt by the first wireless unit of a packet of receive sequence “1” (or an ACK timeout) transmitted by the second wireless unit indicates to the first wireless unit that its transmission of the sequence “1” packet was not received and it retransmits this packet.
  • the packet of sequence “1” transmitted by the first wireless unit is received by the second wireless unit but the acknowledgment which it transmits is lost en route to the first wireless unit, the first wireless unit will either time out the acknowledgement (and retransmit) or receive another packet, which includes an acknowledgment in the form of the correct sequence number.
  • any retransmission by the first wireless unit will generally be unnecessary, since the duplicate sequence number will be detected by the second wireless unit upon receipt of the retransmitted packet and the message re-acknowledged (and the duplicate, retransmitted packet discarded).
  • the communication link between the applicable host/device wireless units is reset (i.e., the send sequence number and the receive sequence number are both set to “0”).
  • the receiving wireless unit Upon receipt of a valid reset message, the receiving wireless unit acknowledges it with a packet of receive sequence number “1” and send sequence number “0”.
  • the term “three retransmissions” is intended to indicate that a set of three retransmissions of an original message have occurred, which results in the occurrence of four ACK timeouts and three BACKOFF timeouts. In one embodiment this consumes an average of approximately (4*1.2)+(3*(0.5+1)) ms or 9.3 ms, depending on the device ID. This interval provides a basis for the 10 ms duration of the LISTEN timeout, which is described below.
  • the receipt of an ACK by a host/device wireless unit concludes a present transaction between such unit and the device/host wireless unit with which it is in communication.
  • the wireless unit 112 listens for unsolicited (random access) messages from the wireless units 114 , 116 following receipt of an ACK.
  • the wireless units 114 , 116 enter a sleep mode following receipt of an ACK.
  • the host wireless unit 112 retransmits the previously received message following expiration of the ACK timeout period.
  • the keyboard/mouse wireless unit 114 , 116 enters sleep mode as soon as it transmits this “lost” ACK, it will not receive the retransmission from the host wireless unit 112 and the host wireless unit 112 will be unaware that its message has been successfully received.
  • the keyboard/mouse wireless unit 114 , 116 is configured to wait a short period in LISTEN mode prior to entering sleep mode so as to maximize the likelihood that it will receive any possible retransmission from the host wireless unit 112 .
  • any message/acknowledgement transaction should complete in less than approximately 10 ms.
  • a keyboard/mouse wireless unit 114 , 116 sends an ACK only message, it waits until expiration of a LISTEN timeout period of 10 ms before entering sleep mode. This effectively ensures that any retransmissions from the host wireless unit 112 will be received by the keyboard/mouse wireless unit 114 , 116 prior to expiration of the LISTEN timeout period.
  • packets transmitted by the keyboard/mouse wireless unit 1114 , 116 are of the following general format:
  • the radio interface 250 ( FIG. 2 ) is representative of the set of registers and signals used in transferring messages between baseband hardware 260 within the MAC layer 208 and the remainder of each wireless unit.
  • the baseband hardware 260 within the keyboard/mouse wireless units 114 , 116 performs encryption/decryption, CRC generation and checking, serialization/de-serialization, and also provides an interface to the RF units 414 , 514 .
  • the radio interface 250 within the keyboard/mouse wireless units 114 , 116 facilitates performance of at least the following functions: (i) enabling of the transmitter within the RF unit 414 , 514 , (ii) enabling of the receiver within the RF unit 414 , 514 , (iii) sending a message to the RF unit 414 , 514 , (iv) receiving a message from the RF unit 414 , 514 , (v) link quality assessment, (vi) selection of the rate used within the RF unit 414 , 415 , (vii) selection of the channel used within the RF unit 414 , 415 , (viii) control of output power of the transmitter within the RF unit 414 , 415 , (ix) setting the long sequence of the receiver within the RF unit 414 , 415 , and (x) setting the long sequence of the destination wireless' unit within the transmitter of the RF unit 414 , 415 .
  • an event trace diagram 800 depicts the enabling of the transmitter/receiver within the RF units 414 , 514 using single-bit signals under control of the MAC layer 208 .
  • the wireless unit 114 , 116 enters sleep mode, it disables both the transmitter and the receiver within its RF unit 414 , 514 .
  • the MAC layer 208 initiates the sending of a message by loading the body of the message into a set of registers within the radio interface 250 and signaling “send” to the baseband hardware 260 .
  • the MAC layer 208 loads the following information into registers within the radio interface 250 :
  • the MAC layer 208 calculates the proper long sequence of the destination device by writing the device ID of such device into a register within the radio interface and reading back the long sequence.
  • the MAC layer 208 is configured to track both of the keyboard/mouse wireless units 114 , 116 and maintain separate long sequences for each of them.
  • the MAC layer 208 of the host wireless unit 112 also calculates a long sequence for the pairing device ID when the unit 112 is operative in a dynamic pairing (DP) mode (discussed below).
  • DP dynamic pairing
  • the baseband hardware 260 When “send” is asserted, the baseband hardware 260 continues the transmission process by sending the short sequence, which is a predetermined fixed training sequence used to bit synchronize the receiving modem to the transmitting modem, the specified long sequence, followed by the header and the body of the message itself. If the header specifies a device type of keyboard, the message portion is encrypted prior to transmission. Finally, the CRC is appended to the transmission.
  • the short sequence is a predetermined fixed training sequence used to bit synchronize the receiving modem to the transmitting modem, the specified long sequence, followed by the header and the body of the message itself. If the header specifies a device type of keyboard, the message portion is encrypted prior to transmission. Finally, the CRC is appended to the transmission.
  • the baseband hardware 260 listens for a message with a long sequence matching the long sequence of the applicable keyboard/mouse wireless unit 114 , 116 .
  • the MAC layer 208 calculates its “own” long sequence by writing the device ID of the applicable keyboard/mouse wireless unit 114 , 116 into a register within the radio interface 250 . Except during pairing (discussed below), this need only be done once; during pairing, the reserved pairing device 1D is instead written to the radio interface 250 .
  • the MAC layer 208 also sets a message pointer register (16 bits) in order to inform the baseband hardware 260 of the location in which the received message should be placed.
  • the baseband hardware 260 receives the ensuing header and message into a header register and a message buffer (not shown), respectively.
  • the message is first decrypted if the header specifies a device type of keyboard.
  • the baseband hardware 260 checks the received CRC. If the CRC is valid, it asserts “data ready” to the MAC layer 208 . Conversely, the baseband hardware 260 must not present data (i.e., assert “data ready”) to the MAC layer 208 if the CRC is invalid, although the data may already be present within the message buffer.
  • the MAC layer 208 is configured to respond as quickly as possible to the receipt of a data message with a message in the reverse direction indicating acknowledgement.
  • the applicable RF units are capable of falling back to operation in the MDR mode (i.e., 30 kb/s).
  • 5 channels are available for hopping during operation in the MDR mode.
  • the LDR mode is employed in order to comply with the pertinent regulations. Fallback from operation in the HDR mode to the MDR mode and channel selection are controlled by the MAC layer 208 . This control is facilitated by a received signal strength indication (“RSSI”) provided by the RF unit, which is asserted in the presence of strong interference within the frequency bands of interest.
  • RSSI received signal strength indication
  • FIG. 9 there is shown a state transition diagram 900 representative of the manner in which the MAC layer 208 changes the data rate and channel of the wireless unit in which it is disposed.
  • the data rate and channel of the RF unit of a wireless interface device are changed, if necessary, immediately prior to transmission of a data packet. These changes are based upon the current RSSI status and the success or failure of the previous transmission by the RF unit.
  • the channel sequence followed is 0-3-1-4-2-0. It has been found that adhering to a fixed sequence of this type minimizes the searching required to re-locate a partner wireless unit following a channel change. Since an interfering signal may straddle adjacent channels, it is desirable to avoid hopping to an adjacent channel; and the sequence above (and its mirror in time) is the only such sequence which prevents this from occurring.
  • the selected channel is only changed in response to link failure (which presumably occurs due to interference). Since the host wireless unit 112 rarely initiates a transaction with a keyboard/mouse wireless unit 114 , 116 (i.e., most data traffic is inbound to the unit 112 ), while operative in medium rate mode it is possible for it to “sit” on a bad channel as it is unlikely to receive information indicating that the channel is bad. In order to avoid this situation, the host wireless unit 112 is configured to change channels every 1 to 2 seconds during operation in medium rate mode.
  • each keyboard/mouse wireless unit 114 , 116 Since each keyboard/mouse wireless unit 114 , 116 is likely to be in sleep mode when this change in channel occurs, each will generally experience an ACK timeout following transmission of its next message. This timeout will also result in a change in channel. It is noted that in the case of the wireless unit 114 of the keyboard 104 , the ACK timeout will cause it to reset encryption; accordingly, the host wireless unit 112 must likewise do so.
  • the selected channel changes after each successful transmission.
  • the channel number is reset to zero whenever the communication link is established; otherwise, whenever a transition to the medium data rate occurs, the channel last used is selected.
  • This approach is intended to maintain channel synchronization between the wireless units at either end of the communication link.
  • hardware encryption is reset whenever the channel or rate is changed; this will generally be preceded by a link reset message exchange in order to ensure timing synchronization.
  • each device message contains a payload of 24 bits.
  • the bits in each message payload are utilized as follows:
  • Mouse report 5 bits indicating the state of the buttons, and 6 bits for each of 3 axes containing the delta position in that axis since the last report. MS (most significant) bit is always 1.
  • Keyboard report 1 bit indicating key pressed or released, 5 bits specifying the column of the keypress, and 3 bits specifying the row.
  • the MS bit of the report is always 0. If a scroller is present, motion is reported as if the scroller were a mouse axis in a separate field. This message is always encrypted.
  • Reset request This message is comprised of all zeros.
  • the wireless keyboard does not encrypt this message, since it is sent when the keyboard and transceiver may be out of synchronization.
  • the wireless units 112 , 114 and 116 are designed for operation in either one of two modes, determined at the time of manufacturing; specifically, operation may occur in either a “dynamically paired” (DP) mode or in an “out of the box” or (OOB) mode.
  • the DP mode is designed for business or commercial situations where multiple users may have similar devices in close proximity to each other.
  • the keyboard/mouse wireless unit 114 , 116 randomly generates an ID code, which is transferred to the host wireless unit 112 at pairing time. Also at pairing time, the keyboard/mouse wireless unit 114 and 116 learn the ID code of the host wireless unit 112 , which is used on all transmissions from the keyboard/mouse wireless unit 114 and 116 .
  • the OOB mode is intended for consumer usage environments in which multiple devices are unlikely to be located closely together. This mode does not require performance of a pairing process, and thus a keyboard/mouse wireless unit 114 , 116 is ready to use as soon as batteries are inserted into the wireless keyboard 104 or wireless mouse 106 in which it is disposed. In this mode, all mouse wireless units 114 use the same fixed ID code, and all keyboard wireless units 116 share a single (different) fixed ID code.
  • each wireless unit 112 , 114 , 116 is either pre-assigned a device ID or are assigned a dynamically generated device ID at pairing. With the exception of a few reserved sequences (e.g., all “0” or all “1”), in the exemplary embodiment all 11-bit device IDs are valid. If a device is in DP mode, at pairing time it generates a random 11-bit ID in hardware upon powering-up. This device II) is passed through a hardware block described in the above-referenced copending provisional patent application, which converts the device ID into a 16-bit long sequence which is incorporated within messages intended for receipt by the applicable wireless unit. Prior to enabling the receiver within its RF unit, a wireless unit 112 , 114 and 116 writes its 16-bit long sequence to its radio interface. During operation, the receiver listens for messages having addresses containing this long sequence.
  • a long sequence prefix identifies the ID code of the intended recipient
  • the host wireless transceiver unit 112 does not possess a priori knowledge of the device ID of the keyboard/mouse wireless unit 114 , 116 . Rather, during operation in DP mode a “pairing” operation is performed pursuant to which a device ID is dynamically generated by the keyboard/mouse wireless unit 114 , 116 and
  • each transceiver is identified by a predefined address. Specifically, a host transceiver is assigned TR-DEFAULT as an address, a keyboard transceiver is assigned KB-DEFAULT as an address, and a mouse is assigned M-DEFAULT as an address. Following completion of a successful pairing operation between a host and device transceiver, the paired transceivers will have unique addresses. In addition, in this embodiment a host transceiver assumes its unique address when communicating with a paired device transceiver. However, the host transceiver will continue to use TR-DEFAULT during communication with unpaired device transceivers.
  • patch EEPROM is included within the host/device transceivers, in one embodiment all will have unique addresses. In the case in which the host/device transceivers lack an EEPROM, in one embodiment the host transceiver uses the preamble corresponding to the TR-DEFAULT address. In the case in which the host/device transceivers include an EEPROM, the host transceiver uses the preamble corresponding to its unique address.
  • FIG. 12 is an event trace diagram 1200 representative of the messages exchanged during a pairing operation involving a keyboard/mouse wireless unit 114 , 116 (a “device”) and the host wireless unit 112 .
  • the pairing operation is initiated by the manual push of a predefined button of the host wireless unit 112 followed by the pressing of a predefined button of the keyboard 104 or mouse 106 associated with the device within a few seconds.
  • a dedicated button may be provided on the dongle for use during pairing.
  • Success of the pairing operation is evidenced by proper operation of the device (e.g., by keystrokes or mouse clicks being processed by the host PC following receipt by the host wireless unit 112 ). If the pairing operation fails, both sides continue to attempt to pair until success or expiration of a predefined number of attempts (e.g. 1000). If the timeout period expires, the device goes to sleep until the pairing button of the keyboard 104 or mouse 106 associated with the device is pushed again.
  • a predefined number of attempts e.g. 1000
  • the host wireless unit 112 begins transmitting “pairing request” messages which contain the transceiver ID code of the host wireless unit 112 and which are addressed to a reserved ID code (e.g., all “is”).
  • a reserved ID code e.g., all “is”.
  • the device temporarily assumes the reserved ID and listens for pairing requests from the host wireless unit 112 . If the device successfully receives a request, it responds with an ACK containing a pairing accept message to the transceiver ID code. This message contains the actual device ID code of the transmitting device.
  • the host wireless unit 112 between issuing pairing request messages, listens for incoming messages. If it receives a pairing accept message from the device, it remembers the ID code of its new partner and acknowledges it. Once, the acknowledgement is received at the device, the device assumes its “rear’ identity; that is, it begins sending and receiving messages on the basis of its actual device ID. Once the device has assumed its actual identity, it transmits a reset message to the host wireless unit 112 . If the reset message is acknowledged by the host wireless unit 112 , the applicable communication link 108 , 110 is considered established and normal operation ensues.
  • the host transceiver transmits pairing request messages periodically (every 50 ms in the case of HDR), using a fixed PAIRING-PREAMBLE.
  • the pairing request message will generally contain the unique address of the host transceiver (32 bits), and host transceiver preamble (16 bits).
  • the pairing button triggering the keyboard/mouse transceiver is pressed, it will listen to pairing request messages for a pairing interval (55 ms in the case of HDR) using the fixed PAIRING-PREAMBLE. When this period expires, the keyboard/mouse transceiver checks whether there are any user input events.
  • the system 1100 includes a host wireless unit 1112 of a host PC 1102 , a wireless unit 1114 of a wireless keyboard 1104 , and a wireless unit 1116 of a wireless mouse 1106 .
  • the host wireless unit 1112 In the embodiment of FIG. 11 , costs of implementing the system 1100 are minimized by designing the host wireless unit 1112 to incorporate an EEPROM 1134 as well as a host transceiver module 1130 .
  • the host transceiver module 1130 is disposed to implement all of the above-described functionality of the host wireless unit 112 .
  • the EEPROM 1134 stores configuration options for each of the wireless units of the system 1100 ; that is, configuration information is stored for the host transceiver module 1130 and keyboard/mouse wireless units 1114 , 1116 .
  • the parameters stored within the EEPROM 1134 may be distributed to the keyboard/mouse wireless units 1114 , 1116 upon the establishment of radio communication within the system 1100 .
  • the keyboard/mouse wireless units 1114 , 1116 each include a small amount of writable non-volatile memory (e.g., 4 KB).
  • the keyboard/mouse wireless units 1114 , 1116 do not include writable non-volatile memory, and power-up in a fixed state defined only by hardware inputs and built-in defaults. Since requiring multiple pins for configuration is cumbersome and expensive, in the exemplary embodiment each keyboard/mouse wireless unit 1114 , 1116 uses only one pin for configuration input to specify operation in either the DP or OOB mode.
  • various operational parameters are set to the default values stored within corresponding locations of its writable non-volatile memory or registers.
  • the host transceiver module 1130 reads the EEPROM 1134 and identifies those operational parameters of the keyboard/mouse wireless units 1114 , 1116 with respect to which the default values should be overridden. For each of these identified parameters, the host transceiver module 1130 sends a configuration message to the keyboard/mouse wireless unit 1114 , 1116 .
  • Each configuration message includes a parameter ID uniquely identifying a register or the location within the non-volatile memory of the keyboard/mouse wireless unit 1114 , 1116 , as well as a parameter value to be stored in such location.
  • each parameter is initialized upon power-up of the keyboard/mouse wireless unit 1114 , 1116 to a default value; however, the sending of a configuration message permits the default value to be overridden with a desired value appropriate for the intended application and/or system environment.
  • the keyboard/mouse wireless unit 1114 , 1116 does not attempt to validate or otherwise check these values; rather, it simply writes the selected register or memory location and proceeds.
  • the host wireless unit 1112 issues a configuration message containing the parameter ID and the desired value. These values simply replace the defaults until the keyboard/mouse wireless unit 1114 , 1116 loses power. Upon again becoming energized, the keyboard/mouse wireless unit 1114 , 1116 re-establishes its radio link with the host wireless unit 1112 , and the parameter overrides are retransmitted.
  • EEPROM 1134 is required within the host the host wireless unit 1112 .
  • the absence of the EEPROM 1134 is generally not a sufficient basis upon which to assume that operation in the OOB mode is intended, as the apparent absence of EEPROM 1134 may in fact be the result of a failure.
  • one configuration input is used at the hardware pin level. Specifically, pulling up this pin with a resistor 1140 indicates that EEPROM 1134 is not present.
  • the host wireless unit 1112 and the keyboard/mouse wireless unit 1114 , 1116 each have built-in defaults for all parameters, only variations need be stored within the EEPROM 1134 . Accordingly, in implementations of the system 1100 in which no changes are required to be made to these built-in defaults, no EEPROM 1134 is required. That being said, if the system 30 1100 is intended to be used in DP mode, it will necessary for some provision to be made for the host wireless unit 1112 to remember its pairings when the host PC 1102 is turned off and the host wireless unit 1112 loses power.
  • each keyboard/mouse wireless unit 1114 , 1116 it is necessary for each keyboard/mouse wireless unit 1114 , 1116 to know in which mode (DP or OOB) it is to be operative upon powering up. Since in this case only two possible operational modes exist, only one bit of configuration information need be provided in order to select between modes.
  • DP mode selection resistor
  • 1152 By providing the option of adding a mode selection resistor 1150 , 1152 to each the keyboard/mouse wireless units 1114 , 1116 , providing this configuration information to each device may be achieved at a “cost” of only one resistor per device and obviates the need to provide additional pins.
  • the presence of the resistor 1150 , 1152 results in the keyboard/mouse wireless unit 1114 , 1116 becoming operative in the OOB mode (i.e., the device uses a single static device ID for communicating with the host wireless unit 1112 . If the resistor 1150 , 1152 is absent, then the keyboard/mouse wireless unit 1114 , 1116 elects a random device ID and expects the pairing procedure discussed above to be followed.
  • the records for each wireless unit 1112 , 111 are protected by checksums which are verified each time the host wireless unit 1112 powers up.
  • the resistor 1140 is used to indicate whether or not the EEPROM 1134 should be present. If the resistor 1140 is present, no attempt is made to access an EEPROM 1140 and the system 1100 operates utilizing its default values. If the resistor 1140 is absent, then the EEPROM 1134 must be present and checksum tests are performed upon the records of the EEPROM 1134 .
  • Table V a list of exemplary default values and ranges is provided for various operational parameters (or, equivalently, “options”) of the keyboard wireless unit 1114 .
  • a corresponding option value is transferred from the host wireless unit 1112 to the keyboard wireless unit 1114 once a communication link has been established between the units 1112 , 1114 . It is observed that a set of keyboard-related options are also implemented by the host wireless unit 1112 (see Table IV below), and thus need be transferred to the keyboard wireless unit 1114 .
  • Table VI provides a list of exemplary default values and ranges for various options of the mouse wireless unit 1116 .
  • a corresponding option value is transferred from the host wireless unit 1112 to the mouse wireless unit 1116 once a communication link has been established between the units 1112 , 1116 .
  • a large percentage of an optical mouse's battery life is typically consumed by the mouse's optical sensor. To conserve battery life, the sensor operation is suspended periodically after movement of the mouse is stopped. The suspension duration is increased in a stepwise fashion as the time since the last movement is increases. In the preferred embodiment there are four steps. S0, S1, S3 and S4. The duration of each step and the and the duration of the suspension during each step is configurable.
  • mice-related options are also implemented by the host wireless unit 1112 (see Table VII below), and thus need be transferred to the mouse wireless unit 1114 .
  • TABLE VI Mouse Configuration Options Option Default Min Max # Description [unit] Value Value Value Value M1 Paired/Out of Box OOB Paired OOB (OOB) Mode
  • OOB Paired OOB (OOB) Mode M3 Button Scan Rate 5 1 7 [# of scans for debounce]
  • Table VII provides a list of exemplary default values and ranges for various options of the host transceiver module 1130 .
  • the first and second option groups i.e., Group I and Group 2 relate to the operation of the keyboard/mouse wireless units 1114 , 1116 , but are processed locally by the host transceiver module 1130 .
  • the third logical group i.e., Group 3) of Table VII consists of options pertinent to operation of the host transceiver module 1130 itself.
  • TK2 Keyboard Device ID OOB value (high byte) (H)
  • TK3 Keyboard Device ID OOB value (low byte) (L)
  • TK4 Battery Levels to 2 0 7 Report (no report)
  • TK5 Use Alternate Scan No No Yes Code Table?
  • TK6 Scroller Type Volume Volume Scroll Control Control Keys TK100- Alternate Scan Code — TK260 Table Group 2 TM1 Mouse Present?
  • each may include a number of external pins defined as general purpose I/O (GPIO). Electrically, each of these pins will generally be implemented as an open drain output with the ability to be read back as an input if an associated output register contains a “1” bit.
  • GPIO pins are grouped into sets of eight, which are manipulated in parallel. Each group of eight is assigned a group number.
  • the host wireless unit 112 may request to set or read a group of GPIO pins of a wireless unit 1114 , 1116 .
  • the host wireless unit 1112 conveys such a request to the device wireless unit 1114 , 1116 by way of a GPIO read or GPIO write message containing an identification of the group number.
  • a GPIO write message the value to be written is also provided.
  • the device wireless unit 1114 , 1116 Upon receipt of a GPIO read message, the device wireless unit 1114 , 1116 responds with a GPIO data message containing the requested data. It is the responsibility of the host wireless unit 1112 to write a “1” to any input bit before it is read.
  • the present invention further contemplates that the operation of the wireless units 114 , 116 be amenable to customization in view of the requirements of various applications.
  • the software executing on the wireless units 112 , 114 , 116 has been designed to incorporate various “hooks” in order to allow certain parameters adjusted. Such hooks are also intended to allow portions the software to be extended or replaced by supplementary software included within an inexpensive external serial “patch” EEPROM of the general type described above with reference to FIG. 11 .
  • a high-level representation is provided of a system 2200 comprised of wireless units incorporating EEPROM patches in accordance with one aspect of the present invention.
  • the system 2200 includes a host wireless unit 2212 incorporating transceiver software within a ROM 2222 and transceiver patch software within an EEPROM 2232 .
  • the system 2200 further includes a keyboard wireless transceiver 2214 containing a ROM 2224 in which is stored keyboard software and an EEPROM 2234 in which is stored keyboard patch software.
  • the system 2200 also includes a mouse wireless transceiver 2216 configured with a ROM 2224 incorporating mouse software and an EEPROM 2236 incorporating mouse patch software.
  • the host transceiver 2212 and device transceivers 2214 , 2216 are ROM-based designs. That is, the bulk of the program code stored within these transceivers is normally executed from ROM. However, the inclusion of serial EEPROM within one or all of the transceivers 2212 , 2214 and 2216 facilitates a patching procedure allowing certain default operational parameters to be changed at startup and limited changes to be made to the operating software of the transceiver.
  • FIG. 23 is a flowchart representative of certain aspects of the operation of the system 2200 .
  • the processor within each transceiver 2212 , 2214 , 2216 initializes critical hardware and software then checks the I 2 C bus to which it is connected for the presence of an external EEPROM. If an EEPROM is present, the processor reads the first few EEPROM bytes and compares them to a predefined number sequence. If the sequence matches, the content of the EEPROM is copied to specified locations in the processors external RAM. Execution of the software stored within the ROM 2222 , 2224 , 2226 of the transceiver 2212 , 2214 , 2216 then continues.
  • a “config” data block in the external RAM of a processor included within each host/device transceiver 2212 , 2214 , 2216 the software stored within ROM 2222 , 2224 , 2226 expects to find certain critical operating parameters.
  • This data block is initialized by the software stored within ROM 2222 , 2224 , 2226 upon start up. If no EEPROM patch software is present; the software stored within ROM 2222 , 2224 , 2226 uses the values loaded at start up. If a patch EEPROM 2232 , 2234 , 2236 is present, the config data block can optionally be over-written as the contents of the patch EEPROM 2232 , 2234 , 2236 are read.
  • the software stored within ROM 2222 , 2224 , 2226 also expects to find a control table potentially containing pointers to code patches within external RAM of the applicable processor. Each pointer potentially points to a ROM code replacement function. For most entries in this table a null pointer value is expected. If a null entry is found, the software stored within ROM 2222 , 2224 , 2226 executes the original ROM code function for that pointer location. However, if the software within the patch EEPROM 2232 , 2234 , 2236 over-writes the control table value with a non-null pointer, the replacement function referenced by the pointer is executed in place of the ROM code function. Replacement functions can be other functions previously defined in ROM 2222 , 2224 , 2226 , or newly-defined functions loaded from the patch EEPROM 2232 , 2234 , 2236 to RAM at start up.
  • the EEPROM patching procedure discussed above may be used for a variety of purposes including, for example, for default parameter substitutions, procedure substitutions, and the execution of precompiled functions. The first two of these potential uses is summarized below.
  • Those parameters assigned default ROM values which may be replaced are defined in a predefined file within the patch EEPROM 2232 , 2234 , 2236 .
  • This file declares a predefined type (i.e., “Mask ROM Config t”) which, when instantiated, defines the available substitutable parameters.
  • a predefined file (i.e., “MRCONT.H”) contains the type definition for the Mask ROM Control “t” type referenced above.
  • this structure is instantiated as a series of null function pointers.
  • Each null pointer is a placeholder for a potential substitute procedure of the general form illustratively represented by FIG. 24 .
  • the null function pointer corresponding to the default procedure is replaced with a function pointer pointing to the new replacement procedure.
  • Replacement procedures are located in the RAM program area (loaded from the applicable patch EEPROM 2232 , 2234 , 2236 on power up). Alternatively, replacement procedures can reference the preexisting functions in the code within ROM 2222 , 2224 , 2226 .
  • the architecture of the host wireless unit 112 (or, equivalently, “host transceiver 112 ”) is substantially similar to that of the device wireless units 114 , 116 . Accordingly, for the sake of clarity of presentation the following discussion does not repeat those aspects of the preceding discussion equally applicable to the host and device wireless units, and is instead intended to highlight the structural and operational differences there between.
  • Table I provides information regarding each of the messages transmitted from the keyboard/mouse wireless units 114 , 116 to the host wireless unit 112 , and vice-versa.
  • the host transceiver 112 sends messages containing the following 24-bit payloads:
  • the system 100 implements a power management scheme consistent with the “OnNow” initiative for system-wide power management defined by Microsoft Corporation.
  • Microsoft has published “Device Class Power Management Reference Specifications” for various device classes, including the input device class applicable to keyboards, mice, joysticks, and the like (see, e.g., www.microsoft.com).
  • the Reference Specifications for the input device class defines four power states, D0 through D3.
  • a device operative in the D0 state is completely active and normally functioning, and consumes power at the highest level possible.
  • state D3 corresponds to the case in which power may have been fully removed from the device, and it considered to be completely “off”.
  • state D2 has been characterized as being inapplicable to input devices, the only remaining state is D1.
  • the D1 state requires that device power consumption be equal to or greater than the D2 state, but less than the D0 state. Accordingly, in the D1 state hardware such as displays and indicators (e.g., LED devices) are turned off, but state information such as num, caps, and scroll lock state are preserved.
  • transitions between power states within a device are explicitly commanded by drivers within the PC host, and are not performed autonomously.
  • host wireless unit 112 and keyboard/mouse wireless units 114 , 116 define a power state D1 as follows:
  • FIG. 14 depicts a flowchart 1400 representative of a carrier sense/clear channel assessment procedure (CS/CCA) procedure executed by the MAC layer 208 of the keyboard/mouse wireless unit 114 , 116 prior to transmission of a message.
  • CS/CCA carrier sense/clear channel assessment procedure
  • a 1-bit CCA report is provided by the RF unit 414 , 514 ; namely, a CCA of “1” indicates the channel is busy, and a CCA of “0” indicates the channel is clear.
  • a CCA of “1” indicates the channel is busy
  • a CCA of “0” indicates the channel is clear.
  • Ttx The transmitter latency (Ttx) and receiver latency (Ttx) for various data rates are provided in Table V, and the durations of various types of message packets are set forth in Table VI.
  • TABLE V Data rate Ttx ( ⁇ s) Trx ( ⁇ s) 112.5 kb/s 29 21 28.125 kb/s 82 67 9.375 kb/s 224 138
  • Table VII provides a tabular listing of the value of Bmin as a function of data rate. TABLE VII Bmin (ms) Data rate Keyboard Mouse 112.5 kb/s 1.287 1.429 28.125 kb/s. 4.159 4.728 9.375 kb/s 11.767 13.474 Spreading 10.367 11.929
  • the CCA threshold level utilized by the RF unit 414 , 514 in generating the CCA report during execution of the CS/CCA procedure illustrated by FIG. 14 does not remain the same for all applications. Rather, even for a given application, the CCA 20 threshold level will generally depend upon the distance between the transmitting/receiving devices as well as the distance between an interferer and such devices.
  • a flowchart 1500 is provided of procedure for dynamically adjusting the CCA threshold level used by the RF unit 414 , 514 when generating a CCA report.
  • Table VIII shows an exemplary mapping between CCA threshold level (TH) and RF control signals: TABLE VIII CCA threshold CCA_Vth_b2 CCA_Vth_b1 CCA_Vth_b0 level (TH) 0 0 0 ⁇ 48 dBm 0 0 1 ⁇ 54 dBm 0 1 0 ⁇ 60 dBm 0 1 1 ⁇ 66 dBm 1 1 0 ⁇ 72 dBm 1 1 1 ⁇ 78 dBm
  • CCA_Vth_b2, CCA_Vth_b1 and CCA_Vth_b0 are three control line bits used to set the CCA threshold level.
  • FIG. 16 is a high-level flow diagram representative of a general approach to interference handling consistent with the present invention.
  • data is transmitted and received by wireless units in four different modes: a high data rate (HDR) mode; a medium data rate (MDR) mode; a low data rate (LDR) mode and a spreading mode.
  • the HDR mode is the default mode, which can provide 150 kbps data transmission.
  • the data rates for the MDR, LDR and spread mode are 30 kbps, 10 kbps and 13.64 kbps respectively.
  • each wireless unit 112 , 114 , 116 is able to detect interference and switch to appropriate modes automatically. As a consequence, highly reliable wireless data transfers may be affected even in an environment with multiple other wireless users.
  • spreading mode may be invoked to mitigate interference engendered by the presence of other host/device transceivers within the vicinity of a host/device transceiver pair desiring to communicate.
  • the device transceiver of a host/device transceiver pair controls the switching between normal and spreading mode.
  • a device transceiver 114 , 116 initiates spreading mode operation by sending, to the host transceiver 112 , a packet, which has been spread in the manner described in the above-referenced copending patent application.
  • the modem 308 at the host transceiver 308 will notify the MAC layer 208 that spreading mode has been enabled, which results in the host transceiver 112 also sending the ACK in spreading mode.
  • the device transceiver 114 , 116 will send a packet in normal mode.
  • the modem 308 at the host transceiver 112 notifies the MAC layer 208 that the device transceiver 114 , 116 has switched back to normal mode. This results in the host transceiver 112 sending the ACK in normal mode.
  • a given host transceiver 112 will generally be in communication with more than one device transceiver 114 , 116 . Accordingly, the host transceiver 112 is disposed to 20 communicate with each device transceiver 114 , 116 in accordance with the mode that has been currently selected by such transceiver 114 , 116 .
  • the device transceivers 114 , 116 elect to switch from normal mode to spreading mode when more than a predefined number of failures occur within a predefined number of the most recent transmissions. For example, it has been found that switching to spreading mode is appropriate if more than 21 failures occur in connection with the most recent 25 attempted transmissions. Similarly, the device transceivers 114 , 116 may elect to switch from spreading mode to normal mode when less than a predefined number of failures occur within a predefined number of the most recent transmissions. For example, it has been found that a return to normal mode from spreading mode may be when less than 18 failures occur in connection with the most recent 25 transmissions.
  • a flow chart 1700 is provided of an exemplary manner in which the host transceiver 112 transitions between operation within the HDR and MDR modes, and vice-versa.
  • a transition is made from HDR to MDR mode when a received signal strength indication (RSSI) generated by the RF unit 314 indicates the presence of strong interference (e.g., narrow-band interference) such as from citizen band (CB) radio.
  • RSSI received signal strength indication
  • CB citizen band
  • the RSSI generated by the RF unit 314 is checked periodically (e.g., every 2 ms). If it is determined to be necessary to switch to MDR mode, switching occurs to a particular MDR channel in accordance with the sequence 0-3-1-4-2-0 . . . . In the case of the initial switch from HDR to MDR mode, the host transceiver 112 first attempts to operate in a predefined MDR channel (e.g., channel 4 ).
  • a predefined MDR channel e.g., channel 4
  • the host transceiver 112 will switch to channel “L” the next time a transition to MDR mode is required.
  • a flow chart 1800 is provided of an exemplary manner in which a device transceiver 114 , 116 transitions between operation within the HDR and MDR modes, and vice-versa.
  • a device transceiver 114 , 116 transitions from the HDR to MDR mode when an RSSI generated by the applicable RF unit 414 , 514 indicates the presence of strong interference (e.g., narrow-band interference).
  • strong interference e.g., narrow-band interference
  • the device transceiver 114 , 116 when the device transceiver 114 , 116 is in receiving mode (i.e., in order to receive the ACK), RSSI from the RF unit 414 , 514 is checked. If it is determined to be necessary to switch to MDR mode, switching occurs to a particular MDR channel in accordance with the sequence -3-1-4-2-0 . . . . In the case of the initial switch from HDR to MDR mode, the device transceiver 114 , 116 first attempts to operate in a predefined MDR channel (e.g., channel 4 ).
  • a predefined MDR channel e.g., channel 4
  • the device transceiver 114 , 116 will switch to channel “L” the next time a transition to MDR mode is required.
  • Timer 1 50 ms
  • Timer 2 1 seconds
  • T 100 ms.
  • the host transceiver 112 may be incorporated within a dongle or the like and connected to the host PC 102 through a Universal Serial Bus (USB).
  • USB Universal Serial Bus
  • the host transceiver 112 includes an integrated USB function controller 10 and a full speed (12 Mb/s) transceiver.
  • USB devices may be self-powered or receive energy via the USB cable through which they communicate with a hosting entity.
  • USB supports a variety of power modes: On, Suspend, and Off. When placed in Suspend mode, USB devices retain the ability to wakeup the hosting system.
  • USB Universal Serial Bus
  • a device placed on the bus is permitted to draw up to 500 mA; however, many hosting entities will not permit a device to draw more than 100 mA from the bus.
  • the host transceiver 112 informs the host PC 102 as to the amount of current required for its operation. However, when the host transceiver 112 enters the Suspend mode in accordance with the USB protocol, it cannot draw any more than 500 uA from the bus (assuming the host transceiver is bus-powered rather than battery-powered).
  • the USB protocol requires the host transceiver 112 to enter the Suspend state if its bus has been inactive for 3 ms.
  • the host PC 102 can initiate a resume command to the host transceiver 112 when it is in Suspend mode.
  • the host transceiver 112 can also issue a remote wakeup to the host PC when it is inactive in order to render it active.
  • the host transceiver 112 In view of the limitations on the amount of current which can be drawn by the host transceiver 112 from its USB during operation in Suspend mode, it will generally not be possible for the host transceiver 112 to remain “awake” (i.e., fully operational) at all times when operative in this mode. Accordingly, in accordance with one aspect of the invention the host transceiver 112 only periodically becomes fully operational and capable of receiving messages from device transceivers 114 , 116 when functioning in Suspend mode. As is discussed below, the messaging protocols of any device transceivers 114 , 116 in communication with a host transceiver 112 are also modified upon entry of the host transceiver 112 into Suspend mode.
  • FIG. 19 a timing diagram 1900 is provided which is representative of the transition of the host transceiver 112 into and out of “awake” and “sleep state” operation during its operation in Suspend mode consistent with the USB protocol.
  • the host transceiver operates in an awake state for a period of W ms once every B ms, and is otherwise in a sleep state.
  • Each awake period will generally be of the same duration and of sufficient length to permit capturing of the header of a message packet transmitted by a device transceiver.
  • 114 , 116 exemplary computations of appropriate values of the parameters W and B are given below for the case of transmissions by the mouse transceiver 116 during both normal and spreading mode operation.
  • FIG. 20 there is shown a state transition diagram 2000 representative of the operation of the transceiver 112 when in Suspend mode.
  • the transceiver 112 transitions from sleep state to awake state every awake period of B ms, and remains in awake state for W ms. If validation of the header of a message from the mouse transceiver 116 occurs during the W ms duration of an awake state, the host transceiver remains in the awake state. If such a header validation occurs and no packets are received for N ms, the host transceiver 112 returns to sleep state.
  • a state transition diagram 2100 depicts the corresponding modifications to the messaging protocol of the mouse transceiver 116 upon entry of its partner host transceiver 112 into Suspend mode.
  • the mouse transceiver 116 is disposed to re-transmit a packet if an ACK is not received in response to the initial transmission of the packet. If a predefined number of such re-transmissions also fail, the mouse transceiver 116 sends link-reset packets.
  • the moue transceiver 116 transmits link-reset packets for E ms if no packets are queued for transmission; otherwise, the next queued packet is transmitted and operation continues as described above.
  • the parameters E, B, W, and N are configurable.

Abstract

A computing system wherein communication between a host computer and peripheral units, e.g. computer mouse and keyboard, is performed using RF signals. The host computer and the peripheral units each contain a transceiver for managing and transmitting the RF communication messages. An acknowledgement is sent by the receiving transceiver to the sending transceiver to signify that the message was successfully received. If no acknowledgement is received by the sending transceiver, a subsequent RF communication message is sent until an acknowledgement is received. A sleep mode is invoked between messages to conserve battery power in the peripheral units, and the peripheral units send a report message to the host when awaking periodically, or by a user demand, from the sleep mode signifying that the peripheral unit is active and ready to send or receive messages.

Description

  • This application claims priority to U.S. Provisional Patent Application JAAL-001, “High-Reliability Computer Interface for Wireless Input Device”, Ser. No. 60/553,820, filed on Mar. 16, 2004, which is herein incorporated by reference in its entirety.
  • This application claims priority to U.S. Provisional Patent Application JAAL-002, “Wireless Transceiver System for Computer Input Devices”, Ser. No. 60/553,821, filed on Mar. 16, 2004, which is herein incorporated by reference in its entirety.
  • This application claims priority to U.S. Provisional Patent Application JAAL-003, “Wireless Transceiver System for Computer Input Devices”, Ser. No. 60/554,058, filed on Mar. 16, 2004, which is herein incorporated by reference in its entirety.
  • RELATED PATENT APPLICATION
  • This application is related to U.S. Patent Application docket number JA05-002, serial number ______, filed on ______, assigned to a common assignee.
  • FIELD OF THE INVENTION
  • The present invention relates generally to computer systems and, more particularly, to an interface between a computer and input devices in communication with the computer over wireless links.
  • BACKGROUND OF THE INVENTION
  • Various computers and microprocessor-based devices and systems provide one or more user input devices to allow a user to control certain operations. Such an input device may be separated from the host computer or device and thus a communication link and an interface may be implemented to support proper communications between the input device and the host computer or device. Generally, each of the input device and the host computer/device includes appropriate software and hardware, for the communication link and interface.
  • For example, a typical desktop or laptop computer may have a keyboard and a pointing device for a user to input data or commands for controlling or operating the computer. Examples of the pointing device for computers include a mouse, a touch pad, a trackball, and a pointing stick (IBM laptops). In addition to keyboards and pointing devices, examples of some other user input devices include joysticks and game pads for computers and microprocessor-based game machines, control units for other microprocessor-based devices. In general, a user uses an input button, a control stick, one key or a key combination, or a combination thereof to input data or a command. Circuitry in the input device converts the input data or command into a proper form for transmitting to the computer or device.
  • Such an input device generally uses a particular communication link to transmit the input data or command to the computer or device. An input device may be a wireless input device using a wireless communication link or a wired link using an electrical cable. Input devices with wired links may be implemented based on the PS/2 keyboard interface, the USB 1.0 and USB 2.0 interfaces, and other interfaces. The wireless communication link may be implemented by a radiation transmitter to send the input to a corresponding radiation receiver at the computer or device. Many wireless input devices use RF radiation links based on different radio interfaces such as IEEE 802.5.14 for low speed links and wireless USB 2.0 and IEEE 1394 for relatively high speed links. Some of these wired or wireless input devices may use the Human Interface Device (HID) protocol over wired or wireless USB links or other non-USB communication links.
  • Wireless input devices beneficially increase the flexibility of the interaction between a user and a host computer in that no wired connection is required with the host computer. However, given that a wired connection generally provides a source of power for an input device, wireless input devices are required to be self-powered (e.g., battery-powered). Unfortunately, batteries used to power existing wireless input devices typically last for a period of time significantly less than the useful life of such devices. As a consequence, the convenience and value of such devices are diminished as a consequence of the need for regular battery replacement.
  • Existing wireless input devices are also frequently of limited range and the wireless link established for communication with the host computer is often rather unreliable and/or exhibits a high latency. In addition, such wireless links are often relatively insecure and thus susceptible to eavesdropping or unauthorized monitoring.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • This invention will be described with reference to the accompanying drawings, wherein:
  • FIG. 1 is a diagram of a computer system of the present invention incorporating a wireless input interface;
  • FIG. 2 is a diagram of the layered architecture of the present invention for the wireless unit contained in the host computer;
  • FIG. 3 is a block diagram of the wireless unit of the present invention;
  • FIG. 4 is a block diagram of the present invention depicting an exemplary embodiment of the wireless unit;
  • FIG. 5 is a block diagram of the present invention depicting an exemplary embodiment of the wireless unit;
  • FIG. 6 is an event trace diagram of the present invention for mouse sleep sequence;
  • FIG. 7 is an event trace diagram of the present invention for mouse sleep sequence with lost messages;
  • FIG. 8 is an event trace diagram of the present invention for enabling of the transmitter/receiver within the RF units;
  • FIG. 9 is a state transition diagram of the present invention demonstrating the manner in which the data rate and channel of the wireless unit are changed;
  • FIG. 10 is an event trace diagram of the present invention for normal keyboard sequence;
  • FIG. 11 is shown a computer system of the present invention;
  • FIG. 12 is an event trace diagram of the present invention demonstrating the messages exchanged during a pairing operation;
  • FIG. 13 is a state transition diagram of the present invention;
  • FIG. 14 is a flowchart of the present invention of a carrier sense/clear channel assessment procedure;
  • FIG. 15 is a flowchart of the procedure for dynamically adjusting the CCA threshold level used by the RF unit;
  • FIG. 16 is a high-level flow diagram representative of a general approach to interference handling consistent with the present invention;
  • FIG. 17 is a flow diagram of the present invention for the method in which a host transceiver converts between HDR and MDR modes;
  • FIG. 18 is a flow diagram of the present invention for the method in which a device transceiver converts between operations within the HDR and MDR modes;
  • FIG. 19 is a timing diagram of the present invention for the transition of the host transceiver into and out of “awake” and “sleep state” operation;
  • FIG. 20 is a state transition diagram of the present invention for operation of the host transceiver when in Suspend mode;
  • FIG. 21 is a state transition diagram of the present invention depicting the modifications to the messaging protocol of the mouse transceiver upon entry of the host transceiver into Suspend mode;
  • FIG. 22 is a high-level diagram of the present invention showing the incorporation of EEPROM in the wireless transceivers;
  • FIG. 23 is a flow diagram of the present invention for the inclusion of a patch EEPROM in the wireless transceivers; and
  • FIG. 24 is a flow diagram of the present invention for substituting a new function for a default function.
  • DETAILED DESCRIPTION OF THE INVENTION SYSTEM OVERVIEW
  • Turning now to FIG. 1, a computer system 100 incorporating a wireless input interface in accordance with the invention includes a host computer 102, a wireless keyboard 104 and a wireless pointing device or “mouse” 106. As illustrated in FIG. 1, the wireless keyboard 104 and the wireless mouse 106 are in communication with the host computer 102 over wireless communication links 108 and 110, respectively. As shown, the host computer 102 includes or is attached to a wireless unit 112 through which the communication links 108 and 110 are respectively established with a wireless unit 114 within the wireless keyboard 114 and a wireless unit 116 of the wireless mouse 106. The wireless unit 112 may be built into the chassis of the host computer 102 or added as an external peripheral device in the form of, for example, a “dongle”. As an external peripheral device, the wireless unit 112 may either be interfaced to the computer 102 through a wired USB connection or by other available means such as the PS/2 keyboard connector.
  • During operation of the system 100, the wireless keyboard 0.104 and the wireless mouse 106 interact with the host computer 102 via wireless communication links 108 and 110. In particular, the wireless unit 112 receives keystroke and other data originating from the wireless keyboard 104 and the wireless mouse 106 over wireless communication links 108 and 110 and passes it to the host computer 102 in such a way that the host computer 102 is unaware of the existence of the wireless links 108 and 110.
  • As is described hereinafter, the wireless units 112, 114 and 116 of the present invention are configured to enable the communication links 108 and 110 to exhibit low latency and high reliability relative to conventional approaches employed using wireless peripheral devices. In addition, given that the wireless keyboard 104 and wireless mouse 106 will generally be battery powered devices, minimization of power consumption will typically be a primary design consideration. As a consequence, the wireless units 114 and 116 respectively incorporated within the wireless keyboard 104 and the wireless mouse 106 are disposed to cycle among various power-saving modes so as to conserve battery power and thereby substantially reduce the frequency of required battery replacement operations.
  • High-Level Architecture of Wireless Units
  • FIG. 2 illustratively represents a view of the layered architecture 200 of the wireless unit 112, it being understood that in the exemplary embodiment the wireless units 114, 116 are of essentially the same general architecture. As will be apparent to those skilled in the art, the layers depicted in FIG. 2 may be realized in hardware, firmware, or as software instructions stored on a computer-readable medium. Referring to FIG. 2, the unit 112 is seen to include a physical layer 204, a media access control (MAC) layer 208, and a device interface layer 212. As shown, the physical layer 204 interfaces with an antenna element 220.
  • The device interface layer 212 may be implemented as any known interface permitting the wireless unit 112 to interface with the host computer 102. Such a known interface may be designed to support communications between the host computer 102 and the wireless unit 112 in accordance with a standard communications protocol. For example, the device interface 212 may by designed to serve as a USB; PS2 or GPIO interface.
  • As is described below, the MAC layer 208 serves to control access to the wireless communication links 108, 110. That is, MAC layer 208 is responsible for enabling data to be transferred between the device interface 212 and the physical layer 204, and vice-versa. As shown, a portion of the functions associated with the MAC layer 208 in the exemplary embodiment are carried out by baseband hardware 260, but this is certainly not required. The physical layer 204 may comprise any structure or collection of elements functioning to transmit and receive bits of data over the wireless communication links 108, 110. As shown, the physical layer 204 includes a radio interface portion 250, which represents the registers and signals that are used to transfer messages between the physical layer 204 and the MAC layer 208. One potential implementation of the physical layer 204 is described in, for example, the above-referenced provisional application filed on even date herewith.
  • FIG. 3 illustratively represents a block diagram of the wireless unit 112 of FIG. 1 according to an exemplary embodiment of the present invention. As shown, the wireless unit 112 (also referred to herein as the host transceiver 112) includes a CPU 302 that is coupled via a CPU bus (not shown) to ROM 304, RAM 306, a modem 308, baseband hardware 309, wake-up logic 310, USB 312, and an input/output (I/O) module 316. The wakeup logic in the host device, although it is not generally required in this application, is an integral part of the logic implementation, which is the same in both the computer and peripheral input device. Also shown coupled to the modem 308 is an RF unit 314, which is coupled to an antenna 220. A power interface portion 330 provides power regulation to both analog and digital components of the host transceiver 112. In one embodiment, the host transceiver 112 is realized as a single system-on-chip IC with protocol stack and application software being integrated in built-in mask ROM, but this is certainly not required.
  • In the exemplary embodiment, when the host transceiver 112 is transmitting information to one of the wireless devices 114, 116, the information is first encrypted, formatted and protected with a cyclical redundancy check (CRC) by the baseband hardware 309. The modem 308 then receives and encodes (e.g., with differential binary phase shift key (BPSK) encoding) the formatted, encrypted and CRC protected information before it is up-converted for transmission by the RF portion 314.
  • When receiving a signal from one of the devices 114, 116, the RF unit 314 down converts the received signal to an intermediate frequency (IF), and converts the IF frequency signal to a digital IF signal. The modem 308 then decodes the digital IF signal and checks the CRC to regenerate the original encrypted information, which is then decrypted by the baseband hardware 309.
  • With respect to transmitting and receiving data, the modem 308 in the exemplary embodiment has four different modes: a high data rate (HDR) mode; a medium data rate (MDR) mode; a low data rate (LDR) mode and a spread mode. The HDR mode is the default mode, which can provide 150 kbps data transmission. The data rates for the MDR, LDR and spread mode are 30 kbps, 10 kbps and 13.64 kbps respectively. As described further herein, spread mode is used when there is interference from similar wireless device(s) (e.g., other host and device transceivers), and MDR is used when there is strong interference (e.g., narrow-band interference) such as from citizen band (CB) radio.
  • In the exemplary embodiment, the host transceiver 112 is able to detect interference and switch to appropriate modes automatically. As a consequence, the host transceiver 112 provides highly reliable wireless data transfers even in an environment with multiple other wireless users. In the exemplary embodiment, the LDR mode is for European compliance purposes and may be omitted in transceivers intended for non-European markets. The data transmission rates of the exemplary embodiment (i.e., 150 kbps, 30 kbps, 10 kbps and 13.64), are more than sufficient for typical manual input devices (e.g., the keyboard 104 and mouse 106), with very little or no perceptible latency.
  • The RF portion 314 in the exemplary embodiment operates to transmit and receive signals in accordance with the operating mode (i.e., the HDR, MDR, LDR and spread mode) of the modem 308. In MDR mode for example, the RF portion 314 supports multiple selectable transmit frequencies so data may be selectively transmitted over a frequency channel that is substantially free from a strong narrowband interferer such as a citizens band (CB) radio.
  • In the exemplary embodiment, the I/O unit 316 of the host transceiver 112 is programmable to allow general-purpose I/O pins (not shown) of the host transceiver 112 to be selectively dedicated to a variety of interface communication protocols for communication with the host computer 102. As shown in FIG. 3 for example, the UO unit 312 is programmable so as to allow the following five I/O communication protocols to be selectively used with the general-purpose 10 pins: a general purpose input/output (GPIO) 318, an intelligent interface controller (I 2C) path 320, a universal asynchronous receiver/transmitter interface (UART) 322, a USB interface 324 and a bidirectional synchronous serial interface (PS/2) 326.
  • The I2C interface 320 is a two-wire, bi-directional serial bus which” provides a simple method of data exchange between devices. In the exemplary embodiment, the I2C interface is used for downloading executable programs from external EEPROM to RAM 306 (e.g., to change functionality of certain aspects of the host transceiver), and/or reading configuration parameters that are stored in external EEPROM. In one embodiment, (e.g., when CPU clock is 12 MHz) the clock speed for the I2C interface is software programmable from 200 Hz to 400 KHz (When CPU clock is 12 MHz). The host transceiver 112 may either be selected (e.g., via software) to be a master or a slave device.
  • The UART interconnect 322 provides serial communications between the host transceiver and terminal equipment (e.g., the host computer 102). In one embodiment, the baud rate is software programmable from 250 bps to 330 Kbps. The universal Serial Bus (USB) interface 324 is a personal computer (PC) interconnect that can support simultaneous attachment of multiple devices. The USB module 312 in the present embodiment is realized by dedicated hardware and includes a USB function controller (not shown) and a full speed (12 Mb/s) USB transceiver (not shown). The PS/2 interface 326 is a two-wire (DATA, CLOCK), bi-directional synchronous serial interface. The PS/2 interface 326 in one embodiment includes two PS/2 interfaces: one for communications with the keyboard 104 and the other for communications with the mouse 106.
  • In one embodiment, dedicated hardware in the host transceiver 112 is associated with one or more of the above described communication protocols. Although it is not necessary to dedicate hardware for I/O communications, latency may be substantially reduced over alternative CPU-driven software implementations.
  • Referring next to FIG. 4, shown is a block diagram depicting an exemplary embodiment of the wireless unit 114 of FIG. 1. As shown, the wireless unit 114 (also referred to herein as the keyboard transceiver 114) includes a CPU 402 that is coupled to ROM 404, RAM 406, a modem 408, baseband hardware 409, RF unit 414 and an I/O module 416, which in the exemplary embodiment, are substantially the same as the corresponding functional components within the host transceiver 112. Also shown are wake-up logic portion 410 and a keyboard scan module 412.
  • As shown, four exemplary communication protocols are available for the keyboard transceiver 114 to communicate with other devices: a general-purpose input/output (GPIO) 418, an intelligent interface controller (I2C) path 420, a universal asynchronous receiver/transmitter interface (UART) 422, and a keyboard interface 424. These protocols and interfaces are made available to support various design options for the keyboard.
  • The keyboard interface 424 in one embodiment is realized with 20 GPIO ports that are dedicated to 20 corresponding columns of a keyboard's bare key switch contacts and 8 GPIO ports that are dedicated to 8 corresponding rows of the keyboard's bare key switch contacts. In addition, three optional high-drive open-drain outputs support up to three LED devices on the keyboard. In this embodiment, the I/O module 416 is programmed to switch the 28 GPIO ports dedicated to the keyboard to the keyboard scan module 412.
  • The keyboard scan module 412 detects key presses and releases by receiving inputs from the keyboard interface 424 and performing debouncing and rollover handling. Debouncing is performed by keeping an image of the keyboard state in memory for the last N1 (e.g., three) scan cycles. In the exemplary embodiment, the keyboard scan module 412 does not report a state change until it persists for N1 scan cycles (the scan rate is approximately N2 (e.g., four) milliseconds per scan). As a consequence, the debounce time is approximately N1*N2 milliseconds. In one embodiment, the values of N1 and N2 may be changed via the host transceiver 112 by updating EEPROM of the host transceiver 112 with new values. The host transceiver 112 then sends the updated information to the keyboard transceiver 114 in a configuration message when communication is established with the host transceiver 112.
  • In operation, each time a key press or release is detected, the keyboard scan module 412 provides key code (i.e., column and row) information to the CPU 402, and the CPU 402 generates a message indicating the row and column. The message with row and column information is than transmitted from the keyboard transceiver 114 to the host transceiver 112. The host transceiver 112 receives the message and then maps the row and column data into key codes, macros, or special functions.
  • After a period of inactivity, the CPU 402 instructs the wake-up logic portion 410, as described further herein, to place the keyboard transceiver 114 in a sleep mode. The wake-up logic portion 410, in combination with the power interface 430, then effectively shuts down the CPU 402 by depriving it of a clock signal. In addition, a scan oscillator (not shown) in the keyboard scan module 412 is also deactivated so that the keyboard scan module 412 no longer carries out the keyboard scanning described above. Instead, the row inputs to the keyboard scan module 412 are logically ORed together so that any key-press will trigger the keyboard scan module 412 to restart the scanning process.
  • When the keyboard scan module 412 (operating in sleep mode) detects a key press, it sends a key press notification signal to the wake-up logic portion 410, which in combination with the power interface 430, brings the keyboard transceiver 114 out of sleep mode by reactivating the clock signal to the CPU 402. Additional details of communications between the keyboard transceiver 114 and the host transceiver 112 when the keyboard transceiver 114 enters and exits sleep mode are described in the above-referenced provisional application filed on even date herewith.
  • Referring next to FIG. 5, shown is a block diagram depicting an exemplary embodiment of the wireless unit 116 of FIG. 1. As shown, the wireless unit 116 (also referred to herein as the mouse transceiver 116) includes a CPU 502 that is coupled to ROM 504, RAM 506, a modem 508, baseband hardware 509, RF unit 514, and the I/O module 516, which in the exemplary embodiment, are substantially the same as the corresponding functional components within the keyboard transceiver 114. Also coupled to the CPU 502 is a wake-up logic portion 510, which is in communication with a mouse scan module 512.
  • As shown, four exemplary communication protocols are available for the mouse transceiver 114 to communicate with other devices: a general-purpose input/output (GPIO) 518, an intelligent interface controller (I2C) path 520, a universal asynchronous receiver/transmitter interface (UART) 522, and a mouse interface 524. These protocols and interfaces are made available to support various design options for the mouse.
  • In the exemplary embodiment, the mouse transceiver 116 receives, via a mouse interface 524, motion signals from mouse motion transducer 510, which is configured and positioned within the wireless mouse 106 to convert motion of the wireless mouse 106 into the motion signals.
  • Advantageously, the configuration of the mouse interface 524 in this embodiment is selectable to conform to the communication protocol of the mouse motion transducer 524, which may vary depending upon the manufacturer and the type of technology (e.g., mechanical or optical position tracking) utilized by the wireless mouse 106. Specifically, the I/O module 516 is programmable so that GPIO pins of the mouse transceiver 116 (not shown) are, dedicated for communications in accordance with the protocols utilized by the wireless mouse 106.
  • In one embodiment for example, the mouse interface 524 is configured to communicate as an optical mouse interface according to a secure digital I/O communication protocol (SDIO), which uses an I2C-like read/write sequencing scheme in which the mouse transceiver 116 operates as the master and the wireless mouse 106 as the slave. This configuration may be used, for example, to communicate with Agilent™ wireless mouse devices with SDIO interface capability including Agilent™ device No. ADNS-2030.
  • In another embodiment, the mouse interface 524 is configured to communicate as an optical mouse interface according to serial peripheral interface (SP1) protocols. In this embodiment, the mouse interface 524 includes four signals: a clock (CLK), a slave output (SO), a slave input (S1) and a slave select (CS), and the mouse transceiver 116 operates as the master while an optical sensor in the mouse 106 operates as the slave.
  • When the wireless mouse 106 utilizes mechanical position tracking technology, the mouse interface 524 includes one pair of quadrature signals for each of the X, Y, and Z axes, wherein the X and Y axes are associated with the translational movement of the wireless mouse 106 and the Z-axis is associated with movement of a roller ball of the wireless mouse 106.
  • In the exemplary embodiment, the mouse scan module 512 operates in either a mechanical mode or an optical mode depending upon whether the wireless mouse 106 utilizes mechanical or optical position tracking. When operative in the mechanical mode, a single-axis state machine of a type described in the above-referenced copending patent application is executed by the mouse scan module 512 with respect to each of three perpendicular directional axes (i.e., the X, Y and Z axes). Operation in the mechanical mode also relies upon a button press detector (not shown), which preferably implements “debouncing” in the same manner as was described above with reference to the keyboard scan module 512. Although the button press detector operates substantially identically in the mechanical and optical modes, in the exemplary embodiment the mouse scan module 512 does not execute state machines during operation in the optical mode. Instead, the mouse scan module 512 sends serial messages to the wireless mouse 106 and receives back position difference information or “deltas”. These position deltas replace the counter values utilized during mechanical mode operation within the mouse position reports generated by the mouse scan module 512.
  • Operation of Mouse and Keyboard Wireless Units Transition Among Operative States
  • As mentioned above with reference to FIG. 2, the MAC layer 208 is responsible for formatting messages conveyed by the MAC layer 208 to and from the device interface 212 and the physical layer 204. This aspect of the MAC layer 208 may be appreciated with reference to FIGS. 6, 7 and 10, which are event trace diagrams representative of various messages exchanged between the host wireless unit 112 and the keyboard/ mouse wireless units 114, 116 under the control of their respective MAC layers 208.
  • Referring initially to FIG. 10, an event trace diagram 1000 is provided which depicts the message sequences associated with normal operation of the keyboard/ mouse wireless units 114, 116. In addition, FIG. 10 also illustrates a message sequence between the mouse wireless unit 116 and the host wireless unit 112 in the case in which a message sent by the mouse wireless unit 116 is lost or corrupted and re-transmitted.
  • Turning now to FIG. 6, there is shown an event trace diagram 600 representative of an event sequence pursuant to which the wireless unit 116 for the wireless mouse 106 transitions into and out of sleep state under the control of its MAC layer 208. In the case in which the wireless unit 116 is awakened due to expiration of this time-out interval, the counters associated with each of the three directional axes are compared against a predefined value (e.g., 2). If none of the counters exceed this threshold, the time-out is restarted and sleep resumed; otherwise, a mouse report message is sent to the host transceiver 112 and these counters are reset to zero. As is shown in FIG. 6, once receipt of this mouse report message is acknowledged by the host transceiver 112, the wireless unit 116 returns to sleep state. If an acknowledgment is not received, the mouse report message is discarded and the wireless unit 116 returns to sleep state.
  • FIG. 7 illustrates, in a manner similar to FIG. 6, an event trace diagram 700 which represents an event sequence pursuant to which the wireless unit 116 for the wireless mouse 106 transitions into and out of sleep state under the control of its MAC layer 208 in the case in which messages are lost between the host wireless unit 112 and the wireless unit 1116.
  • Consistent with the invention, the MAC layer 208 is also responsible for the overall transfer of data between the device interface 212 and the physical layer 204 and controls the transition of the applicable wireless unit 112, 114, 116 into and out of various operative states. Specifically, the MAC layer 208 of a given wireless unit is disposed to govern its transition among sleep, listen, backoff and pending states in the manner described hereinafter.
  • Turning now to FIG. 13, there is shown a state transition diagram 1300 representative of the manner in which transitions are made between the various states of a state machine executed by the MAC layer *208. In general, whenever one of the wireless units 114, 116 receives a message containing a long sequence (described below) identifying such unit 114, 116, its MAC layer 208 checks the CRC to decide if the message is valid. A message received from the host wireless unit 112 (other than an ACK only) is acknowledged immediately. This acknowledgement may, but need not be, accompanied by data intended for the host wireless unit 112. If a wireless unit 114, 116 sends data with or without a “piggyback” acknowledgement, the host wireless unit 112 is disposed to acknowledge the new data.
  • As is indicated by FIG. 13, if data is sent by a wireless unit 114, 116 and an acknowledgement is not immediately received following a short “ACK time-out” period, it is retransmitted by the wireless unit 114, 116 after waiting a “BACKOFF time-out” intended to break deadlocks caused by simultaneous transmissions. The “ACK time-out” period is selected to be roughly equal to the sum of (i) the round trip message transfer time between the applicable device (i.e., the wireless keyboard 104 or wireless mouse 106) and the host computer 102, and (ii) an allowance for processing time. In this regard an ACK time-out period of approximately 1.2 ms has been found to be appropriate for a number of anticipated implementations. It is observed that the time-out values described herein as being associated with the MAC layer 208, including the above-described ACK time-out period, are dependent upon the data rate used for the relevant transmission. In particular, the values provided herein assume operation in a the HDR mode (i.e., 150 kb/s) discussed above. For transmissions occurring during operation in the MDR mode (i.e., 30 kb/s), the provided timeout values should be quintupled. Finally, the provided timeout values should be multiplied by a factor of 15 in connection with operation in the LDR mode (i.e., 10 kb/s).
  • In the exemplary embodiment the BACKOFF timeout is randomized between wireless units. Such randomization may be effected by, for example, utilizing the device ID of the applicable wireless unit in generating the period of the BACKOFF timeout. If a wireless unit is required to delay for the period of an additional BACKOFF timeout in connection with a given transmission, the duration of the BACKOFF timeout may be increased linearly in accordance with the device ID. Specifically, in an embodiment where N corresponds to the number of consecutive ACK timeouts for a given data packet, and IDMx is the device ID of the transmitting wireless unit, the duration of the BACKOFF timeout is given as BACKOFFmin+(N*f(IDx)). In this embodiment BACKOFFmin is approximately 0.5 ms, and f(IDx) is chosen such that the average extension per consecutive BACKOFF timeout increases by approximately 1 ms.
  • In order to avoid or minimize any confusion resulting from retransmission of the same data, each message preferably contains a one-bit “transmit sequence number” which is incremented (toggled) for each new transmission and maintained the same for a retransmission. To avoid similar difficulties from arising in connection with lost acknowledgements, a one-bit “receive sequence number” is incremented whenever a new packet is acknowledged by a wireless unit. This bit indicates the sequence number expected in the next packet from the transmitting wireless unit, and thus effectively serves as an acknowledgment of receipt of the prior packet. In other words, if a wireless unit successfully receives a packet numbered “zero”, the receive sequence number is set to “I” in the next packet sent by such wireless unit. This receive sequence number of “1” is repeated in subsequent transmissions from the wireless interface device until it successfully receives another packet, which should have a transmit sequence number of “1”.
  • In the case in which a first host/device wireless unit sends a packet of sequence “1” which is not received by a second device/host wireless unit, the receipt by the first wireless unit of a packet of receive sequence “1” (or an ACK timeout) transmitted by the second wireless unit indicates to the first wireless unit that its transmission of the sequence “1” packet was not received and it retransmits this packet. If, on the other hand, the packet of sequence “1” transmitted by the first wireless unit is received by the second wireless unit but the acknowledgment which it transmits is lost en route to the first wireless unit, the first wireless unit will either time out the acknowledgement (and retransmit) or receive another packet, which includes an acknowledgment in the form of the correct sequence number. However, any retransmission by the first wireless unit will generally be unnecessary, since the duplicate sequence number will be detected by the second wireless unit upon receipt of the retransmitted packet and the message re-acknowledged (and the duplicate, retransmitted packet discarded).
  • In the event that more than three retransmissions of a packet occur, in one embodiment the communication link between the applicable host/device wireless units is reset (i.e., the send sequence number and the receive sequence number are both set to “0”). Upon receipt of a valid reset message, the receiving wireless unit acknowledges it with a packet of receive sequence number “1” and send sequence number “0”. It is observed that the term “three retransmissions” is intended to indicate that a set of three retransmissions of an original message have occurred, which results in the occurrence of four ACK timeouts and three BACKOFF timeouts. In one embodiment this consumes an average of approximately (4*1.2)+(3*(0.5+1)) ms or 9.3 ms, depending on the device ID. This interval provides a basis for the 10 ms duration of the LISTEN timeout, which is described below.
  • The receipt of an ACK by a host/device wireless unit concludes a present transaction between such unit and the device/host wireless unit with which it is in communication. In the absence of any new messages to transmit, the wireless unit 112 listens for unsolicited (random access) messages from the wireless units 114, 116 following receipt of an ACK. In contrast, the wireless units 114, 116 enter a sleep mode following receipt of an ACK. In the case in which the last ACK of a transaction is lost in transit following transmission by a keyboard/ mouse wireless unit 114, 116, the host wireless unit 112 retransmits the previously received message following expiration of the ACK timeout period. If the keyboard/ mouse wireless unit 114, 116 enters sleep mode as soon as it transmits this “lost” ACK, it will not receive the retransmission from the host wireless unit 112 and the host wireless unit 112 will be unaware that its message has been successfully received. In view of this possibility, the keyboard/ mouse wireless unit 114, 116 is configured to wait a short period in LISTEN mode prior to entering sleep mode so as to maximize the likelihood that it will receive any possible retransmission from the host wireless unit 112. As noted above, in one embodiment any message/acknowledgement transaction should complete in less than approximately 10 ms. Therefore, when a keyboard/ mouse wireless unit 114, 116 sends an ACK only message, it waits until expiration of a LISTEN timeout period of 10 ms before entering sleep mode. This effectively ensures that any retransmissions from the host wireless unit 112 will be received by the keyboard/ mouse wireless unit 114, 116 prior to expiration of the LISTEN timeout period.
  • In the exemplary embodiment, packets transmitted by the keyboard/ mouse wireless unit 1114, 116 are of the following general format:
      • 1. Short and long preamble sequences (16 bits)
      • 2. Transmit sequence number (1 bit)
      • 3. Receive sequence number (1 bit)
      • 4. Data present (=0)/acknowledgement only (=1) (1 bit)
      • 5. Reserved bits set to zero (1 bit)
      • 6. Device indication (3 bits, 0=keyboard, 1=mouse, other values reserved for future use)
      • 7. Mouse or keyboard data (24 bits) All zeros reserved as reset indication
  • 8. 8 bit CRC over the entire message excluding preamble.
    TABLE I
    Format for packet sent from keyboard/mouse transceiver
    Header Payload
    PL- Device Header- MAC Payload
    Preamble T R ACE RSV Length Indicator CRC MAC Payload CRC CRC
    16 1 1 1 1 7 3 8 0 − (27 − 1)*8 16
  • TABLE II
    Format for packet sent from keyboard/mouse
    transceiver (no payload case)
    Header
    PL- Device
    Preamble T R ACE RSV Length Indicator Header-CRC
    16 1 1 1 1 7 3 8
  • TABLE III
    Format for packet sent from host transceiver (payload case)
    Header
    PL- Device Payload
    Preamble T R ACK RSV Length Indicator Header-CRC MAC Payload CRC
    16 1 1 1 1 7 3 8 0 − (27− 1)*8 16
  • Radio Interface and Transmission Rate Selection
  • As was mentioned above, the radio interface 250 (FIG. 2) is representative of the set of registers and signals used in transferring messages between baseband hardware 260 within the MAC layer 208 and the remainder of each wireless unit. In the exemplary embodiment the baseband hardware 260 within the keyboard/ mouse wireless units 114, 116 performs encryption/decryption, CRC generation and checking, serialization/de-serialization, and also provides an interface to the RF units 414, 514.
  • In the exemplary embodiment the radio interface 250 within the keyboard/ mouse wireless units 114, 116 facilitates performance of at least the following functions: (i) enabling of the transmitter within the RF unit 414, 514, (ii) enabling of the receiver within the RF unit 414, 514, (iii) sending a message to the RF unit 414, 514, (iv) receiving a message from the RF unit 414, 514, (v) link quality assessment, (vi) selection of the rate used within the RF unit 414, 415, (vii) selection of the channel used within the RF unit 414, 415, (viii) control of output power of the transmitter within the RF unit 414, 415, (ix) setting the long sequence of the receiver within the RF unit 414, 415, and (x) setting the long sequence of the destination wireless' unit within the transmitter of the RF unit 414, 415.
  • Referring to FIG. 8, an event trace diagram 800 depicts the enabling of the transmitter/receiver within the RF units 414, 514 using single-bit signals under control of the MAC layer 208. As is indicated by FIG. 8, when the wireless unit 114, 116 enters sleep mode, it disables both the transmitter and the receiver within its RF unit 414, 514.
  • Message Transmission
  • In the exemplary embodiment the MAC layer 208 initiates the sending of a message by loading the body of the message into a set of registers within the radio interface 250 and signaling “send” to the baseband hardware 260. In particular; prior to asserting “send” the MAC layer 208 loads the following information into registers within the radio interface 250:
    • 1. Long sequence of destination (16 bits)
    • 2. Header (8 bits)
    • 3. Pointer to message (16 bits)
    • 4. Power Level (2 bits)
    • 5. Data Rate (1 bit)
    • 6. Channel (3 bits)
    • 7. Length of message (which asserts “send”).
      The “long sequence” is a 16 bit, bit sequence that is generated from the unit's 1-bit device ID. By expanding the number of bits used to represent the ID, it is possible to distinguish between valid ID's received without bit errors and ID that are invalid because a bit error occurred during transmission. The “header” (8 bits) comprise, transmit and receive sequence number bits, the “ACK only” bit, two zero bits, and the 3-bit device type The “power level” is the RF transmitter's power level. It can be adjusted with four possible settings. Higher power for better range and reduced bit errors, lower power to conserved battery life.
  • Prior to initiating the process of sending a message, the MAC layer 208 calculates the proper long sequence of the destination device by writing the device ID of such device into a register within the radio interface and reading back the long sequence. In the case of the host wireless unit 112, the MAC layer 208 is configured to track both of the keyboard/ mouse wireless units 114, 116 and maintain separate long sequences for each of them. The MAC layer 208 of the host wireless unit 112 also calculates a long sequence for the pairing device ID when the unit 112 is operative in a dynamic pairing (DP) mode (discussed below).
  • When “send” is asserted, the baseband hardware 260 continues the transmission process by sending the short sequence, which is a predetermined fixed training sequence used to bit synchronize the receiving modem to the transmitting modem, the specified long sequence, followed by the header and the body of the message itself. If the header specifies a device type of keyboard, the message portion is encrypted prior to transmission. Finally, the CRC is appended to the transmission.
  • Message Reception
  • Upon enabling of the receiver of the RF unit 414, 514, the baseband hardware 260 listens for a message with a long sequence matching the long sequence of the applicable keyboard/ mouse wireless unit 114, 116. Prior to performing this enabling operation, the MAC layer 208 calculates its “own” long sequence by writing the device ID of the applicable keyboard/ mouse wireless unit 114, 116 into a register within the radio interface 250. Except during pairing (discussed below), this need only be done once; during pairing, the reserved pairing device 1D is instead written to the radio interface 250. The MAC layer 208 also sets a message pointer register (16 bits) in order to inform the baseband hardware 260 of the location in which the received message should be placed.
  • Once a matching long sequence is detected, the baseband hardware 260 receives the ensuing header and message into a header register and a message buffer (not shown), respectively. In the host wireless transceiver unit 1.12, the message is first decrypted if the header specifies a device type of keyboard. The baseband hardware 260 then checks the received CRC. If the CRC is valid, it asserts “data ready” to the MAC layer 208. Conversely, the baseband hardware 260 must not present data (i.e., assert “data ready”) to the MAC layer 208 if the CRC is invalid, although the data may already be present within the message buffer. The MAC layer 208 is configured to respond as quickly as possible to the receipt of a data message with a message in the reverse direction indicating acknowledgement.
  • Data Rate Selection
  • As was mentioned above, except where prohibited by regulation communication occurs between wireless units in the HDR mode (i.e., at 150 kb/s) by default. In order to provide more robustness in the presence of severe interference, the applicable RF units are capable of falling back to operation in the MDR mode (i.e., 30 kb/s). In the exemplary embodiment, 5 channels are available for hopping during operation in the MDR mode. In European jurisdictions, the LDR mode is employed in order to comply with the pertinent regulations. Fallback from operation in the HDR mode to the MDR mode and channel selection are controlled by the MAC layer 208. This control is facilitated by a received signal strength indication (“RSSI”) provided by the RF unit, which is asserted in the presence of strong interference within the frequency bands of interest.
  • Turning now to FIG. 9, there is shown a state transition diagram 900 representative of the manner in which the MAC layer 208 changes the data rate and channel of the wireless unit in which it is disposed. In the exemplary embodiment the data rate and channel of the RF unit of a wireless interface device are changed, if necessary, immediately prior to transmission of a data packet. These changes are based upon the current RSSI status and the success or failure of the previous transmission by the RF unit. When a change in channel is required, the channel sequence followed is 0-3-1-4-2-0. It has been found that adhering to a fixed sequence of this type minimizes the searching required to re-locate a partner wireless unit following a channel change. Since an interfering signal may straddle adjacent channels, it is desirable to avoid hopping to an adjacent channel; and the sequence above (and its mirror in time) is the only such sequence which prevents this from occurring.
  • As is indicated by FIG. 9, during operation at the medium rate the selected channel is only changed in response to link failure (which presumably occurs due to interference). Since the host wireless unit 112 rarely initiates a transaction with a keyboard/mouse wireless unit 114, 116 (i.e., most data traffic is inbound to the unit 112), while operative in medium rate mode it is possible for it to “sit” on a bad channel as it is unlikely to receive information indicating that the channel is bad. In order to avoid this situation, the host wireless unit 112 is configured to change channels every 1 to 2 seconds during operation in medium rate mode. Since each keyboard/ mouse wireless unit 114, 116 is likely to be in sleep mode when this change in channel occurs, each will generally experience an ACK timeout following transmission of its next message. This timeout will also result in a change in channel. It is noted that in the case of the wireless unit 114 of the keyboard 104, the ACK timeout will cause it to reset encryption; accordingly, the host wireless unit 112 must likewise do so.
  • Referring again to FIG. 9, during operation of a wireless unit at the low data rate it is seen that the selected channel changes after each successful transmission. During operation at both the low and medium data rates, the channel number is reset to zero whenever the communication link is established; otherwise, whenever a transition to the medium data rate occurs, the channel last used is selected. This approach is intended to maintain channel synchronization between the wireless units at either end of the communication link. Except during operation in low data rate mode, in exemplary embodiments hardware encryption is reset whenever the channel or rate is changed; this will generally be preceded by a link reset message exchange in order to ensure timing synchronization.
  • Device Message Format
  • Referring now to Table IV below, descriptions are provided of the messages transmitted from the keyboard/ mouse wireless units 114, 116 to-the host wireless unit 112, and vice-versa. As may be appreciated by reference to Table IV, each device message contains a payload of 24 bits. The bits in each message payload are utilized as follows:
  • Mouse report: 5 bits indicating the state of the buttons, and 6 bits for each of 3 axes containing the delta position in that axis since the last report. MS (most significant) bit is always 1.
  • Keyboard report: 1 bit indicating key pressed or released, 5 bits specifying the column of the keypress, and 3 bits specifying the row. The MS bit of the report is always 0. If a scroller is present, motion is reported as if the scroller were a mouse axis in a separate field. This message is always encrypted.
  • Reset request: This message is comprised of all zeros. The wireless keyboard does not encrypt this message, since it is sent when the keyboard and transceiver may be out of synchronization.
  • Pairing accept: MS bits=010, LS (least significant) bits contain device ID.
  • GPIO data: MS bits=011, middle byte specifies group, low byte specifies value. The section below concerning “GPIO Pins” includes additional pertinent information.
    TABLE IV
    DIREC-
    TION
    Host <> DESCRIP- Format (MSb <---> LSb, 24 bits)
    Dev NAME TION 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
    <-----> Link Reset MAC 0 0 0 0 0 0 0
    Reset layer
    resync
    -------> Device Reset 0 0 0 0 0 0 1
    Reset device
    state
    (keys
    down,
    etc.)
    -------> Shut- Go to 0 0 0 0 0 0 2
    down sleep
    -------> Keep Poll 0 0 0 0 0 0 3
    Alive
    -------> Test Enter test 0 0 0 1 0 Test Number Test Parameter
    mode
    <------- Key- Report 0 0 1 0 0 Scroller Up Row Column
    board keypress/ Motion /
    Report release (if present) Dn
    N/A N/A Future use 0 0 1 1 Undefined
    <-----> Pairing request/ 0 1 0 0 0 Sender Device ID
    accept
    -------> Optical Write 0 1 0 1 0 Register # Data
    Mouse mouse
    register
    <------> GPIO Read/write 0 1 1 0 0 R Group Value
    GPIO pins /
    (to device, W
    value to
    TxRx)
    -------> Config- Write 0 1 1 1 0 Register # Data
    Set config.
    parameter
    <------- Mouse Report 1 Btn State X Motion Y Motion Z Motion
    Report buttons/ <-> 40
    motion
  • Operational Modes and Pairing Procedure
  • The wireless units 112, 114 and 116 are designed for operation in either one of two modes, determined at the time of manufacturing; specifically, operation may occur in either a “dynamically paired” (DP) mode or in an “out of the box” or (OOB) mode. The DP mode is designed for business or commercial situations where multiple users may have similar devices in close proximity to each other. As is discussed below, the keyboard/ mouse wireless unit 114, 116 randomly generates an ID code, which is transferred to the host wireless unit 112 at pairing time. Also at pairing time, the keyboard/ mouse wireless unit 114 and 116 learn the ID code of the host wireless unit 112, which is used on all transmissions from the keyboard/ mouse wireless unit 114 and 116.
  • The OOB mode is intended for consumer usage environments in which multiple devices are unlikely to be located closely together. This mode does not require performance of a pairing process, and thus a keyboard/ mouse wireless unit 114, 116 is ready to use as soon as batteries are inserted into the wireless keyboard 104 or wireless mouse 106 in which it is disposed. In this mode, all mouse wireless units 114 use the same fixed ID code, and all keyboard wireless units 116 share a single (different) fixed ID code.
  • As may be appreciated from the above, each wireless unit 112, 114, 116 is either pre-assigned a device ID or are assigned a dynamically generated device ID at pairing. With the exception of a few reserved sequences (e.g., all “0” or all “1”), in the exemplary embodiment all 11-bit device IDs are valid. If a device is in DP mode, at pairing time it generates a random 11-bit ID in hardware upon powering-up. This device II) is passed through a hardware block described in the above-referenced copending provisional patent application, which converts the device ID into a 16-bit long sequence which is incorporated within messages intended for receipt by the applicable wireless unit. Prior to enabling the receiver within its RF unit, a wireless unit 112, 114 and 116 writes its 16-bit long sequence to its radio interface. During operation, the receiver listens for messages having addresses containing this long sequence.
  • Whenever a message is transmitted a wireless unit 112, 114, 116, a long sequence prefix identifies the ID code of the intended recipient In the DP mode, the host wireless transceiver unit 112 does not possess a priori knowledge of the device ID of the keyboard/ mouse wireless unit 114, 116. Rather, during operation in DP mode a “pairing” operation is performed pursuant to which a device ID is dynamically generated by the keyboard/ mouse wireless unit 114, 116 and
      • communicated to the host wireless unit 112. This operation is performed following each loss of power within the keyboard/mouse wireless unit 114, 116 (e.g., whenever the batteries of a unit 114, 116 are changed).
  • In one embodiment of the OOB mode, each transceiver is identified by a predefined address. Specifically, a host transceiver is assigned TR-DEFAULT as an address, a keyboard transceiver is assigned KB-DEFAULT as an address, and a mouse is assigned M-DEFAULT as an address. Following completion of a successful pairing operation between a host and device transceiver, the paired transceivers will have unique addresses. In addition, in this embodiment a host transceiver assumes its unique address when communicating with a paired device transceiver. However, the host transceiver will continue to use TR-DEFAULT during communication with unpaired device transceivers.
  • In the case in which patch EEPROM is included within the host/device transceivers, in one embodiment all will have unique addresses. In the case in which the host/device transceivers lack an EEPROM, in one embodiment the host transceiver uses the preamble corresponding to the TR-DEFAULT address. In the case in which the host/device transceivers include an EEPROM, the host transceiver uses the preamble corresponding to its unique address.
  • FIG. 12 is an event trace diagram 1200 representative of the messages exchanged during a pairing operation involving a keyboard/mouse wireless unit 114, 116 (a “device”) and the host wireless unit 112. As shown, the pairing operation is initiated by the manual push of a predefined button of the host wireless unit 112 followed by the pressing of a predefined button of the keyboard 104 or mouse 106 associated with the device within a few seconds. When the host wireless unit 112 is incorporated within a dongle (not shown) attached to the host PC 102, a dedicated button may be provided on the dongle for use during pairing. Success of the pairing operation is evidenced by proper operation of the device (e.g., by keystrokes or mouse clicks being processed by the host PC following receipt by the host wireless unit 112). If the pairing operation fails, both sides continue to attempt to pair until success or expiration of a predefined number of attempts (e.g. 1000). If the timeout period expires, the device goes to sleep until the pairing button of the keyboard 104 or mouse 106 associated with the device is pushed again.
  • As is indicated by FIG. 12, when the predefined button activating pairing operation of the host wireless unit 112 is pressed, the host wireless unit 112 begins transmitting “pairing request” messages which contain the transceiver ID code of the host wireless unit 112 and which are addressed to a reserved ID code (e.g., all “is”). When the predefined button of the keyboard 104 or mouse 106 attached to the device is pressed, the device temporarily assumes the reserved ID and listens for pairing requests from the host wireless unit 112. If the device successfully receives a request, it responds with an ACK containing a pairing accept message to the transceiver ID code. This message contains the actual device ID code of the transmitting device.
  • The host wireless unit 112, between issuing pairing request messages, listens for incoming messages. If it receives a pairing accept message from the device, it remembers the ID code of its new partner and acknowledges it. Once, the acknowledgement is received at the device, the device assumes its “rear’ identity; that is, it begins sending and receiving messages on the basis of its actual device ID. Once the device has assumed its actual identity, it transmits a reset message to the host wireless unit 112. If the reset message is acknowledged by the host wireless unit 112, the applicable communication link 108, 110 is considered established and normal operation ensues.
  • When the pairing button associated with the host transceiver is pressed, in the exemplary embodiment the host transceiver transmits pairing request messages periodically (every 50 ms in the case of HDR), using a fixed PAIRING-PREAMBLE. The pairing request message will generally contain the unique address of the host transceiver (32 bits), and host transceiver preamble (16 bits). When the pairing button triggering the keyboard/mouse transceiver is pressed, it will listen to pairing request messages for a pairing interval (55 ms in the case of HDR) using the fixed PAIRING-PREAMBLE. When this period expires, the keyboard/mouse transceiver checks whether there are any user input events. If there are user events, the keyboard/mouse transceiver transmits them for (2× period−pairing interval) (2×50−55=45 ms for HDR). If there are not any user inputs, the keyboard/mouse transceiver immediately returns to the pairing process. If the keyboard/mouse transceiver successfully receives a pairing request, it responds with an ACK containing a pairing accept message using the preamble of the host transceiver. This message contains the unique address (32 bits) of the keyboard/mouse transceiver. If the host transceiver hears the pairing accept message from the keyboard/mouse transceiver, it remembers the address of the keyboard/mouse transceiver and acknowledges the pairing accept message. When this acknowledgement is received at the keyboard/mouse transceiver, the keyboard/mouse transceiver assumes the its new address.
  • Device Configurability Options
  • Referring now to FIG. 11, there is shown a computer system 1100 in accordance with the present invention to which reference will be made in describing one manner in which various parameters of wireless units operative within the system 1100 may be configured upon establishment of radio communication links between such units. As shown, the system 1100 includes a host wireless unit 1112 of a host PC 1102, a wireless unit 1114 of a wireless keyboard 1104, and a wireless unit 1116 of a wireless mouse 1106.
  • In the embodiment of FIG. 11, costs of implementing the system 1100 are minimized by designing the host wireless unit 1112 to incorporate an EEPROM 1134 as well as a host transceiver module 1130. In this regard the host transceiver module 1130 is disposed to implement all of the above-described functionality of the host wireless unit 112. In addition, the EEPROM 1134 stores configuration options for each of the wireless units of the system 1100; that is, configuration information is stored for the host transceiver module 1130 and keyboard/ mouse wireless units 1114, 1116. By taking advantage of the two-way radio links between the host transceiver module 1130 and keyboard/ mouse wireless units 1114, 1116, the parameters stored within the EEPROM 1134 may be distributed to the keyboard/ mouse wireless units 1114, 1116 upon the establishment of radio communication within the system 1100.
  • In certain embodiments the keyboard/ mouse wireless units 1114, 1116 each include a small amount of writable non-volatile memory (e.g., 4 KB). Alternatively, the keyboard/ mouse wireless units 1114, 1116 do not include writable non-volatile memory, and power-up in a fixed state defined only by hardware inputs and built-in defaults. Since requiring multiple pins for configuration is cumbersome and expensive, in the exemplary embodiment each keyboard/ mouse wireless unit 1114, 1116 uses only one pin for configuration input to specify operation in either the DP or OOB mode. Upon power-up of a keyboard/ mouse wireless unit 1114, 1116, various operational parameters are set to the default values stored within corresponding locations of its writable non-volatile memory or registers.
  • Once a radio link has been established between the host transceiver module 1130 and a 30 keyboard/ mouse wireless unit 1114, 1116, the host transceiver module 1130 reads the EEPROM 1134 and identifies those operational parameters of the keyboard/ mouse wireless units 1114, 1116 with respect to which the default values should be overridden. For each of these identified parameters, the host transceiver module 1130 sends a configuration message to the keyboard/ mouse wireless unit 1114, 1116. Each configuration message includes a parameter ID uniquely identifying a register or the location within the non-volatile memory of the keyboard/ mouse wireless unit 1114, 1116, as well as a parameter value to be stored in such location. As mentioned above, the value of each parameter is initialized upon power-up of the keyboard/ mouse wireless unit 1114, 1116 to a default value; however, the sending of a configuration message permits the default value to be overridden with a desired value appropriate for the intended application and/or system environment. In the exemplary embodiment the keyboard/ mouse wireless unit 1114, 1116 does not attempt to validate or otherwise check these values; rather, it simply writes the selected register or memory location and proceeds.
  • In summary, for each parameter to be changed in a keyboard/ mouse wireless unit 1114, 1116, the host wireless unit 1112 issues a configuration message containing the parameter ID and the desired value. These values simply replace the defaults until the keyboard/ mouse wireless unit 1114, 1116 loses power. Upon again becoming energized, the keyboard/ mouse wireless unit 1114, 1116 re-establishes its radio link with the host wireless unit 1112, and the parameter overrides are retransmitted.
  • If no parameter overrides are required and the system 1100 is operating in OOB mode, then no EEPROM 1134 is required within the host the host wireless unit 1112. However, the absence of the EEPROM 1134 is generally not a sufficient basis upon which to assume that operation in the OOB mode is intended, as the apparent absence of EEPROM 1134 may in fact be the result of a failure. In order to detect this situation, one configuration input is used at the hardware pin level. Specifically, pulling up this pin with a resistor 1140 indicates that EEPROM 1134 is not present.
  • As the host wireless unit 1112 and the keyboard/ mouse wireless unit 1114, 1116 each have built-in defaults for all parameters, only variations need be stored within the EEPROM 1134. Accordingly, in implementations of the system 1100 in which no changes are required to be made to these built-in defaults, no EEPROM 1134 is required. That being said, if the system 30 1100 is intended to be used in DP mode, it will necessary for some provision to be made for the host wireless unit 1112 to remember its pairings when the host PC 1102 is turned off and the host wireless unit 1112 loses power.
  • In the embodiment of FIG. 11, it is necessary for each keyboard/ mouse wireless unit 1114, 1116 to know in which mode (DP or OOB) it is to be operative upon powering up. Since in this case only two possible operational modes exist, only one bit of configuration information need be provided in order to select between modes. By providing the option of adding a mode selection resistor 1150, 1152 to each the keyboard/ mouse wireless units 1114, 1116, providing this configuration information to each device may be achieved at a “cost” of only one resistor per device and obviates the need to provide additional pins. In an exemplary embodiment the presence of the resistor 1150, 1152 results in the keyboard/ mouse wireless unit 1114, 1116 becoming operative in the OOB mode (i.e., the device uses a single static device ID for communicating with the host wireless unit 1112. If the resistor 1150, 1152 is absent, then the keyboard/ mouse wireless unit 1114, 1116 elects a random device ID and expects the pairing procedure discussed above to be followed.
  • In order to provide positive confirmation of the validity of the contents of the EEPROM 1134, the records for each wireless unit 1112, 111 are protected by checksums which are verified each time the host wireless unit 1112 powers up. As discussed above, in order to resolve the ambiguity, which may exist if the EEPROM 1134 is not accessible upon the host wireless unit 1112 powering on (i.e., either the EEPROM 1134 is present but defective or is simply not present), the resistor 1140 is used to indicate whether or not the EEPROM 1134 should be present. If the resistor 1140 is present, no attempt is made to access an EEPROM 1140 and the system 1100 operates utilizing its default values. If the resistor 1140 is absent, then the EEPROM 1134 must be present and checksum tests are performed upon the records of the EEPROM 1134.
  • Referring now to Table V, a list of exemplary default values and ranges is provided for various operational parameters (or, equivalently, “options”) of the keyboard wireless unit 1114. For each operational parameter that is to bet set at something other than its default value, a corresponding option value is transferred from the host wireless unit 1112 to the keyboard wireless unit 1114 once a communication link has been established between the units 1112, 1114. It is observed that a set of keyboard-related options are also implemented by the host wireless unit 1112 (see Table IV below), and thus need be transferred to the keyboard wireless unit 1114.
    TABLE V
    Keyboard Configuration Options
    Option Default Min Max
    # Description Value Value Value
    K1 Paired/Out of Box OOB Paired OOB
    (OOB) Mode
    K3 Scan Rate (# of 5 1 7
    scans for debounce)
    K4 Scan Time (ms between 4 1 7
    scans)
    K6 “Same Keys Down” 2 0 (never) 63
    Timeout (seconds)
    K7 Phantom Timeout (seconds) 20 0 (never) 63
    K8 Keep-Alive (Out of Range 0 (Do not 0 (Do not 255
    Detection) Interval wake up) wake up)
    (seconds)
  • Table VI provides a list of exemplary default values and ranges for various options of the mouse wireless unit 1116. For each operational parameter that is to bet set at something other than its default value, a corresponding option value is transferred from the host wireless unit 1112 to the mouse wireless unit 1116 once a communication link has been established between the units 1112, 1116. A large percentage of an optical mouse's battery life is typically consumed by the mouse's optical sensor. To conserve battery life, the sensor operation is suspended periodically after movement of the mouse is stopped. The suspension duration is increased in a stepwise fashion as the time since the last movement is increases. In the preferred embodiment there are four steps. S0, S1, S3 and S4. The duration of each step and the and the duration of the suspension during each step is configurable.
  • It is observed that a set of mouse-related options are also implemented by the host wireless unit 1112 (see Table VII below), and thus need be transferred to the mouse wireless unit 1114.
    TABLE VI
    Mouse Configuration Options
    Option Default Min Max
    # Description [unit] Value Value Value
    M1 Paired/Out of Box OOB Paired OOB
    (OOB) Mode
    M3 Button Scan Rate 5 1 7
    [# of scans for
    debounce]
    M4 Button Scan Time 4 1 7
    [ms between scans]
    M5 Mouse Type Mech. Mech. Optical
    M6 S0 → S1 Timeout 200 0 255
    [ms] (never)
    M7 S1 Sample Rate [ms] 10 1 255
    M8 S1 → S2 Timeout 60 0 255
    [sec] (never)
    M9 S2 Sample Rate [ms] 65 1 255
    M10 S2 → S3 Timeout 120 0 255
    [10 sec] (never)
    M11 S3 Sample Rate [ms] 0 0 255
    (0 implies button press
    required to wakeup)
    M12 Keep-Alive (Out of 0 (Do not 0 (Do not 255
    Range Detection) Interval wake up) wake up)
    (seconds)
  • Table VII provides a list of exemplary default values and ranges for various options of the host transceiver module 1130. In the exemplary embodiment there exist three logical groups of options processed by the host transceiver module 1130. The first and second option groups (i.e., Group I and Group 2) relate to the operation of the keyboard/ mouse wireless units 1114, 1116, but are processed locally by the host transceiver module 1130. The third logical group (i.e., Group 3) of Table VII consists of options pertinent to operation of the host transceiver module 1130 itself.
    TABLE VII
    Host Transceiver Configuration Options
    Option Default Min Max
    # Description [unit] Value Value Value
    Group
    1
    TK1 Keyboard Present? Yes No Yes
    TK2 Keyboard Device ID OOB value
    (high byte) (H)
    TK3 Keyboard Device ID OOB value
    (low byte) (L)
    TK4 Battery Levels to 2 0 7
    Report (no report)
    TK5 Use Alternate Scan No No Yes
    Code Table?
    TK6 Scroller Type Volume Volume Scroll
    Control Control Keys
    TK100- Alternate Scan Code
    TK260 Table
    Group
    2
    TM1 Mouse Present? Yes No Yes
    TM2 Mouse Device ID OOB value
    (high byte) (H)
    TM3 Mouse Device ID OOB value
    (low byte) (L)
    TM4 Optical Mouse Frame 1500 (H) 0 255
    Rate (high limit) (=5)
    (high byte)
    TM5 Optical Mouse Frame 1500 (L) 0 255
    Rate (high limit) (=220)
    (low byte)
    TM6 Optical Mouse Frame 1500 (H) 0 255
    Rate (low limit) (=5)
    (high byte)
    TM7 Optical Mouse Frame 1500 (L) 0 255
    Rate (low limit) (=220)
    (low byte)
    TM8 # of Mouse Buttons 3 0 5
    TM9 Counts per (0.1) 20? 0 255
    Inch (multiple of
    10 cpi; 20 =
    200 cpi)
    TM10 Battery Levels to 2 0 7
    Report (no report)
    TM11 PS/2 Commands Standard Standard BTC
    TM100 Optical Mouse Init 0 0 15
    Command Count
    TM101 Init Command 1 0 255
    Register
    TM102 Init Command 1 0 255
    Value
    TM103 up Rest of Init 0 255
    Commands (2 options
    per command, up to
    a maximum of TM130)
    Group 3
    TT1 Transceiver Device ID OOB value
    (high byte) (H)
    TT2 Transceiver Device ID OOB value
    (low byte) (L)
    TT3 European Operation No No Yes
    (low rate hopping)
    TT4 Encryption Key

    GPIO Pins
  • In order to enhance the potential for configurability of the wireless units 1114, 1116, each may include a number of external pins defined as general purpose I/O (GPIO). Electrically, each of these pins will generally be implemented as an open drain output with the ability to be read back as an input if an associated output register contains a “1” bit. Upon power-up, the device wireless unit 1114, 1116 unit initializes its GPIO pins to “1” values and thereafter is not involved in changing their values. For reference purposes, GPIO pins are grouped into sets of eight, which are manipulated in parallel. Each group of eight is assigned a group number.
  • Under certain circumstances the host wireless unit 112 may request to set or read a group of GPIO pins of a wireless unit 1114, 1116. To this end the host wireless unit 1112 conveys such a request to the device wireless unit 1114, 1116 by way of a GPIO read or GPIO write message containing an identification of the group number. In the case of a GPIO write message, the value to be written is also provided. Upon receipt of a GPIO read message, the device wireless unit 1114, 1116 responds with a GPIO data message containing the requested data. It is the responsibility of the host wireless unit 1112 to write a “1” to any input bit before it is read.
  • Device Customization and Application Development
  • In addition to enabling the wireless units 114, 116 to be flexibly configured in the manner described in the previous section, in one aspect the present invention further contemplates that the operation of the wireless units 114, 116 be amenable to customization in view of the requirements of various applications. To this end, the software executing on the wireless units 112, 114, 116 has been designed to incorporate various “hooks” in order to allow certain parameters adjusted. Such hooks are also intended to allow portions the software to be extended or replaced by supplementary software included within an inexpensive external serial “patch” EEPROM of the general type described above with reference to FIG. 11.
  • Referring to FIG. 22, a high-level representation is provided of a system 2200 comprised of wireless units incorporating EEPROM patches in accordance with one aspect of the present invention. In particular, the system 2200 includes a host wireless unit 2212 incorporating transceiver software within a ROM 2222 and transceiver patch software within an EEPROM 2232. The system 2200 further includes a keyboard wireless transceiver 2214 containing a ROM 2224 in which is stored keyboard software and an EEPROM 2234 in which is stored keyboard patch software. Finally, the system 2200 also includes a mouse wireless transceiver 2216 configured with a ROM 2224 incorporating mouse software and an EEPROM 2236 incorporating mouse patch software.
  • In general, the host transceiver 2212 and device transceivers 2214, 2216 are ROM-based designs. That is, the bulk of the program code stored within these transceivers is normally executed from ROM. However, the inclusion of serial EEPROM within one or all of the transceivers 2212, 2214 and 2216 facilitates a patching procedure allowing certain default operational parameters to be changed at startup and limited changes to be made to the operating software of the transceiver.
  • FIG. 23 is a flowchart representative of certain aspects of the operation of the system 2200. As shown in FIG. 23, upon powering-up the processor (not shown) within each transceiver 2212, 2214, 2216 initializes critical hardware and software then checks the I2C bus to which it is connected for the presence of an external EEPROM. If an EEPROM is present, the processor reads the first few EEPROM bytes and compares them to a predefined number sequence. If the sequence matches, the content of the EEPROM is copied to specified locations in the processors external RAM. Execution of the software stored within the ROM 2222, 2224, 2226 of the transceiver 2212, 2214, 2216 then continues.
  • Within a “config” data block in the external RAM of a processor included within each host/ device transceiver 2212, 2214, 2216, the software stored within ROM 2222, 2224, 2226 expects to find certain critical operating parameters. This data block is initialized by the software stored within ROM 2222, 2224, 2226 upon start up. If no EEPROM patch software is present; the software stored within ROM 2222, 2224, 2226 uses the values loaded at start up. If a patch EEPROM 2232, 2234, 2236 is present, the config data block can optionally be over-written as the contents of the patch EEPROM 2232, 2234, 2236 are read.
  • The software stored within ROM 2222, 2224, 2226 also expects to find a control table potentially containing pointers to code patches within external RAM of the applicable processor. Each pointer potentially points to a ROM code replacement function. For most entries in this table a null pointer value is expected. If a null entry is found, the software stored within ROM 2222, 2224, 2226 executes the original ROM code function for that pointer location. However, if the software within the patch EEPROM 2232, 2234, 2236 over-writes the control table value with a non-null pointer, the replacement function referenced by the pointer is executed in place of the ROM code function. Replacement functions can be other functions previously defined in ROM 2222, 2224, 2226, or newly-defined functions loaded from the patch EEPROM 2232, 2234, 2236 to RAM at start up.
  • Consistent with the invention, the EEPROM patching procedure discussed above may be used for a variety of purposes including, for example, for default parameter substitutions, procedure substitutions, and the execution of precompiled functions. The first two of these potential uses is summarized below.
  • Parameter Substitutions
  • Those parameters assigned default ROM values which may be replaced (i.e., “substitutable parameters”) are defined in a predefined file within the patch EEPROM 2232, 2234, 2236. This file declares a predefined type (i.e., “Mask ROM Config t”) which, when instantiated, defines the available substitutable parameters.
  • Procedure Substitutions
  • A predefined file (i.e., “MRCONT.H”) contains the type definition for the Mask ROM Control “t” type referenced above. By default this structure is instantiated as a series of null function pointers. Each null pointer is a placeholder for a potential substitute procedure of the general form illustratively represented by FIG. 24. In order to substitute a new function for a default function, the null function pointer corresponding to the default procedure is replaced with a function pointer pointing to the new replacement procedure. Replacement procedures are located in the RAM program area (loaded from the applicable patch EEPROM 2232, 2234, 2236 on power up). Alternatively, replacement procedures can reference the preexisting functions in the code within ROM 2222, 2224, 2226.
  • Operation of Host Wireless Unit
  • As may be appreciated by reference to FIG. 3-5, in the exemplary embodiment the architecture of the host wireless unit 112 (or, equivalently, “host transceiver 112”) is substantially similar to that of the device wireless units 114, 116. Accordingly, for the sake of clarity of presentation the following discussion does not repeat those aspects of the preceding discussion equally applicable to the host and device wireless units, and is instead intended to highlight the structural and operational differences there between.
  • Host Transceiver Message Format
  • As mentioned above, Table I provides information regarding each of the messages transmitted from the keyboard/ mouse wireless units 114, 116 to the host wireless unit 112, and vice-versa. As may be appreciated by reference to Table I, the host transceiver 112 sends messages containing the following 24-bit payloads:
      • Pairing request: Most significant (MS) byte identifies message, least significant (LS) bits specify device ID. Only sent to reserved pairing ID.
      • Configuration: MS byte identifies message, middle byte specifies a configuration register or memory location, and low byte contains data to be written to the specified register or memory location.
      • Optical mouse command: MS byte identifies message, middle byte specifies optical mouse chip register, low byte specifies value to be written to the optical mouse chip.
      • GPIO read: MS byte identifies command, middle byte specifies a GPIO group. LS byte unused.
      • CPIO write: MS byte identifies command, middle byte specifies a GPIO group, LS byte contains data to be written to the GPIO pins of the specified group.
      • Shutdown message: Sent only on behalf of the host PC 102. The destination wireless unit 114, 116 sends an ACK upon receipt of a Shutdown message, then goes to its lowest-power state. Note that a wakeup message, which is described in the above-referenced copending patent application, will not “rouse” a wireless unit 114, 116 from its lowest-power state.
      • Keep-Alive: Optionally used in order to detect when a wireless unit 0.114, 116 moves out of range of the host wireless unit. In response to receipt of a Keep-Alive message, the wireless unit 114, 116 sends an ACK and then may sleep for the configured keep-alive interval.
    Power Management
  • In the exemplary embodiment the system 100 implements a power management scheme consistent with the “OnNow” initiative for system-wide power management defined by Microsoft Corporation. As part of this initiative, Microsoft has published “Device Class Power Management Reference Specifications” for various device classes, including the input device class applicable to keyboards, mice, joysticks, and the like (see, e.g., www.microsoft.com). The Reference Specifications for the input device class defines four power states, D0 through D3. A device operative in the D0 state is completely active and normally functioning, and consumes power at the highest level possible. In contrast, state D3 corresponds to the case in which power may have been fully removed from the device, and it considered to be completely “off”. As state D2 has been characterized as being inapplicable to input devices, the only remaining state is D1. The D1 state requires that device power consumption be equal to or greater than the D2 state, but less than the D0 state. Accordingly, in the D1 state hardware such as displays and indicators (e.g., LED devices) are turned off, but state information such as num, caps, and scroll lock state are preserved. In the exemplary embodiment transitions between power states within a device are explicitly commanded by drivers within the PC host, and are not performed autonomously.
  • Consistent with one aspect of the present invention, host wireless unit 112 and keyboard/ mouse wireless units 114, 116 define a power state D1 as follows:
      • Upon receipt of a “go to D1” command via a PS/2 port, the host wireless unit 112 transmits a power down message to all connected keyboard/ mouse wireless units 114, 116.
      • The host wireless unit 112, after receiving all necessary ACK's, shuts off its RF unit 314 (both transmitter and receiver) and all LED devices.
      • After performing the above shut down operations, the processor of the host wireless unit 112 halts in a mode where a PS/2 interrupt or power cycling is the only way to wake it up. The wireless unit 112 should be in the lowest power consumption state possible, consistent with receiving a PS/2 message.
      • A keyboard/ mouse wireless unit 114, 116, upon receiving a power down message, sends an ACK in response and waits for an ACK timeout period in order to ensure that the ACK is received. Following expiration of this time out period, the wireless unit 114, 116 shuts down both the transmitter and receiver of its RF unit 414, 514. In the case of the mouse wireless unit 116, instructions are also provided to any optical mouse chip within its wireless mouse 106 to enter a power down state.
      • The keyboard/ mouse wireless unit 114, 116 then enters a sleep mode until a key of the wireless keyboard 104 or wireless mouse 106 is pressed, as applicable.
      • Once the keyboard/ mouse wireless unit 114, 116 wakes up in response to the occurrence of such a key press, it resumes operation, retaining the device ID of any paired devices. Such resumption of operation generally entails: (i) restoring the LED devices of the wireless keyboard/ mouse 104, 106, and (ii) turning on the receiver of its RF unit 414, 514, utilizing the same rate and channel selections as were in place prior to sleep mode being entered.
      • Upon waking up, the keyboard/ mouse wireless unit 114, 116 also attempts to send a reset message to the host wireless unit 112. Failure is handled as before; that is, the key press initiating the wakeup operation is discarded.
    Collision Avoidance and Interference Handling Collision Avoidance
  • FIG. 14 depicts a flowchart 1400 representative of a carrier sense/clear channel assessment procedure (CS/CCA) procedure executed by the MAC layer 208 of the keyboard/ mouse wireless unit 114, 116 prior to transmission of a message. As shown, in the event a message needs to be transmitted by the keyboard/ mouse wireless unit 114, 116, the receiver of its RF unit 414, 514 is enabled and it waits for a predefined period for PLL locking to occur. Next, the receiver of its RF unit 414, 514 provides a CCA report indicative of the level of interference present within the channel in which it desired to transmit the message. In the exemplary embodiment a 1-bit CCA report is provided by the RF unit 414, 514; namely, a CCA of “1” indicates the channel is busy, and a CCA of “0” indicates the channel is clear. The details of the remainder of CS/CCA procedure is illustrated by FIG. 14
  • The duration of the random backoff (B) occurring within the CS/CCA procedure FIG. 14 may be expressed as B=Bmin+N*W, where:
      • Bmin=Packet duration+Ttx+Trx+TMAC+TPLL+ACK−duration+Ttx
      • TMAC=MAC processing time (assuming 150 μs)
      • TPLL=PLL switching time=150 μs
      • Ttx=transmitter latency
      • Trx=receiver latency
        and where W=0.5*Bmin and N is a random integer (e.g., 0<=N<=S3). In addition, the “window T” referenced in FIG. 14 corresponds to the on-air turnaround time between the transmitter and receiver of different wireless units in the case of an ACK, and is given by T=TPLL+TMAC+Ttx
  • The transmitter latency (Ttx) and receiver latency (Ttx) for various data rates are provided in Table V, and the durations of various types of message packets are set forth in Table VI.
    TABLE V
    Data rate Ttx (μs) Trx (μs)
    112.5 kb/s 29 21
    28.125 kb/s 82 67
    9.375 kb/s 224 138
  • TABLE VI
    Duration
    Packet Packet Duration for
    duration duration for “piggy-
    for for normal back”
    keyboard mouse ACK ACK
    Data rate (μs) (μs) (μs) (μs)
    112.5 kb/s 596 738 312 738
    28.125 kb/s 2,383 2,952 1,245 2,952
    9.375 kb/s 7,147 8,854 3,734 8,854
    Spreading 6,556 8,118 3,432 8,118
  • Table VII provides a tabular listing of the value of Bmin as a function of data rate.
    TABLE VII
    Bmin (ms)
    Data rate Keyboard Mouse
    112.5 kb/s 1.287 1.429
    28.125 kb/s. 4.159 4.728
    9.375 kb/s 11.767 13.474
    Spreading 10.367 11.929
  • In the exemplary embodiment the CCA threshold level utilized by the RF unit 414, 514 in generating the CCA report during execution of the CS/CCA procedure illustrated by FIG. 14 does not remain the same for all applications. Rather, even for a given application, the CCA 20 threshold level will generally depend upon the distance between the transmitting/receiving devices as well as the distance between an interferer and such devices.
  • Turning now to FIG. 15, a flowchart 1500 is provided of procedure for dynamically adjusting the CCA threshold level used by the RF unit 414, 514 when generating a CCA report. In the embodiment of FIG. 15, the default values are: M=−60 dBm, N=2000 packets, x=60%, y=10%, and b=7%, where M, N, x, y, a, and b are configurable parameters.
  • Table VIII shows an exemplary mapping between CCA threshold level (TH) and RF control signals:
    TABLE VIII
    CCA threshold
    CCA_Vth_b2 CCA_Vth_b1 CCA_Vth_b0 level (TH)
    0 0 0 −48 dBm
    0 0 1 −54 dBm
    0 1 0 −60 dBm
    0 1 1 −66 dBm
    1 1 0 −72 dBm
    1 1 1 −78 dBm
  • In Table VIII, it is noted that (CCA_Vth_b2=1, CCA_Vth_b1=0 CCA_Vth_b0=0) and (CCA_Vth_b2=1, CCA_Vth_b1=0 CCA_Vth b0=1) are not used. CCA_Vth_b2, CCA_Vth_b1 and CCA_Vth_b0 are three control line bits used to set the CCA threshold level.
  • Interference. Handling
  • FIG. 16 is a high-level flow diagram representative of a general approach to interference handling consistent with the present invention. As was discussed above, data is transmitted and received by wireless units in four different modes: a high data rate (HDR) mode; a medium data rate (MDR) mode; a low data rate (LDR) mode and a spreading mode. The HDR mode is the default mode, which can provide 150 kbps data transmission. The data rates for the MDR, LDR and spread mode are 30 kbps, 10 kbps and 13.64 kbps respectively. Spreading mode is used when there is interference from similar wireless device(s) (e.g., other host and device transceivers), and MDR is used when there is strong interference (e.g., narrow-band interference) such as from citizen band (CB) radio. In certain embodiments each wireless unit 112, 114, 116 is able to detect interference and switch to appropriate modes automatically. As a consequence, highly reliable wireless data transfers may be affected even in an environment with multiple other wireless users.
  • Normal/Spreading Mode and Spreading/Normal Mode Switching
  • Consistent with one aspect of the invention, spreading mode may be invoked to mitigate interference engendered by the presence of other host/device transceivers within the vicinity of a host/device transceiver pair desiring to communicate. In an exemplary embodiment the device transceiver of a host/device transceiver pair controls the switching between normal and spreading mode.
  • A device transceiver 114, 116 initiates spreading mode operation by sending, to the host transceiver 112, a packet, which has been spread in the manner described in the above-referenced copending patent application. Upon receiving a packet in spreading mode, the modem 308 at the host transceiver 308 will notify the MAC layer 208 that spreading mode has been enabled, which results in the host transceiver 112 also sending the ACK in spreading mode.
  • If the host transceiver 112 and device transceiver 114, 116 are in spreading mode and the device transceiver 114, 116 makes decision to switch to normal mode, the device transceiver 114, 116 will send a packet in normal mode. Upon receiving this packet in normal mode, the modem 308 at the host transceiver 112 notifies the MAC layer 208 that the device transceiver 114, 116 has switched back to normal mode. This results in the host transceiver 112 sending the ACK in normal mode.
  • Of course, a given host transceiver 112 will generally be in communication with more than one device transceiver 114, 116. Accordingly, the host transceiver 112 is disposed to 20 communicate with each device transceiver 114, 116 in accordance with the mode that has been currently selected by such transceiver 114, 116.
  • In the exemplary embodiment the device transceivers 114, 116 elect to switch from normal mode to spreading mode when more than a predefined number of failures occur within a predefined number of the most recent transmissions. For example, it has been found that switching to spreading mode is appropriate if more than 21 failures occur in connection with the most recent 25 attempted transmissions. Similarly, the device transceivers 114, 116 may elect to switch from spreading mode to normal mode when less than a predefined number of failures occur within a predefined number of the most recent transmissions. For example, it has been found that a return to normal mode from spreading mode may be when less than 18 failures occur in connection with the most recent 25 transmissions.
  • Switching Between HDR and MDR
  • Turning now to FIG. 17, a flow chart 1700 is provided of an exemplary manner in which the host transceiver 112 transitions between operation within the HDR and MDR modes, and vice-versa. In the exemplary embodiment a transition is made from HDR to MDR mode when a received signal strength indication (RSSI) generated by the RF unit 314 indicates the presence of strong interference (e.g., narrow-band interference) such as from citizen band (CB) radio.
  • Within the host transceiver 112, the RSSI generated by the RF unit 314 is checked periodically (e.g., every 2 ms). If it is determined to be necessary to switch to MDR mode, switching occurs to a particular MDR channel in accordance with the sequence 0-3-1-4-2-0 . . . . In the case of the initial switch from HDR to MDR mode, the host transceiver 112 first attempts to operate in a predefined MDR channel (e.g., channel 4). If in fact “L” is the channel through which the host/device transceivers are communicating immediately prior to transitioning back to operation in HDR mode (i.e., in the event the RSSI again becomes sufficiently low to warrant HDR mode operation), then the host transceiver 112 will switch to channel “L” the next time a transition to MDR mode is required.
  • When in the HDR mode and the host transceiver has determined RSSI to be high for K seconds, the mode is switched to the MDR mode. While RSSI is high in the MDR mode, the host transceiver listens for N seconds. If a message is received, the host transceiver stays in the channel in which the message was received. The transceiver remains on the channel provided no interval of greater than M seconds elapses without receiving a message. If after M seconds no message is received and RSSI remains high the communication channel is switched to the next channel and the encryption is reset. Then the host transceiver listens again for N seconds. After N seconds the next channel is selected. After each channel has been selected and no message has been received the transceiver is switched back to the HDR mode and the encryption is reset. In an exemplary embodiment the following values are utilized for the parameters identified in FIG. 17: N=100 ms, M=5 second and K=100 ms.
  • Referring to FIG. 18, a flow chart 1800 is provided of an exemplary manner in which a device transceiver 114, 116 transitions between operation within the HDR and MDR modes, and vice-versa. As in the case of the host transceiver 112, a device transceiver 114, 116 transitions from the HDR to MDR mode when an RSSI generated by the applicable RF unit 414, 514 indicates the presence of strong interference (e.g., narrow-band interference).
  • As shown in FIG. 18, when the device transceiver 114, 116 is in receiving mode (i.e., in order to receive the ACK), RSSI from the RF unit 414, 514 is checked. If it is determined to be necessary to switch to MDR mode, switching occurs to a particular MDR channel in accordance with the sequence -3-1-4-2-0 . . . . In the case of the initial switch from HDR to MDR mode, the device transceiver 114, 116 first attempts to operate in a predefined MDR channel (e.g., channel 4). If in fact “L” is the channel through which the host/device transceivers are communicating immediately prior to transitioning back to operation in HDR mode (i.e., in the event the RSSI again becomes sufficiently low to warrant HDR mode operation), then the device transceiver 114, 116 will switch to channel “L” the next time a transition to MDR mode is required.
  • In an exemplary embodiment the following values are utilized for the parameters identified in FIG. 18: Timer1=50 ms, Timer2=1 seconds and T=100 ms.
  • Power-Saving Operation During USB Suspend State
  • As was indicated above, in certain embodiments the host transceiver 112 may be incorporated within a dongle or the like and connected to the host PC 102 through a Universal Serial Bus (USB). Those skilled in the art are aware that the USB is a personal computer (PC) interconnect capable of supporting simultaneous attachment of multiple devices. In the exemplary embodiment the host transceiver 112 includes an integrated USB function controller 10 and a full speed (12 Mb/s) transceiver.
  • USB devices may be self-powered or receive energy via the USB cable through which they communicate with a hosting entity. USB supports a variety of power modes: On, Suspend, and Off. When placed in Suspend mode, USB devices retain the ability to wakeup the hosting system.
  • A number of requirements are imposed upon devices, which are placed on a USB. See, e.g., “An Overview of the Universal Serial Bus (USB), Part 1”, SSS Online (December 2000). For example, a device placed on the bus is permitted to draw up to 500 mA; however, many hosting entities will not permit a device to draw more than 100 mA from the bus. Consistent with the USB protocol, the host transceiver 112 informs the host PC 102 as to the amount of current required for its operation. However, when the host transceiver 112 enters the Suspend mode in accordance with the USB protocol, it cannot draw any more than 500 uA from the bus (assuming the host transceiver is bus-powered rather than battery-powered). In this regard the USB protocol requires the host transceiver 112 to enter the Suspend state if its bus has been inactive for 3 ms. The host PC 102 can initiate a resume command to the host transceiver 112 when it is in Suspend mode. Similarly, the host transceiver 112 can also issue a remote wakeup to the host PC when it is inactive in order to render it active.
  • In view of the limitations on the amount of current which can be drawn by the host transceiver 112 from its USB during operation in Suspend mode, it will generally not be possible for the host transceiver 112 to remain “awake” (i.e., fully operational) at all times when operative in this mode. Accordingly, in accordance with one aspect of the invention the host transceiver 112 only periodically becomes fully operational and capable of receiving messages from device transceivers 114, 116 when functioning in Suspend mode. As is discussed below, the messaging protocols of any device transceivers 114, 116 in communication with a host transceiver 112 are also modified upon entry of the host transceiver 112 into Suspend mode.
  • Turning now to FIG. 19, a timing diagram 1900 is provided which is representative of the transition of the host transceiver 112 into and out of “awake” and “sleep state” operation during its operation in Suspend mode consistent with the USB protocol. As shown, the host transceiver operates in an awake state for a period of W ms once every B ms, and is otherwise in a sleep state. Each awake period will generally be of the same duration and of sufficient length to permit capturing of the header of a message packet transmitted by a device transceiver. 114, 116. In order to facilitate understanding of this aspect of the invention, exemplary computations of appropriate values of the parameters W and B are given below for the case of transmissions by the mouse transceiver 116 during both normal and spreading mode operation.
  • During normal mode operation, the worst-case time required to capture the header of a packet transmitted by the mouse transceiver 116 (i.e., the awake period W) may be expressed as: W = Tosc + T PLL + Packet duration + Ttx + T PLL + ACK time - out duration + T PLL + acquisition sequence / header duration = ( 500 + 200 + 573 + 11 + 200 + 253 + 200 + 253 ) μs , for HDR mode = 2.190 ms , for HDR mode
    where,
      • Tosc=time for oscillator warm up=500 μs
      • TPPL=time for PLL settling=200 μs
      • Ttx=transmission latency=11 μs
  • In an exemplary implementation of the host transceiver 112, its power consumption during an awake time of 2.190 ms is estimated to be =44 ms×mA. It follows that the interval (B) between awake periods should be <=(44 mA ms)/(2.5 mA), or 17.6 ms. That is, when operative in Suspend mode the host transceiver enters an awake state every 17.6 ms (for HDR mode), and is otherwise in sleep state.
  • During spreading mode operation, the worst-case time required to capture the header of a packet transmitted by the mouse transceiver 11.6 (i.e., the awake period W) may be expressed as: W = Tosc + T PLL + Packet duration + Ttx + T PLL + ACK time - out duration + T PLL + acquisition sequence / header duration = ( 500 + 200 + 573 * 11 + 11 + 200 + 253 * 11 + 200 + 253 * 11 ) μs , for HDR mode = 13.0 ms , for HDR mode
    where,
      • Tosc=time for oscillator warm up 500 μs.
      • TPLL=time for PLL settling=200 μs.
      • Ttx=transmitter latency=11 μs.
  • In an exemplary implementation of the host transceiver 112, its power consumption during an awake time of 13.0 ms during spreading mode is estimated to be 314.25 ms×mA. It follows that the interval (B) between awake periods should be <=(314.25 mA ms)/(2.5 mA), 125.7 ms. That is, when operative in Suspend mode the host transceiver enters an awake state every 125.7 ms (for HDR mode), and is otherwise in sleep state.
  • Referring now to FIG. 20, there is shown a state transition diagram 2000 representative of the operation of the transceiver 112 when in Suspend mode. As is indicated by FIG. 20, the transceiver 112 transitions from sleep state to awake state every awake period of B ms, and remains in awake state for W ms. If validation of the header of a message from the mouse transceiver 116 occurs during the W ms duration of an awake state, the host transceiver remains in the awake state. If such a header validation occurs and no packets are received for N ms, the host transceiver 112 returns to sleep state.
  • Turning now to FIG. 21, a state transition diagram 2100 depicts the corresponding modifications to the messaging protocol of the mouse transceiver 116 upon entry of its partner host transceiver 112 into Suspend mode. As shown, in this context the mouse transceiver 116 is disposed to re-transmit a packet if an ACK is not received in response to the initial transmission of the packet. If a predefined number of such re-transmissions also fail, the mouse transceiver 116 sends link-reset packets. If these link-reset packets also fail to result in a resetting of the applicable communication link, then the moue transceiver 116 transmits link-reset packets for E ms if no packets are queued for transmission; otherwise, the next queued packet is transmitted and operation continues as described above.
  • In the embodiment of FIGS. 19-21, the parameters E, B, W, and N are configurable. An 25 exemplary set of default values of these parameters are B=140 ms, W=14 ms, E=140 ms, N=140 ms.
  • The foregoing description, for purposes of explanation, used specific nomenclature to provide a thorough understanding of the invention. However, it will be apparent to one skilled in the art that the specific details are not required in order to practice the invention. In other instances, well-known circuits and devices are shown in block diagram form in order to avoid unnecessary distraction from the underlying invention. Thus, the foregoing descriptions of specific embodiments of the present invention are presented for purposes of illustration and description. They are not intended to be exhaustive or to limit the invention to the precise forms disclosed, obviously many modifications and variations are possible in view of the above teachings. The embodiments were chosen and described in order to best explain the principles of the invention and its practical applications, to thereby enable others skilled in the art to best utilize the invention and various embodiments with various modifications as are suited to the particular use contemplated.
  • While the invention has been particularly shown and described with reference to preferred embodiments thereof, it will be understood by those skilled in the art that various changes in form and details may be made without departing from the spirit and scope of the invention.

Claims (40)

1. A method of communication between a media access control (MAC) and a radio unit within a transceiver, comprising:
a) writing a device ID of said receiving device to a radio unit;
b) enabling read mode, and receiving a message;
c) processing said message and preparing an acknowledgement (ACK) message;
d) disabling read mode;
e) setting up registers in said radio unit and enabling send mode; and
f) sending said ACK message and disabling send mode upon completion of sending said ACK message.
2. The method of claim 1, wherein processing said message includes a cyclical redundancy check (CRC) whereby said ACK message is blocked if the CRC finds said message to be bad.
3. A method for changing operating states of a wireless communication system under a control of a media access control (MAC) unit, comprising:
a) operating in a high data rate (HDR) mode when a received signal strength indicator (RSSI) is high and changing to a medium data rate (MDR);
b) selecting a next MDR channel when an acknowledgement (ACK) message timer expires;
c) changing to said HDR mode from said MDR mode when all available said MDR channels have been tried and said ACK timer expires for each said available MDR channels; and
d) changing to said HDR mode when RSSI is low and operating in said HDR mode when RSSI is low.
4. The method of claim 3, wherein said RSSI is monitored by a radio frequency unit coupled to said MAC and provides an indication of the strength of other signals, or noise, operating on said MDR channel.
5. The method of claim 3, wherein said next MDR channel is selected from a plurality of channels in which no two adjacent channels are selected in an immediate sequence to reduce the possibility that unwanted signals on a first selected channel being present on a second channel.
6. A method for collision avoidance and information handling, comprising;
a) preparing to send a message from a peripheral RF transceiver;
b) enabling an RF receiver and waiting for locking of a phase lock loop;
c) performing a clear channel assessment CCA by the RF receiver;
d) performing a random backoff if a channel is busy and then switch to a transmit mode;
e) awaiting a window of time T, then check the CCA report from said RF receiver, if channel is not busy, then switch to transmit mode, otherwise if channel is busy, perform a random backoff, then switch to transmit mode;
f) transmitting said message and after switching to said RF receiver to wait for an acknowledgement (ACK) that the message transmitted was received and ending if an ACK is received;
g) returning to step c) if there is no ACK and a number of transmissions has not exceeded a maximum;
h) exiting process if the number of transmissions has exceeded the maximum and waiting for a new message.
7. The method of claim 6, wherein said CCA is a measurement of a level of interference within said channel.
8. The method of claim 6, wherein said random backoff is a function a size of said message, a transmitter and a receiver latency, a time to process for preparing to send said message and switching time of said phase lock loop.
9. The method of claim 6, wherein said window of time T is a function of a switching time of said phase lock loop, a time to process for preparing to send said message and a transmission latency.
10. A method for dynamically adjusting a clear channel assessment (CCA), comprising:
a) setting a CCA threshold to a default value;
b) measuring performance and backoff rates for a plurality of sent radio frequency (RF) messages;
c) increasing said CCA threshold to threshold=threshold plus a specified decibel level if the backoff rate is greater than a first backoff amount and said performance is less than a first performance amount, and returning to step b) to measure performance and backoff rates; and
d) decreasing said CCA threshold to threshold=threshold minus a specified decibel level if the backoff rate is less than a second backoff amount and said performance is greater than a second performance amount, and returning to step b) to measure performance and backoff rates.
11. The method of claim 10, wherein said backoff is a time delay before resending an RF message thereby breaking deadlocks caused by simultaneous RF transmissions.
12. The method of claim 10, wherein said CCA is a measurement of a level of interference within a communication channel.
13. A method for interference handling, comprising:
a) receiving a received signal strength indication (RSSI) at an radio frequency (RF) transceiver;
b) applying a high data rate (HDR) or a medium data rate (MDR) when said RSSI is high, which signifies a relatively high degree of RF interference; and
c) checking conditions to go between a spreading mode and an MDR mode when said RSSI is low, which signifies a relatively low degree of RF interference.
14. The method of claim 13, wherein said HDR is a default data rate mode.
15. The method of claim 13, wherein said MDR is used when there is a strong interference such as might be caused by a citizen band radio.
16. The method of claim 13, wherein said spreading mode is used when there is interference from devices similar to said RF transceiver.
17. A method for switching between a high data rate (HDR) and a medium data rate (MDR) at an RF transceiver, comprising:
a) continuing use of a HDR when a received signal strength indicator (RSSI) is low;
b) switching to a MDR when the RSSI is high and resetting a data encryption;
c) listening for a first period of time on a first channel of a plurality of communication channels after switching to the MDR mode;
d) continuing to communicate in said first channel when said RF message is received, listening for a second period of time, and receiving additional RF messages;
e) switching to a second channel of said plurality of communication channels and resetting said encryption after listening and receiving no RF messages on said first channel, then returning to step c);
f) switching the HDR mode after switching through all available channels of said plurality of channels when in the MDR mode until said all available channels have been used and no RF messages have been received; and
g) switching to the HDR mode and resetting the encryption when the RSSI is low.
18. The method of claim 17, wherein switching to the HDR model further comprises:
a) resetting encryption and listening for a third period of time; and
b) switching to the MDR mode and changing encryption when RSSI is high and no RF message is received during said third period of time.
19. The method of claim 18, wherein said third period of time is for a plurality of seconds.
20. The method of claim 17, wherein said first and second periods of time is for a plurality of milliseconds.
21. The method of claim 17, wherein said plurality of channel are selected in a sequence where no two channels having adjacent frequencies are selected as a next channel from said plurality of channels.
22. A method for performing in a medium data rate (MDR) mode, comprising;
a) transmitting a first RF message in a MDR mode over a first communication channel and listening for an first acknowledgement (ACK);
b) remaining in said first communication channel if said first ACK is received, transmitting a second RF message and waiting for a second ACK;
c) remaining in said first communication channel if said second ACK is received;
d) retransmitting said second RF message as a first retransmission of said second RF message and waiting for a third ACK and remaining in said first communication channel if said third ACK is received; and
e) retransmitting said second RF message as a second retransmission of the second RF message if a first timer has not expired and if said third ACK is not received, otherwise switch a second communication channel and reset encryption.
23. The method of claim 22, wherein transmitting said first RF message further comprises:
a) switching to said second communication channel and resetting encryption if said first ACK of the first RF message is not received;
b) retransmitting said first RF message as a first retransmission of said first RF message and remaining in said second communication channel if said ACK to said first retransmission of said RF message is received;
c) switching to a third communication channel, resetting encryption, retransmitting said first RF message as a second retransmission if a second timer has not expired; and
d) switching to a high data rate (HDR), resetting encryption mode, retransmitting said first RF message as a third retransmission of said first RF message and listening for said ACK for the third retransmission and returning to said MDR mode if no said ACK received, a third timer has expired and a received signal strength indicator is high.
24. The method of claim 23, wherein said second timer is in the order of seconds and said third timer is in the order of milliseconds.
25. The method of claim 22, wherein said first timer is in the order of milliseconds.
26. A method for a host transceiver in suspend mode, comprising:
a) waiting for a first period of time and entering an awake state;
b) listening for RF messages during a second period of time, detecting no valid header data, entering a sleep state, and returning to step a);
c) validating a header of a message, listening for a third period of time, receiving no data packet, entering a sleep state and returning to step a); and
d) validating said header of a message, listening for a third period of time, receiving a packet of data, remaining in said awake state and returning to step b).
27. The method of claim 26, wherein said first period of time is an amount of time between said awake states.
28. The method of claim 25, wherein said second period of time is an amount of time in which the host is awake.
29. The method of claim 25, wherein said third period of time necessary to receive said data packet and respond with an acknowledgement.
30. A method for modifying messaging protocol of a mouse transceiver upon entry of a host transceiver into a suspend mode, comprising:
a) transmitting a first message from a mouse to a host transceiver and if an acknowledgement ACK is received by said mouse continue transmitting additional messages;
b) re-transmitting said first message if ACK is received, then continue transmitting additional messages;
c) re-transmitting said first message if ACK not received and if a predefined number of retransmissions has not been exceeded;
d) sending a link reset from said mouse to said host transceiver if a predefined number of retransmissions has not been exceeded;
e) receiving ACK from said host transceiver for said link reset and returning to transmitting messages from said mouse to said host;
f) sending said link reset from said mouse to said host transceiver if no ACK for link reset received from said host transceiver and if said predetermined number of said link reset not exceeded; then g) transmitting a second message if said second message packet is in a queue; and
h) sending said link reset for a period of time if no said message packet is in the queue.
31. The method of claim 30, wherein said period of time is a plurality of milliseconds that is reconfigurable.
32. A computing system using radio frequency (RF) signals to communicate between a plurality of computing units, comprising:
a) a plurality of transceivers located in a plurality of computing units and communicating between said plurality of computing units with RF signals;
b) each transceiver of said plurality of transceivers contain a software ROM that controls operations of said each transceiver; and
c) a software patch EEPROM added to said each transceiver to allow modifications and additions to commands contained within said software ROM.
33. The computing system of claim 32, wherein said plurality of computing units comprise a host computer, a keyboard and a mouse.
34. The computing system of claim 32, wherein said each transceiver controls communications and is personalized to the characteristics of each computing unit of said plurality of computing units with said ROM and said EEPROM.
35. A method for using a patch EEPROM for controlling operations of a radio frequency (RF) transceiver, comprising:
a) initializing a transceiver in a computing unit;
b) copying an EEPROM into RAM if a patch EEPROM exists then resuming initialization from a ROM; and
c) continuing operation using said ROM if a patch EEPROM does not exist.
36. The method of claim 35, wherein said ROM provides commands for operating said transceiver.
37. The method of claim 35, wherein said EEPROM provides modified and additional commands for operating said transceiver.
38. A method for using null function pointers to substitute a new function into an operation of a radio frequency (RF) transceiver, comprising:
a) calling a substitute function if a function pointer is not equal to null and continuing operation of a RF transceiver; and
b) running an original function if said function pointer is null and continuing operation of said RF transceiver.
39. The method of claim 38, wherein said substitute function replaces a default function when a default pointer is replaced with said function pointer.
40. The method of claim 38, wherein said substitute function resides in memory and is loaded into said memory upon power-on of said transceiver.
US11/081,381 2004-03-16 2005-03-16 High-reliability computer interface for wireless input devices Abandoned US20050243059A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US11/081,381 US20050243059A1 (en) 2004-03-16 2005-03-16 High-reliability computer interface for wireless input devices

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
US55382104P 2004-03-16 2004-03-16
US55405804P 2004-03-16 2004-03-16
US55382004P 2004-03-16 2004-03-16
US11/081,381 US20050243059A1 (en) 2004-03-16 2005-03-16 High-reliability computer interface for wireless input devices

Publications (1)

Publication Number Publication Date
US20050243059A1 true US20050243059A1 (en) 2005-11-03

Family

ID=34994309

Family Applications (6)

Application Number Title Priority Date Filing Date
US11/081,381 Abandoned US20050243059A1 (en) 2004-03-16 2005-03-16 High-reliability computer interface for wireless input devices
US11/082,008 Abandoned US20050235159A1 (en) 2004-03-16 2005-03-16 Wireless transceiver system for computer input devices
US11/081,363 Expired - Fee Related US7626576B2 (en) 2004-03-16 2005-03-16 Wireless transceiver system for computer input devices
US11/081,380 Abandoned US20050243058A1 (en) 2004-03-16 2005-03-16 High-reliability computer interface for wireless input devices
US11/081,376 Abandoned US20060035590A1 (en) 2004-03-16 2005-03-16 High-reliability computer interface for wireless input devices
US11/082,009 Abandoned US20050237304A1 (en) 2004-03-16 2005-03-16 Wireless transceiver system for computer input devices

Family Applications After (5)

Application Number Title Priority Date Filing Date
US11/082,008 Abandoned US20050235159A1 (en) 2004-03-16 2005-03-16 Wireless transceiver system for computer input devices
US11/081,363 Expired - Fee Related US7626576B2 (en) 2004-03-16 2005-03-16 Wireless transceiver system for computer input devices
US11/081,380 Abandoned US20050243058A1 (en) 2004-03-16 2005-03-16 High-reliability computer interface for wireless input devices
US11/081,376 Abandoned US20060035590A1 (en) 2004-03-16 2005-03-16 High-reliability computer interface for wireless input devices
US11/082,009 Abandoned US20050237304A1 (en) 2004-03-16 2005-03-16 Wireless transceiver system for computer input devices

Country Status (2)

Country Link
US (6) US20050243059A1 (en)
WO (2) WO2005089387A2 (en)

Cited By (24)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20060227112A1 (en) * 2005-04-07 2006-10-12 Jaalaa, Inc. Combined keyboard and wireless transceiver
US20070070035A1 (en) * 2005-09-29 2007-03-29 Ray Asbury Method for pairing 1-way devices without buttons
US20070069828A1 (en) * 2005-09-26 2007-03-29 Chien Chin M Supply independent Schmitt trigger RC oscillator
US20080018518A1 (en) * 2006-07-21 2008-01-24 Asustek Computer Inc. Remote system capable of controlling an electronic device and method thereof
US20090153305A1 (en) * 2005-07-08 2009-06-18 Antonio Ambrosetti Method and System for Locating Objects
US20090216901A1 (en) * 2008-02-27 2009-08-27 Schloming Rafael H Three-way communication protocol
US20100131700A1 (en) * 2006-10-31 2010-05-27 Gemalto S.A Memory indexing system and process
US20100189020A1 (en) * 2009-01-23 2010-07-29 Qualcomm Incorporated Methods and systems using fast connection setup procedure for wimax networks
WO2011130752A1 (en) * 2010-04-16 2011-10-20 Mastandrea Nicholas J Wearable motion sensing computing interface
US8269531B1 (en) 2007-03-12 2012-09-18 Cypress Semiconductor Corporation Programmable power supervisor
US20130017794A1 (en) * 2011-07-15 2013-01-17 Cisco Technology, Inc. Mitigating Effects of Identified Interference with Adaptive CCA Threshold
KR101517576B1 (en) * 2008-02-22 2015-05-06 레이저 (아시아-퍼시픽) 피티이 엘티디 Power usage management of wireless input devices
US9312949B1 (en) * 2013-03-05 2016-04-12 Square, Inc. Pairing techniques for a wireless card reader
US20160218766A1 (en) * 2015-01-28 2016-07-28 Lam Research Corporation Dual Push Between A Host Computer System And An RF Generator
CN106104408A (en) * 2013-11-29 2016-11-09 行动股份有限公司 Wearable calculates device
US10405030B2 (en) * 2010-08-20 2019-09-03 Saturn Licensing Llc Server load balancing for interactive television
US10999012B2 (en) * 2014-11-07 2021-05-04 Strong Force Iot Portfolio 2016, Llc Packet coding based network communication
US11057310B2 (en) 2015-07-07 2021-07-06 Strong Force Iot Portfolio 2016, Llc Multiple protocol network communication
US11087315B2 (en) 2015-09-24 2021-08-10 Square, Inc. Server-assisted pairing for wireless communications
US11108665B2 (en) 2014-11-07 2021-08-31 Strong Force Iot Portfolio 2016, Llc Packet coding based network communication
US11474618B2 (en) * 2019-07-24 2022-10-18 Hewlett-Packard Development Company, L.P. Communication link based on activity on a keyboard
US11481750B2 (en) 2015-06-30 2022-10-25 Block, Inc. Pairing a payment object reader with a point-of-sale terminal
US11625109B2 (en) * 2021-09-14 2023-04-11 Finalmouse LLC Computer mouse
US11871237B1 (en) 2016-06-30 2024-01-09 Block, Inc. Pairing a payment object reader with a point-of-sale terminal

Families Citing this family (121)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6876947B1 (en) 1997-10-02 2005-04-05 Fitsense Technology, Inc. Monitoring activity of a user in locomotion on foot
US7400733B1 (en) * 2002-02-27 2008-07-15 Atheros Communications, Inc. Key refresh at the MAC layer
DE602004008769T2 (en) * 2003-05-09 2008-01-24 Nxp B.V. Method and arrangement for adjusting the transmission power of a mobile transmission device
US7848703B1 (en) * 2004-12-30 2010-12-07 Cypress Semiconductor Corporation Method and apparatus for binding wireless devices
US8140013B1 (en) 2003-06-04 2012-03-20 Cypress Semiconductor Corporation Wireless communication device and method
EP1678705A4 (en) * 2003-10-31 2007-07-04 Jaalaa Inc Computer interface with both wired and wireless links
TWM266618U (en) * 2004-07-19 2005-06-01 Behavior Tech Computer Corp Multiple output connection head with wireless data collection capability
US7313640B2 (en) * 2004-08-03 2007-12-25 Logitech Europe S.A. System and method for transmitting bidirectional signals over a cable antenna
US7150402B2 (en) * 2004-11-19 2006-12-19 Yuan-Jung Chang Device and method for a wireless mouse to detect the battery status of a host computer
US7392061B2 (en) * 2004-12-15 2008-06-24 Intel Corporation Methods and apparatus for operating transceiver systems of a wireless platform
TWI258098B (en) * 2004-12-31 2006-07-11 Pixart Imaging Inc Method and related apparatus for decreasing delay time and power consumption of a wireless mouse
TW200638778A (en) * 2005-04-26 2006-11-01 Z Com Inc Wireless network device with signal detection function and switching method for the same
TWI268669B (en) * 2005-05-27 2006-12-11 Bluepacket Communications Co Ltd System and method for wireless signal transmission establishing an inter-transmission and exchange of files between a computer peripheral and a host system through a wireless signal transmission module
US7634290B2 (en) * 2005-05-31 2009-12-15 Vixs Systems, Inc. Adjusting transmit power of a wireless communication device
US8207937B2 (en) * 2005-06-24 2012-06-26 Logitech Europe S.A. Communication protocol for networked devices
US7785192B2 (en) * 2005-07-21 2010-08-31 Wms Gaming, Inc. Dynamic power management in a gaming machine
DE102005040889A1 (en) * 2005-08-29 2007-03-15 Siemens Ag Method and arrangement for the secure transmission of data in a multi-hop communication system
US7664961B2 (en) * 2005-09-12 2010-02-16 Imation Corp. Wireless handheld device with local biometric authentication
US9000883B2 (en) * 2005-09-20 2015-04-07 GM Global Technology Operations LLC Control apparatus and method utilizing identifying keys
TWI305728B (en) * 2006-04-26 2009-02-01 Pixart Imaging Inc Interactive wireless game apparatus and wireless peripheral module
US7486114B2 (en) * 2006-05-17 2009-02-03 International Business Machines Corporation Signal detector with calibration circuit arrangement
US7478188B2 (en) * 2006-06-02 2009-01-13 Hewlett-Packard Development Company, L.P. System and method for connecting a WUSB device to multiple WUSB hosts
US7995034B2 (en) * 2006-06-22 2011-08-09 Microsoft Corporation Input device having a presence sensor
US20080049716A1 (en) * 2006-06-30 2008-02-28 Intel Corporation Error rate based power management of a high-speed serial link
US8072309B2 (en) * 2006-09-14 2011-12-06 Crown Equipment Corporation Systems and methods of remotely controlling a materials handling vehicle
US7768415B2 (en) 2006-09-28 2010-08-03 Nike, Inc. Sensor device with persistent low power beacon
TWI346475B (en) * 2006-12-08 2011-08-01 Primax Electronics Ltd Channel switching method for wireless peripheral
KR101393629B1 (en) * 2007-01-17 2014-05-09 삼성디스플레이 주식회사 Display device and driving method thereof
US8060661B1 (en) 2007-03-27 2011-11-15 Cypress Semiconductor Corporation Interface circuit and method for programming or communicating with an integrated circuit via a power supply pin
US8788959B1 (en) * 2007-04-25 2014-07-22 Cypress Semiconductor Corporation System and method for monitoring a target device
US9720805B1 (en) 2007-04-25 2017-08-01 Cypress Semiconductor Corporation System and method for controlling a target device
US8266575B1 (en) 2007-04-25 2012-09-11 Cypress Semiconductor Corporation Systems and methods for dynamically reconfiguring a programmable system on a chip
US7831847B2 (en) * 2007-05-07 2010-11-09 Mediatek Inc. Integrated circuit with power control and power control method thereof
US7664894B2 (en) * 2007-09-14 2010-02-16 Broadcom Corporation Wireless human interface device (HID) coordination
US20090151849A1 (en) * 2007-12-13 2009-06-18 Kimberly-Clark Worldwide, Inc. Cosmetic Wipe that Provides a Visual Indication of its Effectiveness
US8566431B2 (en) * 2008-01-16 2013-10-22 Razer (Asia-Pacific) Pte. Ltd. Identification device and method for device identification
KR100897297B1 (en) * 2008-02-15 2009-05-14 주식회사 하이닉스반도체 Apparatus and method for generating reset signal of semiconductor integrated circuit
US8355003B2 (en) * 2008-06-13 2013-01-15 Microsoft Corporation Controller lighting activation by proximity and motion
US8897719B2 (en) * 2008-06-30 2014-11-25 Sibeam, Inc. Initializing a transceiver in a wireless communication system
US9531986B2 (en) 2008-06-30 2016-12-27 Sibeam, Inc. Bitmap device identification in a wireless communication system
US20090327547A1 (en) * 2008-06-30 2009-12-31 In Sung Cho I2c bus compatible with hdmi
US9264762B2 (en) 2008-06-30 2016-02-16 Sibeam, Inc. Dispatch capability using a single physical interface
US20100009633A1 (en) * 2008-07-08 2010-01-14 Lucent Technologies, Inc. Security encryption for wireless peripherals
US8089468B2 (en) * 2008-08-15 2012-01-03 Lenovo (Singapore) Pte. Ltd. Slate wireless keyboard connection and proximity display enhancement for visible display area
US8129939B2 (en) * 2008-08-15 2012-03-06 Lenovo (Singapore) Pte. Ltd. Slate wireless keyboard charging and connection
US8051231B2 (en) * 2008-11-06 2011-11-01 International Business Machines Corporation Data communications among electronic devices within a computer
US8327048B2 (en) 2009-01-07 2012-12-04 Sony Computer Entertainment Inc. Using USB suspend/resume to communicate information through a USB device
US8352652B2 (en) * 2009-01-07 2013-01-08 Sony Computer Entertainment Inc. Using analog signals to communicate through an A/D converter and USB interface
US9065685B2 (en) * 2009-02-13 2015-06-23 Cisco Technology, Inc. Network switch employing a proxy to facilitate power savings in a telephone network
US20100251375A1 (en) * 2009-03-24 2010-09-30 G2, Inc. Method and apparatus for minimizing network vulnerability
US8082354B2 (en) * 2009-03-31 2011-12-20 Hewlett-Packard Development Company, L.P. Method of notifying a communications device
TWI383293B (en) * 2009-04-14 2013-01-21 Generalplus Technology Inc Power saving method in sleep mode and keyboard controller using the same
CA2729983C (en) 2009-04-24 2016-07-26 Skullcandy, Inc. Wireless synchronization mechanism
JP5603647B2 (en) * 2009-05-13 2014-10-08 キヤノン株式会社 Power feeding device, power feeding device control method, and power feeding communication system
JP5597022B2 (en) 2009-05-13 2014-10-01 キヤノン株式会社 Power supply apparatus and control method
KR101545490B1 (en) * 2009-05-29 2015-08-21 엘지전자 주식회사 Image Display Device and Operating Method for the Same
KR20100128958A (en) * 2009-05-29 2010-12-08 엘지전자 주식회사 Image display device and control method for the same
KR101598336B1 (en) 2009-05-29 2016-02-29 엘지전자 주식회사 Operating a Remote Controller
US8704958B2 (en) * 2009-06-01 2014-04-22 Lg Electronics Inc. Image display device and operation method thereof
US20100306688A1 (en) * 2009-06-01 2010-12-02 Cho Su Yeon Image display device and operation method therefor
KR101572843B1 (en) * 2009-06-03 2015-11-30 엘지전자 주식회사 Image Display Device and Operating Method for the Same
US20100316820A1 (en) * 2009-06-16 2010-12-16 Rainer Kolb Composite Materials Comprising Propylene-Based Polymer Blend Coatings
US20100316808A1 (en) * 2009-06-16 2010-12-16 Gregory Keith Hall Polyolefin Compositions for Coating Applications
US20110059277A1 (en) * 2009-09-04 2011-03-10 Rainer Kolb Elastomeric Surface Coatings for Plastic Articles
CN101995945A (en) * 2009-08-27 2011-03-30 旭丽电子(广州)有限公司 Wireless peripheral device and factory matching system thereof
US9397785B1 (en) 2010-04-12 2016-07-19 Marvell International Ltd. Error detection in a signal field of a WLAN frame header
US8891784B2 (en) 2010-07-06 2014-11-18 GM Global Technology Operations LLC Microphone assembly for use with an aftermarket telematics unit
US8494447B2 (en) 2010-07-29 2013-07-23 General Motors Llc Aftermarket telematics unit for use with a vehicle
US8604937B2 (en) 2010-07-29 2013-12-10 General Motors Llc Telematics unit and method for controlling telematics unit for a vehicle
US8571752B2 (en) 2010-08-05 2013-10-29 General Motors Llc Vehicle mirror and telematics system
US8543289B2 (en) * 2010-09-30 2013-09-24 Genreal Motors LLC Aftermarket telematics system
US8463494B2 (en) 2010-10-07 2013-06-11 General Motors Llc Aftermarket telematics unit and method for installation verification
US8504858B2 (en) 2011-02-02 2013-08-06 Avago Technologies General Ip (Singapore) Pte. Ltd. Wireless input device with a power saving system
CN103444114B (en) 2011-02-04 2017-07-14 马维尔国际贸易有限公司 Control model PHY for WLAN
US20120229307A1 (en) * 2011-03-10 2012-09-13 Chun-Liang Tsai Low power wireless short range transmission system
TWI492555B (en) * 2011-03-10 2015-07-11 Favepc Inc Low power wireless short range transmission system
CN102739610B (en) * 2011-04-08 2015-10-07 瑞昱半导体股份有限公司 Be used in machinery of consultation and the electronic installation of HDMI (High Definition Multimedia Interface) ethernet channel
WO2013152111A1 (en) 2012-04-03 2013-10-10 Marvell World Trade Ltd. Physical layer frame format for wlan
US9729420B2 (en) 2012-04-26 2017-08-08 Hewlett-Packard Development Company, L.P. Decreasing USB interference to adjacent wireless device
US20130307796A1 (en) * 2012-05-16 2013-11-21 Chi-Chang Liu Touchscreen Device Integrated Computing System And Method
US9152527B2 (en) * 2012-07-09 2015-10-06 Qualcomm Incorporated Method and apparatus for identifying wireless peripherals and their states at a docking host for wireless docking
TWI486965B (en) * 2012-10-03 2015-06-01 Pixart Imaging Inc Communication method used for transmission port between access device and control device, and access device
CN103077139B (en) * 2013-02-01 2016-05-11 威盛电子股份有限公司 Use integrated circuit and the control method thereof of internal integrate circuit bus
TWI480760B (en) * 2013-02-06 2015-04-11 Chi Pei Wang Prevent the input data is recorded in the computer network system side
WO2014183059A1 (en) 2013-05-10 2014-11-13 Marvell World Trade Ltd. Physical layer frame format for wlan
CN104158531A (en) * 2013-05-13 2014-11-19 鸿富锦精密工业(深圳)有限公司 Electronic device
KR20210153759A (en) 2013-09-10 2021-12-17 마벨 아시아 피티이 엘티디. Extended guard interval for outdoor wlan
US20150100795A1 (en) * 2013-10-07 2015-04-09 Microsemi Corporation Secure Storage Devices, Authentication Devices, and Methods Thereof
US10218822B2 (en) 2013-10-25 2019-02-26 Marvell World Trade Ltd. Physical layer frame format for WLAN
KR20160077134A (en) 2013-10-25 2016-07-01 마벨 월드 트레이드 리미티드 Range extension mode for wifi
US10194006B2 (en) 2013-10-25 2019-01-29 Marvell World Trade Ltd. Physical layer frame format for WLAN
WO2015116227A1 (en) * 2014-02-03 2015-08-06 Empire Technology Development Llc Encrypted communication between paired devices
US11855818B1 (en) 2014-04-30 2023-12-26 Marvell Asia Pte Ltd Adaptive orthogonal frequency division multiplexing (OFDM) numerology in a wireless communication network
CN106576061B (en) * 2014-06-02 2020-09-04 爱唯思有限公司 System and method for secure communication over a network using a linked address
US10034325B2 (en) 2015-09-24 2018-07-24 Mediatek Inc. Enhance at command for backoff timer control
US9756568B2 (en) * 2015-09-24 2017-09-05 Mediatek Inc. Enhance AT command for backoff timer control
KR102409276B1 (en) * 2016-02-15 2022-06-15 엘지이노텍 주식회사 Mouse pad and wireless power transmission system including wireless power transceiver and receiver
EP3491761B1 (en) 2016-07-28 2020-06-03 Razer (Asia-Pacific) Pte Ltd. Receiver devices, transmitter devices, methods for controlling a receiver device, methods for controlling a transmitter device, and computer-readable media
CN109716313B (en) 2016-07-29 2022-09-16 雷蛇(亚太)私人有限公司 Interface apparatus, method of controlling interface apparatus, and computer-readable medium
US10462744B2 (en) * 2017-02-14 2019-10-29 Intel IP Corporation Methods and systems for reuse of a wireless medium during wake-up of a wireless device
US10620714B2 (en) * 2017-04-07 2020-04-14 Hewlett-Packard Development Company, L.P. Configuration based operation mode
US20180351552A1 (en) * 2017-06-02 2018-12-06 Pixart Imaging Inc. Trigger circuit
US20180359117A1 (en) * 2017-06-12 2018-12-13 Qualcomm Incorporated Virtual channel instantiation over vgi/vgmi
KR102453689B1 (en) * 2017-12-13 2022-10-11 삼성전자주식회사 Periodical process performing system and system on chip
DE102018200379B4 (en) * 2018-01-11 2020-06-18 Robert Bosch Gmbh Sensor arrangement and method for operating a sensor arrangement
SG11202012971PA (en) * 2018-07-23 2021-01-28 Razer Asia Pacific Pte Ltd A wireless lighting effect configuration data transmission system
US10908699B2 (en) * 2018-08-24 2021-02-02 Lite-On Electronics (Guangzhou) Limited Electronic apparatus, wireless input device and control method thereof
CA3226839A1 (en) 2019-02-01 2020-08-06 Crown Equipment Corporation On-board charging station for a remote control device
US11641121B2 (en) 2019-02-01 2023-05-02 Crown Equipment Corporation On-board charging station for a remote control device
TWI702517B (en) * 2019-03-15 2020-08-21 致伸科技股份有限公司 Wireless mouse and data transmission method thereof
CN111695167B (en) * 2019-03-15 2023-07-07 致伸科技股份有限公司 Wireless mouse device and information transmission method thereof
US11782593B1 (en) 2019-06-09 2023-10-10 Advanced Electronic Design, Inc. Wireless personal protection device and methods of use
DE102019212225A1 (en) 2019-08-14 2021-02-18 Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. Driver circuit for one or more optical transmitter components, receiver circuit for one or more optical receiver components for optical wireless communication and methods
CN211149411U (en) * 2019-11-08 2020-07-31 富港电子(昆山)有限公司 Switch module applied to wireless mouse
CN113377217B (en) * 2020-03-09 2023-07-25 东莞宝德电子有限公司 Dual-mode mouse device
TWI772205B (en) * 2021-10-19 2022-07-21 致伸科技股份有限公司 Wireless input system
TWI789092B (en) * 2021-11-01 2023-01-01 世洋科技股份有限公司 Wireless keyboard and mouse combo
WO2023096568A1 (en) * 2021-11-26 2023-06-01 Razer (Asia-Pacific) Pte. Ltd. System and method for facilitating data communication
WO2023129828A1 (en) * 2021-12-29 2023-07-06 Voyetra Turtle Beach, Inc. Wireless keyboard
US11841994B1 (en) * 2022-06-02 2023-12-12 Pixart Imaging Inc. Optical navigation system and optical sensor control method
US20240012766A1 (en) * 2022-07-08 2024-01-11 Dell Products, L.P. Managing peripheral device connectivity based on context

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5696903A (en) * 1993-05-11 1997-12-09 Norand Corporation Hierarchical communications system using microlink, data rate switching, frequency hopping and vehicular local area networking
US6195712B1 (en) * 1997-06-13 2001-02-27 Intel Corporation Dynamic discovery of wireless peripherals
US6934566B2 (en) * 2000-12-21 2005-08-23 Samsung Electronics Co., Ltd Wireless communication device and controlling method thereof

Family Cites Families (45)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4409479A (en) * 1981-12-03 1983-10-11 Xerox Corporation Optical cursor control device
US5115463A (en) * 1990-06-25 1992-05-19 David Moldavsky Extended cordless telephone system
US6374311B1 (en) * 1991-10-01 2002-04-16 Intermec Ip Corp. Communication network having a plurality of bridging nodes which transmit a beacon to terminal nodes in power saving state that it has messages awaiting delivery
JP2902249B2 (en) * 1993-01-21 1999-06-07 富士通株式会社 How to prevent unauthorized use of mobile phone terminals
US5539400A (en) * 1994-08-22 1996-07-23 National Semiconductor Corporation Ultra-low power, scan on demand keypad encoder
US5784402A (en) * 1995-01-09 1998-07-21 Kamilo Feher FMOD transceivers including continuous and burst operated TDMA, FDMA, spread spectrum CDMA, WCDMA and CSMA
JP2001513918A (en) * 1996-01-26 2001-09-04 オラング―オタング コンピューターズ インコーポレイテッド Key palette
US6026165A (en) * 1996-06-20 2000-02-15 Pittway Corporation Secure communications in a wireless system
US6151355A (en) * 1996-10-07 2000-11-21 Dataradio Inc. Wireless modem
US5958023A (en) * 1997-01-07 1999-09-28 Micron Electronics, Inc. Method for low power wireless keyboard that detects a host computer query for the state of a key then powers up to determine and transmit back the state of that key
US5990868A (en) * 1997-04-01 1999-11-23 Compaq Computer Corp. Method and apparatus for performing power conservation in a pointing device located on a wireless data entry device
KR100229602B1 (en) * 1997-04-12 1999-11-15 윤종용 Wire/wireless input apparatus with pointing device and computer system for use with the same
US6151645A (en) * 1998-08-07 2000-11-21 Gateway 2000, Inc. Computer communicates with two incompatible wireless peripherals using fewer transceivers
US6873836B1 (en) * 1999-03-03 2005-03-29 Parkervision, Inc. Universal platform module and methods and apparatuses relating thereto enabled by universal frequency translation technology
US6567388B1 (en) * 1999-03-05 2003-05-20 Qualcomm, Incorporated Method and apparatus for efficient data retransmission in a voice-over-data communication system
US6590940B1 (en) * 1999-05-17 2003-07-08 Ericsson Inc. Power modulation systems and methods that separately amplify low and high frequency portions of an amplitude waveform
KR100340423B1 (en) * 1999-07-28 2002-06-12 이형도 Method for transmissing data of wireless keyboard having track-ball
US6882334B1 (en) * 1999-12-14 2005-04-19 Gateway, Inc. Apparatus and method for detection of communication signal loss
TW493120B (en) * 2000-02-11 2002-07-01 Rf Link Systems Inc Waking up system and method for universal serial bus of wireless computer input device
JP2001312336A (en) * 2000-04-28 2001-11-09 Toshiba Corp Information processor provided with radio communication function and power saving method for peripheral equipment
JP2002073424A (en) * 2000-08-31 2002-03-12 Mitsubishi Electric Corp Semiconductor device, terminal device and communication method
US7015833B1 (en) * 2000-08-31 2006-03-21 Logitech Europe S.A. Multilink receiver for multiple cordless applications
US7283502B1 (en) * 2000-09-21 2007-10-16 Lucent Technologies Inc. Enhancement of framing protocol frame format to support quality of service
CN1146261C (en) * 2000-10-27 2004-04-14 清华大学 Method for retransmitting lost packets in fading channel
US9317241B2 (en) * 2000-10-27 2016-04-19 Voxx International Corporation Vehicle console capable of wireless reception and transmission of audio and video data
US20020118735A1 (en) * 2000-12-20 2002-08-29 Kindred Daniel R. Method and apparatus for interfacing between a radio frequency unit and a modem
US7038906B2 (en) * 2001-03-01 2006-05-02 Mds Advertising, Inc. Portable computer stand with integral communication method and apparatus
US6674999B2 (en) * 2001-03-16 2004-01-06 Skyworks Solutions, Inc Dynamically varying linearity system for an RF front-end of a communication device
US7292645B2 (en) * 2001-05-29 2007-11-06 Agere Systems Inc. Binary transmitter and method of transmitting data in binary format
JP3702812B2 (en) * 2001-06-25 2005-10-05 日本電気株式会社 Authentication method and authentication apparatus in wireless LAN system
US20030034209A1 (en) * 2001-08-16 2003-02-20 Golden Friends Corporation Wireless transmission control apparatus for elevator systems
US6968445B2 (en) * 2001-12-20 2005-11-22 Sandbridge Technologies, Inc. Multithreaded processor with efficient processing for convergence device applications
US20030131127A1 (en) * 2002-01-05 2003-07-10 King Randy J. KVM video & OSD switch
US7336602B2 (en) * 2002-01-29 2008-02-26 Intel Corporation Apparatus and method for wireless/wired communications interface
US6985755B2 (en) * 2002-04-17 2006-01-10 Broadcom Corporation Reduced power consumption wireless interface device
US7260357B2 (en) * 2002-04-17 2007-08-21 Broadcom Corporation Bluetooth fast connection mode for wireless peripheral device
US7116729B2 (en) * 2002-04-29 2006-10-03 Broadcom Corporation Trimming of local oscillation in an integrated circuit radio
US7170870B2 (en) * 2002-05-07 2007-01-30 Microsoft Corporation Data packet transmission for channel-sharing collocated wireless devices
US20040021635A1 (en) * 2002-07-31 2004-02-05 Wenkwei Lou Error rejection for optical scroll wheel
US7961759B2 (en) * 2002-12-31 2011-06-14 Vixs Systems, Inc. Method and apparatus for synchronized channel transmission
JP4103611B2 (en) * 2003-02-03 2008-06-18 ソニー株式会社 Wireless ad hoc communication system, terminal, authentication method, encryption method, terminal management method in terminal, and program for causing terminal to execute these methods
US7055759B2 (en) * 2003-08-18 2006-06-06 Honeywell International Inc. PDA configuration of thermostats
US7026935B2 (en) * 2003-11-10 2006-04-11 Impinj, Inc. Method and apparatus to configure an RFID system to be adaptable to a plurality of environmental conditions
US7629961B2 (en) * 2004-03-01 2009-12-08 Microsoft Corporation Dynamically adjusting operation of one or more sensors of a computer input device
US20060114231A1 (en) * 2004-11-12 2006-06-01 Creative Technology Ltd. Optical wireless mouse power saving feature

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5696903A (en) * 1993-05-11 1997-12-09 Norand Corporation Hierarchical communications system using microlink, data rate switching, frequency hopping and vehicular local area networking
US6195712B1 (en) * 1997-06-13 2001-02-27 Intel Corporation Dynamic discovery of wireless peripherals
US6934566B2 (en) * 2000-12-21 2005-08-23 Samsung Electronics Co., Ltd Wireless communication device and controlling method thereof

Cited By (57)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20060227112A1 (en) * 2005-04-07 2006-10-12 Jaalaa, Inc. Combined keyboard and wireless transceiver
US20090153305A1 (en) * 2005-07-08 2009-06-18 Antonio Ambrosetti Method and System for Locating Objects
US7529317B2 (en) * 2005-09-26 2009-05-05 Broadcom Corporation Supply independent Schmitt trigger RC oscillator
US20070069828A1 (en) * 2005-09-26 2007-03-29 Chien Chin M Supply independent Schmitt trigger RC oscillator
US8044928B2 (en) * 2005-09-29 2011-10-25 Cypress Semiconductor Corporation Method for pairing 1-way devices
US20070070035A1 (en) * 2005-09-29 2007-03-29 Ray Asbury Method for pairing 1-way devices without buttons
US20080018518A1 (en) * 2006-07-21 2008-01-24 Asustek Computer Inc. Remote system capable of controlling an electronic device and method thereof
US20100131700A1 (en) * 2006-10-31 2010-05-27 Gemalto S.A Memory indexing system and process
US8280060B1 (en) * 2007-03-12 2012-10-02 Cypress Semiconductor Corporation Secure wireless transmission
US9210571B1 (en) * 2007-03-12 2015-12-08 Cypress Semiconductor Corporation Secure wireless communication
US8786357B1 (en) 2007-03-12 2014-07-22 Luciano Processing L.L.C. Intelligent voltage regulator
US8269531B1 (en) 2007-03-12 2012-09-18 Cypress Semiconductor Corporation Programmable power supervisor
US8278978B1 (en) 2007-03-12 2012-10-02 Cypress Semiconductor Corporation Programmable voltage regulator
US9429964B2 (en) 2007-03-12 2016-08-30 Tamiras Per Pte. Ltd., Llc Intelligent voltage regulator
US10545519B2 (en) 2007-03-12 2020-01-28 Tamiras Per Pte. Ltd., Llc Intelligent voltage regulator
US11237578B2 (en) 2007-03-12 2022-02-01 Tamiras Per Pte. Ltd., Llc Intelligent voltage regulator
US8471609B1 (en) 2007-03-12 2013-06-25 Luciano Processing L.L.C. Intelligent power supervisor
US8510584B1 (en) 2007-03-12 2013-08-13 Luciano Processing L.L.C. Ultra low power sleep mode
US9143027B2 (en) 2007-03-12 2015-09-22 Luciano Processing L.L.C. Intelligent power supervisor
US10162774B2 (en) 2007-03-12 2018-12-25 Tamiras Per Pte. Ltd., Llc Intelligent voltage regulator
US8680902B1 (en) 2007-03-12 2014-03-25 Luciano Processing L.L.C. Programmable power supervisor
US8761397B1 (en) 2007-03-12 2014-06-24 Cypress Semiconductor Corporation Secure wireless transmission
KR101517576B1 (en) * 2008-02-22 2015-05-06 레이저 (아시아-퍼시픽) 피티이 엘티디 Power usage management of wireless input devices
US8812711B2 (en) * 2008-02-27 2014-08-19 Red Hat, Inc. Three-way communication protocol
US20090216901A1 (en) * 2008-02-27 2009-08-27 Schloming Rafael H Three-way communication protocol
US8654737B2 (en) * 2009-01-23 2014-02-18 Qualcomm Incorporated Methods and systems using fast connection setup procedure for WiMAX networks
US20100189020A1 (en) * 2009-01-23 2010-07-29 Qualcomm Incorporated Methods and systems using fast connection setup procedure for wimax networks
CN103109462A (en) * 2010-04-16 2013-05-15 尼古拉斯·J.·马斯坦德雷亚 Wearable motion sensing computing interface
WO2011130752A1 (en) * 2010-04-16 2011-10-20 Mastandrea Nicholas J Wearable motion sensing computing interface
US10405030B2 (en) * 2010-08-20 2019-09-03 Saturn Licensing Llc Server load balancing for interactive television
US8666319B2 (en) * 2011-07-15 2014-03-04 Cisco Technology, Inc. Mitigating effects of identified interference with adaptive CCA threshold
US20130017794A1 (en) * 2011-07-15 2013-01-17 Cisco Technology, Inc. Mitigating Effects of Identified Interference with Adaptive CCA Threshold
US9312949B1 (en) * 2013-03-05 2016-04-12 Square, Inc. Pairing techniques for a wireless card reader
US9443118B1 (en) * 2013-03-05 2016-09-13 Square, Inc. Pairing techniques for a wireless card reader
CN106104408A (en) * 2013-11-29 2016-11-09 行动股份有限公司 Wearable calculates device
US20220166544A1 (en) * 2014-11-07 2022-05-26 Strong Force Iot Portfolio 2016, Llc Packet coding based network communication
US20220166543A1 (en) * 2014-11-07 2022-05-26 Strong Force Iot Portfolio 2016, Llc Packet coding based network communication
US20220166547A1 (en) * 2014-11-07 2022-05-26 Strong Force Iot Portfolio 2016, Llc Packet coding based network communication
US11817955B2 (en) * 2014-11-07 2023-11-14 Strong Force Iot Portfolio 2016, Llc Packet coding based network communication
US20210266103A1 (en) * 2014-11-07 2021-08-26 Strong Force Iot Portfolio 2016, Llc Packet coding based network communication
US11108665B2 (en) 2014-11-07 2021-08-31 Strong Force Iot Portfolio 2016, Llc Packet coding based network communication
US11817954B2 (en) * 2014-11-07 2023-11-14 Strong Force Iot Portfolio 2016, Llc Packet coding based network communication
US11799586B2 (en) * 2014-11-07 2023-10-24 Strong Force Iot Portfolio 2016, Llc Packet coding based network communication
US20220166545A1 (en) * 2014-11-07 2022-05-26 Strong Force Iot Portfolio 2016, Llc Packet coding based network communication
US20220166542A1 (en) * 2014-11-07 2022-05-26 Strong Force Iot Portfolio 2016, Llc Packet coding based network communication
US11824746B2 (en) 2014-11-07 2023-11-21 Strong Force Iot Portfolio 2016, Llc Packet coding based network communication
US10999012B2 (en) * 2014-11-07 2021-05-04 Strong Force Iot Portfolio 2016, Llc Packet coding based network communication
US20220166546A1 (en) * 2014-11-07 2022-05-26 Strong Force Iot Portfolio 2016, Llc Packet coding based network communication
US20160218766A1 (en) * 2015-01-28 2016-07-28 Lam Research Corporation Dual Push Between A Host Computer System And An RF Generator
US9667303B2 (en) * 2015-01-28 2017-05-30 Lam Research Corporation Dual push between a host computer system and an RF generator
US11481750B2 (en) 2015-06-30 2022-10-25 Block, Inc. Pairing a payment object reader with a point-of-sale terminal
US11057310B2 (en) 2015-07-07 2021-07-06 Strong Force Iot Portfolio 2016, Llc Multiple protocol network communication
US11087315B2 (en) 2015-09-24 2021-08-10 Square, Inc. Server-assisted pairing for wireless communications
US11871237B1 (en) 2016-06-30 2024-01-09 Block, Inc. Pairing a payment object reader with a point-of-sale terminal
US11474618B2 (en) * 2019-07-24 2022-10-18 Hewlett-Packard Development Company, L.P. Communication link based on activity on a keyboard
US20230244330A1 (en) * 2021-09-14 2023-08-03 Finalmouse LLC Computer mouse
US11625109B2 (en) * 2021-09-14 2023-04-11 Finalmouse LLC Computer mouse

Also Published As

Publication number Publication date
WO2005089387A2 (en) 2005-09-29
US20050235159A1 (en) 2005-10-20
US20050243058A1 (en) 2005-11-03
US20050254647A1 (en) 2005-11-17
US7626576B2 (en) 2009-12-01
WO2005089387A3 (en) 2005-12-22
US20060035590A1 (en) 2006-02-16
US20050237304A1 (en) 2005-10-27
WO2005089388A2 (en) 2005-09-29
WO2005089388A3 (en) 2005-12-01

Similar Documents

Publication Publication Date Title
US20050243059A1 (en) High-reliability computer interface for wireless input devices
US7656853B2 (en) Reducing power consumption of a wireless device
US7380145B2 (en) Modifying a power management algorithm based on wireless communication parameters
EP1356366B1 (en) Computer peripheral device that remains operable when central processor operations are suspended
US6618580B2 (en) Apparatus and method for remotely powering-down a wireless transceiver
US9813998B2 (en) Techniques for entering a low-power link state
EP1650669B1 (en) Method and system for reducing power consumption of handsets through uart auto flow control
CN110990066B (en) Sleep awakening method of communication terminal
US20050144488A1 (en) Method and apparatus of lowering I/O bus power consumption
US20040021635A1 (en) Error rejection for optical scroll wheel
US11435810B1 (en) Information handling system and peripheral bi-directional wakeup interface
US11665645B2 (en) Information handling system and peripheral wakeup radio interface configuration
WO2022100374A1 (en) Hierarchical management method and system for terminal device
US11943712B2 (en) Information handling system and peripheral group wakeup radio interface synchronized communications
US11737026B2 (en) Information handling system and peripheral wakeup radio interface synchronized communications
US11907039B2 (en) Information handling system location wakeup radio interface synchronized communications
JP2007124517A (en) Wireless communication device
US6668180B1 (en) Signaling method and apparatus with a host and human input device
Langer et al. A power-aware sensor network architecture.

Legal Events

Date Code Title Description
AS Assignment

Owner name: JAALAA, INC., CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:MORRIS, MARTIN GEORGE;ANANDAKUMAR, KRISHNASAMY;SINGAMSETTY, SURESH KUMAR;AND OTHERS;REEL/FRAME:016531/0769

Effective date: 20050630

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION