WO1999003288A1 - System and method for updating a memory in an electronic device via wireless data transfer - Google Patents

System and method for updating a memory in an electronic device via wireless data transfer Download PDF

Info

Publication number
WO1999003288A1
WO1999003288A1 PCT/US1998/013047 US9813047W WO9903288A1 WO 1999003288 A1 WO1999003288 A1 WO 1999003288A1 US 9813047 W US9813047 W US 9813047W WO 9903288 A1 WO9903288 A1 WO 9903288A1
Authority
WO
WIPO (PCT)
Prior art keywords
data
electronic device
channel
recited
memory
Prior art date
Application number
PCT/US1998/013047
Other languages
French (fr)
Inventor
John Joseph Hayes, Jr.
David Charles Hall
Original Assignee
Ericsson 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 Ericsson Inc. filed Critical Ericsson Inc.
Priority to JP2000502642A priority Critical patent/JP2001510315A/en
Priority to AU79855/98A priority patent/AU752584B2/en
Priority to EEP200000021A priority patent/EE200000021A/en
Priority to EP98930470A priority patent/EP0995326B1/en
Priority to DE69834114T priority patent/DE69834114D1/en
Priority to KR10-2000-7000117A priority patent/KR100485017B1/en
Priority to BR9810583-3A priority patent/BR9810583A/en
Publication of WO1999003288A1 publication Critical patent/WO1999003288A1/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W8/00Network data management
    • H04W8/22Processing or transfer of terminal data, e.g. status or physical capabilities
    • H04W8/24Transfer of terminal data
    • H04W8/245Transfer of terminal data from a network towards a terminal
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/65Updates

Definitions

  • the current invention relates generally to wireless telecommunications devices and, in particular, to an automated and wireless method for loading data into electronic devices which have a wireless interface.
  • Modern cellular telephones contain a microcontroller and other circuits which perform various functions such as controlling radio circuits, providing a user interface and user features through interaction with a display, keypad and other phone elements, minimizing power consumption to extend talk and standby times, controlling battery charging, and many other functions.
  • a software program executed by the microcontroller is stored in a non- volatile memory device in the phone, which retains data even when no power is applied to the memory. In some phone designs, this memory is a "read only memory", or ROM. The data content of a ROM is determined when the ROM is manufactured. Once the manufacturing process for a ROM is complete, the data content of the ROM cannot be changed. In other phone designs, a "flash" memory is used. The data content of a flash memory can be altered electronically.
  • Altering program data in phones which use a ROM is very labor intensive, due to the need to unpack the phone (from the shipping package), disassemble the phone, remove the old ROM, install the new ROM, re-assemble the phone, test and re-pack the phone.
  • the program can be changed by connecting a cable from a programming device to the phone, thereby eliminating the need to physically replace the memory module.
  • the labor required is still quite substantial because the phone must be unpacked, updated, tested and re-packed.
  • the problem of memory updating is not restricted to cellular telephones, but is common to any electronic device having data or programs stored in a nonvolatile memory.
  • An electronic device has a wireless communication interface including an RF transceiver, a microprocessor and an associated non- volatile memory
  • the data content of the nonvolatile memory is partitioned into blocks. Each block can be re-programmed independently of each other block.
  • the device also includes a timer circuit coupled to a battery. The timer circuit is operable to "wake up", or power the device at predetermined intervals (for example, once per day).
  • the microprocessor When the device is awakened by the timer, the microprocessor causes the RF unit to scan one or more predetermined channels in search of a carrier modulated with data. If a carrier is found and the modulation technique, data rate, data content, etc. of the received signal meet predetermined requirements, the electronic device examines the data conveyed by the RF carrier and uses the data to re-program specified blocks of the memory.
  • a second device referred to herein as a "wireless programmer” or “programming unit” generates a signal for re-programming the memory of an electronic device, and receives and processes confirmation signals from the electronic device.
  • the wireless programmer (which may be a specially configured personal computer) includes a central processing unit, memory, RF transceiver, antenna and various data input/output means (such as a keypad, monitor, modem, touch screen display, mouse, bar code reader, etc.).
  • the transceiver is used to establish a two-way data link with the electronic device to be programmed.
  • the wireless programmer stores the updated software, revision number of the updated software, and (at the end of the re-programming process) a list of electronic devices by serial number which have been successfully re- programmed, and their corresponding software revision levels.
  • the data communication method between the wireless programmer and the electronic device is secured by using an authentication process to prevent accidental or unauthorized re-programming.
  • a method of reprogramming an electronic device includes the steps of loading the wireless programmer with appropriate data, including updated software or data, revision levels and a list of electronic devices to be updated, by serial number, placing the wireless programmer in proximity to the electronic device and turning the wireless programmer on for ⁇ period of time, and automatically updating the memory of the electronic device.
  • the wireless programmer is constructed as a kiosk which may be placed in a public area such as a cellular phone showroom.
  • the kiosk has a user interface including a touch screen monitor and a credit card reader, and a compartment for depositing an electronic device to be updated.
  • the user may use the touch screen monitor to select upgrade features to be added to his cellular telephone and place the cellular telephone into the compartment, where the memory of the telephone is updated automatically and wirelessly.
  • the telephone compartment is a multi-compartmented container capable of holding a number of different phones simultaneously.
  • the re-programming method described above is related to changing the software in an electronic device, it may also be used to change the content of data fields in the device corresponding to user settings (such as personal identification codes and emergency numbers) or manufacturing date codes, or to activate the device.
  • FIGURE 1 is a block diagram of a wireless system consisting of a wireless programmer and one or more electronic devices.
  • FIGURE 2 is a block diagram of an electronic device.
  • FIGURE 3 illustrates how data is organized in the memory of the electronic device.
  • FIGURE 4 is a block diagram of a wireless programmer.
  • FIGURE 4A shows a wireless programmer embodied as a standalone kiosk.
  • FIGURE 4B shows an internal structure of a wireless programmer/kiosk.
  • FIGURE 4C shows an exemplary screen display of a wireless programmer/kiosk.
  • FIGURE 5 A is a block diagram showing an arrangement of logical channels between a wireless programmer and an electronic device.
  • FIGURE 5B shows a frame structure for the Notification Channel.
  • FIGURE 5C is a flow diagram showing the flow of information on the Authentication Channel.
  • FIGURE 5D shows a frame structure for the Data Channel.
  • FIGURE 5E is a flow diagram showing the flow of information on the
  • FIGURE 5F is a flow diagram showing the flow of information on the Authentication/ Acknowledgement Channel in a two-channel embodiment.
  • FIGURE 5G shows a frame structure for the Notification/Data Channel in a two-channel embodiment.
  • FIGURE 6 illustrates how data is exchanged between the wireless programmer and an electronic device on the authentication channel.
  • FIGURE 6A illustrates how data is exchanged between the wireless programmer and an electronic device on the acknowledgment channel.
  • FIGURES 7, 7A, 7B, 7C and 7D are flowcharts which illustrate the logical operation of the wireless programmer.
  • FIGURES 8, 8A, 8B and 8C are flowcharts which illustrate the logical operation of an electronic device.
  • a system and method for wireless re-programming of memories in electronic devices is described, wherein an electronic device establishes a wireless, bi-directional data communication path with a wireless programming device.
  • the wireless programming device is referred to herein as a "wireless programmer.”
  • channels communication paths between the electronic device and the wireless programmer are referred to as "channels" which may be implemented using any one of a number of physical or logical wireless data communication techniques.
  • the communication paths may based upon a frequency division multiplexing system (such as AMPS) whereby one carrier per channel is modulated with data on a continuous basis.
  • AMPS frequency division multiplexing system
  • TDMA time division multiple access
  • a channel is associated with a specific time slot on a single RF carrier frequency. Data for a specific receiver may be sent in one of several time slots, while other time slots may be used on the same carrier for other receivers.
  • the wireless link could implement a short-range RF communication protocol such as MC-Link.
  • the wireless link could comprise a channel other than an RF channel, such as an infrared channel or magnetic coupling.
  • CDMA code division multiple access
  • data may be conveyed to several receivers using only one carrier, with the data directed to a specific receiver through modulation with a unique spreading code.
  • CDMA code division multiple access
  • Wireless data communication methods typically employ means for bit and byte synchronization, error detection or correction, interleaving, etc. to ensure a reliable communication link.
  • Such techniques are well known in the art and are described, for example, in the IS-54, and IS- 136 Standards published by Telecommunications Industry Association.
  • the system of the present invention may be advantageously implemented using a communication scheme which supports such features.
  • Figure 1 illustrates a system which includes a wireless programmer 200 and one or more electronic devices 100. While the wireless programmer 200 is operating within range of the electronic devices 100, wireless communication paths are established with each electronic device 100 when the devices 100 are placed in memory update mode. Timers within each device 100 may be employed to automatically turn the device 100 on and place the device in memory update mode, or the device may be placed in memory update mode by means of a physical or software selectable switch. If certain conditions are satisfied as described in detail below, the memory content of the device 100 will be altered as a result of the communication between the device 100 and the wireless programmer 200.
  • the system and method described herein is particularly advantageous for a number of applications.
  • the first is in reprogramming the memories of devices which have been manufactured and packaged, but which for some reason contain errors in their stored program code or which contain an operational parameter that is incorrect or otherwise needs to be changed.
  • a wireless programmer 200 is placed in proximity to a-group of devices to be updated and a wireless update routine or program is commenced within the wireless programmer 200.
  • the wireless programmer then begins to continuously broadcast update information.
  • each device 100 automatically powers on and is placed in memory update mode, it searches for a wireless communication channel containing update information. Once the communication channel is found, the wireless device 100 receives the update information and stores it in nonvolatile memory. The wireless device then powers down.
  • the wireless programmer As the wireless programmer is transmitting update information to the wireless devices 100, the wireless programmer is also receiving acknowledgement signals from the devices 100 which have been successfully updated. In this manner, the wireless programmer 200 can maintain a record of which devices 100 have been successfully updated. Thus, a batch of devices may be updated without having to unpack and repack each device.
  • system of the present invention may be used to efficiently and easily update the memory of a device 100 which has already been distributed to an end user.
  • an end user wishing to upgrade the software in his device may return the device 100 to the manufacturer or dealer, who then updates the device using the methods described herein.
  • wireless programmer 200 may be operated by the user to quickly and efficiently update or upgrade the device, eliminating the need for the user to send the device back to the manufacturer or distributor.
  • Wireless Electronic Device Configuration Figure 2 illustrates a block diagram of an electronic device 100 according to the present invention.
  • electronic device 100 is a cellular telephone.
  • the principles of the present invention are particularly suited for use in updating memories in small hand-held portable telephones.
  • the present invention may be used to update the memory of any type of electronic device which contains an electrically alterable memory and a wireless communication interface, such as a pager or a laptop computer equipped with a wireless modem.
  • An electronic device 100 of the present invention includes a wireless communication interface 195.
  • wireless communication interface 195 includes an RF transceiver having a transmitter 114 and a receiver 115 which are coupled to a common antenna 118.
  • the transmitter and receiver circuits 114, 115 are controlled by a microcontroller 120 that may be one of a variety of commonly available microcontrollers.
  • wireless communication interface 195 may include an infrared communication unit or other wireless communication device.
  • Audio signals for transmission or audio signals that have been received pass through the audio processing circuit 122.
  • Audio processing circuit 122 converts the received audio signals to signals suitable for broadcast over speaker 124 and converts the electrical signals from the microphone 126 to signals suitable for transmission by transmitter circuit 114.
  • the microcontroller 120 also controls the display 127 for the device 100 and receives input signals from the keypad 132.
  • System connector 180 provides an electrical interface which is used by electronic device 100 to input or output data and/or other signals. System connector 180 can be used to update the memory in the device using standard, wire-based methods, as are well known in the art.
  • Nonvolatile memory 136 which is capable of storing data even if power is not applied to the memory, may include an electrically erasable programmable read only memory (EEPROM) module, a static ram (SRAM) module with battery backup, or any other type of nonvolatile digital memory. Moreover, nonvolatile memory 136 could comprise any other type of nonvolatile digital storage means, such as a magnetic disk or tape.
  • EEPROM electrically erasable programmable read only memory
  • SRAM static ram
  • nonvolatile memory 136 could comprise any other type of nonvolatile digital storage means, such as a magnetic disk or tape.
  • nonvolatile memory 136 comprises an EEPROM module.
  • a software program resides in area 135 of memory 136, while data resides in area 1-34.
  • Microcontroller 120 can fetch and execute instructions which reside in memory 136.
  • the memory contents can be altered either on a byte-by-byte basis, or in blocks of bytes. Referring to Figure 3, a memory partitioning arrangement for the embodiment where the contents of memory 136 can be altered in blocks is illustrated.
  • Memory 136 is logically divided into a plurality of N blocks 305, each of which can be altered without disturbing other blocks of the memory.
  • each block 305 may be further divided logically into sub-blocks 315 to facilitate re-writing the data contents.
  • sub-blocks 315 for memory updating is described in greater detail below.
  • Blocks 305 may be individually numbered for reference or may be identified by their respective hexadecimal addresses in memory.
  • nonvolatile memory 136 additionally stores a number of operating parameters and user settings for the device 100. Among the stored parameters is a 32-bit binary Electronic Serial Number (ESN). In a typical cellular telephone system, each cellular telephone has a unique ESN which is used to identify the particular cellular telephone and its manufacturer.
  • ESN Electronic Serial Number
  • electronic device 100 additionally includes a random access memory (RAM) 138.
  • RAM random access memory
  • the data content of RAM 138 is volatile. That is, the contents of RAM 138 are lost if power ceases to be applied to RAM 138.
  • RAM 138 is used to store temporary data values, and can also be used to store a software program for execution by microcontroller 120. Electrical currerlt required to operate the components of electronic device
  • the 100 is provided by a battery 101.
  • the battery 101 is connected to most components of the device 100 via switch 142.
  • a regulator 160 connected to the battery through switch 142 provides a constant voltage (Vcc) to the other electrical components in the device, except for the wake-up circuit 190.
  • Vcc constant voltage
  • switch 142 When switch 142 is open, the battery 101 is disconnected from most of the circuits within the device, with the exception of the wake-up circuit 190 (which is always coupled to the battery 101).
  • the wake-up circuit 190 will now be described with reference to Figure 2.
  • set or “high” refers to a logic level that is the higher of two valid digital output states
  • reset or “low” refers to a logic level that is the lower of two valid digital output states
  • Wake-up circuit 190 includes counter 150, oscillator 151, resistors 152 and 153 and diodes 154, 155, 156 and 157.
  • Oscillator 151 provides a clock signal for counter 150.
  • Counter 150 has a clock input, a load input 150a and an output 150b.
  • the design of digital counters such as counter 150 is very well known in the art.
  • Counter 150 is loaded with a counter initialization value when the load input line is strobed. The counter initialization value may be hard wired into counter 150, or it may be loaded at data input 150c by microcontroller 120.
  • Each clock pulse received from oscillator 151 causes the counter value to decrease by one.
  • the counter value equals zero, two actions occur: First, clock pulses from the oscillator are inhibited from clocking the counter, thereby stopping the counting process, and second, the counter output 150b is set. The counter output 150b is reset for any non-zero counter value.
  • Counter 150 When the load input 150a is high, the counting process is inhibited and the counter is loaded with a non-zero value (the counter initialization value).
  • Counter 150 operates (counts) when the load input 150a is low and the counter value is not equal to zero.
  • the time required for the counter value to reach zero is based upon the actual value loaded into the counter and the oscillation frequency of the oscillator 151. In practice, these values will be selected to produce a desired wake-up interval. For example, if the desired wake-up interval is every 24 hours and the oscillator frequency is 1 kHz, then the counter initialization value -will be 86,400,000.
  • the desired wake-up interval may be a factory set default value, such as 24 hours, or may be modified by the user by means of a menu selection. For example, if the user knows that the device 100 is to be updated, he can select "Memory Update Mode" from a configuration menu, the effect of which is to select a very short wake-up interval (and correspondingly load the counter 150 with a small initialization value) . Once the device 100 has been updated, the user can return the device to its normal operating mode.
  • the wake-up interval is initally factory set at 24 hours to permit wireless updating of the device at a factory or distribution center if necessary. After a predetermined period (such as one month, for example) the wireless update feature will be disabled automatically. Then, if the device needs to be updated at a later date, it can be placed into Memory Update Mode manually by the user or a technician. In yet another embodiment, after an event such as activation, the update feature is disabled automatically. In still another embodiment, the device 100 may be placed directly into Memory Update Mode by means of a menu or function selection or a switch.
  • Diodes 154, 155, 156 and resistor 153 are used to create a "logical OR" function for controlling switch 142. Whenever the anode of any of these diodes is high, the control voltage to switch 142 is high, causing switch 142 to close. Diodes 156 and 157 prevent potentially damaging voltage from being applied to microcontroller 120 outputs when no power is applied to the microcontroller 120.
  • Device 100 also includes a switch 143 and a clamp 161 for enabling the user to power the device 100 on and off.
  • Switch 143 is a normally open, momentary contact switch which is activated by the user to turn the device 100 on and off.
  • Clamp 161 has an input 161a and an output 161b.
  • Clamp 161 the design of which is well known in the art, has the following characteristics:
  • the output voltage of the clamp is equal to the input voltage for all input voltages between 0 volts and Vcc volts.
  • the output voltage equals Vcc volts whenever the input voltage is greater than Vcc.
  • Clamp 161 prevents damage to the microcontroller 120 by preventing voltages in excess of Vcc from being applied to the microcontroller.
  • Input 161a of clamp 161 is coupled to switch 143.
  • Output 161b of clamp 161 is coupled to input 120a of microcontroller 120.
  • the microcontroller output to diode 157 is set, thereby setting the counter load input 150a. While the load input 150a is set (which, for this case, is the duration of time the phone is on), the counter 150 is inhibited from counting and is loaded with the initialization value, as described above.
  • the input to diode 157 becomes low, resetting the load input 150a to counter 150. This enables the counter 150 to operate, counting down from the initialization value loaded into the counter 150 when the load input 150a was set.
  • the counter 150 counts down to zero from the counter initialization value. (This occurs because the test circuit 190 is powered directly from the battery 101 and the load input 150a to the counter 150 is low).
  • the counting- process stops and the counter output 150b is set. With the output 150b set, voltage is applied to the control input 142a of switch 142 through diode 154, causing switch 142 to close. This applies battery voltage to regulator 160 which applies power to the microcontroller 120.
  • microcontroller 120 When microcontroller 120 begins instruction execution, it first tests the clamp output 161b to determine if switch 143 is closed (indicating power-up caused by user input). In this example, switch 143 will not be closed because the phone was turned on by the wake-up circuit 190. Microcontroller 120 then sets the output to diode 156, which provides a second source of current for resistor 153. This action latches device 100 in an "on" state. As long as output 172 remains high, the state of switch 143 or counter output has no effect on switch 142.
  • the action by the wake-up circuit 190 to turn the device 100 on places the device in a memory update mode (as opposed to a normal mode of operation which occurs when the device is turned-on by the user).
  • memory update mode program execution branches to a group of instructions which provide functionality required to perform wireless transfer of data to the phone.
  • microcontroller 120 if the user attempts to turn the phone on while a counter initiated power-up has occurred, the user input is ignored by microcontroller 120 until all memory re-programming processing is complete.
  • FIG. 4 illustrates a block diagram of a wireless programmer 200.
  • the wireless programmer 200 communicates with one or more electronic devices 100 via a wireless link to load binary data and/or program code into the devices 100.
  • Wireless programmer 200 includes a microcontroller 230, a memory 240, and an RF unit 290.
  • Wireless programmer 200 may include a number of input/output devices such as a keyboard 210, a monitor 220, and a printer 250.
  • Wireless programmer 200 also includes a data I/O unit 260 which may connect other I/O devices such as a touch screen, modem and bar code reader, for example.
  • RF Unit 290 includes at least one radio transmitter 270, at least one radio receiver 280 and an antenna 240.
  • the keyboard 210 allows a user to input data and commands.
  • the monitor 220 and printer 250 allow the user to receive information from the programmer.
  • Data and software programs are stored in the memory 240, which may include but are not necessarily limited to RAM, ROM, hard or floppy discs.
  • Data input/output devices are used load the prograrnmer 200 with programs, files and data.
  • the radio transmitter 270 and receiver 280 are linked to antenna 240 and use one or more communication paths to exchange data with electronic devices 100. All operations of the wireless programmer 200 are controlled by microcontroller 230.
  • Wireless programmer 200 is provided with a set of programmed instructions stored in memory 240 which comprise a program referred to herein as a "wireless update routine” or “wireless update program” which controls the logical operation of wireless programmer 200.
  • the wireless programmer 200 is constructed as a kiosk 205 which may be placed in a public area such as a cellular phone showroom.
  • the kiosk 205 has a user interface including a touch screen monitor 220, a credit card reader 235, and a bar code scanner 245.
  • Kiosk 205 also has a compartment 225 for receiving an electronic device 100 to be updated. Compartment 225 is covered by a door 226.
  • the compartment 225 is a multi-compartmented container capable of holding a number of different phones simultaneously.
  • Figure 4B illustrates a cross-sectional view of kiosk 205 containing a multi-compartmented carousel 225 accessible via a door 226.
  • Carousel 225 rotates about an axis 227 to permit deposit and removal of a particular device 100 through door 226.
  • the status of the wireless programmer 200' s operation is displayed on monitor 220.
  • An exemplary screen display of monitor 220 is shown in Figure 4C, which shows the current status of three concurrent wireless update procedures.
  • four communication channels are defined for communication between wireless programmer 200 and an electronic device 100.
  • the defined channels which are illustrated in Figure 5 A, include a Notification Channel 455, an Authentication Channel 460, a Data Channel 465 and an Acknowledgement Channel 470. The structure and operation of these channels are described below.
  • the Notification channel 455 is a one-way communication channel from wireless programmer 200 to device 100. Data is sent continuously on this channel in a plurality of sequential frames. Each frame contains the following fields:
  • LOC Location i.e., frequency, time slot, spreading code, etc.
  • the structure of the Notification channel 455 is illustrated in Figure 5B.
  • the wireless programmer 200 continuously transmits a plurality of sequential notification frames N; 456, each of which may carry unique update notification data.
  • notification frame Nl may carry notification information for updating a first model of cellular telephones to a first revision level
  • notification frame N2 carries notification information for updating a second model of cellular telephones to a second revision level
  • the Notification channel frame may additionally include a field containing the electronic serial numbers of all devices to be updated to the software revision level specified in the RN field.
  • the Authentication Channel 460 is a two-way communication channel which provides means for the devices 100 and the wireless programmer 200 to exchange authentication information. Data flow on the Authentication Channel 460 is illustrated in Figure 5C, and is explained in greater detail below.
  • the Data Channel 465 is a one-way communication channel from the wireless programmer 200 to electronic device 100. Data is sent continuously on the Data Channel 465 to convey data values for those blocks of memory to be altered. The electronic devices 100 receive data bytes to update all affected blocks within the nonvolatile memory 136. Data transmitted on the data channel is organized into frames having the following fields:
  • the frame structure of a Data Channel 465 is shown in Figure 5D.
  • wireless programmer 200 continuously transmits a series of data frames D, 466, each of which comprises each of the fields described in Table 2.
  • data frames D, 466 each of which comprises each of the fields described in Table 2.
  • Multiple data frames may be transmitted on any one Data Channel 465. This permits the update of multiple subblocks in a given reprogramming operation. For example if a given reprogramming operation includes updating five memory subblocks in a particular class of devices 100, the Data Channel 465 will carry five data frames D1-D5.
  • the Acknowledgement Channel 470 is a two-way communication channel that provides means for each device 100 to inform the wireless programmer that all memory blocks have been properly updated. Data flow on the Acknowledgement Channel 470 is illustrated in Figure 5E, and is explained in greater detail below.
  • the Notification channel 455 and Data channel 465 convey data from the wireless programmer 200 to the electronic devices 100; no data is returned to wireless programmer 200 by any device 100 on these channels.
  • the Authentication channel 460 and Acknowledgment channel 470 are used to convey data in both directions.
  • the RF signal transmitted by the wireless programmer 200 is consistent with the modulation methods, data rates, coding, error detection methods, etc. used by the wireless communication standard for which the device 100 was designed and programmed. This permits the device 100 to be updated in accordance with the present invention with no (or very little) additional modification required.
  • the device 100 searches for the Notification channel 455.
  • the device 100 reads the transmitted information from the Notification channel 455 and continues the memory update process by proceeding to (i.e., tuning to) the Authentication channel 460 to perform the authentication procedure. If the device 100 successfully authenticates the wireless programmer 200, it then proceeds to tune to the Data channel 465 identified in the LOC field of the Notification channel; if not, the device 100 switches off. Device 100 reads the appropriate information from the Data channel 465 to update memory. Upon successfully updating memory, the device 100 proceeds to tune to the Acknowledgment channel 470 to acknowledge successful reprogramming.
  • Each Authentication request by a device 100 comprises the device's ESN plus an
  • Authentication request string AUTH Upon receipt of an authentication request, the wireless programmer 200 responds with the received ESN plus the caluculated Authentication result R, as described above.
  • Acknowledgement on the Authentication/ Acknowledgement Channel 910 is performed by the device 100 transmitting an acknowledgement signal to the wireless programmer 200 to indicate successful completion of the wireless memory update process.
  • the acknowledgement signal comprises the device's ESN plus an acknowledgement string ACK.
  • the wireless programmer 200 then responds with the same " acknowledgement string to confirm acknowledgement.
  • the device 100 may transmit a failure signal comprising the device's ESN plus a negative acknowledgement string, illustrated in Figure 5F as NAK.
  • a system implemented in accordance with the present invention may be configured to provide a separate acknowledgement for each subblock of memory successfully updated.
  • Figure 5G illustrates the structure of the Notification Data Channel 920 which is logically divided into a number of frames 930.
  • One frame is a notification frame, while the other frames comprise the data frames.
  • the internal structure of the notification and data frames may be similar to those described above in connection with the four-channel embodiment.
  • Figure 7 illustrate logical operation of a wireless programmer 200.
  • the wireless programmer 200 displays a plurality of menu selections on the monitor 220 in step 401.
  • the menu selection comprises user commands and options for the operation of wireless programmer 200 such as Configure, Transmit, and List. Other commands or options may be included in the menu selection.
  • step 402 If, in step 402, a selection is made, processing continues with step 403. If, in step 402, a selection is made, processing continues with step 403. If
  • the "configure" selection causes the wireless programmer 200 to load update data and programs into memory in preparation for a programming operation.
  • data file(s) are loaded via the data input/output unit 260.
  • the data portion of the file(s) transferred may include, without limitation:
  • serial number of each device 100 to be modified (which in the case of a cellular telephone, will be a 32-bit ESN).
  • a data value for each device 100 for use in an authentication process ensures that devices 100 respond only to memory update signals from a legitimate wireless programmer 200. This data value is called an "Authentication Key” or "A-Key”.
  • a definition of the communication channels to be used to communicate with the device 100 4.
  • wireless programmer 200 executes an authentication algorithm for each devfce 100 using the A-key to generate an authentication result R for each device 100.
  • the computed authentication result R for each device 100 is stored in wireless programmer 200.
  • the device's A-key is used directly as its authentication result.
  • a complex algorithm (such as the well-known the cave algorithm) may be used to generate the authentication result R from the A-Key.
  • the "Transmit” selection is used to execute the Transmit routine, which alters the memory contents of devices 100. Operation of the wireless programmer 200 upon selection of the "Transmit” command is described in Fig. 7B.
  • the menu selections illustrated in Figure 7 may be used when the wireless programmer 200 is under the control of an operator, for example when the wireless programmer 200 is used to update devices at a manufacturing plant. If the wireless programmer 200 is a kiosk to be used by a consumer, the menu selections should be altered accordingly, for example to permit the user to select a particular option or upgrade, identify his device by serial number, pay for the upgrade using a credit card, etc.
  • step 420 transmission of data on the Notification Channel 455 is initiated, and in step 421, transmission of data on the Data Channel is initiated.
  • step 422 wireless programmer 200 determines if data from a device
  • the Transmit routine proceeds to point C of Figure 7C. If data has been received on the Authentication Channel 460, a test is performed in step 423 to determine if the received data represents a valid ESN. If not, the program jumps to point C of Figure 7C. If a valid ESN has been received, a test is performed in step 424 to determine if the ESN is in the data file. If not, an authentication string equal to the ESN concatenated with '0' is transmitted on the Authentication channel 460 in step 426 and then the program proceeds to point C.
  • step 425 determines if an acknowledgment has already been received for the ESN. If so, the device 100 need not continue (since the data has already been altered successfully). Therefore, the program goes to step 426 to transmit a data string equal to the ESN concatenated with '0'. Upon receipt of this data string, the device 100 powers off.
  • a test is made to determine if data has been received on the Acknowledgment Channel 470. If no data has been received on the Acknowledgement Channel, then the routine proceeds to step 433. If data has been received, a test is made in step 429 to determine if the received data represents a valid ESN. If not, then the routine proceeds to step 433.
  • step 430 the ESN is transmitted on the Acknowledgment Channel 470.
  • step 431 a test is made to determine if the ESN is in the database. If yes, the database is updated to indicate that an acknowledgment was received for that ESN.
  • step 433 a test is made to determine if the escape key was pressed. If yes, then the program (in step 434) stops data transmission on the notification and data channels and returns to start. If no, the program jumps to point B of Figure 7B.
  • Figure 7D provides a flow diagram for the routine executed when the user selects "List" from the main menu of the wireless programmer 200 in step 405 of Fig. 7. Referring to Fig.
  • step 440 a list is displayed in step 440 which includes the ESN for all devices 100 for which an acknowledgment was received.
  • a list is displayed which includes all devices 100 in the database which did not provide an acknowledgment.
  • the program returns to step 401 of Fig. 7 to redisplay the menu selections.
  • Figure 6 illustrates more clearly the data exchanged between a device 100 and the wireless programmer 200 on the Authentication Channel 460 to authenticate the wireless programmer 200.
  • a first device 100 initiates communication by transmitting an authentication request comprising its ESN (denoted ESN1) to the wireless programmer 200.
  • ESN1 is used to search a database of ESN's installed in the wireless programmer 200 during configuration. If found in the database, the previously calculated authentication result R corresponding to the received ESN is fetched. If ESN 1 is not found in the database, an invalid authentication result (e.g., zero) is used.
  • an Authentication string comprising the ESN concatenated with Authentication result R is transmitted by wireless programmer 200 to device 100 as an authentication response.
  • the authentication result R is compared to the authentication result computed by the device 100. If the two numbers match, the wireless programmer 200 has been authenticated and the device 100 proceeds with the memory update process by tuning to the Data channel. If the numbers do not match, the device 100 powers down and does not continue the memory update process.
  • Figure 6 illustrates a case where the ESN's sent by two devices 100 partially overlap.
  • the data received by the wireless programmer 200 will be corrupted; the wireless programmer will make no response to the corrupted ESN.
  • Each device 100 will then wait a random time period and try again to authenticate the wireless programmer 200.
  • the random delay period may be based on the ESN of the device 100. For example, it may be generated using a random number generation algorithm seeded with a portion of the device's ESN.
  • Figure 5E illustrates the data exchanged between a device 100 and the wireless programmer 200 on the Acknowledgment Channel 470. As illustrated in Fig. 5E, the device 100 initiates communication on the acknowledgement channel with wireless programmer 200 by transmitting its ESN (ESN1) to the wireless programmer 200. When wireless programmer 200 receives an ESN on the
  • Acknowledgement Channel 470 (constituting an acknowledgement request), it searches the previously described ESN database. If the received ESN is not found in the ESN database, no action is taken by the wireless programmer 200. If the ESN is found in the database, the database entry for that ESN is updated to indicate that the phone has successfully updated memory. The database is also revised to reflect the updated revision level of software in the updated device 100.
  • the wireless programmer 200 then transmits an acknowledgement response containing the received ESN to the device 100.
  • the device 100 receives the acknowledgement response containing its ESN from the wireless programmer 200, the device 100 powers off.
  • the device 100 will make several acknowledgement attempts on the Acknowledgment Channel 400 if its ESN is not received from the wireless programmer 200.
  • Figure 6 A illustrates a case where the ESN's sent by two devices 100 on the Acknowledgement Channel 470 partially overlap. In such a case, the data received by the wireless programmer 200 will be corrupted, and the wireless programmer 200 will make no response on the Acknowledgement Channel 470. Each device 100 will then implement a time-out and try again.
  • FIG. 8 along with figures 8 A, 8B and 8C provide a flowchart for the wireless update program executed in a device 100.
  • the program starts at power up in step 801.
  • step 801 a test is made to determine if the device 100 was powered-up by user action (as described above). If the device 100 was powered on by the user, the device 100 is latched on (in step 802) and a test is made to determine if a valid software revision number is stored in memory (in step 803). If a valid software revision number is not present, then an error condition is shown in the display 127 and program execution stops. Otherwise, processing continues to provide normal operation for the user.
  • step 805 the program proceeds to.step 805, where the device 100 is latched on.
  • the device 100 searches available communication paths for a notification channel.
  • the Notification Channel 455 contains a field which identifies it as a notification channel.
  • steps 806 through 810 the device 100 searches available communication paths for a notification channel.
  • the Notification Channel 455 contains a field which identifies it as a notification channel.
  • steps 806 through 810 the device 100 searches available communication paths for a notification channel.
  • the Notification Channel 455 contains a field which identifies it as a notification channel.
  • steps 806 through 810 the device 100 searches available communication paths for a notification channel.
  • step 811 the following data from the data channel is stored in RAM:
  • step 812 the list of block numbers of memory to be altered (received from the notification channel) is compared to a list of restricted blocks; if any restricted blocks are in the list from the notification channel, the device 100 is turned off. Otherwise, processing continues at point A in figure 8A.
  • step 815 of figure 8 A the device 100 computes and stores the authentication result R using the device's prestored A-key.
  • the device 100 attempts to communicate with the wireless programmer 200 on the Authentication Channel 460 as follows: A first timer is started in the device 100 in step 816. The starting value of the timer is random, which creates a random delay before communications are attempted. After the timer has expired (step 817), the device 100 transmits its ESN on the Authentication Channel 460 (step 818). In steps 819, 820 and 821, the device 100 waits a pre-determined period of time (as controlled by a second timer) for a response from the wireless programmer 200. If no response is received within the second time-out period, the program proceeds to step 822. If a response is received, the program proceeds to step 823.
  • step 822 a test is made to determine if the maximum number of attempts to authenticate have been exceeded. If not, the program returns to step 816 to make another attempt. If a previous authentication attempt failed due to a data collision with another device 100 (i.e. two or more devices 100 have sent data on the Authentication Channel 460 at the same time), the random delay caused by the random timer in step 816 will tend to prevent additional collisions with the same devices 100. If the maximum number of attempts has been exceeded, the device 100 turns itself off in step 824.
  • step 823 the device 100 checks if the received authentication result R matches its computed authentication result. If not, the phone turns itself off in step 824. If the authentication results match, the wireless programmer has been authenticated and the program proceeds to point B in figure 8B.
  • step 840 of figure 8B the Data Channel 465 is acquired.
  • the data from the Data Channel 465 is used to update the flash memory block by block.
  • step 841 a test is made to determine if the channel tuned contains an identifier which indicates that it is indeed the data channel. If not, the device 100 is turned off in step 842. If yes, the software revision number (which is either located within a data location in the flash or in another nonvolatile memory) is set to an invalid number (in step 843).
  • step 853 the program used to write or read data to flash is copied from the flash and replicated in RAM.
  • step 844 the received data stream is monitored until data is received which indicates the beginning of a data string for any block/sub-block.
  • step 845 A test is then made (in step 845) to determine if the data string for that sub-block has already been updated in flash. If yes, the program returns to step 844 to await data for the next sub-block. If no, then subsequent steps are executed to store the data string in RAM and use it to update flash, as described below.
  • step 846 the block number/sub-block number and data string for the sub-block are stored in RAM.
  • step 847 the data string is loaded into the sub- block of the flash.
  • step 848 the data just stored in the flash sub-block is read from flash and compared to the data in RAM (in step 849). If the comparison is not successful, the program returns to step 844. If successful, data is stored in RAM which records the sub-block number and block number which was successfully updated (in step 850). In step 851, a test is made to determine if all sub-blocks (for all blocks) have been updated. If no, the program returns to step 844. If yes, the software revision number is updated with the new value. Any programming steps referenced above which read or write data to flash (steps 847, 848) are preferably executed from RAM.
  • step 8C the device 100 attempts to communicate with the wireless programmer 200 on the Acknowledgment Channel 470.
  • the acknowledgment channel is tuned in step 865.
  • a first timer is started in step 866 which has a starting value which is random. This creates a random delay before communications are attempted.
  • the device 100 transmits its ESN on the Acknowledgment Channel (step 868).
  • steps 869, 870 and 871 the device 100 waits a pre-determined period of time (as controlled by a second timer) for a response from the wireless programmer 200. If no response is received within the time-out period, the program proceeds to step 872. If a response is received, the device 100 is turned off in step 873.
  • step 872 a test is made to determine if the maximum number of attempts to acknowledge have been exceeded. If not, the program returns to step 866 to make another attempt. If a previous acknowledgment attempt failed due to a data collision with another device 100, the random delay caused by the random timer in step 866 will tend to prevent additional collisions with the same phone(s). If the maximum number of attempts has been exceeded, the device 100 turns itself off in step 873.
  • the wireless programmer 200 and the device 100 being programmed both possess the capability to receive and transmit data via a wireless communication link. It would also be possible to employ the concepts presented herein to update memory in a device capable only of receiving wireless signals. Modifications necessary to utilize the present invention in connection with a receive-only device will be readily apparent to one skilled in the art upon reviewing this Specification. For example, with regard to authentication for a receive-only device, the following is one alternative: Continuously broadcast an ESN and Authentication result on one channel for all devices being programmed. The wireless device, upon receiving its specific ESN and Authentication result pair would simply compare the result received with a result stored at time of manufacture to authenticate the wireless programmer.
  • a system and method for wirelessly updating the memory of an electronic device has been described.
  • the system is particularly advantageous for updating a program or data stored in nonvolatile memory in an electronic device such as a cellular telephone.
  • the system and method may be used for example at a manufacturing plant for simultaneously updating the memories of a number of devices, or for updating devices that have already been shipped to consumers one at a time.

Abstract

An electronic device has a microprocessor operable in a plurality of modes including a memory update mode, a nonvolatile memory and a wireless communication interface for receiving data over a wireless communication channel. In one embodiment, the electronic device includes a wake-up or timer circuit for automatically placing the electronic device in a wireless memory update mode. Data received by said wireless communication interface is stored in the nonvolatile memory by the microprocessor in response to receipt of the data while the microprocessor is in memory update mode. A programming unit for transmitting update data has a microprocessor, a wireless communication interface and a memory containing update data. A communication path is established between the programming unit and the electronic device. A system for updating data stored in a nonvolatile memory of a plurality of electronic devices includes a programming unit and a plurality of electronic devices. A method of updating data stored in the nonvolatile memories of a plurality of electronic devices includes placing a programming unit in proximity to the plurality of electronic devices and activating a wireless update routine in the programming unit.

Description

SYSTEM AND METHOD FOR UPDATING A MEMORY IN AN ELECTRONIC DEVICE VIA WIRELESS DATA TRANSFER
BACKGROUND OF THE INVENTION
1. Field of the Invention
The current invention relates generally to wireless telecommunications devices and, in particular, to an automated and wireless method for loading data into electronic devices which have a wireless interface.
2. Description of the Related Art
Modern cellular telephones contain a microcontroller and other circuits which perform various functions such as controlling radio circuits, providing a user interface and user features through interaction with a display, keypad and other phone elements, minimizing power consumption to extend talk and standby times, controlling battery charging, and many other functions. A software program executed by the microcontroller is stored in a non- volatile memory device in the phone, which retains data even when no power is applied to the memory. In some phone designs, this memory is a "read only memory", or ROM. The data content of a ROM is determined when the ROM is manufactured. Once the manufacturing process for a ROM is complete, the data content of the ROM cannot be changed. In other phone designs, a "flash" memory is used. The data content of a flash memory can be altered electronically.
Due to the complexity of cellular telephones, manufactured phones sometimes contain errors in the microcontroller software. Additionally, customers often desire updated software for existing phones to obtain new or enhanced features. In either case, the software program for the microcontroller must be changed in phones which have completed and passed all manufacturing steps. If the phone uses a ROM to store the program, the phone must be disassembled and the ROM module must be replaced with a new module containing the desired changes. If the phone uses a flash memory to store the program, in order to update the memory the phone must be physically connected to a device capable of loading, or "flashing" new content into the memory.
In some situations, it is necessary to re-program phones which have been assembled and packaged, but which have not yet been shipped to customers. For this case, the completed phones reside in the manufacturer's warehouse or distribution center. In other situations, changes must be made to phones already received by the customer. In such a case, the customer normally returns the phones to the manufacturer for re-programming.
Altering program data in phones which use a ROM is very labor intensive, due to the need to unpack the phone (from the shipping package), disassemble the phone, remove the old ROM, install the new ROM, re-assemble the phone, test and re-pack the phone. For phones that contain a flash memory, the program can be changed by connecting a cable from a programming device to the phone, thereby eliminating the need to physically replace the memory module. However, the labor required is still quite substantial because the phone must be unpacked, updated, tested and re-packed.
Thus, a costly problem exists for cellular phone manufacturers with regard to software design and software changes. The cellular telephone market demands ever-increasing functionality and feature content (most of which is provided by the software), decreasing costs and shorter time to market. These demands increase the likelihood of software errors and customer requests for software changes in existing products. However, the labor required to modify the software in phones (even those with flash memories) makes these changes very costly. Changes to the data content of non- volatile memories within cellular phones is not always confined to the microcontroller software. For example, a need may arise to change a factory setting (stored as a digital value within the memory), to correct date codes or other data related to manufacturing information, or to load data to activate a phone. The problems identified for changing the software content of a phone also apply to other types of data stored within the non-volatile memories.
Moreover, the problem of memory updating is not restricted to cellular telephones, but is common to any electronic device having data or programs stored in a nonvolatile memory.
SUMMARY OF THE INVENTION
An electronic device has a wireless communication interface including an RF transceiver, a microprocessor and an associated non- volatile memory
(hereinafter referred to as a "flash" memory). The data content of the nonvolatile memory is partitioned into blocks. Each block can be re-programmed independently of each other block. The device also includes a timer circuit coupled to a battery. The timer circuit is operable to "wake up", or power the device at predetermined intervals (for example, once per day).
When the device is awakened by the timer, the microprocessor causes the RF unit to scan one or more predetermined channels in search of a carrier modulated with data. If a carrier is found and the modulation technique, data rate, data content, etc. of the received signal meet predetermined requirements, the electronic device examines the data conveyed by the RF carrier and uses the data to re-program specified blocks of the memory.
A second device, referred to herein as a "wireless programmer" or "programming unit", generates a signal for re-programming the memory of an electronic device, and receives and processes confirmation signals from the electronic device. The wireless programmer (which may be a specially configured personal computer) includes a central processing unit, memory, RF transceiver, antenna and various data input/output means (such as a keypad, monitor, modem, touch screen display, mouse, bar code reader, etc.). The transceiver is used to establish a two-way data link with the electronic device to be programmed. The wireless programmer stores the updated software, revision number of the updated software, and (at the end of the re-programming process) a list of electronic devices by serial number which have been successfully re- programmed, and their corresponding software revision levels. In one embodiment, the data communication method between the wireless programmer and the electronic device is secured by using an authentication process to prevent accidental or unauthorized re-programming.
A method of reprogramming an electronic device includes the steps of loading the wireless programmer with appropriate data, including updated software or data, revision levels and a list of electronic devices to be updated, by serial number, placing the wireless programmer in proximity to the electronic device and turning the wireless programmer on for ^ period of time, and automatically updating the memory of the electronic device.
Once programming is complete, a list of serial numbers of electronic devices which have been successfully updated may be obtained from the wireless programmer. The same method can be used for devices returned from the field.
In one embodiment, the wireless programmer is constructed as a kiosk which may be placed in a public area such as a cellular phone showroom. The kiosk has a user interface including a touch screen monitor and a credit card reader, and a compartment for depositing an electronic device to be updated. The user may use the touch screen monitor to select upgrade features to be added to his cellular telephone and place the cellular telephone into the compartment, where the memory of the telephone is updated automatically and wirelessly. In one embodiment, the telephone compartment is a multi-compartmented container capable of holding a number of different phones simultaneously.
Although the re-programming method described above is related to changing the software in an electronic device, it may also be used to change the content of data fields in the device corresponding to user settings (such as personal identification codes and emergency numbers) or manufacturing date codes, or to activate the device.
BRIEF DESCRIPTION OF THE DRAWINGS
FIGURE 1 is a block diagram of a wireless system consisting of a wireless programmer and one or more electronic devices. FIGURE 2 is a block diagram of an electronic device.
FIGURE 3 illustrates how data is organized in the memory of the electronic device.
FIGURE 4 is a block diagram of a wireless programmer. FIGURE 4A shows a wireless programmer embodied as a standalone kiosk.
FIGURE 4B shows an internal structure of a wireless programmer/kiosk. FIGURE 4C shows an exemplary screen display of a wireless programmer/kiosk.
FIGURE 5 A is a block diagram showing an arrangement of logical channels between a wireless programmer and an electronic device.
FIGURE 5B shows a frame structure for the Notification Channel. FIGURE 5C is a flow diagram showing the flow of information on the Authentication Channel.
FIGURE 5D shows a frame structure for the Data Channel. FIGURE 5E is a flow diagram showing the flow of information on the
Acknowledgement Channel.
FIGURE 5F is a flow diagram showing the flow of information on the Authentication/ Acknowledgement Channel in a two-channel embodiment.
FIGURE 5G shows a frame structure for the Notification/Data Channel in a two-channel embodiment.
FIGURE 6 illustrates how data is exchanged between the wireless programmer and an electronic device on the authentication channel.
FIGURE 6A illustrates how data is exchanged between the wireless programmer and an electronic device on the acknowledgment channel.
FIGURES 7, 7A, 7B, 7C and 7D are flowcharts which illustrate the logical operation of the wireless programmer.
FIGURES 8, 8A, 8B and 8C are flowcharts which illustrate the logical operation of an electronic device.
DETAILED DESCRIPTION OF THE DRAWINGS
A system and method for wireless re-programming of memories in electronic devices is described, wherein an electronic device establishes a wireless, bi-directional data communication path with a wireless programming device. The wireless programming device is referred to herein as a "wireless programmer."
In this specification, communication paths between the electronic device and the wireless programmer are referred to as "channels" which may be implemented using any one of a number of physical or logical wireless data communication techniques. For example, the communication paths may based upon a frequency division multiplexing system (such as AMPS) whereby one carrier per channel is modulated with data on a continuous basis. Alternatively, a time division multiple access (TDMA) system may be used, such as those described in the D-AMPS, GSM or IS-136 standards. In a TDMA system, a channel is associated with a specific time slot on a single RF carrier frequency. Data for a specific receiver may be sent in one of several time slots, while other time slots may be used on the same carrier for other receivers. The wireless link could implement a short-range RF communication protocol such as MC-Link. Moreover, the wireless link could comprise a channel other than an RF channel, such as an infrared channel or magnetic coupling. In still other systems such as code division multiple access (CDMA) systems, data may be conveyed to several receivers using only one carrier, with the data directed to a specific receiver through modulation with a unique spreading code. The particular communication format or standard used is not critical to the present invention. Other wireless communication techniques may be employed by those skilled in the art to implement the present invention without departing from the spirit or scope of the invention.
Wireless data communication methods typically employ means for bit and byte synchronization, error detection or correction, interleaving, etc. to ensure a reliable communication link. Such techniques are well known in the art and are described, for example, in the IS-54, and IS- 136 Standards published by Telecommunications Industry Association. The system of the present invention may be advantageously implemented using a communication scheme which supports such features.
Referring now to the accompanying drawings, Figure 1 illustrates a system which includes a wireless programmer 200 and one or more electronic devices 100. While the wireless programmer 200 is operating within range of the electronic devices 100, wireless communication paths are established with each electronic device 100 when the devices 100 are placed in memory update mode. Timers within each device 100 may be employed to automatically turn the device 100 on and place the device in memory update mode, or the device may be placed in memory update mode by means of a physical or software selectable switch. If certain conditions are satisfied as described in detail below, the memory content of the device 100 will be altered as a result of the communication between the device 100 and the wireless programmer 200.
The system and method described herein is particularly advantageous for a number of applications. The first is in reprogramming the memories of devices which have been manufactured and packaged, but which for some reason contain errors in their stored program code or which contain an operational parameter that is incorrect or otherwise needs to be changed. A wireless programmer 200 is placed in proximity to a-group of devices to be updated and a wireless update routine or program is commenced within the wireless programmer 200. The wireless programmer then begins to continuously broadcast update information. As each device 100 automatically powers on and is placed in memory update mode, it searches for a wireless communication channel containing update information. Once the communication channel is found, the wireless device 100 receives the update information and stores it in nonvolatile memory. The wireless device then powers down. As the wireless programmer is transmitting update information to the wireless devices 100, the wireless programmer is also receiving acknowledgement signals from the devices 100 which have been successfully updated. In this manner, the wireless programmer 200 can maintain a record of which devices 100 have been successfully updated. Thus, a batch of devices may be updated without having to unpack and repack each device.
In another embodiment, the system of the present invention may be used to efficiently and easily update the memory of a device 100 which has already been distributed to an end user. For example, an end user wishing to upgrade the software in his device may return the device 100 to the manufacturer or dealer, who then updates the device using the methods described herein.
Yet another application of the present invention is an a standalone kiosk, such as is commonly found in retail establishments. When a wireless programmer 200 is configured as a kiosk, as is described in more detail below, the wireless programmer 200 may be operated by the user to quickly and efficiently update or upgrade the device, eliminating the need for the user to send the device back to the manufacturer or distributor.
Other uses and applications of the present invention will be apparent to those skilled in the art seeking improved methods of updating memories in electronic devices.
Wireless Electronic Device Configuration Figure 2 illustrates a block diagram of an electronic device 100 according to the present invention. In a preferred embodiment, electronic device 100 is a cellular telephone. The principles of the present invention are particularly suited for use in updating memories in small hand-held portable telephones. However, the present invention may be used to update the memory of any type of electronic device which contains an electrically alterable memory and a wireless communication interface, such as a pager or a laptop computer equipped with a wireless modem.
An electronic device 100 of the present invention includes a wireless communication interface 195. In the embodiment illustrated in Figure 2, wireless communication interface 195 includes an RF transceiver having a transmitter 114 and a receiver 115 which are coupled to a common antenna 118. The transmitter and receiver circuits 114, 115 are controlled by a microcontroller 120 that may be one of a variety of commonly available microcontrollers. In other embodiments, wireless communication interface 195 may include an infrared communication unit or other wireless communication device.
Audio signals for transmission or audio signals that have been received pass through the audio processing circuit 122. Audio processing circuit 122 converts the received audio signals to signals suitable for broadcast over speaker 124 and converts the electrical signals from the microphone 126 to signals suitable for transmission by transmitter circuit 114.
The microcontroller 120 also controls the display 127 for the device 100 and receives input signals from the keypad 132. System connector 180 provides an electrical interface which is used by electronic device 100 to input or output data and/or other signals. System connector 180 can be used to update the memory in the device using standard, wire-based methods, as are well known in the art.
Nonvolatile memory 136, which is capable of storing data even if power is not applied to the memory, may include an electrically erasable programmable read only memory (EEPROM) module, a static ram (SRAM) module with battery backup, or any other type of nonvolatile digital memory. Moreover, nonvolatile memory 136 could comprise any other type of nonvolatile digital storage means, such as a magnetic disk or tape.
In an exemplary embodiment shown in Figure 2, nonvolatile memory 136 comprises an EEPROM module. A software program resides in area 135 of memory 136, while data resides in area 1-34. Microcontroller 120 can fetch and execute instructions which reside in memory 136. Furthermore, the memory contents can be altered either on a byte-by-byte basis, or in blocks of bytes. Referring to Figure 3, a memory partitioning arrangement for the embodiment where the contents of memory 136 can be altered in blocks is illustrated. Memory 136 is logically divided into a plurality of N blocks 305, each of which can be altered without disturbing other blocks of the memory. Given that each block of data may include a large number of bytes, each block 305 may be further divided logically into sub-blocks 315 to facilitate re-writing the data contents. The use of sub-blocks 315 for memory updating is described in greater detail below. Blocks 305 may be individually numbered for reference or may be identified by their respective hexadecimal addresses in memory.
In the case where electronic device 100 is a cellular telephone, nonvolatile memory 136 additionally stores a number of operating parameters and user settings for the device 100. Among the stored parameters is a 32-bit binary Electronic Serial Number (ESN). In a typical cellular telephone system, each cellular telephone has a unique ESN which is used to identify the particular cellular telephone and its manufacturer.
Referring again to Figure 2, electronic device 100 additionally includes a random access memory (RAM) 138. The data content of RAM 138 is volatile. That is, the contents of RAM 138 are lost if power ceases to be applied to RAM 138. RAM 138 is used to store temporary data values, and can also be used to store a software program for execution by microcontroller 120. Electrical currerlt required to operate the components of electronic device
100 is provided by a battery 101. The battery 101 is connected to most components of the device 100 via switch 142. A regulator 160 connected to the battery through switch 142 provides a constant voltage (Vcc) to the other electrical components in the device, except for the wake-up circuit 190. When switch 142 is open, the battery 101 is disconnected from most of the circuits within the device, with the exception of the wake-up circuit 190 (which is always coupled to the battery 101).
Wake-Up Circuit Operation The wake-up circuit 190 will now be described with reference to Figure 2.
For the following circuit description, "set" or "high" refers to a logic level that is the higher of two valid digital output states, "reset" or "low" refers to a logic level that is the lower of two valid digital output states.
Wake-up circuit 190 includes counter 150, oscillator 151, resistors 152 and 153 and diodes 154, 155, 156 and 157.
Oscillator 151 provides a clock signal for counter 150. Counter 150 has a clock input, a load input 150a and an output 150b. The design of digital counters such as counter 150 is very well known in the art. Counter 150 is loaded with a counter initialization value when the load input line is strobed. The counter initialization value may be hard wired into counter 150, or it may be loaded at data input 150c by microcontroller 120.
Each clock pulse received from oscillator 151 causes the counter value to decrease by one. When the counter value equals zero, two actions occur: First, clock pulses from the oscillator are inhibited from clocking the counter, thereby stopping the counting process, and second, the counter output 150b is set. The counter output 150b is reset for any non-zero counter value.
When the load input 150a is high, the counting process is inhibited and the counter is loaded with a non-zero value (the counter initialization value). Counter 150 operates (counts) when the load input 150a is low and the counter value is not equal to zero. After the load input 150a changes from high to low, the time required for the counter value to reach zero is based upon the actual value loaded into the counter and the oscillation frequency of the oscillator 151. In practice, these values will be selected to produce a desired wake-up interval. For example, if the desired wake-up interval is every 24 hours and the oscillator frequency is 1 kHz, then the counter initialization value -will be 86,400,000.
The desired wake-up interval may be a factory set default value, such as 24 hours, or may be modified by the user by means of a menu selection. For example, if the user knows that the device 100 is to be updated, he can select "Memory Update Mode" from a configuration menu, the effect of which is to select a very short wake-up interval (and correspondingly load the counter 150 with a small initialization value) . Once the device 100 has been updated, the user can return the device to its normal operating mode.
In another embodiment, the wake-up interval is initally factory set at 24 hours to permit wireless updating of the device at a factory or distribution center if necessary. After a predetermined period (such as one month, for example) the wireless update feature will be disabled automatically. Then, if the device needs to be updated at a later date, it can be placed into Memory Update Mode manually by the user or a technician. In yet another embodiment, after an event such as activation, the update feature is disabled automatically. In still another embodiment, the device 100 may be placed directly into Memory Update Mode by means of a menu or function selection or a switch.
Diodes 154, 155, 156 and resistor 153 are used to create a "logical OR" function for controlling switch 142. Whenever the anode of any of these diodes is high, the control voltage to switch 142 is high, causing switch 142 to close. Diodes 156 and 157 prevent potentially damaging voltage from being applied to microcontroller 120 outputs when no power is applied to the microcontroller 120. Device 100 also includes a switch 143 and a clamp 161 for enabling the user to power the device 100 on and off. Switch 143 is a normally open, momentary contact switch which is activated by the user to turn the device 100 on and off. Clamp 161 has an input 161a and an output 161b. Clamp 161, the design of which is well known in the art, has the following characteristics: The output voltage of the clamp is equal to the input voltage for all input voltages between 0 volts and Vcc volts. The output voltage equals Vcc volts whenever the input voltage is greater than Vcc. Clamp 161 prevents damage to the microcontroller 120 by preventing voltages in excess of Vcc from being applied to the microcontroller. Input 161a of clamp 161 is coupled to switch 143. Output 161b of clamp 161 is coupled to input 120a of microcontroller 120. When the device 100 is first powered on, the microcontroller 120 determines whether the device was powered on by the user or by the timer circuit 190 by testing the output voltage of clamp 161. If the clamp 161 output voltage is high, then switch 143 was closed, indicating that the device 100 was powered on by the user. If the clamp 161 output voltage is low, the device 100 was powered on by the operation of timer circuit 190.
While the device 100 is on, the microcontroller output to diode 157 is set, thereby setting the counter load input 150a. While the load input 150a is set (which, for this case, is the duration of time the phone is on), the counter 150 is inhibited from counting and is loaded with the initialization value, as described above.
When power is removed from microcontroller 120, the input to diode 157 becomes low, resetting the load input 150a to counter 150. This enables the counter 150 to operate, counting down from the initialization value loaded into the counter 150 when the load input 150a was set. As described above, while the device 100 is in a powered off-state, the counter 150 counts down to zero from the counter initialization value. (This occurs because the test circuit 190 is powered directly from the battery 101 and the load input 150a to the counter 150 is low). When counter 150 reaches a count value of 0, the counting- process stops and the counter output 150b is set. With the output 150b set, voltage is applied to the control input 142a of switch 142 through diode 154, causing switch 142 to close. This applies battery voltage to regulator 160 which applies power to the microcontroller 120.
When microcontroller 120 begins instruction execution, it first tests the clamp output 161b to determine if switch 143 is closed (indicating power-up caused by user input). In this example, switch 143 will not be closed because the phone was turned on by the wake-up circuit 190. Microcontroller 120 then sets the output to diode 156, which provides a second source of current for resistor 153. This action latches device 100 in an "on" state. As long as output 172 remains high, the state of switch 143 or counter output has no effect on switch 142.
The action by the wake-up circuit 190 to turn the device 100 on places the device in a memory update mode (as opposed to a normal mode of operation which occurs when the device is turned-on by the user). In memory update mode, program execution branches to a group of instructions which provide functionality required to perform wireless transfer of data to the phone.
In one embodiment, if the user attempts to turn the phone on while a counter initiated power-up has occurred, the user input is ignored by microcontroller 120 until all memory re-programming processing is complete.
Wireless Programmer Configuration
Figure 4 illustrates a block diagram of a wireless programmer 200. The wireless programmer 200 communicates with one or more electronic devices 100 via a wireless link to load binary data and/or program code into the devices 100. Wireless programmer 200 includes a microcontroller 230, a memory 240, and an RF unit 290. Wireless programmer 200 may include a number of input/output devices such as a keyboard 210, a monitor 220, and a printer 250. Wireless programmer 200 also includes a data I/O unit 260 which may connect other I/O devices such as a touch screen, modem and bar code reader, for example.
RF Unit 290 includes at least one radio transmitter 270, at least one radio receiver 280 and an antenna 240.
The keyboard 210 allows a user to input data and commands. The monitor 220 and printer 250 allow the user to receive information from the programmer. Data and software programs are stored in the memory 240, which may include but are not necessarily limited to RAM, ROM, hard or floppy discs. Data input/output devices are used load the prograrnmer 200 with programs, files and data. The radio transmitter 270 and receiver 280 are linked to antenna 240 and use one or more communication paths to exchange data with electronic devices 100. All operations of the wireless programmer 200 are controlled by microcontroller 230.
Wireless programmer 200 is provided with a set of programmed instructions stored in memory 240 which comprise a program referred to herein as a "wireless update routine" or "wireless update program" which controls the logical operation of wireless programmer 200.
In one embodiment illustrated in Figure 4A, the wireless programmer 200 is constructed as a kiosk 205 which may be placed in a public area such as a cellular phone showroom. The kiosk 205 has a user interface including a touch screen monitor 220, a credit card reader 235, and a bar code scanner 245. Kiosk 205 also has a compartment 225 for receiving an electronic device 100 to be updated. Compartment 225 is covered by a door 226. In one embodiment, the compartment 225 is a multi-compartmented container capable of holding a number of different phones simultaneously. For example, Figure 4B illustrates a cross-sectional view of kiosk 205 containing a multi-compartmented carousel 225 accessible via a door 226. Multiple devices 100 may be contained within carousel 225 and updated simultaneously. Carousel 225 rotates about an axis 227 to permit deposit and removal of a particular device 100 through door 226. The status of the wireless programmer 200' s operation is displayed on monitor 220. An exemplary screen display of monitor 220 is shown in Figure 4C, which shows the current status of three concurrent wireless update procedures.
Channel Definitions and Operation
In one embodiment, four communication channels are defined for communication between wireless programmer 200 and an electronic device 100. The defined channels, which are illustrated in Figure 5 A, include a Notification Channel 455, an Authentication Channel 460, a Data Channel 465 and an Acknowledgement Channel 470. The structure and operation of these channels are described below.
1. Notification channel.
The Notification channel 455 is a one-way communication channel from wireless programmer 200 to device 100. Data is sent continuously on this channel in a plurality of sequential frames. Each frame contains the following fields:
CIC Channel Identification Code (identifying the channel as a notification channel).
RN Revision Number of the new software program to be downloaded.
LOC Location (i.e., frequency, time slot, spreading code, etc.) for the 1) Authentication channel, 2) Data channel and 3) Acknowledgment channel.
CBN Changed Block Numbers - list of block numbers of phone memory to be altered. Table 1 - Notification Channel Frame Structure
The structure of the Notification channel 455 is illustrated in Figure 5B. As illustrated, the wireless programmer 200 continuously transmits a plurality of sequential notification frames N; 456, each of which may carry unique update notification data. This permits concurrent updating of different electronic devices with different update revision levels. For example, notification frame Nl may carry notification information for updating a first model of cellular telephones to a first revision level, while notification frame N2 carries notification information for updating a second model of cellular telephones to a second revision level, and so forth. The Notification channel frame, may additionally include a field containing the electronic serial numbers of all devices to be updated to the software revision level specified in the RN field.
2. Authentication Channel.
The Authentication Channel 460 is a two-way communication channel which provides means for the devices 100 and the wireless programmer 200 to exchange authentication information. Data flow on the Authentication Channel 460 is illustrated in Figure 5C, and is explained in greater detail below.
3. Data Channel.
The Data Channel 465 is a one-way communication channel from the wireless programmer 200 to electronic device 100. Data is sent continuously on the Data Channel 465 to convey data values for those blocks of memory to be altered. The electronic devices 100 receive data bytes to update all affected blocks within the nonvolatile memory 136. Data transmitted on the data channel is organized into frames having the following fields:
Figure imgf000020_0001
Table 2 - Data Channel Frame Structure
The frame structure of a Data Channel 465 is shown in Figure 5D. As illustrated, wireless programmer 200 continuously transmits a series of data frames D, 466, each of which comprises each of the fields described in Table 2. Depending on how many updates are being performed concurrently by wireless programmer 200, there may be multiple Data Channels 465 in operation at any one time.
Multiple data frames may be transmitted on any one Data Channel 465. This permits the update of multiple subblocks in a given reprogramming operation. For example if a given reprogramming operation includes updating five memory subblocks in a particular class of devices 100, the Data Channel 465 will carry five data frames D1-D5.
4. Acknowledgment Channel.
The Acknowledgement Channel 470 is a two-way communication channel that provides means for each device 100 to inform the wireless programmer that all memory blocks have been properly updated. Data flow on the Acknowledgement Channel 470 is illustrated in Figure 5E, and is explained in greater detail below.
As stated above, the Notification channel 455 and Data channel 465 convey data from the wireless programmer 200 to the electronic devices 100; no data is returned to wireless programmer 200 by any device 100 on these channels. The Authentication channel 460 and Acknowledgment channel 470 are used to convey data in both directions.
In a preferred embodiment, the RF signal transmitted by the wireless programmer 200 is consistent with the modulation methods, data rates, coding, error detection methods, etc. used by the wireless communication standard for which the device 100 was designed and programmed. This permits the device 100 to be updated in accordance with the present invention with no (or very little) additional modification required.
As will be explained in greater detail below, when the device 100 is placed in the memory update mode, the device 100 searches for the Notification channel 455. When the Notification channel 455 is found, the device 100 reads the transmitted information from the Notification channel 455 and continues the memory update process by proceeding to (i.e., tuning to) the Authentication channel 460 to perform the authentication procedure. If the device 100 successfully authenticates the wireless programmer 200, it then proceeds to tune to the Data channel 465 identified in the LOC field of the Notification channel; if not, the device 100 switches off. Device 100 reads the appropriate information from the Data channel 465 to update memory. Upon successfully updating memory, the device 100 proceeds to tune to the Acknowledgment channel 470 to acknowledge successful reprogramming.
In another embodiment of the present invention illustrated in Figures 5F and 5G, only two channels are defined: a one-way Notification/Data Channel 920, and a two-way Authentication/ Acknowledgement Channel 910. Data flow on the Authentication/ Acknowledgement Channel 910 is illustrated in Figure 5F. Each Authentication request by a device 100 comprises the device's ESN plus an
Authentication request string AUTH. Upon receipt of an authentication request, the wireless programmer 200 responds with the received ESN plus the caluculated Authentication result R, as described above.
Acknowledgement on the Authentication/ Acknowledgement Channel 910 is performed by the device 100 transmitting an acknowledgement signal to the wireless programmer 200 to indicate successful completion of the wireless memory update process. The acknowledgement signal comprises the device's ESN plus an acknowledgement string ACK. The wireless programmer 200 then responds with the same" acknowledgement string to confirm acknowledgement. Similarly, to indicate that the update process failed, the device 100 may transmit a failure signal comprising the device's ESN plus a negative acknowledgement string, illustrated in Figure 5F as NAK.
A number of advantages are obtained by defining various acknowledgement requests and responses. For example, a system implemented in accordance with the present invention may be configured to provide a separate acknowledgement for each subblock of memory successfully updated.
Figure 5G illustrates the structure of the Notification Data Channel 920 which is logically divided into a number of frames 930. One frame is a notification frame, while the other frames comprise the data frames. The internal structure of the notification and data frames may be similar to those described above in connection with the four-channel embodiment.
It will be readily apparent to those skilled in the art that many variations on the structure, arrangement and protocol of the various channels used in the wireless update method described herein are possible without departing from the scope of the invention.
Wireless Programmer Logical Operation
Figure 7 (in conjunction with Figures 7A, 7B, 7C and 7D) illustrate logical operation of a wireless programmer 200. At the start of execution of the wireless update program, the wireless programmer 200 displays a plurality of menu selections on the monitor 220 in step 401. The menu selection comprises user commands and options for the operation of wireless programmer 200 such as Configure, Transmit, and List. Other commands or options may be included in the menu selection.
If, in step 402, a selection is made, processing continues with step 403. If
"Configure" is selected, the program branches to point A (Figure 7A) in step 403. If "Transmit" is selected, the program branches to point B (Figure 7B) in step
404. Finally, if "List" is selected, the program branches to point D (Figure 7D) in step 405. If no valid selection is made, the program branches back to block 401 to redisplay the menu choices and await input.
Referring to Figure 7A, the "configure" selection causes the wireless programmer 200 to load update data and programs into memory in preparation for a programming operation. In step 410 of Figure 7 A, data file(s) are loaded via the data input/output unit 260. The data portion of the file(s) transferred may include, without limitation:
1. The serial number of each device 100 to be modified (which in the case of a cellular telephone, will be a 32-bit ESN).
2. A data value for each device 100 for use in an authentication process. The authentication process ensures that devices 100 respond only to memory update signals from a legitimate wireless programmer 200. This data value is called an "Authentication Key" or "A-Key".
3. The software version number of the new software to be loaded into the device 100.
4. A definition of the communication channels to be used to communicate with the device 100. 5. The memory blocks to be updated in each device 100 and the data content of each block.
In step 411, wireless programmer 200 executes an authentication algorithm for each devfce 100 using the A-key to generate an authentication result R for each device 100. The computed authentication result R for each device 100 is stored in wireless programmer 200. In one embodiment, the device's A-key is used directly as its authentication result. In other cases, a complex algorithm (such as the well-known the cave algorithm) may be used to generate the authentication result R from the A-Key. After step 411, the program returns to step 401 of Fig. 7 and redisplays the menu selections.
The "Transmit" selection is used to execute the Transmit routine, which alters the memory contents of devices 100. Operation of the wireless programmer 200 upon selection of the "Transmit" command is described in Fig. 7B. The menu selections illustrated in Figure 7 may be used when the wireless programmer 200 is under the control of an operator, for example when the wireless programmer 200 is used to update devices at a manufacturing plant. If the wireless programmer 200 is a kiosk to be used by a consumer, the menu selections should be altered accordingly, for example to permit the user to select a particular option or upgrade, identify his device by serial number, pay for the upgrade using a credit card, etc.
Referring now to Figure 7B, in step 420, transmission of data on the Notification Channel 455 is initiated, and in step 421, transmission of data on the Data Channel is initiated. In step 422, wireless programmer 200 determines if data from a device
100 has been received on the Authentication Channel 460. If no data has been received on the Authentication Channel 460, the Transmit routine proceeds to point C of Figure 7C. If data has been received on the Authentication Channel 460, a test is performed in step 423 to determine if the received data represents a valid ESN. If not, the program jumps to point C of Figure 7C. If a valid ESN has been received, a test is performed in step 424 to determine if the ESN is in the data file. If not, an authentication string equal to the ESN concatenated with '0' is transmitted on the Authentication channel 460 in step 426 and then the program proceeds to point C.
If the ESN is in the data file, a test is made in step 425 to determine if an acknowledgment has already been received for the ESN. If so, the device 100 need not continue (since the data has already been altered successfully). Therefore, the program goes to step 426 to transmit a data string equal to the ESN concatenated with '0'. Upon receipt of this data string, the device 100 powers off.
If an acknowledgment has not already been received, then a data string equal to the ESN concatenated with the calculated authentication result R is transmitted. At point C (step 428 of Figure 7C), processing by the wireless programmer 200 for the Acknowledgment Channel 470 is carried out.
At step 428 of Figure 7C, a test is made to determine if data has been received on the Acknowledgment Channel 470. If no data has been received on the Acknowledgement Channel, then the routine proceeds to step 433. If data has been received, a test is made in step 429 to determine if the received data represents a valid ESN. If not, then the routine proceeds to step 433.
If the received data does represent a valid ESN, then, in step 430, the ESN is transmitted on the Acknowledgment Channel 470. In step 431, a test is made to determine if the ESN is in the database. If yes, the database is updated to indicate that an acknowledgment was received for that ESN. In step 433, a test is made to determine if the escape key was pressed. If yes, then the program (in step 434) stops data transmission on the notification and data channels and returns to start. If no, the program jumps to point B of Figure 7B. Figure 7D provides a flow diagram for the routine executed when the user selects "List" from the main menu of the wireless programmer 200 in step 405 of Fig. 7. Referring to Fig. 7D, a list is displayed in step 440 which includes the ESN for all devices 100 for which an acknowledgment was received. In step 441, a list is displayed which includes all devices 100 in the database which did not provide an acknowledgment. After step 441, the program returns to step 401 of Fig. 7 to redisplay the menu selections.
Figure 6 illustrates more clearly the data exchanged between a device 100 and the wireless programmer 200 on the Authentication Channel 460 to authenticate the wireless programmer 200. On the Authentication Channel 460, a first device 100 initiates communication by transmitting an authentication request comprising its ESN (denoted ESN1) to the wireless programmer 200. When received by the wireless programmer 200, ESN1 is used to search a database of ESN's installed in the wireless programmer 200 during configuration. If found in the database, the previously calculated authentication result R corresponding to the received ESN is fetched. If ESN 1 is not found in the database, an invalid authentication result (e.g., zero) is used. For either case, an Authentication string comprising the ESN concatenated with Authentication result R is transmitted by wireless programmer 200 to device 100 as an authentication response. When the authentication string is received by the device 100, the authentication result R is compared to the authentication result computed by the device 100. If the two numbers match, the wireless programmer 200 has been authenticated and the device 100 proceeds with the memory update process by tuning to the Data channel. If the numbers do not match, the device 100 powers down and does not continue the memory update process.
Figure 6 illustrates a case where the ESN's sent by two devices 100 partially overlap. In this case, the data received by the wireless programmer 200 will be corrupted; the wireless programmer will make no response to the corrupted ESN. Each device 100 will then wait a random time period and try again to authenticate the wireless programmer 200. The random delay period may be based on the ESN of the device 100. For example, it may be generated using a random number generation algorithm seeded with a portion of the device's ESN. Figure 5E illustrates the data exchanged between a device 100 and the wireless programmer 200 on the Acknowledgment Channel 470. As illustrated in Fig. 5E, the device 100 initiates communication on the acknowledgement channel with wireless programmer 200 by transmitting its ESN (ESN1) to the wireless programmer 200. When wireless programmer 200 receives an ESN on the
Acknowledgement Channel 470 (constituting an acknowledgement request), it searches the previously described ESN database. If the received ESN is not found in the ESN database, no action is taken by the wireless programmer 200. If the ESN is found in the database, the database entry for that ESN is updated to indicate that the phone has successfully updated memory. The database is also revised to reflect the updated revision level of software in the updated device 100.
The wireless programmer 200 then transmits an acknowledgement response containing the received ESN to the device 100. When the device 100 receives the acknowledgement response containing its ESN from the wireless programmer 200, the device 100 powers off. Preferably, the device 100 will make several acknowledgement attempts on the Acknowledgment Channel 400 if its ESN is not received from the wireless programmer 200.
Figure 6 A illustrates a case where the ESN's sent by two devices 100 on the Acknowledgement Channel 470 partially overlap. In such a case, the data received by the wireless programmer 200 will be corrupted, and the wireless programmer 200 will make no response on the Acknowledgement Channel 470. Each device 100 will then implement a time-out and try again. Electronic Device Logical Operation
Figure 8, along with figures 8 A, 8B and 8C provide a flowchart for the wireless update program executed in a device 100. Referring to Fig. 8, the program starts at power up in step 801. In step 801 , a test is made to determine if the device 100 was powered-up by user action (as described above). If the device 100 was powered on by the user, the device 100 is latched on (in step 802) and a test is made to determine if a valid software revision number is stored in memory (in step 803). If a valid software revision number is not present, then an error condition is shown in the display 127 and program execution stops. Otherwise, processing continues to provide normal operation for the user.
If the device 100 was not turned on by user action but instead was turned on by the timer circuit 190, the program proceeds to.step 805, where the device 100 is latched on.
In steps 806 through 810, the device 100 searches available communication paths for a notification channel. (As described above, the Notification Channel 455 contains a field which identifies it as a notification channel). Beginning with a first possible communication channel (step 806) all channels are tested until either no notification channels are found (and the device 100 turns off) or a notification channel is found. If a notification channel is found, processing continues with step 811.
In step 811, the following data from the data channel is stored in RAM:
A. Revision number of the new software program to be downloaded.
B. Location (i.e., frequency, time slot, spreading code, etc.) for the authentication channel, data channel and acknowledgment channel.
C. List of block numbers of memory to be altered.
In step 812, the list of block numbers of memory to be altered (received from the notification channel) is compared to a list of restricted blocks; if any restricted blocks are in the list from the notification channel, the device 100 is turned off. Otherwise, processing continues at point A in figure 8A.
In step 815 of figure 8 A, the device 100 computes and stores the authentication result R using the device's prestored A-key.
In steps 816 through 823, the device 100 attempts to communicate with the wireless programmer 200 on the Authentication Channel 460 as follows: A first timer is started in the device 100 in step 816. The starting value of the timer is random, which creates a random delay before communications are attempted. After the timer has expired (step 817), the device 100 transmits its ESN on the Authentication Channel 460 (step 818). In steps 819, 820 and 821, the device 100 waits a pre-determined period of time (as controlled by a second timer) for a response from the wireless programmer 200. If no response is received within the second time-out period, the program proceeds to step 822. If a response is received, the program proceeds to step 823.
In step 822, a test is made to determine if the maximum number of attempts to authenticate have been exceeded. If not, the program returns to step 816 to make another attempt. If a previous authentication attempt failed due to a data collision with another device 100 (i.e. two or more devices 100 have sent data on the Authentication Channel 460 at the same time), the random delay caused by the random timer in step 816 will tend to prevent additional collisions with the same devices 100. If the maximum number of attempts has been exceeded, the device 100 turns itself off in step 824.
In step 823, the device 100 checks if the received authentication result R matches its computed authentication result. If not, the phone turns itself off in step 824. If the authentication results match, the wireless programmer has been authenticated and the program proceeds to point B in figure 8B.
At point B (step 840 of figure 8B), the Data Channel 465 is acquired. In subsequent steps, the data from the Data Channel 465 is used to update the flash memory block by block. In step 841, a test is made to determine if the channel tuned contains an identifier which indicates that it is indeed the data channel. If not, the device 100 is turned off in step 842. If yes, the software revision number (which is either located within a data location in the flash or in another nonvolatile memory) is set to an invalid number (in step 843). In step 853, the program used to write or read data to flash is copied from the flash and replicated in RAM. In step 844, the received data stream is monitored until data is received which indicates the beginning of a data string for any block/sub-block. A test is then made (in step 845) to determine if the data string for that sub-block has already been updated in flash. If yes, the program returns to step 844 to await data for the next sub-block. If no, then subsequent steps are executed to store the data string in RAM and use it to update flash, as described below.
In step 846, the block number/sub-block number and data string for the sub-block are stored in RAM. In step 847, the data string is loaded into the sub- block of the flash. In step 848, the data just stored in the flash sub-block is read from flash and compared to the data in RAM (in step 849). If the comparison is not successful, the program returns to step 844. If successful, data is stored in RAM which records the sub-block number and block number which was successfully updated (in step 850). In step 851, a test is made to determine if all sub-blocks (for all blocks) have been updated. If no, the program returns to step 844. If yes, the software revision number is updated with the new value. Any programming steps referenced above which read or write data to flash (steps 847, 848) are preferably executed from RAM.
After step 852, processing continues at point C of Figure 8C. In Figure 8C, the device 100 attempts to communicate with the wireless programmer 200 on the Acknowledgment Channel 470. The acknowledgment channel is tuned in step 865. A first timer is started in step 866 which has a starting value which is random. This creates a random delay before communications are attempted. After the timer has expired (step 867), the device 100 transmits its ESN on the Acknowledgment Channel (step 868). In steps 869, 870 and 871, the device 100 waits a pre-determined period of time (as controlled by a second timer) for a response from the wireless programmer 200. If no response is received within the time-out period, the program proceeds to step 872. If a response is received, the device 100 is turned off in step 873.
In step 872, a test is made to determine if the maximum number of attempts to acknowledge have been exceeded. If not, the program returns to step 866 to make another attempt. If a previous acknowledgment attempt failed due to a data collision with another device 100, the random delay caused by the random timer in step 866 will tend to prevent additional collisions with the same phone(s). If the maximum number of attempts has been exceeded, the device 100 turns itself off in step 873.
Conclusion
The wireless programmer 200 and the device 100 being programmed both possess the capability to receive and transmit data via a wireless communication link. It would also be possible to employ the concepts presented herein to update memory in a device capable only of receiving wireless signals. Modifications necessary to utilize the present invention in connection with a receive-only device will be readily apparent to one skilled in the art upon reviewing this Specification. For example, with regard to authentication for a receive-only device, the following is one alternative: Continuously broadcast an ESN and Authentication result on one channel for all devices being programmed. The wireless device, upon receiving its specific ESN and Authentication result pair would simply compare the result received with a result stored at time of manufacture to authenticate the wireless programmer.
A system and method for wirelessly updating the memory of an electronic device has been described. The system is particularly advantageous for updating a program or data stored in nonvolatile memory in an electronic device such as a cellular telephone. The system and method may be used for example at a manufacturing plant for simultaneously updating the memories of a number of devices, or for updating devices that have already been shipped to consumers one at a time.

Claims

What is claimed is:
1. An electronic device, comprising: a microprocessor operable in a plurality of modes, said plurality of modes including a memory update mode; a nonvolatile memory coupled to said microprocessor; and a wireless communication interface coupled to said microprocessor for receiving data over a wireless communication channel; wherein data received by said wireless communication interface is stored in said nonvolatile memory by said microprocessor responsive to receipt of said data while said microprocessor is in said memory update mode.
2. An electronic device as recited in claim 1, further comprising means for placing said electronic device in said memory update mode.
3. An electronic device as recited in claim 2, wherein said means for placing comprises (i) a timer circuit, said timer circuit including a counter having a load input, a clock input and an output, said timer further including an oscillator having an output connected to the clock input of said counter, and (ii) a switch coupled between a battery and said microprocessor, said switch being operably controlled by the output of said counter.
4. An electronic device as recited in claim 3, wherein said counter is loaded with a predetermined counter initialization value when the load input of said counter is set.
5. An electronic device as recited in claim 3, wherein said counter is loaded with a counter initialization value by said microprocessor when the load input of said counter is set.
6. An electronic device as recited in claim 2, wherein said means for placing comprises a mode selection switch for placing said electronic device directly into said memory update mode.
7. An electronic device as recited in claim 1, wherein said data stored in said nonvolatile memory represents executable program code.
8. An electronic device as recited in claim 1, wherein said data stored in said nonvolatile memory represents at least one parameter setting for said electronic device.
9. An electronic device as recited in claim 1 , wherein said nonvolatile memory is logically divided into blocks.
10. An electronic device as recited in claim 9, wherein said blocks are logically divided into sub-blocks.
11. An electronic device as recited in claim 1, wherein said wireless communication interface comprises an RF transceiver.
12. An electronic device as recited in claim 1, wherein said wireless communication interface comprises an infrared communication unit.
13. An electronic device as recited in claim 1 , wherein said wireless communication interface communicates using a time division multiple access protocol.
14. An electronic device as recited in claim 1, wherein said wireless communication interface communicates using a frequency division multiple access protocol.
15. An electronic device as recited in claim 1 , wherein said wireless communication interface communicates using a code division multiple access protocol.
16. An electronic device as recited in claim 1, wherein said electronic device comprises a cellular telephone.
17. An electronic device as recited in claim 1 , wherein said electronic device comprises a pager.
18. An electronic device as recited in claim 1 , wherein said electronic device comprises a personal computer.
19. An electronic device as recited in claim 1, wherein, responsive to said microprocessor being placed in said memory update mode, said electronic device scans a predetermined list of channels in search of a notification channel containing a predetermined identification code indicating that a wireless memory update is to be performed.
20. An electronic device as recited in claim 19, wherein, responsive to said electronic device locating said notification channel, said electronic device reads data from a data channel.
21. An electronic device as recited in claim 20, wherein said notification channel is the same as said data channel.
22. A system for updating data stored in a nonvolatile memory of an electronic device, comprising: (a) a programming unit comprising a first microprocessor, a first wireless communication interface and a memory coupled to said first microprocessor, said memory containing update data; (b) an electronic device comprising:
(i) a second microprocessor operable in a plurality of modes, said plurality of modes including a memory update mode,
(ii) a nonvolatile memory coupled to said second microprocessor, and
(iii) a second wireless communication interface coupled to said second microprocessor for receiving update data from said programming unit, wherein update data received by said second wireless communication interface is stored in said nonvolatile memory by said second microprocessor responsive to receipt of said update data while said microprocessor is in said memory update mode; and
(c) a wireless communication path between said programming unit and said electronic device.
23. A system as recited in claim 22, wherein said wireless communication path comprises a unidirectional communication channel for communicating data from said programming unit to said electronic device and a bidirectional communication channel for communicating data between said programming unit and said electronic device.
24. A system as recited in claim 23, wherein said unidirectional communication channel communicates notification data and update data to said electronic device, said notification data being repeated in a plurality of notification frames and said update data being repeated in a plurality of update data frames.
25. A system as recited in claim 23, wherein each of said plurality of notification frames is divided into a plurality of fields including a channel identification field and a location field.
26. A system as recited in claim 23, wherein each of said plurality of update data frames is divided into a plurality of fields including a block number field and a data field.
27. A system as recited in claim 23, wherein said bidirectional channel communicates authentication and acknowledgement signals between said programming unit and said electronic device.
28. A system as recited in claim 22, wherein said wireless communication path comprises first and second unidirectional communication channels for communicating data from said programming unit to said electronic device and first and second bidirectional communication channels for communicating data between said programming unit and said electronic device.
29. A system as recited in claim 28, wherein said first unidirectional communication channel communicates notification data to said electronic device, said notification data being repeated in a plurality of notification frames.
30. A system as recited in claim 28, wherein said second unidirectional communication channel communicates update data to said electronic device, said update data being repeated in a plurality of update data frames.
31. A system as recited in claim 29, wherein each of said plurality of notification frames is divided into a plurality of fields including a channel identification field and a location field.
32. A system as recited in claim 30, wherein each of said plurality of update data frames is divided into a plurality of fields including a block number field and a data field.
33. A system as recited in claim 28, wherein said first bidirectional channel communicates authentication signals between said programming unit and said electronic device.
34. A system as recited in claim 28, wherein said second bidirectional channel communicates acknowledgement signals between said programming unit and said electronic device.
35. A system as recited in claim 22, further comprising a plurality of electronic devices.
36. A programming unit comprising : a microprocessor; a wireless communication interface; and a memory coupled to said first microprocessor, said memory containing update data for updating the memory of one or more electronic devices; wherein said programming unit transmits said update data to said one or more electronic devices over said wireless communication interface and receives signals from said one or more electronic devices acknowledging receipt of said update data.
37. A programming unit comprising: a microprocessor; a wireless communication interface; a memory coupled to said first microprocessor, said memory containing a plurality of update data sets for updating the memory of one or more electronic devices, said plurality of update data sets corresponding to a plurality of software revision levels; and means for selecting an update data set corresponding to a desired software revision level for a particular electronic device; wherein said programming unit transmits said selected update data set to said one or more electronic devices over said wireless communication interface and receives signals from said one or more electronic devices acknowledging receipt of said update data set.
38. A programming unit comprising: a microprocessor, a wireless communication interface, and a memory coupled to said first microprocessor, said memory containing a plurality of update data sets for updating the memory of one or more electronic devices, said plurality of update data sets corresponding to a plurality of software revision levels; means for selecting an update data set corresponding to a desired software revision level for a particular electronic device; and means for receiving one or more electronic devices; wherein said programming unit transmits said selected update data set to said one or more electronic devices over said wireless communication interface and receives signals from said one or more electronic devices acknowledging receipt of said update data set.
39. A programming unit as recited in claim 38, wherein said means for receiving comprises a multi-compartmented carousel for selectively receiving and individually delivering a plurality of electronic devices.
40. A programming unit as recited in claim 38, further comprising means for displaying the operational status of said programming unit.
41. In a system comprising a programming unit and a plurality of electronic devices, said programming unit and said plurality of electronic devices each having a microprocessor and a wireless communication interface, each of said plurality of electronic devices additionally having a respective nonvolatile memory and means for placing said electronic device in a memory update mode, a method of updating data stored in the nonvolatile memory of one of said plurality of electronic devices, comprising: placing said programming unit in proximity to said plurality of electronic devices; and activating a wireless update routine in said programming unit.
42. A method as recited in claim 41 , further comprising: In said programming unit: transmitting notification data on a notification channel; transmitting update data on a data channel; monitoring an authentication channel for the receipt of an authentication request; and responsive to the receipt of a valid authentication request, monitoring an acknowledgement channel for the receipt of an acknowledgement signal from said one of said electronic devices; and
In said one of said plurality of electronic devices: responsive to said electronic device being placed in said memory update mode, searching for the notification channel; reading data from the notification channel indicative of the location of the data channel; reading updated data from the data channel; storing the updated data in the nonvolatile memory of said one of said electronic devices; and transmitting an acknowledgement signal on said acknowledgement channel.
43. A method as recited in claim 42, further comprising: In said programming unit: responsive to receiving an authentication request, selecting an authentication string based on a device identification code contained in said authentication request; and transmitting an authentication response on said authentication channel, said authentication response containing said authentication string; and In said one of said plurality of electronic devices: responsive to locating said notification channel, transmitting an authentication request on said authentication channel, said authentication request containing a device identification code; receiving an authentication response on said authentication channel, said authentication response containing an authentication string; and determining if said authentication string is correct.
44. A method as recited in claim 43, further comprising: In said one of said plurality of electronic devices: responsive to determining that said received authentication string is incorrect, powering off.
45. A method as recited in claim 42, further comprising: In said one of said plurality of electronic devices: responsive to an error occurring while reading said update data from said data channel, sending a negative acknowledgement on said acknowledgement channel and powering off.
46. A method as recited in claim 42, further comprising:
In said one of said plurality of electronic devices: responsive to an error occurring while storing said update data in the nonvolatile memory, sending a negative acknowledgement on said acknowledgement channel and powering off.
47. A method as recited in claim 43, further comprising: In said one of said plurality of electronic devices: responsive to a failure to receive an authentication response within a predetermined time period: waiting for a timeout period; and re-transmitting the authentication request.
48. A method as recited in claim 42, further comprising: In said one of said plurality of electronic devices: after transmitting the acknowledgement signal on the acknowledgement channel, waiting a predetermined time period to receive an acknowledgement response; and responsive to a failure to receive an acknowledgement response: waiting for a timeout period; and re-transmitting the acknowledgement signal.
49. A method as recited in claim 47, wherein said timeout period is a random delay.
50. A method as recited in claim 47, wherein said timeout period is a predetermined period based on an identification number unique to said one of said plurality of electronic devices.
51. A method, as recited in claim 48, wherein said timeout period is a random delay.
52. A method as recited in claim 48, wherein said timeout period is a predetermined period based on an identification number unique to said one of said plurality of electronic devices.
53. In an electronic device having a microprocessor, a wireless communication interface, a nonvolatile memory and means for placing said electronic device in a memory update mode, a method of updating data stored in the nonvolatile memory, comprising:
responsive to said electronic device being placed in said memory update mode, searching for a notification channel; reading data from the notification channel indicative of the location of a data channel; reading updated data from the data channel; storing the updated data in the nonvolatile memory of said electronic device; and transmitting an acknowledgement signal on said acknowledgement channel.
54. A method as recited in claim 53, further comprising: responsive to locating said notification channel, transmitting an authentication request on said authentication channel, said authentication request containing a device identification code unique to said electronic device; receiving an authentication response on said authentication channel, said authentication response containing an authentication string; and determining if said authentication string is correct.
55. A method as recited in claim 54, further comprising: responsive to determining that said received authentication string is incorrect, powering off.
56. In a programming unit having a microprocessor and a wireless communication interface, a method of updating data stored in the nonvolatile memory of one of a plurality of electronic devices, each of said plurality of electronic devices having a microprocessor, a wireless communication interface, a respective nonvolatile memory and means for placing said electronic device in a memory update mode, the method comprising: transmitting notification data on a notification channel; transmitting update data on a data channel; monitoring an authentication channel for the receipt of an authentication request; and responsive to the receipt of a valid authentication request, monitoring an acknowledgement channel for the receipt of an acknowledgement signal from said one of said electronic devices.
57. A method as recited in claim 56, further comprising: responsive to receiving an authentication request, selecting an authentication string based on a device identification code contained in said authentication request; and transmitting an authentication response on said authentication channel, said authentication response containing said authentication string.
PCT/US1998/013047 1997-07-10 1998-06-23 System and method for updating a memory in an electronic device via wireless data transfer WO1999003288A1 (en)

Priority Applications (7)

Application Number Priority Date Filing Date Title
JP2000502642A JP2001510315A (en) 1997-07-10 1998-06-23 System and method for updating memory in an electronic device by wireless data transfer
AU79855/98A AU752584B2 (en) 1997-07-10 1998-06-23 System and method for updating a memory in an electronic device via wireless data transfer
EEP200000021A EE200000021A (en) 1997-07-10 1998-06-23 A system and method for updating the contents of an electronic device memory by wireless data transmission
EP98930470A EP0995326B1 (en) 1997-07-10 1998-06-23 Method for updating a memory in an electronic device via wireless data transfer
DE69834114T DE69834114D1 (en) 1997-07-10 1998-06-23 METHOD FOR UPDATING A MEMORY IN AN ELECTRONIC DEVICE THROUGH WIRELESS DATA TRANSMISSION
KR10-2000-7000117A KR100485017B1 (en) 1997-07-10 1998-06-23 System and method for updating a memory in an electronic device via wireless data transfer
BR9810583-3A BR9810583A (en) 1997-07-10 1998-06-23 System and method for using a memory in an electronic device via wireless data transfer

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US08/892,262 1997-07-10
US08/892,262 US5974312A (en) 1997-07-10 1997-07-10 System and method for updating a memory in an electronic device via wireless data transfer

Publications (1)

Publication Number Publication Date
WO1999003288A1 true WO1999003288A1 (en) 1999-01-21

Family

ID=25399675

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US1998/013047 WO1999003288A1 (en) 1997-07-10 1998-06-23 System and method for updating a memory in an electronic device via wireless data transfer

Country Status (10)

Country Link
US (1) US5974312A (en)
EP (1) EP0995326B1 (en)
JP (1) JP2001510315A (en)
KR (1) KR100485017B1 (en)
CN (1) CN1269951A (en)
AU (1) AU752584B2 (en)
BR (1) BR9810583A (en)
DE (1) DE69834114D1 (en)
EE (1) EE200000021A (en)
WO (1) WO1999003288A1 (en)

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2000029944A1 (en) * 1998-11-16 2000-05-25 Cardsoft International Pty Limited Method and apparatus for programming computing devices
WO2000072139A2 (en) * 1999-05-20 2000-11-30 Transcept, Inc. Broadcast download technique
WO2001065876A1 (en) * 2000-02-29 2001-09-07 Qualcomm Incorporated Programmable mobile communications terminal with randomized off-peak transmissions
GB2363946A (en) * 1999-08-11 2002-01-09 Nec Corp Remote updating of a program in a mobile communication unit
EP1341086A1 (en) * 2000-11-29 2003-09-03 Sony Corporation Information processing terminal
US8384525B2 (en) 2006-05-15 2013-02-26 Nokia Corporation Contactless programming and testing of memory elements
CN104680770A (en) * 2013-11-29 2015-06-03 红板凳科技股份有限公司 Infrared remote controller capable of remotely updating control code
US9496925B2 (en) 2011-09-30 2016-11-15 Nokia Technologies Oy Method, apparatus, and computer program product for remote wireless powering and control of an electronic device

Families Citing this family (167)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR980013092A (en) * 1996-07-29 1998-04-30 김광호 File management apparatus and method of exchange system
US6643506B1 (en) * 1996-08-07 2003-11-04 Telxon Corporation Wireless software upgrades with version control
US6308061B1 (en) * 1996-08-07 2001-10-23 Telxon Corporation Wireless software upgrades with version control
US6487180B1 (en) * 1996-10-15 2002-11-26 Motorola, Inc. Personal information system using proximity-based short-range wireless links
US6600915B1 (en) * 1997-04-22 2003-07-29 John K. Wedeking Cellular device authorized user tracking systems and methods
KR100229568B1 (en) * 1997-07-28 1999-11-15 윤종용 Method and system for monitoring remote bts on cros environment
JPH11120487A (en) * 1997-10-21 1999-04-30 Toyota Motor Corp Mobile object terminal equipment, for providing device, system, and method information and medium recording program for mobile object terminal equipment
KR100247467B1 (en) * 1997-11-07 2000-03-15 윤종용 Method of replace block loading by mmc command
US6591084B1 (en) * 1998-04-27 2003-07-08 General Dynamics Decision Systems, Inc. Satellite based data transfer and delivery system
US6205548B1 (en) * 1998-07-31 2001-03-20 Intel Corporation Methods and apparatus for updating a nonvolatile memory
JP3950589B2 (en) * 1998-08-28 2007-08-01 キヤノン株式会社 Information processing apparatus, program update method, and storage medium
US6697484B1 (en) 1998-12-21 2004-02-24 Micron Technology, Llc Method of programming telephone numbers and identifiers in a telephone
US6597772B1 (en) * 1998-12-21 2003-07-22 Micron Technology, Inc. Method of programming telephone numbers and identifiers in multiple databases
US7010116B1 (en) 1998-12-21 2006-03-07 Micron Technology, Inc. Method of programming telephone numbers and identifiers in a telephone
US6625444B1 (en) 1999-02-02 2003-09-23 Micron Technology, Inc. Method of programming a telephone
JP2002537620A (en) * 1999-02-11 2002-11-05 スマートアイエヌティー カンパニー リミティッド Simplified information and detailed information exchange system between users and information communication terminal suitable for the system
US6253076B1 (en) * 1999-02-25 2001-06-26 Ericsson Inc. Manufacturing method for wireless communications devices employing potentially different versions of integrated circuits
US6721581B1 (en) * 1999-05-07 2004-04-13 Infineon Technologies Ag Reprogrammable digital wireless communication device and method of operating same
US7162020B1 (en) 1999-06-14 2007-01-09 Ascendent Telecommunications, Inc. Method and apparatus for selectively establishing communication with one of plural devices associated with a single telephone number
US7292858B2 (en) 1999-06-14 2007-11-06 Ascendent Telecommunications, Inc. Method and apparatus for communicating with one of plural devices associated with a single telephone number during a disaster and disaster recovery
US7305079B1 (en) 1999-06-14 2007-12-04 Ascendent Telecommunications, Inc. Method and apparatus for communicating with one of plural devices associated with a single telephone number
JP2001051851A (en) * 1999-08-17 2001-02-23 Nec Corp System and method for program modification of portable electronic equipment
US6487403B2 (en) * 1999-08-19 2002-11-26 Verizon Laboratories Inc. Wireless universal provisioning device
WO2001029776A1 (en) 1999-10-18 2001-04-26 Stamps.Com Cryptographic module for secure processing of value-bearing items
EP1224630A1 (en) 1999-10-18 2002-07-24 Stamps.Com Method and apparatus for on-line value-bearing item system
US6236326B1 (en) * 1999-10-29 2001-05-22 Vtech Telecommunications, Ltd. Method and apparatus for intelligently signaling a battery charge condition in a wireless telephone
US6754894B1 (en) 1999-12-03 2004-06-22 Command Audio Corporation Wireless software and configuration parameter modification for mobile electronic devices
AU7939800A (en) * 1999-12-29 2001-07-16 Sun Microsystems, Inc. Updating non volatile memory in a data processing system
AU2001247986A1 (en) * 2000-02-16 2001-08-27 Stamps.Com Secure on-line ticketing
AU2001257297A1 (en) * 2000-05-01 2001-11-12 Authenex, Inc. Method of authenticating user
US6680923B1 (en) * 2000-05-23 2004-01-20 Calypso Wireless, Inc. Communication system and method
CA2409851C (en) 2000-05-23 2013-03-26 Actineon Inc. Programmable communicator
US7546141B2 (en) * 2000-05-23 2009-06-09 Robert Leon Hybrid communication system and method
JP2001344005A (en) * 2000-05-31 2001-12-14 Mitsubishi Electric Corp Method for controlling article
US7680511B2 (en) 2000-06-14 2010-03-16 Ascendent Telecommunications Inc. Method and apparatus for communicating via virtual office telephone extensions
US6874037B1 (en) * 2000-06-19 2005-03-29 Sony Corporation Method and apparatus for synchronizing device information
DE10032774A1 (en) * 2000-07-06 2002-01-17 Endress Hauser Gmbh Co field device
AU2001288350A1 (en) * 2000-08-22 2002-03-04 Novatel Wireless, Inc. Over the air rf wireless data modem programming
US20040014483A1 (en) * 2000-09-08 2004-01-22 Reinhard Vonnoe Maintenance system for control devices of hydrostatic drives
US11467856B2 (en) 2002-12-12 2022-10-11 Flexiworld Technologies, Inc. Portable USB device for internet access service
US11204729B2 (en) 2000-11-01 2021-12-21 Flexiworld Technologies, Inc. Internet based digital content services for pervasively providing protected digital content to smart devices based on having subscribed to the digital content service
US7609402B2 (en) 2001-01-19 2009-10-27 Flexiworld, Inc. Methods for universal data output
AU2002239325A1 (en) 2000-11-20 2002-05-27 Flexiworld Technologies, Inc. Systems and methods for mobile and pervasive output
WO2002075580A1 (en) * 2001-03-16 2002-09-26 Nokia Corporation Mass subscriber handling
US6873842B2 (en) * 2001-03-30 2005-03-29 Xilinx, Inc. Wireless programmable logic devices
US7734285B2 (en) * 2001-04-03 2010-06-08 Qualcomm Incorporated Method and apparatus for network initiated uninstallation of application program over wireless network
US7890661B2 (en) 2001-05-16 2011-02-15 Aol Inc. Proximity synchronizing audio gateway device
US8732232B2 (en) * 2001-05-16 2014-05-20 Facebook, Inc. Proximity synchronizing audio playback device
US7620363B2 (en) * 2001-05-16 2009-11-17 Aol Llc Proximity synchronization of audio content among multiple playback and storage devices
US7127242B1 (en) * 2001-06-11 2006-10-24 Gateway Inc. Inter device personal information transfer
CN1529847A (en) * 2001-07-16 2004-09-15 任宇清 Embedded software update system
US7159214B2 (en) 2001-07-26 2007-01-02 Kyocera Wireless Corp. System and method for compacting field upgradeable wireless communication device software code sections
US7328007B2 (en) * 2001-07-26 2008-02-05 Kyocera Wireless Corp. System and method for organizing wireless communication device system software
CN1275149C (en) * 2001-07-26 2006-09-13 基奥赛拉无线公司 System and method for management of wireless communications device system software downloads in field
US7184759B2 (en) * 2001-07-26 2007-02-27 Kyocera Wireless Corp. Modular software components for wireless communication devices
US7386846B2 (en) * 2001-07-26 2008-06-10 Kyocera Wireless Corp. System and method for the management of wireless communications device system software downloads in the field
US7027806B2 (en) * 2001-07-26 2006-04-11 Kyocera Wireless, Corp. System and method for field downloading a wireless communications device software code section
US7200389B2 (en) * 2001-07-26 2007-04-03 Kyocera Wireless Corp. Dynamic interface software for wireless communication devices
US7197302B2 (en) * 2001-07-26 2007-03-27 Kyocera Wireless Corp. System and method for interchangeable modular hardware components for wireless communication devices
US9554268B2 (en) * 2001-07-26 2017-01-24 Kyocera Corporation System and method for updating persistent data in a wireless communications device
US7143407B2 (en) * 2001-07-26 2006-11-28 Kyocera Wireless Corp. System and method for executing wireless communications device dynamic instruction sets
US7184793B2 (en) * 2001-07-26 2007-02-27 Kyocera Wireless Corp. System and method for over the air area code update
US7809364B2 (en) * 2001-07-30 2010-10-05 Nokia Mobile Phones Limited Apparatus, and associated method, for providing an operation parameter to a mobile station of a radio communication station
US6961537B2 (en) * 2001-08-10 2005-11-01 Kyocera Wireless Corp. System and method for peer-to-peer handset communication
US7117494B2 (en) * 2001-08-10 2006-10-03 Kyocera Wireless Corp. System and method for bi-directional communication and execution of dynamic instruction sets
US7254386B2 (en) * 2001-08-10 2007-08-07 Kyocera Wireless Corp. System and method for improved security in handset reprovisioning and reprogramming
DE10139610A1 (en) 2001-08-11 2003-03-06 Daimler Chrysler Ag Universal computer architecture
JP2003060559A (en) * 2001-08-16 2003-02-28 Nec Access Technica Ltd Radio communication system having change/update function of data
US7506097B2 (en) 2001-09-25 2009-03-17 Caterpillar, Inc. Method and apparatus for installing data in a memory on a work machine
US7072326B2 (en) * 2001-11-30 2006-07-04 Palm, Inc. Network connectivity system and method
US20030110482A1 (en) * 2001-12-06 2003-06-12 Ferguson Alan L. System and method for remotely modifying software on a machine
US7013112B2 (en) * 2001-12-18 2006-03-14 Ixi Mobile (Israel) Ltd. Method, system and computer readable medium for making a business decision in response to information from a short distance wireless network
US20030120911A1 (en) * 2001-12-20 2003-06-26 Muench-Casanova Stephen L. Method of reprogramming modules
SE520932C2 (en) * 2002-03-18 2003-09-16 Optillion Ab communication Module
US20030204711A1 (en) * 2002-04-29 2003-10-30 Guess Alan J. Method and system for restoring custom user configuration settings across a host application download
US11337047B1 (en) 2002-05-21 2022-05-17 M2M Solutions Llc System and method for remote asset management
US6965674B2 (en) * 2002-05-21 2005-11-15 Wavelink Corporation System and method for providing WLAN security through synchronized update and rotation of WEP keys
GB0211644D0 (en) * 2002-05-21 2002-07-03 Wesby Philip B System and method for remote asset management
FI114602B (en) * 2002-06-18 2004-11-15 Nokia Corp A method and apparatus for programming update information on a network unit to a mobile station
US7162229B2 (en) * 2002-06-26 2007-01-09 Interdigital Technology Corporation Method and system for transmitting data between personal communication devices
US7965842B2 (en) * 2002-06-28 2011-06-21 Wavelink Corporation System and method for detecting unauthorized wireless access points
US6970698B2 (en) 2002-07-23 2005-11-29 Sbc Technology Resources, Inc. System and method for updating data in remote devices
US7606242B2 (en) * 2002-08-02 2009-10-20 Wavelink Corporation Managed roaming for WLANS
US7904897B2 (en) * 2002-08-08 2011-03-08 Rudelic John C Executing applications from a semiconductor nonvolatile memory
US7522906B2 (en) * 2002-08-09 2009-04-21 Wavelink Corporation Mobile unit configuration management for WLANs
JP2004078392A (en) * 2002-08-13 2004-03-11 Seiko Epson Corp Automatic setting of network device
US7908401B2 (en) 2002-12-12 2011-03-15 Flexiworld Technology, Inc. Method and device for wireless communication between computing devices
US20040117785A1 (en) * 2002-12-13 2004-06-17 Samsung Electronics Co., Ltd. Component download manager for a wireless mobile station and method of operation
US7046997B2 (en) * 2002-12-23 2006-05-16 Intel Corporation Trial upgrade capability for wireless handheld devices
US7890427B1 (en) * 2003-01-09 2011-02-15 Hewlett-Packard Development Company, L.P. Authentication of notifications received in an electronic device in a mobile services network
US20040176087A1 (en) * 2003-03-07 2004-09-09 Swee-Koon Fam Method for updating code stored in a memory of a portable device
KR20040084530A (en) * 2003-03-28 2004-10-06 엘지전자 주식회사 Software upgrade method for mobile communication device using infrared
WO2004093149A2 (en) 2003-04-11 2004-10-28 Flexiworld Technologies, Inc. Autorun for integrated circuit memory component
US20040229602A1 (en) * 2003-05-12 2004-11-18 Brown N. Craig Scanner with auxiliary non-volatile memory
US20040237081A1 (en) * 2003-05-19 2004-11-25 Homiller Daniel P. Methods and apparatus for generating upgraded software from initial software and software upgrade packages
US7653680B2 (en) * 2003-05-28 2010-01-26 Nec Corporation Mobile software distribution system, server, terminal and method
JP2004354628A (en) * 2003-05-28 2004-12-16 Fuji Xerox Co Ltd Removable member, image formation apparatus, server computer, computer program, and client system
US7603128B1 (en) * 2003-06-09 2009-10-13 Sprint Spectrum L.P. System and method for wireless distribution of location-based information in an enclosure
US7248895B2 (en) * 2003-06-12 2007-07-24 Nokia Corporation Controlling settings for mobile telecommunications apparatus
US20040266417A1 (en) * 2003-06-26 2004-12-30 David Janas Wirelessly programming memory devices
US20050037787A1 (en) * 2003-06-27 2005-02-17 Rosett-Wireless Corporation Wireless intelligent portable-server system (WIPSS)
US7886093B1 (en) * 2003-07-31 2011-02-08 Hewlett-Packard Development Company, L.P. Electronic device network supporting compression and decompression in electronic devices
US20050064901A1 (en) * 2003-09-24 2005-03-24 Sharp Laboratories Of America, Inc. Downloading data files to mobile communication device via an optical communication link
JP2005159905A (en) * 2003-11-27 2005-06-16 Ntt Docomo Inc Data storing device and communication terminal
US7099985B2 (en) * 2003-12-23 2006-08-29 Intel Corporation Using a processor to program a semiconductor memory
JP2005198154A (en) * 2004-01-09 2005-07-21 Seiko Epson Corp Method for setting radio communication equipment
US7904895B1 (en) 2004-04-21 2011-03-08 Hewlett-Packard Develpment Company, L.P. Firmware update in electronic devices employing update agent in a flash memory card
US20050251798A1 (en) * 2004-05-05 2005-11-10 News, Iq, Inc. System and method for inventory control and management
US8526940B1 (en) 2004-08-17 2013-09-03 Palm, Inc. Centralized rules repository for smart phone customer care
US7630330B2 (en) * 2004-08-26 2009-12-08 International Business Machines Corporation System and process using simplex and duplex communication protocols
US9379907B2 (en) * 2004-10-20 2016-06-28 Electro Industries/Gauge Tech Multichannel intelligent electronic device with advanced communication capabilities
CN100430893C (en) * 2005-02-18 2008-11-05 乐金电子(惠州)有限公司 Product upgrading system and its method using radio channel
CA2934721C (en) 2005-03-18 2018-05-01 Gatekeeper Systems, Inc. Two-way communication system for tracking locations and statuses of wheeled vehicles
US8315615B2 (en) * 2005-05-23 2012-11-20 Kyocera Corporation Wireless communication device management system and method
US20070072599A1 (en) * 2005-09-27 2007-03-29 Romine Christopher M Device manufacturing using the device's embedded wireless technology
JP4778970B2 (en) * 2005-10-13 2011-09-21 株式会社エヌ・ティ・ティ・ドコモ Mobile terminal, access control management apparatus, and access control management method
US7814479B2 (en) * 2005-12-14 2010-10-12 International Business Machines Corporation Simultaneous download to multiple targets
TW200732963A (en) * 2006-02-22 2007-09-01 Benq Corp Method for checking a configuration of a wireless communication device and related device
EP2025095A2 (en) 2006-06-08 2009-02-18 Hewlett-Packard Development Company, L.P. Device management in a network
US8752044B2 (en) 2006-07-27 2014-06-10 Qualcomm Incorporated User experience and dependency management in a mobile device
US9202184B2 (en) 2006-09-07 2015-12-01 International Business Machines Corporation Optimizing the selection, verification, and deployment of expert resources in a time of chaos
US8611859B2 (en) * 2006-09-18 2013-12-17 Samsung Electronics Co., Ltd. System and method for providing secure network access in fixed mobile converged telecommunications networks
US8055603B2 (en) 2006-10-03 2011-11-08 International Business Machines Corporation Automatic generation of new rules for processing synthetic events using computer-based learning processes
US8145582B2 (en) 2006-10-03 2012-03-27 International Business Machines Corporation Synthetic events for real time patient analysis
US8587420B2 (en) * 2006-10-24 2013-11-19 Webtech Wireless Inc. Unified vehicle parameters
US7538667B2 (en) * 2006-10-24 2009-05-26 Webtech Wireless Inc. Dynamically configurable wireless device
US8766791B2 (en) * 2006-10-24 2014-07-01 Webtech Wireless Inc. Configurable geofences with inherit aspects and use thereof in configurable wireless devices
US20080141157A1 (en) * 2006-12-06 2008-06-12 Richard Eric Helvick Over-air content shuffling for mobile electronic device
US7792774B2 (en) 2007-02-26 2010-09-07 International Business Machines Corporation System and method for deriving a hierarchical event based database optimized for analysis of chaotic events
US7970759B2 (en) 2007-02-26 2011-06-28 International Business Machines Corporation System and method for deriving a hierarchical event based database optimized for pharmaceutical analysis
US7853611B2 (en) 2007-02-26 2010-12-14 International Business Machines Corporation System and method for deriving a hierarchical event based database having action triggers based on inferred probabilities
US7761735B2 (en) * 2007-04-13 2010-07-20 International Business Machines Corporation Automated firmware restoration to a peer programmable hardware device
US7761734B2 (en) * 2007-04-13 2010-07-20 International Business Machines Corporation Automated firmware restoration to a peer programmable hardware device
US7930262B2 (en) 2007-10-18 2011-04-19 International Business Machines Corporation System and method for the longitudinal analysis of education outcomes using cohort life cycles, cluster analytics-based cohort analysis, and probabilistic data schemas
US7779051B2 (en) 2008-01-02 2010-08-17 International Business Machines Corporation System and method for optimizing federated and ETL'd databases with considerations of specialized data structures within an environment having multidimensional constraints
CA2722782A1 (en) * 2008-05-16 2009-11-19 Tomtom International B.V. Navigation device and method of updating therefor
US8135393B2 (en) * 2008-09-18 2012-03-13 Research In Motion Limited System and method for transactional application lifecycle management for mobile devices
US8188885B2 (en) * 2008-09-22 2012-05-29 Badger Meter, Inc. Wireless data programmer for electronic utility registers and meters
US20100257314A1 (en) * 2008-10-06 2010-10-07 Douglas James Gorny Remote Updating Memory
JP2010252468A (en) * 2009-04-14 2010-11-04 Sony Corp Power transmission device and method, power receiving device and method, and power transmission system
JP2010250460A (en) * 2009-04-14 2010-11-04 Sony Corp Information processing apparatus, method, and information processing system
US8417264B1 (en) 2009-05-14 2013-04-09 Spring Spectrum L.P. Method and apparatus for determining location of a mobile station based on locations of multiple nearby mobile stations
US8750145B2 (en) 2009-11-23 2014-06-10 Interdigital Patent Holdings, Inc. Method and apparatus for machine-to-machine communication registration
EP2348405A1 (en) * 2009-12-22 2011-07-27 EchoStar Global B.V. A method and system for changing software or firmware on an electronic device
JP5419168B2 (en) * 2010-09-07 2014-02-19 Necエンジニアリング株式会社 Power-saving communication device
US9158525B1 (en) * 2010-10-04 2015-10-13 Shoretel, Inc. Image upgrade
US10318877B2 (en) 2010-10-19 2019-06-11 International Business Machines Corporation Cohort-based prediction of a future event
US9792104B2 (en) * 2010-11-05 2017-10-17 FedEx Supply Chain Logistics & Electronics, Inc. System and method for flashing a wireless device
US10387135B2 (en) * 2010-11-05 2019-08-20 FedEx Supply Chain Logistics & Electronics, Inc. System and method for remotely flashing a wireless device
US9311488B2 (en) 2010-11-05 2016-04-12 Atc Logistics & Electronics, Inc. System and method for removing customer personal information from an electronic device
US20120119900A1 (en) * 2010-11-15 2012-05-17 Lewis Innovative Technologies Wireless emergency vehicle light and siren kit
KR20120129038A (en) * 2011-05-18 2012-11-28 엘지전자 주식회사 Display device, server, device authentication method
US9860674B1 (en) * 2013-09-09 2018-01-02 Sprint Communications Company L.P. Management of machine-to-machine traffic in a wireless communication network
US10510193B2 (en) 2014-08-12 2019-12-17 SVR Tracking, Inc. Method and system for geofencing of vehicle impound yards
US11516899B2 (en) 2015-05-27 2022-11-29 Electro Industries/Gauge Tech Devices, systems and methods for electrical utility submetering
US10248940B1 (en) * 2015-09-24 2019-04-02 Square, Inc. Modular firmware for transaction system
US10796317B2 (en) 2016-03-09 2020-10-06 Talon Systems Software, Inc. Method and system for auditing and verifying vehicle identification numbers (VINs) with audit fraud detection
US10896429B2 (en) 2016-03-09 2021-01-19 Talon Systems Software, Inc. Method and system for auditing and verifying vehicle identification numbers (VINs) with crowdsourcing
US11423417B2 (en) 2016-03-09 2022-08-23 Positioning Universal, Inc. Method and system for auditing and verifying vehicle identification numbers (VINs) on transport devices with audit fraud detection
US10108412B2 (en) 2016-03-30 2018-10-23 Square, Inc. Blocking and non-blocking firmware update
US10417628B2 (en) 2016-06-29 2019-09-17 Square, Inc. Multi-interface processing of electronic payment transactions
US10817869B2 (en) 2016-06-29 2020-10-27 Square, Inc. Preliminary enablement of transaction processing circuitry
US11010765B2 (en) 2016-06-29 2021-05-18 Square, Inc. Preliminary acquisition of payment information
US10762196B2 (en) 2018-12-21 2020-09-01 Square, Inc. Point of sale (POS) systems and methods with dynamic kernel selection
US10990969B2 (en) 2018-12-21 2021-04-27 Square, Inc. Point of sale (POS) systems and methods for dynamically processing payment data based on payment reader capability
US11049095B2 (en) 2018-12-21 2021-06-29 Square, Inc. Point of sale (POS) systems and methods with dynamic kernel selection
US11037378B2 (en) 2019-04-18 2021-06-15 IGEN Networks Corp. Method and system for creating driver telematic signatures

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0459344A1 (en) * 1990-05-30 1991-12-04 Alcatel Cit Software download device for a communication terminal
US5109403A (en) * 1990-05-11 1992-04-28 Goldstar Products Co., Limited System for programming of features of a mobile cellular telephone unit
WO1992020167A1 (en) * 1991-04-30 1992-11-12 Motorola, Inc. A personal communications device having remote control capability
EP0739148A2 (en) * 1995-04-21 1996-10-23 Siemens Aktiengesellschaft System for remote programming of mobile radio stations and mobile radio station therefor
EP0767426A1 (en) * 1995-10-05 1997-04-09 Siemens Aktiengesellschaft Method for programming an apparatus

Family Cites Families (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4473824A (en) * 1981-06-29 1984-09-25 Nelson B. Hunter Price quotation system
US5297191A (en) * 1990-09-28 1994-03-22 At&T Bell Laboratories Method and apparatus for remotely programming a wireless telephone set
US5581723A (en) * 1993-02-19 1996-12-03 Intel Corporation Method and apparatus for retaining flash block structure data during erase operations in a flash EEPROM memory array
US5457737A (en) * 1993-12-28 1995-10-10 At&T Corp. Methods and apparatus to verify the identity of a cellular mobile phone
US5699275A (en) * 1995-04-12 1997-12-16 Highwaymaster Communications, Inc. System and method for remote patching of operating code located in a mobile unit
US5812930A (en) * 1996-07-10 1998-09-22 International Business Machines Corp. Information handling systems with broadband and narrowband communication channels between repository and display systems
US5726636A (en) * 1996-12-05 1998-03-10 Ericsson Inc. Emergency telephone with automatic low-battery signaling

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5109403A (en) * 1990-05-11 1992-04-28 Goldstar Products Co., Limited System for programming of features of a mobile cellular telephone unit
EP0459344A1 (en) * 1990-05-30 1991-12-04 Alcatel Cit Software download device for a communication terminal
WO1992020167A1 (en) * 1991-04-30 1992-11-12 Motorola, Inc. A personal communications device having remote control capability
EP0739148A2 (en) * 1995-04-21 1996-10-23 Siemens Aktiengesellschaft System for remote programming of mobile radio stations and mobile radio station therefor
EP0767426A1 (en) * 1995-10-05 1997-04-09 Siemens Aktiengesellschaft Method for programming an apparatus

Cited By (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2000029944A1 (en) * 1998-11-16 2000-05-25 Cardsoft International Pty Limited Method and apparatus for programming computing devices
WO2000072139A2 (en) * 1999-05-20 2000-11-30 Transcept, Inc. Broadcast download technique
WO2000072139A3 (en) * 1999-05-20 2001-03-22 Transcept Inc Broadcast download technique
GB2363946B (en) * 1999-08-11 2003-07-23 Nec Corp Mobile communications system for updating a program stored in a mobile terminal
GB2363946A (en) * 1999-08-11 2002-01-09 Nec Corp Remote updating of a program in a mobile communication unit
GB2371724A (en) * 1999-08-11 2002-07-31 Nec Corp System for updating a program stored in a mobile communication terminal
GB2371724B (en) * 1999-08-11 2003-02-19 Nec Corp Mobile communication system for updating a program stored in a mobile terminal
WO2001065876A1 (en) * 2000-02-29 2001-09-07 Qualcomm Incorporated Programmable mobile communications terminal with randomized off-peak transmissions
EP1341086A1 (en) * 2000-11-29 2003-09-03 Sony Corporation Information processing terminal
EP1341086A4 (en) * 2000-11-29 2007-10-24 Sony Corp Information processing terminal
US8384525B2 (en) 2006-05-15 2013-02-26 Nokia Corporation Contactless programming and testing of memory elements
US9496925B2 (en) 2011-09-30 2016-11-15 Nokia Technologies Oy Method, apparatus, and computer program product for remote wireless powering and control of an electronic device
CN104680770A (en) * 2013-11-29 2015-06-03 红板凳科技股份有限公司 Infrared remote controller capable of remotely updating control code

Also Published As

Publication number Publication date
CN1269951A (en) 2000-10-11
BR9810583A (en) 2000-09-05
KR20010021559A (en) 2001-03-15
EP0995326B1 (en) 2006-04-05
EP0995326A1 (en) 2000-04-26
JP2001510315A (en) 2001-07-31
AU752584B2 (en) 2002-09-26
AU7985598A (en) 1999-02-08
US5974312A (en) 1999-10-26
EE200000021A (en) 2000-10-16
KR100485017B1 (en) 2005-04-25
DE69834114D1 (en) 2006-05-18

Similar Documents

Publication Publication Date Title
US5974312A (en) System and method for updating a memory in an electronic device via wireless data transfer
KR0133200B1 (en) Communication receiver providing displayed operating
US4839628A (en) Paging receiver having selectively protected regions of memory
US6677852B1 (en) System and method for automatically controlling or configuring a device, such as an RFID reader
US5522087A (en) System for selectively operating in different modes depending upon receiving signal from a host computer within a time window upon power up
US20060065730A1 (en) RFID system having a field reprogrammable RFID reader
US9691207B2 (en) Electronic lock with user interface
CN100416500C (en) Methods and apparatus for generating upgraded software from initial software and software upgrade packages
EP1860899B1 (en) Mobile station, system and management server for over the air mobile station management
US6151657A (en) Processor with embedded in-circuit programming structures
JP4638049B2 (en) System and method for independently downloading functions to a set of storage locations in a wireless communication device
CN109414969B (en) Tire pressure monitoring sensor for realizing rapid configuration and software update
CN106445578A (en) Remote hardware upgrading method and apparatus, and wireless temperature and humidity monitor
CA2475303A1 (en) System and method for configuring a home appliance communications network
US20050034116A1 (en) Control of programming electronic devices
US5379404A (en) Plug code for automatically recognizing and configuring both non-microprocessor and microprocessor based radio frequency communication devices
WO2000019733A2 (en) Method and apparatus for a unit locked against use until unlocked and/or activated on a selected network
US5295063A (en) Data acquisition system having setup duplication capability
AU8551901A (en) System and method for updating a memory in an electronic device via wireless data transfer
US5553299A (en) Programming/reprogramming a point to point communication apparatus
US6842820B2 (en) Processor with embedded in-circuit programming structures
IL168562A (en) Method and apparatus for transferring information to a remote control
US20030190935A1 (en) Access control method utilizing a key battery
EP1008041B1 (en) Processor with embedded in-circuit programming structures
US7610063B2 (en) System for determining information for circuit packs connected by a single line bus

Legal Events

Date Code Title Description
WWE Wipo information: entry into national phase

Ref document number: 98809002.3

Country of ref document: CN

AK Designated states

Kind code of ref document: A1

Designated state(s): AL AM AT AU AZ BA BB BG BR BY CA CH CN CU CZ DE DK EE ES FI GB GE GH GM GW HU ID IL IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MD MG MK MN MW MX NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT UA UG UZ VN YU ZW

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): GH GM KE LS MW SD SZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA GN ML MR NE SN TD TG

DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
121 Ep: the epo has been informed by wipo that ep was designated in this application
WWE Wipo information: entry into national phase

Ref document number: 1020007000117

Country of ref document: KR

WWE Wipo information: entry into national phase

Ref document number: 1998930470

Country of ref document: EP

WWE Wipo information: entry into national phase

Ref document number: 79855/98

Country of ref document: AU

WWP Wipo information: published in national office

Ref document number: 1998930470

Country of ref document: EP

REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

NENP Non-entry into the national phase

Ref country code: CA

WWP Wipo information: published in national office

Ref document number: 1020007000117

Country of ref document: KR

WWG Wipo information: grant in national office

Ref document number: 79855/98

Country of ref document: AU

WWG Wipo information: grant in national office

Ref document number: 1020007000117

Country of ref document: KR

WWG Wipo information: grant in national office

Ref document number: 1998930470

Country of ref document: EP