throbber
United States Patent [19]
`Michelson
`
`1111
`
`11111111 ftllllllllllllftlllllllllllllllllllllllllllllllll
`US005628028A
`5,628,028
`[llJ Patent Number:
`May 6, 1997
`[45] Date of Patent:
`
`[54] REPROGRAMMABLE PCMCIA CARD AND
`METHOD AND APPARATUS EMPLOYING
`SAME
`
`[75]
`
`Inventor: Henry S. Michelson. North Andover,
`Mass.
`
`[73] Assignee: Data Translation, Inc •. Mass.
`
`[21] Appl No.: 397,390
`
`Mar. 2, 1995
`[22] Filed:
`Int. Cl.6 ........................... G06F 13/10; G06F 15/177
`[51]
`[52] U.S. Cl ........................... 395/828; 3951282; 395/283;
`395/284; 395/822
`[58] Field of Search ..................................... 395/889, 892,
`3951282. 283, 284. 828. 830
`
`[56]
`
`References Cited
`
`U.S. PATENT DOCUMENTS
`
`5,014,193
`5,023,832
`5,034,813
`5;257;387
`5;2.63,148
`5,301,344
`5,302,947
`5,319,751
`5,334,046
`5,357,573
`5,428,748
`
`5/1991 Gamer et al ...................•••••••.. 364/200
`6/1991 Fulcher, Jr. et al. .•...........•.•.••. 364/900
`7/1991 Dolazza et a!. ......•. ..• .............. 358/138
`10/1993 Richek et a!. . ......................... 395/800
`11/1993 Jones, Jr. et a!. •...••..•........•..... 395/500
`4/1994 Kolcbinsky ............................. 395/800
`4/1994 Fuller eta! ............................. 340/825
`6/1994 Gamey .................................... 395/200
`8/1994 Brouilette et al .•.......•.••••...••... 439/540
`10/1994 Walters ..................................... 380125
`611995 Davidson eta!. .. .................... 395/829
`
`5,432,941
`5,517,646
`5,535,331
`5,548,759
`
`7/1995 Crick et a!. ............................. 395noo
`5/1996 Piccirillo et al ........................ 395noo
`7/1996 Swoboda eta! ................... 395/183.21
`8/1996 Lipe ........................................ 395/600
`
`OTHER PUBUC.IITIONS
`
`Personal Computer Memocy Card International Association,
`"PCMCIA PC Card Standard," P. i-ixx, 1-1-1-4. 2-1-
`2-4, 3-1-3-28. 4-1-4-38, Jul. 1993.
`Bindra. Electronic Engineering Times, "FPGAs moving to
`boost DSP applications," Issue 837, Feb. 27, 1995.
`Fuller, Electronic Engineering Times,
`"AT&T rolls
`40.000-gate Orca FPGA." Issue 837, Feb. 27, 1995.
`Romanchi, Test & Measurement World, "Portables Are Pro(cid:173)
`liferating," pp. 41-44, Feb. 15, 1995.
`Beachler et a!., Electronic Engineering Times. "Reconfigu(cid:173)
`ration Showing Promise," pp. T-41-T-44, Apr. 11. 1994.
`Hutchings et al., Electronic Engineering Times, "Digital
`Signal Processing, Reconfiguring Speeds Up Computing,"
`pp. 50-51, Oct. 17, 1994.
`
`Primary Examiner-Jack B. Harvey
`Assistant Examiner-Jigar Pancholi
`Attorney. Agent, or Finn-Fish & Richardson P.C.
`
`[57]
`
`ABSTRACT
`
`A PCMCIA card having an FPGA based card controller that
`is programmed with FPGA programming data stored on a
`host computer through a standard PCMCIA bus.
`
`26 Claims, 4 Drawing Sheets
`
`DATA ACQUISITION PCMCIA CARD
`
`14
`\
`
`PCMCIA
`
`36
`
`EXTERNAL
`CONNECTOR
`
`64
`
`CMCIA DATA
`
`68
`PIN
`PCMCIA
`PCMCIA CONTROL
`CONNECTOR ~---....c..62=-j
`PCMCIA ADDRESS
`
`66
`
`28
`
`DIGITAL l/0
`
`EXHIBrr 10IT3-
`IPR Petition for U.S. Patent No. 6,493,770
`
`

`

`-..
`Ol
`
`N oc
`Q
`-..
`=" N oc
`
`.a;:.
`~
`
`~
`
`~ a
`
`t:r'
`00.
`
`-....l
`~
`~
`~
`'"CJ\
`~
`~
`
`~ f""'''-a
`
`•
`rJ1
`~ •
`
`-1 < z
`u
`0
`z
`LU z
`1-u
`0
`Cl:
`
`LU
`X
`1-
`LIJ
`Cl:
`
`I
`
`FIG. 1
`
`34
`CARD FUNCTIONALITY
`
`CIRCUIT
`
`~
`
`CARD CONTROllER
`
`I
`32
`
`~
`
`CHIP
`
`INTERFACE
`
`PCMCIA
`
`30
`
`EEPROM
`
`CIS
`
`f--
`
`26
`
`-
`
`PCMCIA CARD 14
`
`.
`PCMCIA SYSTEM
`
`10
`
`~
`
`2(
`
`42 1--1-PROG. FILES
`38-. 1-
`
`C+SS
`
`SOFTWARE
`40 1-APPLICATION
`
`HOST MEMORY
`
`' 'tl .I-1-
`
`..... it
`
`2 ~r..
`
`_.)
`1 2
`
`1.§.
`
`ADAPTER
`PCMCIA
`
`22
`
`BlOCK·
`
`PROCESSOR
`
`20
`
`BUS
`
`SYSTEM
`
`lAPTOP OR DESKTOP
`
`HOST COMPUTER
`
`

`

`'"' = N
`
`O'J
`N
`'"' ~
`Ol
`
`O'J
`
`~
`~
`N
`~
`~
`t:r'
`00
`
`-..J
`\C
`""""
`\C
`9'
`~
`~
`
`~ = f""''-a
`e •
`
`•
`00
`
`FIG. 2
`
`56
`
`PCMCIA card and host are operational f.
`
`,
`
`programming data file
`the data from the selected FPGA
`controller FPGA by loading it with ~
`I .
`4
`Interface chip programs PCMCIA
`
`J·
`
`interface chip
`file to PCMCIA adapter and
`selected FPGA programming data
`Processor sends data from the
`
`'
`
`I
`
`'-... software and selects an FPGA
`D
`Processor executes application
`
`programming data file
`
`~
`
`configures host and PCMCIA card
`PCMCIA interface chip and
`and reads CIS EEPROM through
`Processor executes C+SS software
`
`~
`
`Adapter interrupts processor L 46
`
`~
`
`insertion of PCMCIA card
`PCMCIA adapter recognizes ~
`44
`
`4
`
`

`

`.... = N
`CIJ
`="' N
`....
`Ot
`
`CIJ
`
`.a:..
`~
`w
`~
`~
`Q"'
`00
`
`~
`\C
`\C
`~
`~
`~
`~
`
`~
`~
`~
`•
`
`~ a
`
`0 • 00
`
`!-'REPROGRAM 65
`
`EXTERNAL I
`
`CONNECTOR
`
`36
`
`I
`
`I
`
`DIGITAL l/0
`
`I D/ A CONVERTER($)
`
`'
`
`I
`
`78
`
`76
`
`-~
`
`I >
`
`60
`
`-
`
`I
`
`FPGA
`
`RPET 63.._
`
`--4~---_j
`I
`I
`ERIPHERAl ADDRESS
`
`26
`CHIP
`INTERFACE
`PCMCIA
`
`3
`
`28
`
`PCMCIA ADDRESS
`62
`CONTROL
`
`66
`
`64
`
`DATA
`
`CONNECTOR
`PCMCIA
`PIN
`68
`
`\
`14
`
`DATA ACQUISITION PCMCIA CARD
`
`L ___________ j FIG. 3
`I CIRCUIT
`I PROGRAMMING
`
`32
`
`r-
`
`

`

`U.S. Patent
`
`May 6, 1997
`
`Sheet 4 of 4
`
`5,628,028
`
`116
`
`"' ....
`.... "' DATA 106'
`
`68 PIN
`PCMCIA
`CONNECTOR / ' -
`'ADDRESS
`
`......
`7
`
`104
`
`18
`'It If\
`
`99
`jl
`
`FPGA
`102
`-
`
`(PRIOR ART)
`FIG. 4a
`
`100
`
`._.RESET 1121'
`EPROM L
`'1
`REPROGRAM
`
`114
`
`1)0
`
`CONTROL
`CIRCUIT
`
`RESET 108
`
`134 ---~ .,
`
`68 PIN
`PCMCIA
`CONNECTOR _,,
`.... .,
`
`DATA
`
`ADDRESS
`
`(PRIOR ART)
`FIG. 4b
`
`FPGA
`124
`
`~
`
`126-
`
`1 28
`130
`1--
`
`I
`-~ EPROM
`
`1l2
`
`RESET 132
`
`

`

`1
`REPROGRAMMABLE PCMCIA CARD AND
`METHOD AND APPARATUS EMPLOYING
`SAME
`
`5,628,028
`
`2
`SUMMARY
`
`5
`
`In general, the invention includes a PCMCIA card having
`an FPGA based card controller that is programmed with
`FPGA programming data stored on a host computer through
`a standard PCMCIA bus. Storing FPGA programming data
`on the host computer allows a user access to a practically
`unlimited number of FPGA programming data files to pro(cid:173)
`gram and reprogram the FPGA of the PCMCIAFPGA based
`card controller for different applications and permits a user
`to supplement. update, improve, or otherwise modify opera(cid:173)
`tion for existing applications. Additionally, storing the
`FPGA programming data files on the host computer saves
`valuable PCMCIA card real estate, reduces the amount of
`power required by the card during FPGA programming, and
`reduces the cost of the PCMCIA hardware.
`In preferred embodiments, the host computer includes a
`PCMCIA adapter circuit coupled to a PCMCIA host socket
`which is mechanically and electrically connected to a PCM(cid:173)
`CIA card connector on the PCMCIA card. A PCMCIA
`interface circuit is connected to the PCMCIA card connector
`on the PCMCIA card. Using Card and Socket Services
`software stored in host memory. the host processor reads
`Card Information Structure (CIS) data from a memory
`device, such as an EEPROM. on the PCMCIA card and
`configures the host computer and PCMCIA card to operate
`together. Additionally, using application software stored in
`host memory, the processor selects an FPGA programming
`data file from host memory and sends data from the selected
`FPGA programming data file through the PCMCIA adapter
`circuit to the PCMCIA interface circuit. The PCMCIA
`interface circuit loads the data into a PCMCIA card con(cid:173)
`troller FPGA to program the FPGA. When an error or a
`different user application is detected or when a user creates
`a new FPGA programming data file or modifies an existing
`FPGA programming data file. the processor is instructed to
`select another FPGA programming data file from host
`memory. The processor then sends data from the newly
`selected FPGA programming data file to the PCMCIA
`40 interface circuit, and the PCMCIAinterface circuit loads the
`data into the PCMCIA card controller FPGA to reprogram
`the FPGA. The PCMCIA card may also have a functionality
`circuit that includes additional functional hardware specific
`to the function of the PCMCIA card.
`Additional advantages and features are apparent from the
`following.
`
`BACKGROUND
`This invention relates to programming and reprogram(cid:173)
`ming the hardware configuration of a (PCMCIA) card.
`Personal computer memory card international association
`(PCMCIA) cards are computer cards that meet the minimum
`compliance requirements of the PCMCIA standard (e.g., 10
`release 2.1. which is hereby incorporated by reference).
`PCMCIA cards are typically used to add functionality or
`memory to a personal, portable. or desktop computer (i.e.,
`host computer), as described in PCMCIA Standard release
`2.1. The most popular PCMCIA cards are fax/modems and 15
`memory cards used in laptop computers. For example. a
`memory card having a hard disk drive can provide 200 MB
`of additional memory. Many other PCMCIA cards are
`available. including input/output (I/0) PCMCIA cards that
`transfer data between a host computer system and an I/0 bus 20
`and data acquisition cards. Typically, data acquisition cards
`receive and digitize analog information from sensors and
`temporarily store the information before transferring it to the
`host computer. Additionally, data acquisition cards are used
`by the host computer to send control and data signals to 25
`external analog and digital controllers.
`A typical PCMCIA card includes a standard PCMCIA
`connector connected to a PCMCIA interface circuit through
`a standard PCMCIA bus. The PCMCIA interface circuit 30
`operates according to the standard PCMCIA protocol to send
`data to and receive data from a host computer. The typical
`PCMCIA card also includes a PCMCIA card controller that
`sends data to and receives data from the PCMCIA interface
`circuit and controls the operation of the functional hardware
`on the card. For example, if the PCMCIA card is a memory
`card, then the functional hardware is memory (e.g., a bank
`of random access memory (RAM) chips (static or dynamic)
`or a hard disk drive) and the PCMCIA card controller
`controls reading and writing to the memory.
`PCMCIA card controllers and interface circuits can be
`implemented as hardwired logic (e.g .. one or more custom
`gate arrays) or as programmable logic (e.g., one or more
`field programmable gate arrays (FPGAS). FPGAs are typi(cid:173)
`cally programmed for operation whenever power is cycled 45
`off and then on. For example, if a PCMCIA card is inserted
`within a powered-up host computer or inserted into a
`powered-down host computer that is then powered-up. the
`DErAILED DESCRIPTION
`PCMCIA card FPGA is programmed.
`F1G. 1 is a block diagram of a PCMCIA system including
`The programmable architecture of FPGAs is provided 50 a host computer and a PCMCIA card, according to the
`through programmable logic blocks interconnected by a
`invention.
`hierarchy of routing resources. The devices are customized
`F1G. 2 is a flow chart depicting the steps required to
`by loading programming data into internal static memory
`configure a host computer and a PCMCIA card and the steps
`cells. FPGA programming data are design-specific data that
`define the functional operation of the FPGA' s internal 55 required to program a programmable PCMCIA FPGA based
`blocks and their interconnections (e.g., the functional opera-
`card controller with FPGA programming data resident in
`tion of the PCMCIA card controller and interface circuit).
`host memory.
`F1G. 3 is a block diagram of a data acquisition PCMCIA
`Typically, when a PCMCIA card, having the PCMCIA
`card controller and interface circuit implemented in an
`card, according to the invention.
`FPGA(s). is inserted in an operating (i.e., powered) host 60
`F1GS. 4a and 4b are block diagrams of prior art FPGA
`computer or is inserted in a powered down host computer
`programming circuits.
`Referring to F1G. 1, a PCMCIA system 10 includes a host
`that is then powered-up, the FPGA is programmed with
`computer 12 and a PCMCIA card 14. Within host computer
`FPGA programming data stored in non-volatile memory
`12, a PCMCIA adapter 16, connected to a standard 68 pin
`(e.g .• EPROM, EEPROM, Flash memory, etc.) on the PCM-
`CIA card. The EPROM(s) required to store the FPGA 65 PCMCIAhost socket 18 (e.g., part number 146025-1, manu-
`factured by AMP, Inc.), is coupled to a system bus 20 that
`programming data generally consumes a large amount of the
`interconnects PCMCIA adapter 16. a host processor 22, and
`PCMCIA card real estate.
`
`35
`
`

`

`5~628,028
`
`3
`a host memory 24. Within PCMCIA card 14, a PCMCIA
`interlace chip 26 (e.g., part number Z86017, manufactured
`by Zilog). connected to a standard 68 pin PCMCIA card
`connector 28 (e.g., part number 535632-L manufactured by
`AMP. Inc.), is coupled to a Card Information Structure (CIS)
`EEPROM 30 (e.g., part number XL90C21-S08, manufac(cid:173)
`tured by Atmel), a PCMCIA card controller 32, and a card
`functionality circuit 34. Both card controller 32 and card
`functionality circuit 34 are coupled to external connector 36
`(e.g., part number 558134-L manufactured by AMP, Inc.). 10
`No external connector is needed if the PCMCIA card is a
`memory card, and no card functionality circuit may be
`necessary where the PCMCIA card is an I/0 card (i.e., all
`functionality is located within the card controller 32).
`Address. data. and control signals are transferred between 15
`host computer 12 and PCMCIA card 14 through PCMCIA
`adapter 16 and PCMCIA interlace chip 26 which are
`designed to transfer data in accordance with PCMCIA
`release 2.1 protocol. PCMCIA cards are 3.37 inches (85.6
`mm) in length and 2.126 inches (54 mm) in width. However, 20
`there are three different maximum thicknesses specified for
`PCMCIA cards: a type one card is 0.13 inches (3.3 mm) in
`thickness; a type two card is 0.196 inches (5 mm) in
`thickness; and a type three card is 0.413 inches (10.5 mm)
`in thickness. The standard PCMCIA host socket is about 25
`2.126 inches (54 mm) in width and has 68 pins arranged in
`two rows, and the standard PCMCIA card connector is also
`about 2.126 inches (54 mm) in width and has 68 pin sockets
`that correspond to the pins of the host socket. The left side
`of the card connector is mechanically keyed differently from 30
`the right side, and the host socket is keyed to accept this
`configuration to prevent the PCMCIA card from being
`inserted upside down.
`Referring also to F1G. 2, when PCMCIA card 14 card
`connector 28 is inserted in PCMCIA host socket 18 of host 35
`computer U. PCMCIA adapter 16 recognizes (step 44) the
`insertion and interrupts (step 46) processor 22. Alternatively,
`if PCMCIA card 14 is inserted while host computer 12 is
`turned off (i.e., powered-down), host computer 12learns of
`the existence of PCMCIA card 14 during the power-on 40
`procedure. Processor 22 then executes (step 48) Card and
`Socket Services 38 (C&SS) software resident in host
`memory 24 and through PCMCIA interlace chip 26 reads
`CIS data from CIS EEPROM 30. As a minimum. the CIS
`data must sufficiently identify the PCMCIA card to the host, 45
`to enable the processor 22 to configure the host computer 12
`and the PCMCIA card 14 to operate together and to enable
`the processor to select the appropriate application software
`40 from host memory 24. The CIS data specifically identify
`the card manufacturer (e.g .. Data Translation, Inc.) and card 50
`identification (ID) number and includes a variety of set-up
`infonnation, including base address, interrupt level, size of
`address window, and other infonnation regarding the card's
`functionality, as specified by release 2.1. The CIS data are
`entered into the EEPROM at the time of card manufacture 55
`and are not thereafter changed. Hence, configuration of host
`computer 12 and PCMCIA card 14 is completed without the
`use of card controller 32.
`Processor 22 then executes (step 50) the application
`software 40 resident in host memory 24 that corresponds to 60
`PCMCIA card 14. The application software 40 causes the
`processor to either select a default FPGA programming data
`file 42 from host memory 24 that corresponds to a particular
`application for PCMCIA card 14 or request input from the
`user as to which FPGA programming data file 42 is to be
`selected from host memory 24. Processor 22 then sends (step
`52) the data from the selected FPGA programming data file
`
`4
`42 through PCMCIA adapter 16 to PCMCIA interface chip
`26. Interface chip 26 then programs (step 54) a field pro(cid:173)
`grammable gate array (FPGA, not shown in F1G. 1) within
`card controller 32 by loading the data from the FPGA
`5 programming data file 42 into the FPGA. Where the appli(cid:173)
`cation software causes the processor to select a default data
`programming file, PCMCIA card 14 and host computer 12
`are made operable (step 56) without user intervention.
`Referring to F1G. 3, card controller 32 includes a PCM-
`CIA card controller FPGA 60 (e.g., part number
`XC3042TQ100-100. manufactured by Xilinx. as described
`in Xilinx Programmable Logic Data Book, which is hereby
`incorporated by reference). Through a standard PCMCIA
`bus (i.e., PCMCIA address lines 62, data lines 64, and
`control lines 66) connected to PCMCIA connector 28,
`interlace chip 26 receives FPGA programming data from
`host computer 12 (F1G. 1). Interlace chip 26 initiates FPGA
`60 programming through FPGA programming circuit 68,
`which drives reset line 63 and reprogram line 65, and
`completes FPGA 60 programming by loading the FPGA
`programming data into FPGA 60 through peripheral data
`lines 72.
`The PCMCIA card interlace circuit and PCMCIA card
`controller of typical prior art PCMCIA cards are usually
`combined in the same (i.e., common) FPGA. As a result, in
`order to send CIS data to the host. the FPGA has to first be
`programmed with data stored in nonvolatile memory (e.g.,
`one or more EEPROMs, EPROMs, or Flash memory) on the
`PCMCIA card. The nonvolatile memory requires valuable
`PCMCIA card real estate, and the power required by the
`memory during FPGA programming reduces the available
`battery power in portable computers,
`Referring to F1G. 4a, in a typical prior art PCMCIA card
`99, an EPROM(s) 100 is used to store FPGAprogramming
`data and is connected to a PCMCIA interlace and card
`controller FPGA 102 through address lines 104 and data
`lines 106 (e.g., byte wide parallel inputs). On power-up, a
`reset circuit (not shown) asserts a reset line 108 to FPGA 102
`and to a control circuit 110. Control circuit 110 asserts a reset
`line 112 to EPROM 100 and asserts a reprogram line 114 to
`EPROM 100 and FPGA 102 to initiate programming of
`FPGA 102 with FPGA programming data stored in EPROM
`100. As a result, PCMCIA card 99 is programmed without
`intervention from the host computer (not shown) to which
`PCMCIA card 99 is connected through PCMCIA card
`connector 116.
`Referring to F1G. 4b, in another typical prior art PCMCIA
`card 120, an EPROM 122 is used to store FPGA program(cid:173)
`ming data and is connected to a PCMCIA interlace and card
`controller FPGA 124 through a serial data-in line 126. a
`strobe line US, and a reprogram line 130. On power-up, a
`reset circuit (not shown) asserts a reset line 132 to FPGA 124
`and to EPROM 122 to initiate programming of FPGA 124
`with FPGA programming data stored in EPROM U2. As a
`result, again PCMCIA card 120 is programmed without
`intervention from the host computer (not shown) to which
`PCMCIA card 120 is connected through PCMCIA card
`connector 134.
`Referring again to F1G. 3, as an example, PCMCIA card
`14 is a data acquisition card, and card functionality circuit 34
`includes an analog to digital (A/D) converter 76 (e.g., part
`number LTC1290. manufactured by Linear Technology) and
`a digital to analog (D/A) converter 78 (e.g., part number
`65 MAX532, manufactured by Maxim) connected through
`external connector 36 to sensors (not shown) and an external
`analog controller (not shown). FPGA 60 is also connected to
`
`

`

`5,628,028
`
`5
`an external digital controller (not shown) through external
`connector 36. The C&SS software 38, application software
`40. and FPGA programming data files 42 in host memory 24
`cause the processor 22 to program FPGA 60 to operate as a
`data acquisition PCMCIA card controller. to. e.g .• transfer
`data and control signals between host computer 12 and the
`external controllers.
`ND converter 76 receives analog signals from the sensors
`and converts them to digital signals before sending them
`over the ND bus 82 to PCMCIA card controller FPGA 60. 10
`Card controller FPGA 60 stores data received from ND
`converter 76 in a 512x9 FIFO 80 (e.g .• part number
`MS7201AL-50, manufactured by Mosel-Vitalic) using
`FIFO data-in signals 84 and FIFO control signals 86 before
`transferring the data to the host computer 12 through periph- 15
`eral data lines 72 and PCMCIA interface chip 26.
`Data sent from host computer 12 for transmission to the
`external analog and digital controllers is first stored in a
`512x9 FIFO 81 (e.g .• part number MS7201AL-50, manu(cid:173)
`factured by Mosel-Vitalic) through PCMCIA interface chip
`26 and peripheral data lines 72. Card controller FPGA 60
`then retrieves the stored data from FIFO 81 through FIFO
`data-out signals 85 and sends the stored digital data over the
`D/A bus 88 to D/A converter 78 or over digital input/output
`(I/0) bus 90 directly through external connector 36 to the
`external digital controller. D/ A converter 78 converts digital
`signals received from FPGA 60 into analog signals before
`sending them through external connector 36 to the external
`analog controller.
`As an example. external connector 36 has fifteen pin
`connections: eight pins connected to ND converter 76 and
`eight sensors (not shown); two pins connected to D/A
`converter 78 and to the external analog controller; four
`digital I/0 pins connected to FPGA 60 and to the external
`digital controller; and one ground pin connected to ground.
`For a variety of reasons, including the detection of a
`PCM CIA card controller 60 malfunction (e.g .• error condi(cid:173)
`tion detected) or the detection of a user request to change the
`PCMCIA card application (e.g., software interrupt), PCM(cid:173)
`CIA card controller 60 may be reprogramed. The host
`computer executes application software 40 (FIG. 1) in host
`memory 24 to select a new FPGA programming data file 42
`from host memory 24 and then sends the data from the
`newly selected FPGA ·programming data file 42 through
`PCMCIAadapter 16 to PCMCIAinterface chip 26. Interface
`chip 26 uses FPGA programming circuit 68 to reset PCM(cid:173)
`CIA card controller FPGA 60 and enable reprogramming,
`and interface chip 26 completes reprogramming by loading
`the data from the newly selected FPGA programming data
`file into card controller FPGA 60.
`For example, instead of simply storing all the data
`received from the sensors in the FIFO before sending it to
`the host computer, card controller FPGA 60 can be repro(cid:173)
`grammed with additional functionality that formats the data
`received from the sensors according to the host computer's
`requirements before storing the data in the FIFO. Similarly,
`card controller FPGA 60 can be reprogrammed with addi(cid:173)
`tional functionality that analyzes the sensor data and inter(cid:173)
`rupts the host computer when predetermined thresholds are
`exceeded. In such a system. the host computer need not
`interact with the PCMCIA card unless a predetermined
`threshold is exceeded.
`For example, a data acquisition PCMCIA card may be
`coupled to a temperature controller and sensors for deter(cid:173)
`mining the temperature of a room. Such a PCMCIA card
`continually receives data from the sensors and. in a simple
`
`6
`data acquisition card, the host computer periodically reads
`the data acquisition FIFO and analyzes the data to determine
`if predetermined temperature thresholds have been
`exceeded. The PCMCIA card could be reprogrammed to
`5 analyze the data received from the sensors and interrupt the
`host computer when a predetermined temperature threshold
`is exceeded. Hence, the host computer would only read the
`PCMCIA card FIFO when notified that a threshold had been
`exceeded.
`Moreover. the operation of the PCMCIA card controller
`may need to change for different user applications. For
`example, if a temperature controller is moved to a smaller
`room where temperature fluctuates more quickly, the PCM(cid:173)
`CIA card controller needs to be reprogrammed to accept data
`from the temperature sensors more frequently. In such a
`situation. the user notifies the processor of a change in
`application and the processor selects a corresponding FPGA
`programming data file and sends the data to the PCMCIA
`interface which reprograms the PCMCIA card controller
`20 FPGA by loading the FPGA with the new FPGA program(cid:173)
`ming data.
`Typically host memory is very large and is supplemented
`with extended memory (not shown). Hence, a practically
`unlimited number of FPGA programming data files can be
`25 stored within the host computer and made available to the
`user. The programming and reprogramming of the PCMCIA
`card controller FPGA is limited only by the size (i.e.,
`capability) of the FPGA. The functionality of the PCMCIA
`card is limited only by the fixed hardware (i.e., the func-
`30 tiona! hardware) on the PCMCIA card (e.g., ND or D/A
`converters, contacts on and configuration of the external
`connector, and FIFO size).
`For example. a PCMCIA card controller FPGA can be
`35 programmed to function as an I/0 card controller, a data
`acquisition card controller, a fax/modem card controller, or
`a memory card controller; however, the PCMCIA card can
`only function as these card types if the additional functional
`hardware is available on the card. For an I/0 card controller,
`40 the FPGA can be programmed (and reprogrammed) with the
`functionality required to transfer data between the host
`computer and the I/0 bus (e.g., Small Computer System
`Interface (SCSI)), and, thus, the only additional functional
`hardware required is an external I/0 bus connector and
`45 electrical conductors from the I/0 bus connector to the
`FPGA. For a memory card, additional functional hardware
`typically includes a bank of static or dynamic RAM chips,
`ROM chips, flash memory, or a hard disk drive, and the
`addressing and refreshing functionality can be located
`50 within the PCMCIA card controller FPGA and, hence,
`reprogrammable. As an example, where a portion of a disk
`drive or a portion of a bank of RAMs becomes damaged and
`non-functional, the addressing functionality in the FPGA
`can be reprogrammed to address only the working portion of
`55 the memory hardware. For a fax/modem, additional func(cid:173)
`tional hardware generally includes a phone connection, ND
`and D/A converters, buffers, and amplifiers, and function(cid:173)
`ality controlling hardware, for instance, hardware control(cid:173)
`ling the baud rate, can be located within the FPGA and, thus,
`reprogrammable.
`The FPGA programming data files can be supplied with
`the PCMCIA card or new, additional, or updated FPGA
`programming data files can be obtained at a later time.
`Similarly, users can create their own FPGA programming
`65 data files or make modifications as desired.
`The PCMCIA interface was described above as a particu(cid:173)
`lar integrated circuit chip; however, other hardware can be
`
`60
`
`

`

`5,628,028
`
`7
`used to implement the functionality of the intertace chip.
`Similarly, the PCMCIA card was described as a data acqui(cid:173)
`sition card, however, the programmable PCMCIA card con(cid:173)
`troller FPGA can be used on all PCMCIA card types (e.g.,
`fax modem. memory, etc.) with the FPGA programming data 5
`files stored on a host computer.
`Other embodiments are within the following claims.
`What is claimed is:
`1. A method of configuring the specific operating func(cid:173)
`tionality for a PCMCIA card connected to a host computer 10
`via a standard PCMCIA card connector on said PCMCIA
`card and a standard PCMCIA host socket on said host
`computer comprising:
`storing at least one FPGA programming data file for
`configuring a PCMCIA card controller FPGA in a host 15
`memory of said host computer.
`sending data from said FPGA programming data file to
`the PCMCIA intertace circuit on the PCMCIA card
`through a standard PCMCIA bus, and
`programming the PCMCIA card controller FPGA to have
`said specific functionality by loading the FPGA with
`the data from said stored FPGA programming data file.
`whereby said PCMCIA card is not limited to a dedicated
`specific operating functionality provided on said card 25
`and can be programmed and reprogrammed with any
`one of a variety of FPGA programming data files
`provided by said host.
`2. The method of claim 1. further comprising:
`reading CIS data from a CIS storage device on the 30
`PCMCIA card through a PCMCIA intertace circuit on
`the PCMCIA card and a PCMCIA adapter on the host
`computer. said sending of data being triggered by an
`application on said host responding to said CIS data.
`3. The method of claim 1. wherein more than one FPGA 35
`programming data file is stored in said host memory, and
`further comprising:
`selecting another stored FPGA programming data file;
`sending data from said another stored FPGA program(cid:173)
`ming data file through the standard PCMCIA bus to the 40
`PCMCIA intertace circuit on the PCMCIA card; and
`reprogramming the PCMCIA card controller FPGA by
`loading the FPGA with the data from said another
`stored FPGA programming data file.
`4. The method of claim 3, further comprising before 45
`selecting:
`detecting a new user application, said selecting being in
`response to said detecting.
`5. The method of claim 3, further comprising before
`selecting:
`detecting an error condition.
`6. The method of claim 1. further comprising:
`storing new FPGA programming data files in the host
`memory.
`7. The method of claim 6, further comprising:
`selecting a newly stored FPGA programming data file;
`sending data from said newly stored FPGA programming
`data file through the standard PCMCIA bus to the
`PCMCIA intertace circuit on the PCMCIA card; and 60
`reprogramming the PCMCIA card controller FPGA by
`loading the FPGA with the data from said newly stored
`FPGA programming data file.
`8. A PCMCIA card comprising
`a printed circuit board;
`a standard PCMCIA card connector mounted on said
`printed circuit board;
`
`55
`
`65
`
`20
`
`50
`
`8
`a PCMCIA intertace circuit electrically connected to the
`PCMCIA card connector for transferring data through
`the PCMCIA connector according to standard PCM(cid:173)
`CIA protocol, for transferring CIS data to a host com(cid:173)
`puter system, for transferring FPGA programming data
`received from the host computer system, said transfer(cid:173)
`ring of FPGA programming data being triggered in
`response to receipt of said CIS data at said host
`computer system, and for programming a PCMCIA
`card controller FPGA with said FPGA programming
`data received from said host computer system;
`a CIS storage device, electrically connected to the PCM(cid:173)
`CIA intertace circuit, for storing CIS data; and
`a PCMCIA card controller, including the PCMCIA card
`controller FPGA. electrically connected to the PCM(cid:173)
`CIA intertace circuit, for controlling the operation of
`the card to have specific operating functionality speci(cid:173)
`fied by said FPGA programing data received from said
`host computer system.
`whereby said PCMCIA card is not limited to a dedicated
`specific operating functionality provided on said card
`and can be programmed and reprogramed with anyone
`of a variety of FPGA programming data files provided
`by said host.
`9. The PCMCIA card of claim 8, further comprising:
`an FPGA programming circuit electrically connected to
`the PCMCIA intertace circuit and the PCMCIA card
`controller.
`10. The PCMCIA card of claim 8, wherein the CIS storage
`device is an EEPROM.
`11. The PCMCIA card of claim 8, further comprising:
`a card functionality circuit.
`12. The PCMCIA card of claim 11, wherein the PCMCIA
`card is a memory card and the functionality circuit includes:
`a bank of random access memory devices for storing data.
`13. The PCMCIA card of claim 11. wherein the PCMCIA
`card is a memory card and the functionality circuit includes:
`a disk drive for storing data.
`14. The PCMCIA card of claim 11. wherein the PCMCIA
`card is an 1/0 card and the functionality circuit includes:
`an external 1/0 bus connector; and
`conductors electrically connecting the 1/0 bus connector
`to the PCMCIA card controller FPGA.
`15. The PCMCIA card of claim 11, wherein the PCMCIA
`card is a fax/modem card and the functionality circuit
`includes:
`an external telephone co

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