[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

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

High-reliability computer interface for wireless input devices Download PDF

Info

Publication number
US20050243058A1
US20050243058A1 US11/081,380 US8138005A US2005243058A1 US 20050243058 A1 US20050243058 A1 US 20050243058A1 US 8138005 A US8138005 A US 8138005A US 2005243058 A1 US2005243058 A1 US 2005243058A1
Authority
US
United States
Prior art keywords
message
ack
unit
host
peripheral device
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,380
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,380 priority Critical patent/US20050243058A1/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 US20050243058A1 publication Critical patent/US20050243058A1/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

  • 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.
  • 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. 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. 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. 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 . 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 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 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 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.
  • 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 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 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 AgilentT M 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 (SPI) protocols.
  • the mouse interface 524 includes four signals: a clock (CLK), a slave output (SO), a slave input (SI) 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
  • SI slave input
  • CS slave select
  • 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. 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 116 .
  • 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 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.
  • 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).
  • 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 “1” 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 1 12 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.
  • 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 .
  • 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 “long sequence” is a 16 bit, bit sequence that is generated from the unit's 11-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.
  • 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 ID 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.
  • 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 11 ) 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.
  • a wireless unit 112 , 114 and 116 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 1 12 , 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 .
  • 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.
  • 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 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 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.
  • 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 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. S 0 , S 1 , S 3 and S 4 . The duration of each step and the and the duration of the suspension during each step is configurable.
  • 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 1 and Group 2
  • the third logical group i.e., Group 3
  • 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?
  • 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.
  • 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 .
  • host wireless unit 112 and keyboard/mouse wireless units 114 , 116 define a power state D 1 as follows:
  • 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
  • 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.
  • 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 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
  • 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.
  • 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.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Human Computer Interaction (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Position Input By Displaying (AREA)
  • Mobile Radio Communication Systems (AREA)
  • Transceivers (AREA)
  • Input From Keyboards Or The Like (AREA)

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

    RELATED PATENT APPLICATION
  • 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.
  • This application is related to U.S. patent application docket number JA05-002, Ser. No. ______, 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 .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 I/O pins: a general purpose input/output (GPIO) 318, an intelligent interface controller (I2C) 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 N I (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 AgilentTM 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 (SPI) protocols. In this embodiment, the mouse interface 524 includes four signals: a clock (CLK), a slave output (SO), a slave input (SI) 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 1 16 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 116.
  • 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 “1” 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 1 12 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 114, 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) AR 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 11-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 ID 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 11) 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 1 12, 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 “1s”). 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., 4KB). 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 1 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 Description Default Max
    # [unit] Value Min 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 .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, DO through D3. A device operative in the DO 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 DO 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 1 12. Failure is handled as before; that is, the key press initiating the wakeup operation is discarded.
    Collision Avoidance and Interferecne 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%, a=2%, 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 (36)

1. A method for sending messages between computing units of a computing system using radio frequency (RF) communications, comprising:
a) sending a first RF message from a first unit to a second unit and starting an acknowledgement (ACK) timer;
b) receiving said first RF message at said second unit and performing a cyclical redundancy check (CRC) on said first RF message;
c) sending a second RF message from said second unit to the first unit acknowledging that the first message was received when the CRC performed on said first RF message is good;
d) receiving said second message at the first unit and performing the CRC on the second message; and
e) canceling said ACK timer when the CRC performed on the second message is good.
2. The method of claim 1, wherein the first unit is a host computer and the second unit is a peripheral computing device whereby the second unit enters a low power sleep mode upon sending said second RF message.
3. The method of claim 2, wherein the peripheral computing device is a keyboard, or a mouse, that is RF coupled to the host computer.
4. The method of claim 1, wherein the first unit is a peripheral computing device and said second unit is a host computer whereby the first unit enters into a low power sleep mode upon receiving said second message and performing the CRC to find the second message is good.
5. The method of claim 1, wherein the ACK timer allows a predetermined amount of time for sending and processing of said first and second RF messages.
6. A method for handling a corrupted message sent between computing units of a computing system using radio frequency (RF) communications, comprising:
a) sending a first RF message from a first unit to a second unit and starting an acknowledgement (ACK) timer at the first unit;
b) receiving said first RF message at said second unit and performing a cyclical redundancy check (CRC) on said first RF message;
c) discarding said first message at the second unit when the CRC determines the first message is corrupted;
d) starting a backoff timer at the first unit when the ACK timer expires;
e) resending said first RF message from said first unit to said second unit and starting said ACK timer at the first unit;
f) receiving said resent first RF message at said second unit and performing a cyclical redundancy check (CRC) on said resent first RF message;
g) sending a second RF message from said second unit to said first unit confirming receipt of said resent first RF message when the CRC on the resent first message is good; and
h) receiving said second RF message at said first unit, performing the CRC on the second message, and canceling the ACK timer when the CRC on the second message is good.
7. The method of claim 6, wherein the ACK timer allows a predetermined amount of time for sending and processing of said first and second RF messages.
8. The method of claim 6, wherein said backoff timer provides a time delay before resending said RF message thereby breaking deadlocks caused by simultaneous RF transmissions.
9. The method of claim 6, wherein the first unit is a host computer and the second unit is a peripheral computing device whereby said second unit enters into a sleep mode after sending said second RF message and the ACK timer has expired.
10. The method of claim 9, wherein the peripheral computing device is a keyboard, or a mouse, that is RF coupled to the host computer.
11. The method of claim 6, wherein the first unit is a peripheral computing device and said second unit is a host computer whereby said first unit enters a sleep mode after the second RF message is received and CRC is good and the ACK timer expires.
12. A method for handling a corrupted acknowledgement message sent between computing units of a computing system using radio frequency (RF) communications, comprising:
a) sending an RF message from a first unit to a second unit and starting an acknowledgement (ACK) timer at the first unit;
b) receiving said RF message at said second unit and performing a cyclical redundancy check (CRC) on said RF message;
c) sending a first ACK message to said first unit when the CRC determines the RF message is good;
d) receiving said first ACK message at said first unit, determining said ACK message is corrupt using the CRC, and discarding the first ACK message;
e) starting a backoff timer at the first unit when the ACK timer expires;
f) resending said RF message from said first unit to said second unit when the backoff timer expires and starting said ACK timer at the first unit;
g) receiving said resent RF message at said second unit, determining the resent message good with the CRC, discarding the resent RF message;
h) sending a second a second ACK message from said second unit to said first unit confirming receipt of said resent RF message; and
i) receiving said second ACK message at said first unit, performing the CRC on the second ACK message, and canceling the ACK timer when the CRC on the second message is good.
13. The method of claim 12, wherein the ACK timer allows a predetermined amount of time for sending and processing of said RF message and the ACK message.
14. The method of claim 12, wherein said backoff timer provides a time delay before resending said RF message thereby breaking deadlocks caused by simultaneous RF transmissions.
15. The method of claim 12, wherein the first unit is a host computer and the second unit is a peripheral computing device.
16. The method of claim 15, wherein the peripheral computing device is a keyboard, or a mouse, that is RF coupled to the host computer whereby the second unit enters a low power sleep mode after receiving said ACK message with a good CRC.
17. The method of claim 12, wherein the first unit is a peripheral computing device and said second unit is a host computer whereby said first unit enters sleep mode after sending said ACK message.
18. A method for normal radio frequency (RF) communications between a host computer and a peripheral device awakened from a sleep state, comprising:
a) awaking a peripheral computing device from a sleep state by an activated function of said peripheral device;
b) coupling to a transceiver of said peripheral computing device a signal representing said activated function;
c) sending an RF message representing said activated function to said transceiver of a host computer and starting an acknowledgement (ACK) timer;
e) receiving said RF message by said transceiver of said host computer and determining that the RF message is good by a cyclical redundancy check (CRC);
g) sending an ACK message to said peripheral device indicating said RF message was received; and
h) receiving said ACK message at the transceiver of the peripheral device, determining that the ACK message to be good by the CRC; canceling said ACK timer and returning said transceiver of the peripheral device to said sleep state.
19. The method of claim 18, wherein said peripheral computing devices is a keyboard.
20. The method of claim 18, wherein said peripheral computing device is a mouse.
21. A method for lost or garbled communications between a peripheral device and a host computer using radio frequency (RF) communications, comprising:
a) sending an RF message to a host computer from a peripheral device and starting an acknowledgement (ACK) timer;
b) receiving said RF message by the host computer, determining that a cyclical redundancy check (CRC) of said RF message is not good and discarding said RF message by the host computer;
c) starting a backoff timer when said ACK timer at the peripheral device expires;
d) resending said RF message to the host computer when the backoff timer expires and starting said ACK timer;
e) receiving said RF message at the host computer, determining that the CRC of said RF message is good and sending an ACK message to the peripheral device;
f) receiving at said peripheral device said ACK message and determining the CRC of the ACK message is good; and
g) canceling said ACK timer and placing said peripheral device into a sleep state.
22. The method of claim 21, wherein said backoff timer provides a time delay before resending said RF message thereby breaking deadlocks caused by simultaneous RF transmissions.
23. The method of claim 21, wherein said peripheral device is a keyboard.
24. The method of claim 21, wherein the peripheral device is a mouse.
25. A method for a peripheral device sleep sequence, comprising:
a) awaking a peripheral device when a sleep timer expires;
b) sending a radio frequency (RF) message from the peripheral device to a host computer and starting an acknowledgement (ACK) timer;
c) receiving said RF message at said host computer and determining by a cyclical redundancy check (CRC) that said RF message is good;
d) sending an ACK message to said peripheral device;
e) receiving said ACK message at said peripheral device, determining said ACK message good with said CRC, and canceling said ACK timer; and
f) starting said sleep timer and returning said peripheral device to sleep mode.
26. The method of claim 25, wherein said ACK message has attached to it a command from said host which is processed by said peripheral device if the CRC performed on said ACK message with the command is determined to be good.
27. The method of claim 25, wherein said peripheral device is a keyboard.
28. The method of claim 27, wherein said peripheral device is an optical mouse or a mechanical mouse.
29. A method for a peripheral device sleep sequence with lost messages at the peripheral device, comprising:
a) awaking a peripheral device when a sleep timer expires;
b) sending a radio frequency (RF) message to a host computer from said peripheral device and starting an acknowledgement (ACK) timer at said peripheral device;
c) receiving said RF message at said host computer and determining that a cyclical redundancy check (CRC) of said RF message is good;
d) sending a first host ACK message to said peripheral device;
e) receiving said first host ACK message at said peripheral device wherein said CRC is bad and said first host ACK message is discarded;
f) starting a backoff timer when ACK timer at the peripheral device expires;
g) resending said RF message to the host computer when backoff timer expires and starting said ACK timer at the peripheral device;
h) receiving the resent RF message at the host computer, determining the CRC of the resent RF message to be good, ignoring the resent RF message, and sending a second host ACK message to the peripheral device; and
i) receiving said second host ACK message at the peripheral device, determining the CRC to be good, canceling the ACK timer, starting the sleep timer, and placing the peripheral device into a sleep state.
30. The method of claim 29, wherein said backoff timer provides a time delay before resending said RF message thereby breaking deadlocks caused by simultaneous RF transmissions.
31. The method of claim 29, wherein said peripheral device is a keyboard.
32. The method of claim 29, wherein said peripheral devices is a computer mouse.
33. A method for a peripheral device sleep sequence with lost messages at a host computer, comprising:
a) awaking a peripheral device when a sleep timer expires, sending an RF message to the host computer and starting said ACK timer at said peripheral device;
b) receiving said RF message at said host computer, determining said CRC to be good, sending a host ACK message with a command to said peripheral device and starting the ACK timer at the host;
c) receiving said host ACK message with a command at said peripheral device, determining said CRC of the host ACK message with said command to be good, canceling AKC timer at the peripheral device, processing the command, sending a first peripheral device ACK message to the host and starting the ACK timer;
d) receiving said first peripheral device ACK message at the host, determining the CRC of the first peripheral device ACK message to be bad and discarding the first peripheral device ACK message;
e) starting a backoff timer at said host when the ACK timer at host expires;
f) resending to said peripheral device the host ACK with the command when the backoff timer at the host expires and starting the ACK timer at the host;
g) receiving the resent host ACK with the command at the peripheral device, determining the CRC of the resent host ACK with the command to be good, discarding the resent host ACK as a duplicate of previously received host ACK message, sending a second peripheral device ACK message to the host, and starting the ACK timer at the peripheral device;
h) receiving the second peripheral device ACK message at the host, determining the CRC of the second peripheral device ACK message to be good and canceling the ACK timer at the host; and
i) starting a sleep timer at said peripheral device when ACK timer at the peripheral device expires and place peripheral device into a sleep mode.
34. The method of claim 33, wherein said backoff timer provides a time delay before resending said RF message thereby breaking deadlocks caused by simultaneous RF transmissions.
35. The method of claim 33, wherein said peripheral device is a keyboard.
36. The method of claim 33, wherein said peripheral devices is a computer mouse.
US11/081,380 2004-03-16 2005-03-16 High-reliability computer interface for wireless input devices Abandoned US20050243058A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US11/081,380 US20050243058A1 (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
US55405804P 2004-03-16 2004-03-16
US55382004P 2004-03-16 2004-03-16
US55382104P 2004-03-16 2004-03-16
US11/081,380 US20050243058A1 (en) 2004-03-16 2005-03-16 High-reliability computer interface for wireless input devices

Publications (1)

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

Family

ID=34994309

Family Applications (6)

Application Number Title Priority Date Filing Date
US11/081,376 Abandoned US20060035590A1 (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/082,009 Abandoned US20050237304A1 (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,381 Abandoned US20050243059A1 (en) 2004-03-16 2005-03-16 High-reliability computer interface for wireless input devices

Family Applications Before (4)

Application Number Title Priority Date Filing Date
US11/081,376 Abandoned US20060035590A1 (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/082,009 Abandoned US20050237304A1 (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

Family Applications After (1)

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

Country Status (2)

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

Cited By (17)

* 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
US20060270433A1 (en) * 2005-05-31 2006-11-30 Kelton James R Adjusting transmit power of a wireless communication device
US20080129445A1 (en) * 2006-09-14 2008-06-05 Crown Equipment Corporation Systems and methods of remotely controlling a materials handling vehicle
US20080137545A1 (en) * 2006-12-08 2008-06-12 Primax Electronics Ltd. Channel switching method for use with wireless peripheral device
US20090153305A1 (en) * 2005-07-08 2009-06-18 Antonio Ambrosetti Method and System for Locating Objects
US20100250760A1 (en) * 2009-03-31 2010-09-30 Mark Emmerich Method of Notifying a Communications Device
US20120257638A1 (en) * 2011-04-08 2012-10-11 Zhihui Xiong Negotiation method and electronic apparatus used in ethernet channel of high definition multimedia interface
US20140223179A1 (en) * 2013-02-06 2014-08-07 Chi-Pei Wang Computer network system for preventing logging of input data
US20150100795A1 (en) * 2013-10-07 2015-04-09 Microsemi Corporation Secure Storage Devices, Authentication Devices, and Methods Thereof
US20170094603A1 (en) * 2015-09-24 2017-03-30 Mediatek Inc. Enhance AT Command for Backoff Timer Control
US10034325B2 (en) 2015-09-24 2018-07-24 Mediatek Inc. Enhance at command for backoff timer control
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
US11201019B2 (en) * 2019-11-08 2021-12-14 Cheng Uei Precision Industry Co., Ltd. Wireless mouse and switch module applied therein
US11429210B2 (en) * 2018-07-23 2022-08-30 Razer (Asia-Pacific) Pte. Ltd. Wireless lighting effect configuration data transmission system
US11429095B2 (en) 2019-02-01 2022-08-30 Crown Equipment Corporation Pairing a remote control device to a vehicle
US11641121B2 (en) 2019-02-01 2023-05-02 Crown Equipment Corporation On-board charging station for a remote control device
US20230147849A1 (en) * 2020-04-29 2023-05-11 Hewlett-Packard Development Company, L.P. Change of operating mode

Families Citing this family (133)

* 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
ATE372611T1 (en) * 2003-05-09 2007-09-15 Nxp Bv METHOD AND ARRANGEMENT FOR ADJUSTING THE TRANSMIT POWER OF A MOBILE TRANSMISSION DEVICE
US8140013B1 (en) 2003-06-04 2012-03-20 Cypress Semiconductor Corporation Wireless communication device and method
US7848703B1 (en) * 2004-12-30 2010-12-07 Cypress Semiconductor Corporation Method and apparatus for binding wireless devices
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
US8207937B2 (en) * 2005-06-24 2012-06-26 Logitech Europe S.A. Communication protocol for networked devices
WO2007014135A2 (en) * 2005-07-21 2007-02-01 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
US7529317B2 (en) * 2005-09-26 2009-05-05 Broadcom Corporation Supply independent Schmitt trigger RC oscillator
US8044928B2 (en) * 2005-09-29 2011-10-25 Cypress Semiconductor Corporation Method for pairing 1-way devices
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
TW200807903A (en) * 2006-07-21 2008-02-01 Asustek Comp Inc Remote system capable of controlling an electronic device and method thereof
US7768415B2 (en) 2006-09-28 2010-08-03 Nike, Inc. Sensor device with persistent low power beacon
EP1918822A1 (en) * 2006-10-31 2008-05-07 Axalto SA Memory indexing system and process
KR101393629B1 (en) * 2007-01-17 2014-05-09 삼성디스플레이 주식회사 Display device and driving method thereof
US8316158B1 (en) 2007-03-12 2012-11-20 Cypress Semiconductor Corporation Configuration of programmable device using a DMA controller
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
US8266575B1 (en) 2007-04-25 2012-09-11 Cypress Semiconductor Corporation Systems and methods for dynamically reconfiguring a programmable system on a chip
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
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
US8644769B2 (en) * 2008-02-22 2014-02-04 Razer (Asia-Pacific) Pte Ltd Power usage management of wireless input devices
US8812711B2 (en) * 2008-02-27 2014-08-19 Red Hat, Inc. Three-way communication protocol
US8355003B2 (en) * 2008-06-13 2013-01-15 Microsoft Corporation Controller lighting activation by proximity and motion
US9264762B2 (en) 2008-06-30 2016-02-16 Sibeam, Inc. Dispatch capability using a single physical interface
US20090327547A1 (en) * 2008-06-30 2009-12-31 In Sung Cho I2c bus compatible with hdmi
US9531986B2 (en) 2008-06-30 2016-12-27 Sibeam, Inc. Bitmap device identification in a wireless communication system
US8897719B2 (en) * 2008-06-30 2014-11-25 Sibeam, Inc. Initializing a transceiver in a wireless communication system
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
US8654737B2 (en) * 2009-01-23 2014-02-18 Qualcomm Incorporated Methods and systems using fast connection setup procedure for WiMAX networks
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
TWI383293B (en) * 2009-04-14 2013-01-21 Generalplus Technology Inc Power saving method in sleep mode and keyboard controller using the same
WO2010124190A2 (en) 2009-04-24 2010-10-28 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
KR101598336B1 (en) 2009-05-29 2016-02-29 엘지전자 주식회사 Operating a Remote Controller
KR20100128958A (en) * 2009-05-29 2010-12-08 엘지전자 주식회사 Image display device and control method for the same
KR101545490B1 (en) * 2009-05-29 2015-08-21 엘지전자 주식회사 Image Display Device and Operating Method for the Same
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
US20100316808A1 (en) * 2009-06-16 2010-12-16 Gregory Keith Hall Polyolefin Compositions for Coating Applications
US20100316820A1 (en) * 2009-06-16 2010-12-16 Rainer Kolb Composite Materials Comprising Propylene-Based Polymer Blend Coatings
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
US9110505B2 (en) * 2010-04-16 2015-08-18 Innovative Devices Inc. Wearable motion sensing computing interface
US8891784B2 (en) 2010-07-06 2014-11-18 GM Global Technology Operations LLC Microphone assembly for use with an aftermarket telematics unit
US8604937B2 (en) 2010-07-29 2013-12-10 General Motors Llc Telematics unit and method for controlling telematics unit for a vehicle
US8494447B2 (en) 2010-07-29 2013-07-23 General Motors Llc Aftermarket telematics unit for use with a vehicle
US8571752B2 (en) 2010-08-05 2013-10-29 General Motors Llc Vehicle mirror and telematics system
US8893210B2 (en) * 2010-08-20 2014-11-18 Sony Corporation Server load balancing for interactive television
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
EP2671337B1 (en) 2011-02-04 2018-04-11 Marvell World Trade Ltd. Control mode phy for wlan
TWI492555B (en) * 2011-03-10 2015-07-11 Favepc Inc Low power wireless short range transmission system
US20120229307A1 (en) * 2011-03-10 2012-09-13 Chun-Liang Tsai Low power wireless short range transmission system
US8666319B2 (en) * 2011-07-15 2014-03-04 Cisco Technology, Inc. Mitigating effects of identified interference with adaptive CCA threshold
KR102148441B1 (en) 2012-04-03 2020-10-15 마벨 월드 트레이드 리미티드 Physical layer frame format for wlan
WO2013159312A1 (en) 2012-04-26 2013-10-31 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
US9312949B1 (en) * 2013-03-05 2016-04-12 Square, Inc. Pairing techniques for a wireless card reader
US9414432B2 (en) 2013-04-03 2016-08-09 Marvell World Trade Ltd. Physical layer frame format for WLAN
CN104158531A (en) * 2013-05-13 2014-11-19 鸿富锦精密工业(深圳)有限公司 Electronic device
KR20230141931A (en) 2013-09-10 2023-10-10 마벨 아시아 피티이 엘티디. Extended guard interval for outdoor wlan
US10218822B2 (en) 2013-10-25 2019-02-26 Marvell World Trade Ltd. Physical layer frame format for WLAN
US10194006B2 (en) 2013-10-25 2019-01-29 Marvell World Trade Ltd. Physical layer frame format for WLAN
CN105830410B (en) 2013-10-25 2020-07-03 马维尔亚洲私人有限公司 Method and apparatus for generating physical layer data units for transmission via a communication channel
WO2015081321A1 (en) * 2013-11-29 2015-06-04 Mechio Inc. Wearable computing device
US9603015B2 (en) * 2014-02-03 2017-03-21 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
AU2015271780A1 (en) * 2014-06-02 2016-12-08 iDevices, LLC Systems and methods for secure communication over a network using a linking address
US10999012B2 (en) * 2014-11-07 2021-05-04 Strong Force Iot Portfolio 2016, Llc Packet coding based network communication
US10135746B2 (en) 2015-07-07 2018-11-20 Strong Force Iot Portfolio 2016, Llc Cross-session network communication configuration
US9992088B1 (en) 2014-11-07 2018-06-05 Speedy Packets, Inc. Packet coding based network communication
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
US11087315B2 (en) 2015-09-24 2021-08-10 Square, Inc. Server-assisted pairing for wireless communications
KR102409276B1 (en) * 2016-02-15 2022-06-15 엘지이노텍 주식회사 Mouse pad and wireless power transmission system including wireless power transceiver and receiver
US11871237B1 (en) 2016-06-30 2024-01-09 Block, Inc. Pairing a payment object reader with a point-of-sale terminal
WO2018021960A1 (en) 2016-07-28 2018-02-01 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
AU2016416417B2 (en) 2016-07-29 2021-12-09 Razer (Asia-Pacific) Pte. Ltd. Interface devices, methods for controlling an interface device, and computer-readable media
US10620714B2 (en) * 2017-04-07 2020-04-14 Hewlett-Packard Development Company, L.P. Configuration based operation mode
US9965655B1 (en) * 2017-04-18 2018-05-08 Erkios Systems, Inc. Port security device for computing devices and methods of operating such
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
US10908699B2 (en) * 2018-08-24 2021-02-02 Lite-On Electronics (Guangzhou) Limited Electronic apparatus, wireless input device and control method thereof
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
EP3987731A4 (en) 2019-06-18 2022-05-18 Razer (Asia-Pacific) Pte. Ltd. Method and apparatus for optimizing input latency in a wireless human interface device system
US11474618B2 (en) * 2019-07-24 2022-10-18 Hewlett-Packard Development Company, L.P. Communication link based on activity on a keyboard
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
CN113377217B (en) * 2020-03-09 2023-07-25 东莞宝德电子有限公司 Dual-mode mouse device
CN112286348B (en) * 2020-10-12 2024-05-31 南京浩伟智能科技有限公司 Equipment combining police actual combat VR (virtual reality) exercise and working method
US11625109B2 (en) * 2021-09-14 2023-04-11 Finalmouse LLC Computer mouse
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
US20240201729A1 (en) * 2022-12-16 2024-06-20 Cirrus Logic International Semiconductor Ltd. Event logging based on global clock in system with multiple components

Citations (4)

* 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
US20020069388A1 (en) * 2000-10-27 2002-06-06 Zhisheng Niu Method for retransmission of lost packet in fading channels
US6567388B1 (en) * 1999-03-05 2003-05-20 Qualcomm, Incorporated Method and apparatus for efficient data retransmission in a voice-over-data communication system

Family Cites Families (44)

* 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
EP0876707A4 (en) * 1996-01-26 2001-08-16 Shelton E Harrison Jr 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
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
US7015833B1 (en) * 2000-08-31 2006-03-21 Logitech Europe S.A. Multilink receiver for multiple cordless applications
JP2002073424A (en) * 2000-08-31 2002-03-12 Mitsubishi Electric Corp Semiconductor device, terminal device and communication method
US7283502B1 (en) * 2000-09-21 2007-10-16 Lucent Technologies Inc. Enhancement of framing protocol frame format to support quality of service
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
KR100626675B1 (en) * 2000-12-21 2006-09-22 삼성전자주식회사 Apparatus for wireless communications and method of controlling the same
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 (4)

* 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
US6567388B1 (en) * 1999-03-05 2003-05-20 Qualcomm, Incorporated Method and apparatus for efficient data retransmission in a voice-over-data communication system
US20020069388A1 (en) * 2000-10-27 2002-06-06 Zhisheng Niu Method for retransmission of lost packet in fading channels

Cited By (28)

* 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
US20060270433A1 (en) * 2005-05-31 2006-11-30 Kelton James R Adjusting transmit power of a wireless communication device
US20090153305A1 (en) * 2005-07-08 2009-06-18 Antonio Ambrosetti Method and System for Locating Objects
US8072309B2 (en) * 2006-09-14 2011-12-06 Crown Equipment Corporation Systems and methods of remotely controlling a materials handling vehicle
US20080129445A1 (en) * 2006-09-14 2008-06-05 Crown Equipment Corporation Systems and methods of remotely controlling a materials handling vehicle
US8193903B2 (en) * 2006-09-14 2012-06-05 Crown Equipment Corporation Associating a transmitter and a receiver in a supplemental remote control system for materials handling vehicles
US20120038455A1 (en) * 2006-09-14 2012-02-16 Crown Equipment Corporation Associating a transmitter and a receiver in a supplemental remote control system for materials handling vehicles
US20080137545A1 (en) * 2006-12-08 2008-06-12 Primax Electronics Ltd. Channel switching method for use with wireless peripheral device
US7724708B2 (en) * 2006-12-08 2010-05-25 Primax Electronics, Ltd. Channel switching method for use with wireless peripheral device
US8082354B2 (en) * 2009-03-31 2011-12-20 Hewlett-Packard Development Company, L.P. Method of notifying a communications device
US20100250760A1 (en) * 2009-03-31 2010-09-30 Mark Emmerich Method of Notifying a Communications Device
US20120257638A1 (en) * 2011-04-08 2012-10-11 Zhihui Xiong Negotiation method and electronic apparatus used in ethernet channel of high definition multimedia interface
CN102739610A (en) * 2011-04-08 2012-10-17 瑞昱半导体股份有限公司 Negotiation method and electronic device used in Ethernet channel of high definition multimedia interface
US9307058B2 (en) * 2011-04-08 2016-04-05 Realtek Semiconductor Corp. Negotiation method and electronic apparatus used in ethernet channel of high definition multimedia interface
US20140223179A1 (en) * 2013-02-06 2014-08-07 Chi-Pei Wang Computer network system for preventing logging of input data
US20150100795A1 (en) * 2013-10-07 2015-04-09 Microsemi Corporation Secure Storage Devices, Authentication Devices, and Methods Thereof
US20170094603A1 (en) * 2015-09-24 2017-03-30 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
US10034325B2 (en) 2015-09-24 2018-07-24 Mediatek Inc. Enhance at command for backoff timer control
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
US11109318B2 (en) 2017-02-14 2021-08-31 Intel Corporation Methods and systems for reuse of a wireless medium during wake-up of a wireless device
US11429210B2 (en) * 2018-07-23 2022-08-30 Razer (Asia-Pacific) Pte. Ltd. Wireless lighting effect configuration data transmission system
US11836306B2 (en) 2018-07-23 2023-12-05 Razer (Asia-Pacific) Pte. Ltd. Wireless lighting effect configuration data transmission system
US11429095B2 (en) 2019-02-01 2022-08-30 Crown Equipment Corporation Pairing a remote control device to a vehicle
US11500373B2 (en) 2019-02-01 2022-11-15 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
US11201019B2 (en) * 2019-11-08 2021-12-14 Cheng Uei Precision Industry Co., Ltd. Wireless mouse and switch module applied therein
US20230147849A1 (en) * 2020-04-29 2023-05-11 Hewlett-Packard Development Company, L.P. Change of operating mode

Also Published As

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

Similar Documents

Publication Publication Date Title
US20050243058A1 (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
US7336602B2 (en) Apparatus and method for wireless/wired communications interface
US7260357B2 (en) Bluetooth fast connection mode for wireless peripheral device
US6618580B2 (en) Apparatus and method for remotely powering-down a wireless transceiver
US9813998B2 (en) Techniques for entering a low-power link state
US11435810B1 (en) Information handling system and peripheral bi-directional wakeup interface
US11907039B2 (en) Information handling system location wakeup radio interface synchronized communications
US6366768B1 (en) Circuit and method of frequency synthesizer control with a serial peripheral interface
US20040021635A1 (en) Error rejection for optical scroll wheel
US7707441B2 (en) Method and system for reducing power consumption of handsets through UART auto flow control
CN219831808U (en) Wake-up 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
JP2007124517A (en) Wireless communication device
CN118741474A (en) Method and system for wireless communication between an input device and a host
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/0803

Effective date: 20050630

STCB Information on status: application discontinuation

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