throbber
United States Patent [191
`Beding?eld et a1.
`
`llllll llllllll Ill lllll lllll lllll lllll lllll ||||l l||l| l|||| llllll Ill lllll llll
`5,537,654
`Jul. 16, 1996
`
`US005537654A
`[11] Patent Number:
`{45] Date of Patent:
`
`[54] SYSTEM FOR PCMCIA PERIPHERAL TO
`EXECUTE INSTRUCTIONS FROM SHARED
`MEMORY WHERE THE SYSTEM RESET
`SIGNAL CAUSES SWITCHING BETWEEN
`MODES OF OPERATION BY ALERTING
`THE STARTING ADDRESS
`
`[75] Inventors: John Beding?eld, Largo, Fla; Craig
`Matthews, Long Beach, N .J .
`
`[73] Assignee: AT&T Corp., Murray Hill, NY.
`
`[21] Appl. No.: 64,304
`[22] Filed:
`May 20, 1993
`
`[51] Int. Cl? ...................................................... .. G06F 3/00
`[52] 11.8. C1. ........................ .. 395/834; 395/500; 395/828;
`395/497.01; 364/160; 364/2281; 364/238.2;
`364/243
`[58] Field of Search ................................... .. 395/275, 500,
`395/200, 834, 828, 497.01
`
`[56]
`
`References Cited
`
`U.S. PATENT DOCUMENTS
`
`4,156,907
`4,459,662
`4,519,032
`4,611,202
`
`5/1979 Rawlings et a1.
`7/1984 Skelton et al.
`5/1985 Mendel] ......... ..
`9/1986 DiNitto et al.
`
`364/200
`364/200
`364/200
`340/724
`
`4,809,269
`
`2/1989 Gulick . . . . . . . . . .
`
`. . . . .. 370/94
`
`4/1989 Letwin
`4,825,358
`3/1993 Weiss et al
`5,195,130
`6/1994 Gamey
`5,319,751
`6/1994 Phillips et a1.
`5,321,828
`5,353,432 10/1994 Riehek et a1.
`
`364/200
`379/98
`395/200
`.. 395/500
`395/500
`
`OTHER PUBLICATIONS
`
`Winn Rosch, PCMCIA: The Expansion System of the Future
`PC Magazine, Jan. 26, 1993, pp. 321 to 326.
`European Search Report dated Sep. 9, 1994, regarding EPO
`Application No. EP 94 30 3539.
`EP-A-O 464433 ?led Jun. 15, 1991. Listed as particularly
`relevant if taken alone, as to claims 1-11, 15—18 on Euro
`pean Search Report regarding EPO Application EP 94 30
`3539.
`
`EP—A—0 268285 ?led Nov. 19, 1987. Listed as technological
`background in European Search Report regarding EPO
`Application EP 94 30 3539.
`
`EP-A-0-536 793 ?led Oct. 9, 1992. Listed as technological
`background in European Search Report regarding EPO
`Application EP 94 30 3539.
`
`“Reprogrammability Eases PCMCIA Designs” Publication:
`Electronic Design; publication date Apr. 18, 1994. Listed as
`intermediate document and technological background in
`European Search Report regarding EPO Application EP 94
`30 3539.
`“Microprogram Loading System”, Patent Abstracts of
`Japan, Publication No. JP62025353, publication date Mar. 2,
`1987, Genma Hideaki et al., lnt. Class: G06F 13/00; G06F9/
`24. Listed as technological background in European Search
`Report regarding EPO Application EP 94 30 3539. Trans
`lation: Abstract only.
`
`Primary Examiner-Thomas C. Lee
`Assistant Examiner-Rehana Perveen Krick
`Attorney, Agent, or FirmvJoseph J. Opalach
`
`ABSTRACT
`[57]
`A “Personal Computer Memory Card International Associa
`tion” (PCMCIA) peripheral, e.g., a modern, incorporates a
`shared memory interface to a personal computer. This shared
`memory interface provides the capability to easily program
`the PCMCIA peripheral either in the factory or in the ?eld.
`In addition, the shared memory interface removes the
`requirement of having a resident “boot-up” code in the
`PCMCIA peripheral. Finally, the shared memory interface
`provides the capability to transfer user data from the per
`sonal computer, i.e., data terminal, to the PCMCIA modern
`at a higher data transfer rate than is currently available via
`the modem’s universal asynchronous receive/transmit
`(UART) integrated circuit.
`
`4 Claims, 3 Drawing Sheets
`
`mitten/cg?F
`
`HT
`
`RUN/ABLE SlORLGi llNll Z15
`
`BLACKBERRY Ex. 1020, page 1
`
`

`

`US. Patent
`
`Jul. 16, 1996
`
`Sheet 1 of 3
`
`5,537,654
`
`F l G. 1
`
`r1OO _
`
`_
`
`_
`
`_
`
`_
`
`_
`
`_
`
`_
`
`_
`
`_
`
`_
`
`I
`
`I
`
`.
`
`.
`
`1
`
`-
`
`,
`
`'
`
`.
`
`CPU
`
`HOST ACCESS
`
`CPU mm 144
`
`cE171
`
`7
`
`CEI72
`
`15%
`CHIP ENABLE
`E ROuT1NGLOG1c
`i
`
`15"
`‘521
`
`5
`141
`
`1401 fm WAIT ENABLE
`CONTROL LOGM: ~ ‘73
`Wm
`M2
`A»
`
`PCMC'A BUS '2‘
`
`'
`
`12o
`
`170
`I
`
`<:
`
`CPU
`
`'
`
`-
`
`160
`
`I
`
`GONTROL
`
`PRocEssoR .
`
`AB/US175
`
`PROGRAM MEMORY
`
`<2:
`
`:
`
`:
`
`_
`
`CE
`f
`
`-
`
`'
`
`.
`
`'
`
`I
`
`v
`
`1
`SHARED MEMORY
`CE
`135 PCMCIA
`BUFFER J36
`“ ATTRIBUTE
`CONTROL
`REGION
`PROGRAM “157
`NORMAL
`OowNLOAO
`OPERAT1NG OPERATING
`MOOE
`MOOE
`
`130
`
`
`
`i PcMclA' :—:-—:—: _ [ PCMCIA GONNEGTOR ~
`
`
`
`
`
`
`
`cE(MOsT) _ _
`
`-
`
`_
`
`'
`
`f
`
`_
`
`|NTER|EACE
`1°
`
`PCMCIA SLOT
`HOST CPU
`
`P22?!
`~27°
`
`?FLOPPY 01511 216
`
`200
`
`REMOVABLE sTORAGE UNIT 215
`
`F I G. 2
`
`NORMAL OPERATING MOOE
`DOWNLOAD OPERATING MODE
`
`LINE 151
`0E1
`CEZ
`
`LINE 152
`C£2
`CE1
`
`BLACKBERRY Ex. 1020, page 2
`
`

`

`US. Patent
`
`Jul. 16, 1996
`
`Sheet 2 of 3
`
`5,537,654
`
`FIG. 3
`
`CPU 270
`
`PCMCIA PERIPHERAL MAP
`
`DOWNLOAD MODE LOCATION
`
`RESET LOCATION
`
`SHARED MEMORY I30
`
`FIG. 4
`
`ACCESS RESET MEMORY LOCATION on PCMCIA MODEM 100 I405
`
`WRITE A CONTROL PROGRAM TO SHARED MEMORY REGION 137 I410
`
`II
`
`II
`ACCESS DOWNLOAD MODE MEMORY LOCATION
`
`I415
`
`I
`TRANSFER NEW COMPUTER PROGRAM TO BUFFER 136
`
`I420
`
`II
`ACCESS RESET LOCATION ON PCMCIA MODEM IOO
`
`f 425
`
`BLACKBERRY Ex. 1020, page 3
`
`

`

`US. Patent
`
`Jul. 16, 1996
`
`Sheet 3 of 3
`
`5,537,654
`
`FIG. 5
`
`CPU I70 BEGINS
`SHARED MEMORY ACCESS
`
`505
`'
`--—--> ACTIVATE wAII ENABLE SIGNAL ~
`
`515
`I
`DISABLE WAIT ENABLE
`SIGNAL AND WAIT FOR
`TIME; I
`
`HOST
`ACCESS
`SIGNAL
`INACTIVE
`v
`ACCESS SHARED ,320
`MEMORY
`
`530
`I
`DISABLE WAIT ENABLE N
`
`i)
`
`BLACKBERRY Ex. 1020, page 4
`
`

`

`5,537,654
`
`1
`SYSTEM FOR PCMCIA PERIPHERAL TO
`EXECUTE INSTRUCTIONS FROM SHARED
`MEMORY WHERE THE SYSTEM RESET
`SIGNAL CAUSES SWITCHING BETWEEN
`MODES OF OPERATION BY ALERTING
`THE STARTING ADDRESS
`
`BACKGROUND OF THE INVENTION
`
`2
`of ?ash memory. This computer program includes the boot
`code and the operating program. When the modem‘s CPU
`receives a command from the host to change the operating
`program via one of the serial ports, the modem’s CPU
`executes a download program contained in the active bank
`of ?ash memory. This download software ?rst erases the
`non-active bank of ?ash memory and then copies the
`received data from one of the serial data ports into the
`non-active bank. This received data is the new computer
`program, which contains new boot code and the new oper
`ating program. At the conclusion of this download mode, the
`modem’s CPU toggles a non-volatile switch so that it will
`boot after a reset from the newly updated bank of ?ash
`memory, i.e., it switches which bank of ?ash memory is the
`active bank. This approach is disclosed in the co-pending,
`commonly assigned US. patent application of Hecht et a1.
`entitled “Apparatus and Method for Downloading Pro
`grams,” Ser. No. 07/880,257, ?led on May 8, 1992, now
`pending.
`As described above, although a ?ash memory upgrade for
`a PCMCIA modern via one of the serial ports is an advan
`tageous approach, there are several limitations. One is that
`during manufacture the boot block must be programmed into
`the ?ash memory prior to soldering the ?ash memory onto
`the printed circuit board. This adds cost to the manufacturing
`process of the PCMCIA modem. In addition, if the boot
`block is somehow erased or corrupted and power to the
`PCMCIA modem is lost, there is no recovery mechanism
`other than removing and replacing the ?ash memory. Fur
`thermore, the size of the boot block is ?xed (typically 16K
`bytes), which presents constraints on the functionality of the
`boot block. In addition, the boot block similarly constrains
`the size of the PCMCIA modem‘s operating program since
`a portion of the ?ash memory is dedicated to the boot block.
`Finally, the speed of any field upgrade is limited because of
`the use of a serial data port.
`
`SUMMARY OF THE INVENTION
`
`This invention eliminates all of the above-mentioned
`limitations by providing a method and apparatus for loading
`a ?ash memory after it is a part of a completed PCMCIA
`modem assembly. In accordance with the principles of the
`invention, a PCMCIA peripheral incorporates a shared
`memory interface to a host computer via the PCMCIA
`connector. This shared memory provides the capability to
`easily load or change the computer program of the PCMCIA
`peripheral from the host computer without requiring either
`the a priori presence of a dedicated boot block in the ?ash
`memory or the use of a serial data port.
`In an embodiment of the invention, a PCMCIA modern
`includes a CPU, memory, and a shared memory that is
`coupled to a personal computer (PC) via the PCMCIA
`connector. During normal operation, the CPU accesses and
`executes any computer program stored in the memory. A
`?eld upgrade or initial factory load is performed in the
`following manner. First, the PC applies a reset to the
`PCMCIA modem. During this reset, the PC stores a control
`program in the shared memory. After storing the control
`program, the PC alters the memory map of the PCMCIA
`modem so that after the reset the CPU executes the control
`program stored in the shared memory. This control program
`further provides the ability to the PCMCIA modem to
`transfer a new computer program via the shared memory to
`the memory of the PCMCIA modem, i.e., the control pro
`gram is the boot block software. After transferring the new
`computer program, the PC again initiates a reset of the
`
`The present invention relates to data communications
`equipment and, more particularly, to a modem having a
`“Personal Computer Memory Card lntemational Associa
`tion” interface.
`The “Personal Computer Memory Card International
`Association” (PCMCIA) interface de?nes the physical size
`and the electrical interconnection for a class of computer
`peripherals, i.e., PCMCIA peripherals. Generally, the size of
`a PCMCIA peripheral is approximately that of a “credit
`car
`Each credit card size PCMClA peripheral electrically
`interconnects via a PCMCIA electrical connector to a “host
`computer,” which is typically a “notebook” size personal
`computer (PC). PCMCIA peripherals like memory, modems,
`fax, hard disks, etc., are currently available.
`Like their more conventional cousins, a PCMCIA modem
`is a complex piece of equipment that comprises specialized
`microprocessor circuitry. For example, a PCMCIA modem
`typically includes a general-purpose microprocessor (CPU),
`memory, a telephone line interface to the Public Switched
`Telephone Network (PSTN), and a high-speed digital signal
`processor for processing the respective communications
`signal in both the transmit and receive directions. The
`functionality of the PCMCIA modem is provided by the
`CPU’s execution of a computer program, i.e., the “operating
`program,” that resides in the PCMCIA modem’s memory.
`This memory is usually “?ash memory,“ which is a non
`volatile memory that is ?eld-programmable by the modem’s
`CPU.
`An advantage of the ?ash memory is that it allows ?eld
`upgrades of the modem’s operating program for either
`providing new features or “bug” ?xes. In order to perform
`a field upgrade a part of the ?ash memory is reserved for a
`“boot block” computer program. This part of the ?ash
`memory is write-protected so that it retains its data, i.e., the
`boot block, even when the rest of the ?ash memory is erased
`and reprogrammed. The boot block includes computer soft
`ware for booting-up the modem, e.g., after application of
`power, and for loading the remainder of the ?ash memory
`with the operating program.
`A ?eld upgrade of the modem’s ?ash memory is per
`formed over one of the serial data ports, either the data
`communications port or the data terminal port. First, the
`modem‘s CPU receives a command to reload the operating
`program from a “host” coupled to one of the serial ports.
`Then the modem’s CPU executes that portion of the boot
`block associated with loading the ?ash memory. This part of
`the software ?rst erases the remaining portion of the ?ash
`memory and then receives the new operating program via
`one of the serial ports and writes the new operating program
`to the ?ash memory.
`An alternative approach that does not require a non
`writable boot block in the ?ash memory is provided by
`AT&T Paradyne‘s 3800 modem, which comprises an inde
`pendent “upper bank” and “lower bank” of ?ash memory.
`The modem’s CPU can boot from either bank. The modem’s
`CPU begins operation by executing the computer program
`stored in one of the ?ash memory banks, i.e., the active bank
`
`20
`
`30
`
`50
`
`60
`
`BLACKBERRY Ex. 1020, page 5
`
`

`

`5,537,654
`
`3
`PCMCIA modem that returns the memory map of the
`PCMCIA modem to normal such that after the reset the CPU
`executes the new computer program stored in the PCMCIA
`modem‘s memory.
`In accordance with a feature of the invention, neither the
`?eld upgrade nor the initial program load in the factory
`require any boot block software to be resident in the PCM
`CIA card.
`Another feature of the invention uses the shared memory
`interface to transfer user data from the personal computer,
`i.e., data terminal, to the PCMCIA modern. This results in a
`higher data transfer rate than is currently available via the
`on-board universal asynchronous receive/transmit (UART)
`integrated circuit that couples the modem to any terminal
`equipment.
`
`10
`
`BRIEF DESCRIPTION OF THE DRAWING
`
`FIG. 1 is a block diagram of a portion of a PCMCIA
`20
`modem embodying the principles of the invention;
`FIG. 2 is a table implemented by chip enable routing logic
`150 of FIG. 1;
`FIG. 3 illustrates a PCMCIA peripheral map for host
`computer 200 of FIG. 1;
`FIG. 4 is a flow diagram of a method embodying the
`principles of the invention; and
`FIG. 5 is a ?ow diagram of a memory arbitration method
`performed by CPU 170 of FIG. 1.
`
`25
`
`30
`
`DETAILED DESCRIPTION
`
`FIG. 1 shows a portion of a PCMCIA modem that
`embodies the inventive concepts of this invention. As
`shown, host computer 200 includes PCMCIA slot 220 for
`receiving PCMCIA modern 100, host CPU 270, and remov
`able storage unit 215 for receiving ?oppy disk 216. PCM
`CIA modem 100 includes CPU 170, program memory 160,
`shared memory 130, chip enable routing logic 150, control
`logic 140, and PCMCIA connector 120. CPU 170 is a
`microprocessor-based central processing unit which oper
`ates on, or executes, program data stored in program
`memory 160 or shared memory 130 (discussed below) via
`control processor bus 175, which provides control, address
`and data signals (not shown). PCMCIA modern 100 is
`physically and electrically coupled to host computer 200 via
`PCMCIA interface 10. The latter includes PCMCIA con
`nector 120 of PCMCIA modem 100 and PCMCIA slot 220
`of host computer 200. For the purposes of this example,
`program memory 160 is a ?ash memory. The program data
`stored in program memory 160 is hereinafter referred to as
`the operating computer program. This operating computer
`program provides the modem functionality for transmitting
`and receiving data via a communications facility (not
`shown).
`It is assumed that CPU 170 includes appropriate address
`decode and chip enable logic. Two chip enable signals, CE1
`and CE2, are provided by CPU 170 on lines 171 and 172,
`respectively. These chip enable signals are used to select
`either program memory 160 or shared memory 130. Nor
`mally, these chip enable signals would be coupled directly to
`these memory devices. However, in accordance with the
`principles of the invention, CEl and CB2 are applied to chip
`enable routing logic 150, which provides chip enable signals
`to program memory 160 and shared memory 130 as a
`function of the mode of operation of PCMCIA modem 100.
`This is shown in FIG. 2. For the purposes of this example it
`
`35
`
`45
`
`50
`
`55
`
`65
`
`4
`is assumed that there are two modes of operation: a “normal
`mode” and a “download mode.” During a normal mode, chip
`enable routing logic 150 provides CEl to program memory
`160, via line 151; and provides CE2 to shared memory 174],
`via line 152.
`After a CPU reset signal is applied to CPU 170 via line
`144, CPU 170 applies CE1 to chip enable routing logic 150.
`As is known in the art, after application of a reset signal, a
`micro-processor starts execution at a known starting address
`location. For the purposes of this example, it is assumed that
`this prede?ned location is mapped to an address range
`associated with CEl. The CPU reset signal on line 144 is
`provided by control logic 140 either as a result of RESET
`signal (not shown) de?ned in the PCMCIA interface being
`asserted, e.g., during a power-up condition; or as a result of
`a memory access by host CPU 270 (discussed below). In the
`normal mode of operation, as shown in FIG. 2, CEl is routed
`to program memory 160 so that CPU 170 executes the
`operating computer program. In this normal mode, CPU 170
`accesses shared memory 130 by providing CE2 on line 152
`via chip enable routing logic 150.
`Shared memory 130 is also known as a “dual port ram”
`and has two sets of address, data, and control lines. One set
`is used to interface to PCMCIA bus 121 and the other set is
`used to interface to control processor bus 175. In accordance
`with the principles of the invention, shared memory 130 is
`put to di?'erent use depending on the mode of operation. As
`shown in FIG. 1, during the normal mode of operation,
`shared memory 130 comprises PCMCIA attribute region
`135, which includes the software de?nable Card Information
`Structure, Pin Replacement Register, Con?guration Option
`Register, Card Con?guration and Status Register in accor
`dance with the PCMCIA interface standard. However, dur
`ing the download mode of operation (discussed below),
`shared memory 130 includes region 136, which is a buffer
`that stores data received from host CPU 270 of host com—
`puter 200; and region 137, which stores a control program
`provided by host CPU 270 and subsequently executed by
`CPU 170.
`In accordance with the principles of the invention, the
`other mode of operation—~the download mode—directs
`CPU 170 to begin execution of program data from shared
`memory 130 after the application of a CPU reset signal on
`line 144. In particular, in the download mode of operation,
`chip enable routing logic 150 switches the CE1 signal from
`lead 151 to lead 152, and conversely, switches the CB2
`signal from lead 152 to lead 151. As a result, CPU 170 now
`executes instructions stored in shared memory 130 after
`exiting from a reset condition.
`Whether or not the download mode of operation is entered
`by PCMCIA modern 100 is under the control of host CPU
`270. It should be noted that under the PCMCIA standard,
`portions, or all, of PCMCIA modem 100 is mapped into a
`part of the PCMCIA peripheral space of host CPU 270. An
`illustrative PCMCIA peripheral map of PCMCIA 100 as
`viewed by host CPU 270 is shown in FIG. 3. An illustrative
`method for use in host CPU 270 for switching PCMCIA
`modem 100 to the download mode is shown in FIG. 4. Host
`CPU 270 affects a reset of CPU 170 in step 405 by asserting
`the RESET signal of the PCMCIA interface, or by writing a
`particular data value to a particular memory location on
`PCMCIA modem 100 that is associated with resetting PCM
`CIA modem 100, i.e., a “reset location” as shown in FIG. 3.
`In this example, this reset location is within the shared
`memory region and during normal operation is associated
`with the Con?guration Option Register, which is a pan of
`PCMCIA attribute region 135 as de?ned by the PCMCIA
`
`BLACKBERRY Ex. 1020, page 6
`
`

`

`5,537,654
`
`20
`
`25
`
`35
`
`5
`standard. One of the de?ned data bits of the Con?guration
`Option Register is the “SRESET” bit. CPU 270 affects a
`reset of PCMCIA modem 100 by setting the “SRESET” bit,
`which is d7, equal to a logical one. Control logic 140 of
`PCMCIA modem 100 detects this memory write to the reset
`location and in response thereto generates a CPU reset signal
`on line 144 to CPU 170.
`While the CPU reset signal is active CPU 170 is inactive,
`i.e., performs no memory accesses. Host CPU 270 then
`writes a control program to shared memory region 137 in
`step 410. After step 410, host CPU 270 switches the mode
`of operation of PCMCIA modem 100 by accessing in a
`particular way a respective prede?ned memory location
`associated with the download mode in step 415. In this
`example, host CPU 270 performs three consecutive writes of
`a prede?ned data value to the download mode location.
`Control logic 140 of PCMCIA modem 100 detects these
`consecutive memory accesses and compares the data values
`being written by CPU 270 to the prede?ned data value. If the
`data values being written equal the prede?ned data value,
`control logic 140 applies a control signal on line 142 to chip
`enable routing logic 150. The latter alters the routing of the
`above-mentioned chip enable signals as shown in FIG. 2 for
`the download mode. It is assumed that steps 410 and 415
`occur while the above-mentioned reset signal on line 144 is
`still active. In other words, it is assumed that control logic
`140 generates a CPU reset signal of sufficient width to
`provide the time for host CPU 270 to perform steps 410 and
`415. If host CPU 270 does not switch the mode of operation
`within the period of time when the CPU reset signal is
`active, control logic 140 blocks any subsequent attempts to
`switch modes and PCMCIA modem 100 simply continues to
`remain in the normal mode. In other words, control logic 140
`provides a “lockout mechanism” that prevents inadvertent
`switching of chip enables. This lockout mechanism forces
`PCMCIA modem 100 to default to the normal mode after a
`CPU reset signal is applied unless host CPU 270 accesses in
`the prescribed manner the download mode location. Alter
`natively, to avoid this time constraint on host CPU 270, the
`latter can make use of the SRESET bit for turning on and off
`the CPU reset signal.
`In the download mode and after removal of the CPU reset
`signal, CPU 170 executes the control program in shared
`memory 130. Host CPU 270 men transfers data to shared
`memory region 136 in step 420. This data represents por
`tions of the new computer program to be placed into
`program memory 160. The control program, when executed
`by CPU 170, transfers the data placed in shared memory
`region 136 by host CPU 270 to program memory 160—thus
`changing the operating computer program executed by CPU
`170 during the normal mode of operation. It should be noted
`that no boot block software is required to be resident in the
`PCMCIA peripheral other than the temporary control pro
`gram provided by host CPU 270 in order to accomplish this
`download, irrespective of whether this download is a part of
`a ?eld upgrade or the initial program load in a factory. It is
`assumed that the control program executed by CPU 170
`includes a “hand-shaking” procedure for coordinating the
`transfer of data blocks from host CPU 270 to program
`memory 160. For example, after the data in shared memory
`region 136 is written by CPU 170 to a portion of program
`memory 160, CPU 170 writes to a prede?ned “?ag” location
`of shared memory 130. This ?ag, when read by host CPU
`270, indicates to host CPU 270 to write the next portion of
`the operating computer program to shared memory region
`
`6
`CPU 270 again resets PCMCIA modem 100 in step 425.
`With the application of the CPU reset signal, control logic
`140 switches PCMCIA modem 100 back to the normal mode
`as part of the lock-out mechanism described above. As a
`result, control logic 140 alters the routing of the above
`mentioned chip enable signals as shown in FIG. 2 for the
`normal mode. In the normal mode and after removal of the
`CPU reset signal, CPU 170 executes the new operating
`computer program now stored in program memory 160.
`As can be seen from the above description, when trans‘
`ferring data from the buffer located within shared memory
`region 136 to program memory 160, both CPU 170 and host
`CPU 270 are accessing shared memory 130. For example, at
`the same time CPU 170 is reading program data from shared
`memory region 137—host CPU may be attempting to write
`data to the buffer located within shared memory region 136.
`As a result, a memory contention scheme is required to
`arbitrate between CPU 170 and host CPU 270 when they
`attempt to access shared memory 130 simultaneously.
`In this example, the memory contention scheme is imple
`mented by a combination of hardware, represented by con
`trol logic 140, a software protocol, and the PCMCIA de?ned
`WAIT signal on line 142. Although shown as a separate
`signal for convenience, it should be realized that the WAIT
`signal on line 142 is a subset of PCMCIA bus 121.
`Control logic 140 monitors PCMCIA bus 121 to detect
`any shared memory accesses by host CPU 270. When host
`CPU 270 begins a shared memory access to PCMCIA
`modem 100, control logic 140 activates the host access
`signal on line 141, which is received by CPU 170. In
`addition, CPU 170 provides a wait enable signal on line 173,
`which is received by control unit 140. If the wait enable
`signal is active, control unit 140 enables the generation of
`the WAIT signal on line 142 in response to any subsequent
`shared memory access by host CPU 270. As is known in the
`art, when the PCMCIA WAIT signal on line 142 is active,
`host CPU 270 inserts wait states in the current memory
`access. Conversely, if the wait enable signal is inactive,
`control unit 140 disables the generation of this WAIT signal
`so that no additional wait states are inserted into a shared
`memory access of host CPU 270. It should be noted that the
`PCMCIA speci?cation requires that accesses by host com
`puter 270 via PCMCIA connector 120 be completed with no
`more than a 12 microsecond delay.
`FIG. 5 shows a ?ow diagram for a method used by CPU
`170 for implementing a software protocol to control the
`generation of the wait enable signal on line 173. Whenever
`CPU 170 accesses shared memory, CPU 170 ?rst activates
`the wait enable signal on line 173 in step 505. CPU 170 then
`reads, or samples, the host access signal on line 141 in step
`510. This allows CPU 170 to check if host CPU 270 has
`already begun an access to shared memory. If the host access
`signal is active, then the wait enable signal on line 173 is
`disabled and CPU 170 itself waits for a predetermined
`period of time, T, in step 515 before returning to step 505.
`The latter step is important because host CPU 270 may
`ignore the WAIT signal on line 141 if it was enabled after the
`wait recognition window of host CPU 270. This may occur
`because of the asynchronous relationship of any shared
`memory accesses by the two processors. However, if the
`host access signal is inactive, CPU 170 accesses shared
`memory in step 520 and then disables the wait enable signal
`on line 173 in step 530.
`As described above and in accordance with the principles
`of the invention, host CPU 270 is able to change the
`operating computer program stored in PCMCIA modem 100
`
`45
`
`50
`
`55
`
`After host CPU 270 has ?nished downloading the new
`operating computer program to PCMCIA modem 100, host
`
`BLACKBERRY Ex. 1020, page 7
`
`

`

`5,537,654
`
`10
`
`7
`and thereby provide an easy means to update or change the
`functionality of PCMCIA modem 100. As shown in FIG. 1,
`the program data executed by PCMCIA modem 100 can be
`provided to host CPU 270 via ?oppy disk 216. Indeed, any
`type of programs for PCMCIA modern 100 can be easily
`provided. For example, ?oppy disk 216 can supply a diag
`nostic testing program, which when downloaded by host
`CPU 270 allows PCMCIA modem 100 to perform a series
`of diagnostic tests.
`In addition, the use of shared memory 130 in PCMCIA
`modem 100 also provides other improvements to system
`operation. For example, since the PCMCIA peripheral is a
`modern, host computer 200 is a data terminal. As is known
`in the art, host CPU 270 transfers data for transmission over
`a data communications channel (not shown) by writing data
`in parallel to a UART (not shown) of PCMCIA modem 100.
`This UART then converts the data to a serial form to
`simulate the serial data transmission from the data terminal.
`Consequently, the PCMCIA modem again converts the
`serial data stream from its UART back to a parallel form
`again. Unfortunately, this process tends to limit the speed of
`any data transfer. However, in accordance with the inven
`tion, shared memory 130 can be used to transfer user data
`between the data terminal and the modem at a a higher data
`transfer rate. This is accomplished by dedicating a portion of
`shared memory 130 as a bu?’er for directly transferring data
`from host computer 200 to PCMCIA modern 100.
`In addition, in the prior art, the PCMCIA attribute struc
`ture is typically pre-de?ned and non-changeable, e.g., a
`30
`read-only memory (ROM) is used to provide the PCMCIA
`attribute structure. However, the use of shared memory 130
`allows for a software de?nable PCMCIA card information
`structure that can be dynamically altered by CPU 170.
`The foregoing merely illustrates the principles of the
`invention and it will thus be appreciated that those skilled in
`the art will be able to devise numerous alternative arrange
`ments which, although not explicitly described herein,
`embody the principles of the invention and are within its
`spirit and scope.
`For example, although the inventive concept was
`described in terms of utilizing ?ash memory, any non
`volatile programmable RAM can be used. In fact, even
`
`8
`volatile RAM can be used as long as the PCMCIA peripheral
`is properly initialized by the host computer on power-up of
`the system.
`We claim:
`1. Apparatus comprising:
`a PCMCIA connector;
`a processor responsive to a processor reset signal for
`providing a starting address for accessing a memory
`location to execute at least one instruction stored
`therein;
`a ?rst memory;
`a second memory that is shared with a host computer via
`the PCMCIA connector and which stores PCMCIA
`attribute information in a ?rst mode; and
`control circuitry coupled to a parallel data bus of the
`PCMCIA connector responsive to a system reset signal
`received from the PCMCIA connector for a:) providing
`the processor reset signal to the processor, and b)
`switching between the ?rst and a second mode of
`operation;
`where the system reset signal causes the control circuitry
`to alter the starting address provided by the processor
`in such a way that the memory location is located
`within the ?rst memory in the ?rst mode of operation,
`and in the second mode of operation, the system reset
`signal causes the control circuitry to alter the starting
`address provided by the processor means in such a way
`that the memory location is located within the second
`memory.
`2. The apparatus of claim 1 further including'the host
`computer.
`3. The apparatus of claim 2 wherein the a system reset
`signal is at least one memory access by the host computer to
`the second memory via the PCMCIA connector.
`4. The apparatus of claim 2 wherein the host computer
`includes a removable storage means for receiving from a
`disk inserted therein a plurality of instructions that is copied
`to the second memory.
`
`* *
`
`* * *
`
`20
`
`25
`
`35
`
`BLACKBERRY Ex. 1020, page 8
`
`

This document is available on Docket Alarm but you must sign up to view it.


Or .

Accessing this document will incur an additional charge of $.

After purchase, you can access this document again without charge.

Accept $ Charge
throbber

Still Working On It

This document is taking longer than usual to download. This can happen if we need to contact the court directly to obtain the document and their servers are running slowly.

Give it another minute or two to complete, and then try the refresh button.

throbber

A few More Minutes ... Still Working

It can take up to 5 minutes for us to download a document if the court servers are running slowly.

Thank you for your continued patience.

This document could not be displayed.

We could not find this document within its docket. Please go back to the docket page and check the link. If that does not work, go back to the docket and refresh it to pull the newest information.

Your account does not support viewing this document.

You need a Paid Account to view this document. Click here to change your account type.

Your account does not support viewing this document.

Set your membership status to view this document.

With a Docket Alarm membership, you'll get a whole lot more, including:

  • Up-to-date information for this case.
  • Email alerts whenever there is an update.
  • Full text search for other cases.
  • Get email alerts whenever a new case matches your search.

Become a Member

One Moment Please

The filing “” is large (MB) and is being downloaded.

Please refresh this page in a few minutes to see if the filing has been downloaded. The filing will also be emailed to you when the download completes.

Your document is on its way!

If you do not receive the document in five minutes, contact support at support@docketalarm.com.

Sealed Document

We are unable to display this document, it may be under a court ordered seal.

If you have proper credentials to access the file, you may proceed directly to the court's system using your government issued username and password.


Access Government Site

We are redirecting you
to a mobile optimized page.





Document Unreadable or Corrupt

Refresh this Document
Go to the Docket

We are unable to display this document.

Refresh this Document
Go to the Docket