EP0111381A2 - Distributeurs automatiques de billets - Google Patents
Distributeurs automatiques de billets Download PDFInfo
- Publication number
- EP0111381A2 EP0111381A2 EP83304907A EP83304907A EP0111381A2 EP 0111381 A2 EP0111381 A2 EP 0111381A2 EP 83304907 A EP83304907 A EP 83304907A EP 83304907 A EP83304907 A EP 83304907A EP 0111381 A2 EP0111381 A2 EP 0111381A2
- Authority
- EP
- European Patent Office
- Prior art keywords
- encryption
- data
- control processor
- word
- key word
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Images
Classifications
-
- G—PHYSICS
- G07—CHECKING-DEVICES
- G07F—COIN-FREED OR LIKE APPARATUS
- G07F7/00—Mechanisms actuated by objects other than coins to free or to actuate vending, hiring, coin or paper currency dispensing or refunding apparatus
- G07F7/08—Mechanisms actuated by objects other than coins to free or to actuate vending, hiring, coin or paper currency dispensing or refunding apparatus by coded identity card or credit card or other personal identification means
- G07F7/10—Mechanisms actuated by objects other than coins to free or to actuate vending, hiring, coin or paper currency dispensing or refunding apparatus by coded identity card or credit card or other personal identification means together with a coded signal, e.g. in the form of personal identification information, like personal identification number [PIN] or biometric data
- G07F7/1016—Devices or methods for securing the PIN and other transaction-data, e.g. by encryption
Definitions
- the present invention relates to autoteller systems for the automatic dispensation of money to a user upon presentation of a valid card and receipt of correct information from the user validating his right to use. It particularly relates to autoteller systems which employ the technique of encryption for protection of information on the card and further relates to autoteller systems where a remote host contoller communicates with the system.
- the remote host might have been a computer installation some miles away coupled to the autoteller by a serial data telephone link. The host would keep records of unacceptable cards and so on and instruct the autoteller system in what action to take under different circumstances.
- the same host system might be in supervisory control of many autoteller systems.
- the existence of the telephone line data link lays the system open to public interference and to access by many more employees, since the amount of equipment is multiplied and the line and the external host system are open to inspection by persons not in the vicinity of the autoteller per se.
- the ability of the remote host to command the autoteller system creates the possibilty of new methods of fraud where an interloper sends his own commands to the autoteller system instructing it to perform actions it would otherwise not perform under the circumstances it finds.
- the present invention consists in an autoteller system for dispensing money to a user on presentation of a valid card, said system comprising; a removable master key loader for providing instructions for the performance of an algorithm for the generation of a master key word, a port for receiving said master key loader and for reading said instructions therefrom, an encryption circuit coupled to receive an input word, coupled to receive a current key word, and operable to respond to said current key word to provide an output word being said input word encrypted according to a selected one out of a plurality of manners of encryption, a card reader for reading data from said card, and a data link operable to receive a remotely--provided sub-key word, where said system is operable to receive said instructions from said port and to perform said algorithm to generate said master key word, where said system is operable to couple said master key word as said current key word in said encrytion circuit, where said system is operable to couple said sub-key word as said input word in said encryption circuit, and where said system is operable to couple the
- the.present invention consists in an autoteller system for dispensing money to a user on presentation of a valid card, said system comprising; a removable master key loader for providing instructions for the performance of an algorithm for the generation of a master key word, a port for receiving said master key loader and for receiving said instructions therefrom, an encryption circuit coupled to receive an input word, coupled to receive a current key word and operable to respond to said current key word to provide an output word being said input word encrypted according to a selected.one out of a plurality of manners of encryption, and a data link, where said system is coupled to receive said instructions from said port and is operable to respond thereto to generate said master key word, where said system is operable to couple said master key word as said current key word to said encryption circuit, where said system is coupled to receive from said data link a plural succession of communication sub-key words, and where said system is operable to couple each of said communication sub-key words in turn as said input word to said encryption circuit to store the succession of resultant output words as
- an autoteller system comprises an internal processor in which case the internal processor preferably provides an internal address bus and an internal data bus for use within the auto teller.
- the autoteller preferably comprises a serial data interface for providing data communications with a remote host system.
- the serial data interface preferably communicates with the internal processor via the internal address bus and the internal'data bus.
- the autoteller preferably comprises a card reader preferably communicating with the internal processor via the internal address bus and the internal data bus and operable to read data from a card and communicate that data to the internal processor.
- the autoteller preferably comprises a keyboard and display coupled to the internal processor via the internal address bus and the internal data bus and operable in the one case to communicate data keyed in by the user to the internal processor and in the other case to provide data to the user from the internal processor.
- the autoteller preferably comprises a banknote dispenser preferably commanded via the internal data bus and the internal address bus to dispense money to the user.
- the autoteller preferably comprises an encryption module communicating with the internal processor via the internal address bus and the internal data bus-preferably operable to receive data for encryption from the internal processor and to provide encrypted data to the internal processor.
- the encryption module is preferably selectably operable to decrypt data.
- the autoteller preferably comprises a secure case closed behind a secure door.
- a secure enclosure preferably closed by secure screws unable to be undone without special tools.
- the enclosure preferably houses the internal processor, the encryption module and the interface circuits to the other elements therein.
- the autoteller preferably comprises a key connector outwith the secure enclosure but within the,secure case for providing coupling between the encryption module and a key loader.
- the encryption module preferably comprises a printed-circuit board.
- the printed circuit board preferably comprises a first edge connector for plugging into the common backplane of the internal processor and the interface circuits.
- the printed circuit board preferably comprises a second edge connector for providing connection to a multi-way cable for connecting the encryption module to the key connector.
- the key loader preferably comprises a multi-way plug for coupling to the key connector.
- the key loader is preferably housed within a case housing four indicator light-emitting diodes.
- the key loader preferably comprises a Read-Only Memory.
- the Read-Only-Memory is preferably ultra-violet erasable, in which case the key loader preferably comprises an aperture in the case for irradiating the Read-Only Memory and a light-tight grommet affixable therein for the protection of the Read-Only-Memory.
- the Read-Only-Memory is preferably coupled, via the key connector, to receive an address bus and a data bus.
- the encryption module preferably provides a chip-select signal to the Read-Only-Memory in response whereto the Read-Only-Memory preferably provides the data on the data bus in the location addressed by the address bus.
- the key loader preferably provides a connection to the Read-Only-Memory for programming the Read-Only-Memory when the signal thereon exceeds a predetermined value, under which condition the Read-Only-Memory stores the data on the data bus in the location addressed by the address bus, and which program- inducing signal is preferably not provided by said encryption module.
- the encryption module preferably comprises an encryption control processor.
- the encryption control processor preferably provides an encryption address bus and an encryption data bus for use in the encryption module.
- the encryption address bus is preferably the address bus supplied to the Read-Only-Memory and the encryption data bus is preferably the data bus provided to the Read-Only-Memory.
- the encryption module preferably comprises a communications register for providing communication between the internal data bus of the autoteller and the encryption data bus of the encryption control processor.
- the encryption module preferably a resident Read-Only-Memory (ROM) wherein the systems program of the internal processor is stored.
- the internal processor preferably comprises a volatile Random-Access Memory (RAM) for temporary storage of data during the operation of the encryption module and whose contents are lost if the power is removed from the autoteller.
- the encryption module preferably comprises a secure random-access memory whose contents cannot be recalled by the remote host and which is sustained in the event of the loss of power to the autoteller, the autoteller preferably comprising a battery backup power supply for supplying power only to the secure sustained RAM in the event of power loss.
- the backup power supply is preferably situated on the encryption module.
- the backup power supply is preferably disconnected from the secure, sustained RAM in the event of the printed circuit board housing the encryption module being disconnected from the common back plane of the internal processor of the autoteller, in which case the secure, sustained memory preferably loses its contents.
- the backup power supply preferably comprises a link on the first edge connector which is broken if the printed circuit board is removed therefrom.
- the secure, sustained RAM is preferably operable to store encryption key words.
- the encryption key words are preferably stored in secret locations therein scatterd among other data to create uncertainty as to which words stored in the secure, sustained RAM might be encryption key words.
- the encryption module preferably comprises an encrption block.
- the encryption block is preferably operable receive addresses and data respectively from the encryption address bus and the encryption data bus and is preferably operable to provide selectably encrypted or decrypted data back to the encryption data bus.
- the encryption module preferably comprises a flag register addressable via the encryption address bus and operable to receive first and second flag characters indicative of the encryption module having received the master key word and a session key word.
- the flag register preferably comprises comparison means for detecting if the predetermined flag characters have been deposited therein and operable to communicate the fact to a monitor,
- the monitor preferably monitors the voltage supplied by the battery in the backup power supply and detects if it is low.
- the monitor preferably provides activating signals to a light-emitting diode drive circuit for driving the light-emitting diodes in the key loader.
- the light emitting diodes in the key loader preferably provide indication when the keys have been correctly loaded and when the battery is of low voltage.
- the encryption block preferably comprises a key register comprising a plurality of eight-bit parallel in parallel out registers individually addressable from an address decoder to accept the data on the encryption data bus when addressed by the encryption control processor via the encryption address bus.
- the encryption key register is preferably sixty-four bits long.
- the encryption block preferably comprises an output register preferably comprising a plurality of 8-bit parallel-in-parallel-out registers individually in receipt of data from an encryption circuit itself in receipt of the contents of the key register each operable when individually addressed by the encryption control processor via the address decoder operating on the contents of the encryption address bus to provide their input word onto the encryption data bus.
- the encryption block preferably comprises an input register.
- the input register preferably comprises a direct register for receiving characters for encryption.
- the direct register preferably comprises a plurality of plural-bit parallel-in-parallel-out registers individually addressable via the address decoder operating on the encryption address bus to accept data from the encryption data bus and provide it as output.
- the input register preferably comprises a cyphertext register operable in the same manner as the direct register.
- the encryption control processor preferably is operable to load the cyphertext register with the result of the previous encryption as recovered-from the output register.
- the output of the cyphertext register is preferably provided as the first input to an exclusive-or array in receipt of the output of the direct register as first input and providing output being the parallel-bit exclusive or function of corresponding bits in the two outputs.
- the output of the exclusive-or array is preferably coupled as the first input to a diplexer and the-output of the direct register is preferably provided as the second input to the diplexer which is selectably operable to provide the output of the direct register as output for coupling as input to the encryption circuit if direct operation is required and to provide the output of the exclusive-or array as the input to the encryption circuit if cyphertext chaining of data to and from the remote host system is required.
- the communication register preferably comprises a pair of buffer registers each addressable by the internal processor and by the encryption control processor, a first buffer being for the transfer of data from the internal processor for use by the encryption control processor and a second being for the transfer of data from the encryption control processor for use by the internal processor.
- the encryption module preferably detects the power-on condition.
- the encryption control processor then preferably looks to see if the key loader is present. If the key loader is present the encryption module preferably uses the instructions in the keyloader directly to calculate the master key.
- the algorithm preferably allows access to the encryption block.
- the calculated master key is preferably stored in a temporary location where its parity is checked.
- the Master key is then preferably stored in a secure location in the sustained RAM and the contents of the temporary location deleted.
- the encryption module preferably receives a session sub-key from the remote host via the data link.
- the session sub-key is preferably encrypted using the master key as the key word to the encryption circuit, to create a session key.
- the session key is preferably stored in the sustained RAM in a secret location.
- the sustained RAM preferably contains many pieces of data so that it is impossible to discover by inspection which of the pieces of data are keys.
- the encryption module is preferably operable to receive a succession of communication sub-keys from the remote host system.
- the communication sub-keys are preferably encrypted using the master key as the key word to the encryption circuit to create a corresponding succession of communication keys.
- the communication keys are preferably stored in the secure RAM in the same manner as the master and session keys.
- the remote host is preferably in a position to indicate to the encryption module which one of the communication keys it wishes to use. Thereafter the encryption module is preferably operable to use the indicated communication key to encrypt data.
- the encryption module is preferably selectably operable to operate in the cyphertext manner when instructed to do so via the remote host.
- the cyphertext manner preferably consists in the encryption of current data after it has undergone an exclusive-or combination with the result of the previous encryption.
- the autoteller 10 comprises an autoteller internal processor 12 for controlling the immediate actions of the autoteller 10.
- the internal processor 12 provides an internal data bus 14 for providing data to and receiving data from the various other elements in the autoteller,10.
- the internal processor 12 also provides an internal address bus 16 whereby each of the varoius elements in the autoteller 10 can be addressed for data deposition or data retrieval therefrom.
- the autoteller internal controller 12 is, for preference, a minicomputer. However, it will be apparant that the function of the internal controller 12 can be accomplished using any other type of state-sequence machine ranging from the programmable to the hard-wired.
- the autoteller 10 comprises a serial data interface 18 for providing data communication via a serial data link 20 with a remote host system 22.
- the interface 18 converts parallel data received from the internal data bus 14 when addressed by the internal address bus 16 into a serial stream of binary digits.
- the serial data link 20 is, for - preference, a three-wire system comprising a data wire for receiving the series of binary digits, a clock wire for for carrying a clock signal for clocking the series of binary digits, and a ground wire.
- the serial data link 20 could equally comprise a telephone line and a pair of modems. Equally, any other type of data communication link can be used with the present invention.
- the autoteller 10 also comprises a card reader 24.
- the card reader 24 accepts a card from the autoteller user and, when addressed by the internal processor 12, informs the processor 12 that a card is present.
- the internal processor 12 then commands the card reader 24 to read data from the card and transfer it via the internal data bus 14 to the internal processor 12.
- the autoteller 10 further comprises a keyboard and display.26.
- the internal processor 12 instructs the display 26 to request the user to type out his personal number on the keyboard 26. If the personal number, received via the data bus 14 by the internal processor 12, does not match up with predetermined information recovered from the card by the card reader 24 according to a predetermined relationship after a predetermined number of attempts at entry of the personal number, the internal processor 12 instructs the card reader 24 to swallow the card and deposit it a bin on the assumption that the would-be user had no right to use the card, being unaware of the personal number.
- the autoteller 10 further comprises a banknote dispenser 28. If the user successfully enters his personal number within the predetermined number of attempts the internal processor 12 instructs the display 26 to ask the user how much money he wishes to withdraw. The user then responds by typing out the amount on the keyboard 26 which information is communicated to the internal processor 12. In response the internal processor 12 then instructs the banknote dispenser 28 to dispense the required number and types of banknotes to the user.
- the remote host system 22 can be used to control many more than just one autoteller 10.
- the remote host 22 maintains records of bad cards and instructs the internal processor 12 to retain any card in the card reader 24 which is suspect. It is to be appreciated that the remote host system 22 can address a plurality of autotellers 10 via the same serial data link 20 and it is preferred that this be so. It is however possible to address each autoteller 10 via its own, unique serial data link 20.
- the function of the remote host processor 22 is one of supervision and general control.
- the autoteller 10 communicates its transactions to the remote host system 22 and.the remote host 22 communicates operating instructions to the autoteller 10.
- the autoteller 10 might inform the host 22 of identification information on the card, bank account number, and time of last use, all derived from the card reader 24.
- the remote host system 22 might instruct the autoteller 10 to withold or not to withold payment, or tell the autoteller 10 the upper limit of payment.
- the autoteller 10 ' may be instructed to retain the card or be informed as to what new information to record on the card using a recording facility on the card reader 24.
- the autoteller 10 lastly comprises an encryption module 30.
- the encryption module 30 is operable to receive blocks of data from the internal processor 12 via the internal data bus 14 when addressed by the internal address bus 16 and to render up blocks of encrypted or decrypted data to the internal processor 12 onto the internal data bus 14 when addressed to do so via the internal address bus 16.
- the manner of encryption or decryption is selectable in response to the encryption module responding to commands to use a selectable key.
- the internal processor 12 provides data recovered by the card reader 24 from the presented card to the encryption module 30 for selectable encryption or decryption and receives the selectably encrypted or decrypted data back from the encryption module.30, the manner of encryption or decryption being predetermined by the loading of a key, the key being variable from time to time.
- a second manner of operation one out of a plurality of communi communication keys is selected by the remote host system 22 and data provided to the encryption module 30 from the internal processor 12 fro selectable encryption or decryption and communication back to the internal processor 12.
- the data may have been received from the remote host system 22 by the internal processor 12 via the serial data link 20 and the serial data interface 18, or may be a message originated by the internal processor 12 for communication to the remote host system 22 in a similar manner.
- the encryption module 30 performs a cyphertext operation using a host 22 selectable encryption key whereby received data from the host 22 or data to be sent to the host 22 is divided into blocks and combined in an exclusive-or operation with the result of encryption or decryption of the previous block before itself being encrypted or decrypted.
- encryption is herein defined as the altering of the order of the binary digits in a plural binary digit data word according to a predetermined pattern.
- decryption is herein defined as the altering back of the order of the binary digits in an encrypted plural binary digit word to their original order.
- a key is herein defined as the plural binary digit word defining the pattern of encryption or decryption, whereby alteration of the key alters the pattern of encryption or decryption.
- decryption is merely a special case of encryption, the pattern causing the decryption of a previously- encrypted message being, in absense of previous encryption, just another encryption pattern. While there is no mathematical distinction therebetween, for the purposes of the present invention and the description thereof encryption and decryption are treated as if they were seperate operations.
- Figure 2 shows the mechanical construction of the autoteller 10 of figure 1.
- the autoteller 10 is housed within a secure steel case 32 closed by a secure steel door 34 which can be locked.
- a secure enclosure 36 also made from steel and closed by a steel panel 38 held by special screws 40 which can only be undone using a special tool.
- the enclosure 36 houses the internal processor 12, the encryption module 30 and interface circuits for the other elements of the autoteller 10.
- the autoteller 10 comprises a key connector 42 affixed within the secure case 32 but outwith the secure enclosure 36 for loading encryption keys in a manner to be described hereunder.
- the key connector 42 is therefore accessible to bank personnel whenever the case 32 is opened.
- the autoteller 10 further comprises a banknote dispenser enclosure 44 shown in phantom outline for housing a safe for money and a dispenser mechanism and a user facia protrusion 46 protruding through the wall of the bank and presenting to the user the keyboard and display 26 and the dispensing end of the banknote dispenser.
- FIG. 3 shows mechanical details of the construction of the encryption module 30.
- the encryption module 30 comprises a printed-circuit board 48 with a first edge connector 50 for connecting the printed circuit board 48 into the common backplane of the internal processor 12 through which all power and communication with the common processor 12 is derived.
- the encryption module 30 comprises a second edge connector 52 on the edge of the printed circuit board 48 remote from the first edge connector 50.
- the second edge connector 52 is used to load a secure key into the encryption module 30.
- a plug 54 mates with the second edge connector 52, coupling it to a multi-way flat cable 56 which in turn couples the second edge connector 52-to the key connector 42 shown in figure 2.
- FIG. 4 shows mechanical detail of the key loader in conjunction with the key connector 42.
- the key loader 58 is a pocketable outboard Read-Only-Memory (ROM) for the encryption module 30.
- the key loader 58 is housed in a shatterproof resin case 60 at the extreme and flared end of which is provided a key loader connector 62 for mating with the key connector 42 to provide multiple connections to the encryption module 30.
- the key loader 58 comprises an ultra-violet erasable ROM 66 housed beneath an aperture 64 in the case 60 wherethrough the ROM 64 can be irradiated if required to destroy its contents prior to loading fresh contents.
- the aperture 64 is closed by a light--tight grommet 68 to prevent the accidental irradiation of the ROM 66 and to prevent the slow attrition of its contents by daylight.
- First, second, third and fourth light-emitting diodes (LED's) 70, 72, 74, 76 are provided in the sloping front of the case 60, directly driven via the key connector 42, for indicating key loading status in the encryption module 30.
- Figure 5 shows a schematic circuit diagram of the key loader 58.
- the key loader connector 62 provides a ground line 78 providing a common power return for the key loader 58.
- a first LED driving line 80 supplies illuminating power to the first LED 70
- a second LED driving line 82 provides illuminating power to the second LED 72
- a third LED driving line 84 provides illuminating power to the third LED 74
- a fourth LED driving line 86 provides illuminating power to the fourth LED 76, the first, second, third and fourth LED's 70, 72, 74, 76 each being coupled to the ground line 78 as the common return for the illuminating power.
- the key loader 58 comprises an erasable Read-Only Memory 88 corresponding to the ROM 66 of figure 4.
- the ROM 88 receives operational power via a power line 90.
- the ROM 88 receives a chip selecting input via a chip select line 92 in response whereto the ROM 88 is rendered operational either to receive or render up data.
- the ROM 88 receives a programming input signal via a programme line 94. If the voltage on the program line 94 exceeds a predetermined threshold value for. longer than a predetermined time and the signal is provided on the chip select line 92 the ROM 88 stores the data presented to it in the location addressed. If the ROM 88 is in receipt of the signal on the chip select line 92 alone, it renders up data stored in the location addressed.
- the ROM 88 is provide data on and renders up data to an 8-bit wide data bus 96 provided by the encryption module 30 and its locations are addressed via an 11-bit wide address bus 98.
- the ROM 88 comprises 2048 locations at each one of which an 8-bit parallel word can be stored.
- the encryption module 30 does not programme the ROM, and consequently the programme line 94 is not provided by the encyption module 30.
- the ROM 88 is pre-programmed at another, dedicated installation and it will be apparant to those skilled in the art how this can be done.
- the ROM 88 need not necessarily be ultra-violet erasable, but can be of the once-programmed variety where fuse links are blown and the like, in which case there is no need for the aperture 64 and the grommet 68.
- the ROM 88 can be mask-programmed before assembly into the key loader 58, in which case there is no need for providing programming facilities via the key loader connector 62.
- the ROM 88 can be of the electrically--alterable variety in which case there is no need for the aperture 64 or the grommet 68 but there is a requirement for a line for cancelling the information in an addressed location.
- Figure 6 shows a schematic circuit diagram of the encryption module 30.
- the encryption module 30 comprises a communication register 100 for providing communication with the internal processor 12 of the autoteller 10.
- the encryption module 30 further comprises an encryption control processor 102 which provides an encryption data bus 96 and an encryption address bus 98 for use as will later be described in the encryption module and for use as has already been described via the key connector 42 as the data bus 96 and the address bus 98 in the key loader 58.
- the communication register 100 is in receipt of the internal data bus 14 and of the internal address bus 16 from the internal processor 12 of the autoteller 10 and is also-in receipt of the encryption data bus 96 and of the encryption address bus 98.
- the internal processor 12 can address the communication register 100 to deposit a block of data therein for later retieval by the encryption control processor 102 and can address the communication register 100 to retieve therefrom a block of data previously deposited therein by the encryption control processor 102.
- a resident ROM 104 In association with the encryption control processor 102 and in receipt of the encryption data bus 96 and of the encryption address bus 98 there is provided a resident ROM 104, a volatile RAM 106 and a sustained secure RAM 108.
- the resident ROM 104 is pre-loaded with the operating instructions for the encryption control processor and its contents cannot be changed.
- the volatile RAM 106 is a random-access memory used as a temporary store by the encryption control processor 102.
- the control processor 102 can write data therein or retrieve data therefrom. When power is removed from the encryption module 30 the contents of the volatile RAM 106 are lost.
- the secure sustained RAM 108 is operated in.conjunction with a backup battery power supply 110 providing power thereto via a battery power line 112.
- the energy on the power line 112 is derived from the general source, not shown, provided via the first edge connector 50 which source also charges up a battery in the backup power supply 110.
- the backup power supply 110 provides battery potential on the power line 112 which can sustain the sustained secure RAM 108 for up to ten days.
- the ground return line 114 of the backup power supply 110 is seperately externalised on the first edge connector 50 and is coupled via an external link 116 on the first edge connector 50 to the main power supply ground 118 to the encryption module 30 also provided on the first edge connector 50.
- the ground return line 114 of the battery backup power supply 110 is coupled via the external link 116 to the supply ground 118 so that if power is removed from the autoteller 10 the battery will sustain the sustained RAM 108, since one side of the supply to the sustained RAM 108 is provided via the supply ground 118.
- the link 116 between the ground return line 114 and the power supply ground 118 is broken so that the battery backup power supply 110 is unable to sustain the secure sustained RAM 108 and its contents are lost. The same result ensues if the printed circuit board 48 is unplugged whilst power is still supplied to the autoteller 10.
- the encryption control processor 102 can write data into and retrieve data from the secure RAM 108.
- the secure RAM 108 is used to store data, such as encryption keys, which it is not for interlopers to discover, or subsequently use. Thus, if the encryption module 30 is removed, it is not possible upon subsequent investigation to discover secret information nor is it possible to employ the encryption module 30 elsewhere since all of the secret information necessary for the operation of the autoteller 10 is lost as soon as the encryption module 30 is unplugged.
- the encryption module 30 further comprises an : encryption block 120 coupled to receive the encryption data bus 96 and the encryption address bus 98.
- the encryption control processor 102 is operable to provide the encryption block 120, by a process of addressing and data supply, with a key for encryption, a data character to be encrypted and is operable to address the encryption block 120 to recover the encrypted or selectably decrypted data.
- the encryption module 30 comprises a flag comparator 122 once again coupled to receive the encryption data bus 96 and the encryption address bus 98 from the encryption control processor 102.
- the encryption control processor 102 deposits first and second predetermined flag characters in the flag comparator 122 and the flag comparator 122 provides indication on first and second 124 126 flag lines to a monitor circuit 128 of the presence of the flags.
- the monitor 128 also checks the-battery potential in the backup power supply 110 and detects when it falls below a predetermined value.
- the monitor circuit 128 provides activating signals to a LED driving circuit 130 operable to respond thereto to provide the illuminating energy to the first, second, third and fourth LED's 70, 72, 74, 76 via the first, second, third and fourth LED driving lines 80, 82, 84, 86 respectively.
- Figure 7 shows a schematic circuit diagram of the communication register 100 of figure 6.
- the communication register 100 comprises a first interface RA M 132 for the temporary storage of data to be transferred from the internal processor 12 to the encryption control processor 102 and a second interface RA M 133 for the temporary storage of data to be transferred from the encryption control processor 102 to the internal processor 12.
- the communication register is in receipt of the internal address bus 16 of the autoteller 10 and receives it as an input to a first address decoder 134.
- the communication register 100 is also in receipt of the encryption address bus 98, receiving it as an input on a second address decoder 136.
- the first address decoder 134 examiners the address on - the internal address bus 16 and, if it lies within first and second numerical limits, these limits indicating the boundaries of the address field used by the internal processor 12 for accessing the communication register 100, the first address decoder 134 provides output indicative thereof.
- the second address decoder 136 examines the address on the encryption address bus 98 and, if it lies between third and fourth numerical values, being the upper and lower limits of the address field used by the encryption control processor 102 to access the communication register 100, it provides output indicative thereof.
- the communication register 100 comprises a first address diplexer 138 in receipt of the internal address bus 16 as a first input and in receipt of the encryption address bus 98 as a second input.
- the output indication of the first address decoder 134 is coupled as a first controlling input to the first address diplexer 138 and the output indication of the second address decoder 136 is coupled as a second controlling input to the first address diplexer 138.
- the first address decoder 134 provides its output indication the first address diplexer 138 provides, - as its output, on the first interface RAM address bus 139, as the address input to the first interface RAM 132, the address on the internal address bus 16 of the internal processor 12, regardlessly of the indication provided by the second address decoder 136.
- the first address diplexer 138 When the second address decoder 136 provides its output indication, and the first , address decoder 134 does not provide its output indication, the first address diplexer 138 provides, as output on the first interface address bus 139, the address provided on the encryption address bus 98. When neither the first address decoder 134 nor the second address decoder 136 provides output indication, the first address diplexer 138 provides no output.
- the communication register 100 comprises a second address diplexer 140 in receipt of the internal address bus 16 as a first input and in receipt of the encryption address bus 98 as a second input.
- the output indication of the first address decoder 134 is provided as a first controlling input to the second address diplexer 140 and the output of the second address decoder 136 is provided as a second controlling input to the second address diplexer 140.
- the second address decoder 136 provides its output indication
- the second address diplexer 140 provides, as its output, regardlessly as to whether or not the first address decoder 134 is providing its output indication, on the second interface RAM address bus 141, the address supplied on the encryption address bus 98, as the address input to the second interface RAM 133.
- the second address diplexer 140 provides, as the address input to the second interface RAM 133 via the second interface RAM address bus 141-, the address supplied by the internal address bus 16 of the autoteller 10 internal processor 12.
- the second address diplexer 140 provides no output.
- the communication register 100 comprises a first bidirectional data diplexer 142, in receipt of the contents of the internal data bus 14 and selectably operable to couple the contents of the internal data bus 14 as data input onto a first interface RAM data bus 144.
- the first data diplexer 142 is also selectably operable to couple data provided by the first interface RAM 132 on the first interface R AM data bus 148 as input data onto the encryption data bus 14.
- the first data diplexer 142 receives the ouput of the first address decoder 134 as a first controlling input and receives the output of the second address decoder 136 as a second controlling input.
- the first data diplexer 142 couples the data on the internal data bus 14 as data input to the first interface RAM 132 via the first data interface RAM data bus 144.
- the second address decoder 136 provides its output indication and the first address decoder 134 does not provide its output indication
- the first data diplexer 142 couples output data, provided by the first interface RAM 132 via the first interface RAM data bus 144, onto the encryption data bus 96.
- the first data diplexer 142 neither accepts nor receives data.
- the communication register 100 further comprises a second data diplexer 146 coupled to the second interface RAM via a second interface RAM data bus 148, coupled to selectably receive data from the encryption data bus 96 onto the second interface RAM data bus 148, coupled to selectably provide data from the second interface RAM data bus 148 onto the internal data bus 14, coupled to receive the output of the first address decoder 134 as a first controlling input and coupled to receive the output of the second address decoder 136 as a second controlling input.
- a second data diplexer 146 coupled to the second interface RAM via a second interface RAM data bus 148, coupled to selectably receive data from the encryption data bus 96 onto the second interface RAM data bus 148, coupled to selectably provide data from the second interface RAM data bus 148 onto the internal data bus 14, coupled to receive the output of the first address decoder 134 as a first controlling input and coupled to receive the output of the second address decoder 136 as a second controlling input.
- the second data diplexer 146 couples the data presented on the encryption data bus 96 as input data to be stored by the second interface RAM 133 to the second interface RAM 133 via the second interface RAM data bus 148.
- the first address decoder 134 provides its output indication and the second address decoder 136 does not provide its output indication
- the second data diplexer 146 couples output data- ,from the second interface RAM 133 provided thereby on the second interface RAM data bus 148 as input to the internal data bus 14.
- the second data diplexer 146 neither accepts nor receives data.
- address decoders 134, 136, address diplexers 138, 140, data diplexers 142, 146 and RAMs 132, 133 described allows the internal processor 12 to have a pre-emptive access to the first interface RAM 132 for the deposition of data therein and a secondary right to access to the second interface RAM 133 for the retrieval of data therefrom and allows the encryption control processor 102 to have a pre-emptive right of access to the second interface RAM 133 for the deposition of data therein and a secondary right of access to the first interface RAM 132 for the retrieval of data therefrom.
- the internal processor 12 In operation, if the internal processor 12 wishes to pass data or instruction words to the encryption control processor 102, it first checks to see if the second address decoder 136 is providing its output indication. This is achieved by means of an interrogatable status register, not shown for reasons of simplicity, whose operation will be apparant to those skilled in the art. If the second address decoder 136 is providing its output indication the internal processor 12 waits until it ceases to do so. If there is no such indication the internal processor 12 proceeds immediately with data transfer. The internal processor 12. - calls up the address of the first location in both the first and second interface RAMs. However, contained within the address is an indication as to whether the internal processor 12 wishes to read or write data in the communication. register 100.
- the internal processor 12 If the internal processor 12 wishes to write data only the first interface RAM 132 is activated and if the internal processor 12 wishes to read data only the second interface RAM 133 is activated.
- the internal processor 12 addresses each of the locations in turn, either reading or writing data, in the RAMs 132, 133.
- the internal processor 12 deposits an instruction word indicating the nature of the following message, for example, indicating that the following data is to be encrypted in a certain manner.
- the internal processor 12 In a second location in the first interface RAM 132, if writing, deposits a length word indicating the number of data words following.
- the internal processor 12 retreives the word in.the first location of the second interface RAM 133 earlier deposited therein by the encryption control processor 102 indicative of the nature of the data following, e.g. data encrypted with a particular key, and then retreives the word in the second location of the second interface RAM 133 indicative of the number of data words following. If writing the internal processor 12 goes on to deposit the number of data words indicated and if reading the internal processor 12 goes on to retreive the number of data words indicated, in each case by incrementing the address on the internal address bus 16 through the appropriate sequence of addresses.
- the first and second interface. RAMs 132 133 are each capable of storing 1024 8-bit data words.
- the encryption processor 102 when wishing to operate through the communication register 100, looks to see if the first address decoder 134 is providing its output indication in the same way that the internal processor 12 looks to see if the second address decoder 136 is providing its output indication, waiting in the same manner until it alone wishes to access the communication register 100.
- the only difference between the manner of operation of the encryption control processor 102 and the manner of operation of the internal processor 12 lies in that the internal processor 12 deposits data in the first. interface RAM 132 and retrieves data from the second interface RAM 133 whereas the encryption control processor 102 deposits data in the second interface RAM 133 and retieves data from the first interface RAM 132. In this way the internal processor 12 and the encryption control processor 102 can pass plural-word data messages and identifying instructions between one another.
- the internal processor 12 deals with received messages, save as later described.
- the encryption control processor.102 data words are relieved one by one from locations in the volatile RAM 106 and transferred one by one to the appropriate locations in the second interface RAM 133. It is not possible for the encryption control processor 102 to recover data from the secure RAM 108 since to be able to acces the data therein would mean access to secret information. Thus the encryption control processor 102 is not provided with an instruction it can obey for transferring data from the secure RAM 108 to the communication register 100. However, the encryption control processor 102 can receive information , notably keys, for storage in the secure RAM 108. This is explained below.
- Figure 8 shows a schematic block diagram of the encryption block 120 of figure 6.
- the encryption block 120 comprises an input register 150 operable to receive a series of eight 8-bit data words from the encryption data bus 96 and present them as an input to an encryption circuit 152 via the encryption circuit input bus 154.
- the exact construction and manner of operation of the input register 150 is to be described below. At this stage it is enough to say that a 64-bit input word is assembled for parallel presentation to the encryption circuit 150.
- the encryption block 120 further comprises a key register 156.
- the key register 156 comprises eight 8-bit registers each coupled to receive an 8-bit word from the encryption data bus 96 to present a parallel -64-bit key word to the enctryption circuit 152 via the key bus 158.
- the encryption block 120 further comprises an output register 160 coupled to receive a 64-bit parallel encrypted or decrypted word from the encryption circuit 152 in eight 8-bit registers each individually addressable thereafter to render up their contents onto the encryption data bus 96.
- the encryption block 120 yet further comprises an encryption address decoder 164 coupled to receive the encryption address bus 98 and operable to provide an addressing signal to each of the 8-bit registers in the input register 150, the key register 158 and the output register 160.
- Each of the 8-bit registers constitutes a seperate address to the encryption control processor 102.
- the encryption address decoder 164 decodes the addresses on the encryption address bus 98 and provides a seperate activating signal to the selected one of the 8-bit registers whenever one of the 8-bit registers is.addressed.
- Each of the 8-bit registers receives its own individual activating signal via its own individual addressing line, symbolised in figure 8 by an input register address bus 166 being representative of the collection of addressing lines going to the 8-bit registers in the input register 150, an output register address bus 168 being representative of the collection of address lines going to the output register 160, and a key register address bus 170 being representative of the collection of address lines going to the 8-bit registers in the key register 156.
- control register 152 is a 1-bit control register seperately addressable via the encryption data bus 96 and the encryption address bus 98 decoded by the encryption address decoder 164 to accept one of the binary digits provided by the encryption data bus 96 , in just the same way as the 8-bit registers accept their inputs in, for example, the key register 156.
- the contents of the control register are coupled as a further input to the encryption circuit 152.
- the encryption circuit 152 responds to the content of the control register by encrypting the data provided by the input register 150 if the content of the control register is logically true and by decrypting the data provided by the input register 150 if the content of the control register is logically false.
- the encryption circuit 152 accepts a 64-bit input word from the input register 150, accepts a 64-bit key word from the key register 158, and provides a 64-bit encrypted or decrypted version of the input word to the output register 160.
- the encryption circuit 152 employed as part of the present invention in its preferred embodiment is characterised by the use of Integrated Circuit type WD 2001 made by Western Digital.Corporation and supporting an encryption algorithm defined in the United States National Bureau of Standards Data Encryption Standard (DES).
- DES National Bureau of Standards Data Encryption Standard
- Each of the 2 64 different possible key words provided to the key register 156 elicits a different one of 2 64 different scrambling patterns for the order of the 64 binary digits provided by the input register 150 to be altered before presentation to. the output register 160. If the encryption circuit 152 is ordered to encrypt the input register 150 data it-applies the selected scrambling pattern, and if ordered to decrypt, it applies the complementary "unscrambling" pattern of binary digit positions to
- encryption circuit 152 chosen by way of example to describe the action of the preferred embodiment of the present invention is not restrictive in its type.
- Systems encrypting and decrypting word lengths other than 64-bits are equally applicable, as are systems where input and key data can be supplied time-sequentially rather than in parallel.
- Those skilled in the art will be aware of the modifications to the preferred embodiment which would be required for the use of such alternative systems.
- the encryption control processor 102 loads the key word into the key register 156 8-bit word by 8-bit word until the key register 156 is full and the whole of the key word is therein.
- the encryption control processor 102 subject to the constraints to be described in connection with the construction and operation of the input register 150, then loads the input register 150 8-bit word by 8-bit word until the whole of the input word lies therein and the input register 150-is full.
- the encryption control processor 102 withdraws the resulting encrypted or decrypted result 8-bit word by 8-bit word from the output register 160.
- Figure 9 shows a schematic circuit diagram of the input register 150 of figure 8.
- the input register 150 comprises a direct register 172 coupled to receive the encryption data bus- 96 and eight addressing lines from the input register address bus 166 one for addressing each of eight 8-bit registers therein, the direct register 172 thereby being loadable with a 64 bit direct data word.
- the contents of the direct register 172 are provided as a 64-bit parallel word on a direct register output bus 174.
- the input register 150 further comprises a 64-bit cyphertext register 176 coupled to receive the encryption data bus 96 and a further eight addressing lines from the input register address bus, one for addressing each of eight 8-bit registers therein, the cyphertext register 176 thereby being loadable with a 64-bit cyphertext data word in the manner earlier described.
- the contents of the cyphertext register 176 are provided as a 64-bit parallel output on a cyphertext output bus 178.
- the input register 150 further comprises an exclusive-or array 180, in receipt of the 64-bit parallel direct data word as a first input, in receipt of the 64-bit parallel cyphertext data word as a second input, and operable to provide a 64-bit parallel exclusive-or output word on an exclusive-or output bus 182, where each binary digit in the exclusive-or output word represents the exclusive-or function of the pair of binary digits in the corresponding positions in the direct data word and the cyphertext data word, the exclusive or function being logically true if one or the other but not both of the corresponding binary digits is true and otherwise logically false, the relationship being clarified by the Boolean Equation where E is the binary digit in the Exclusive-or output word, D is the binary digit in the direct data word and C is the binary digit in the cyphertext data word.
- the input register 150 further comprises a cypher flip-flop register 184 in receipt of a single bit from the encryption data bus 96 via a single bit input line 186 and in receipt of a single address line 188 from the input register address bus 166 being decoded from the encryption address bus 98 by the encryption address decoder 164.
- the encryption control processor 102 is thereby able to cause the contents of the cypher flip-flop register 184 to assume a logically true or a logically false condition.
- the condition of the contents of the cypher flip-flop register 184 is coupled as a cypher output signal on a cypher output line 190.
- the input register 150 lastly comprises an encryption diplexer 192 in receipt of the 64-bit parallel direct data word as a first input, in receipt of the 64-bit parallel .
- exclusive-or output word as a second input, in receipt of of the cypher output signal as a controlling input, operable in response to the contents of the cypher flip-flop register 184 being logically false to provide as output, on the 64-bit wide encryption circuit input bus 154, the direct data word on the direct data output bus 174 and operable in response to the contents of the cypher flip-flop register 184 being logically true to provide, as output onto the encryption circuit input bus 154, the exclusive-or output word on the exclusive-or output bus 182.
- the encryption control processor 102 elects whether a straight encryption is required or a cyphertext operation. If straight encryption is required-the encryption control processor 102 addresses the cypher flip-flop register 184 and sets its contents to logically false, having the effect of causing the encryption diplexer 192 to provide, as the input to the encryption circuit 152 on the encryption circuit input bus 154, the contents of the direct register 172. The encryption control processor 102 then loads the direct register 174 with a 64-bit direct data word as described, waits, and accepts the encrypted word from the output register 160.
- the encryption control processor 102 addresses the cypher flip-flop register 184 and sets its content to being logically true. This has the effect of causing the encryption diplexer 192 to provide as the encryption circuit 152 input signal on the encryption circuit input bus 154 the exclusive-or..output word provided on the exclusive-or output bus 182 by the exclusive-or array 180.
- the input register 150 is then ready to commence a cyphertext operation for the cypher-encryption of data messages to and from the remote-host 22.
- the encyption control processor 102 In order to start the cyphertext operation the encyption control processor 102 must first load the cyphertext register 176 with a start word. It achieves this by loading, 8-bit word by 8-bit word, a 64-bit string of all ones into the eight 8-bit registers making up the cyphertext register 176.
- the start word chosen for preference in this instance is an all-zeros word, but this is by no means restrictive and those skilled in the art will be aware of many other start words which can be used.
- the encryption control processor 102 then loads the first eight 8-bit bytes of the message to be cyphertext encrypted into the direcet register 172.
- the exclusive or array 180 provides the encryption circuit 152 input bus 154 with the described exclusive-or function generated between the contents of the cyphertext register 176 and the direct register 172.
- the encryption control processor 102 waits and receives the output of the encryption circuit 152 from the output register 160, and this output is used as the first eight bytes of the cyphertext message.
- the encryption control processor 102 takes the first eight bytes of the cyphertext message and places it intotemporay storage in the volatile RAM 106.
- the encryption control processor 102 then retrieves the first eight bytes from the RAM 106 and loads them into the cyphertext register 176 .
- the encryption control processor 102 then loads the next eight bytes of the message to be cyphertext encrypted into the direct register 172, waits for the encryption circuit 152 to work and stores the result in the volatile RAM 106 as before, once again retrieving the result therefrom and placing it into the cyphertext register 176 and loading the direct register 172 with the next eight bytes,of the message to be cyphertext encrypted.
- the encryption control processor 102 takes the message to be cyphertext encrypted from its store in the RAM 106 by eight byte (64 bit) blocks and loads each bloek into the direct register 172, loading the cyphertext register 176 with the result of the previous encryption.
- the encryption circuit 152 then encrypts the result of forming the exclusive-or function between the contents of the direct register 172, namely the eight byte block of the data to be cyphertext encrypted and the previously cyphertext-encrypted eight byte block, being the contents of the cyphertext register 176.
- the encryption control processor 102 carries on until the whole of the message to be cyphertext encrypted is complete.
- the message is required to be an integral number of 64 bits long.
- the encryption control processor 102 looks to see if the key-loader 58 is present. It does so by calling up address 3000 hexadecimal..This is the address of the first location in the Read-Only memory 88 and contains a predetermined flag character. In this instance. the predetermined flag character is hexadecimal A, but it can any non-zero character desired. If the encryption control processor 102 sees data A at address 3000 hexadecimal it knows that the key loader 58 is plugged onto the key connector 42. In response the encryption control processor 102 jumps to execute the program starting at address 3001, this being the next address in the ROM 88.
- the programme in the ROM 88 is any programme that the autoteller owner wishes to employ to generate a master key word 64 bits long.
- the program has access to use of the encryption block, and to cyphertext encyption. In addition it can use any encryption alogithm of its own style that it pleases. It can start with any data that is chosen, and use any function available through the encryption control processor 102.
- the master key generation program is secret. and known only to the owner of the autoteller. In fact, the program does not even have to be known to the owner, since it is contained on the key loader 58.
- the key loader 58 when not in use is kept by a single bank official who does not need to know what is stored thereon.
- the encryption control processor 88 stores the 8-byte master key it has generated in a temporary location in the volatile RAM 106. It then places a predetermined flag character in the flag comparator 122 indicative of the master key having been loaded. Thereafter it signals to the internal processor 12 that it is ready to receive a session sub-key from the remote host 22. The internal processor 12 signals the host 22 to supply it with a session sub-key via the data link 20 and the serial data interface 18.. The remote host 22 then supplies a 64-bit session sub-key to the internal processor 12 which passes it in turn to the encryption control processor 102.
- the encryption control processor 102 loads the master key from its temporary location in the volatile RAM 106 into the key register 156 of the encyption block 120, loads the received session sub-key into the direct register 172, commands the cypher flip-flop register 184 to produce straight encryption, and accepts the output from the output register 160 as the session key.
- the encryption control processor 102 then destroys the contents of the temorary storage location in the volatile RAM 106 for the master key, storing the master key in the secure RAM 108 in a first predetermined location and storing the session key in the secure RAM 108 in a second predetermined location, scattering other data throughout the secure RAM so that it is not possible to determihe what data in the secure.
- RAM 108 represents keys.
- the encryption control processor 102 If, on inspection of memory location 3000 hexadecimal the encryption control processor 102 does not see A as stored data, then it knows that the key loader 58 is not present on the key connector 42. Accordingly, it retieves the master key from the predetermined location in the secure, sustained RAM 108 and sets the predetermined flag character in the flag comparator 122 if the master key passes its parity check. The encyption control processor 102 then continues as before as if the master key had been loaded by the key loader 58. In either case, as soon as the session key has been successfully loaded from the remote host 22 and encrypted using the master key, the encryption control processor 102 sets a second predetermined flag character in the flag comparator 122 indicative of the successful loading of the session key.
- the session key is used thereafter for the encryption and decryption of data recorded on the card presented to,the autoteller 10 by the prospective user.
- the manner of use is not restrictive, but, purely by way of example, the autoteller 10 can read a card, the internal processor 12 . commanding the card reader 24 .
- the card reader 24 transfers the data it obtains into temporary storage in the internal processor 12.
- the internal processor 12 sends the data, or some selected part of the data from the card, in a block via the communication register 100, together with an instruction as to whether the data is to be encrypted or decrypted. to the encryption module 30.
- the encryption module 30 obeys the instruction, as will become clear from later description, within a predetermined range of operations.
- the encryption module 30 returns the operated-upon data back to the internal processor 12.
- the internal processor 12 can, if it is so desired, command the keyboard 26 to render up its entered number and transfer that number to the encryption module 30 for encryption or decryprion, the encryption module 30 returning the result to the internal processor 12:
- the internal processor 12 can then operate in any desired manner according to any desired algorithm chosen by the owner of the autoteller upon the data derived from the card reader 24 and from the keyboard 26 to determine whether a desired correspondence exists between the number entered on the keyboard 26 and the data from the card reader 24, validating the user's right to employ the card. Thereafter the autoteller 10 can dispense money to the user or not dependently upon whether the correspondence exists and upon whether the host system 22 allows such an action after authorisation communication therewith.
- the master key being loaded soley via the key loader 58. It is to be appreciated that, at the discretion of the owner of the autoteller 10, the master key can be loaded from the remote host system 22. This permits the owner to employ any measure of security that he so desires.
- the internal processor 12 commands the encryption module 30 merely to echo back the message it receives for the encryption module 30 to act as a temporary store and as a possible confidence test upon the encryption module 30.
- the encryption control processor 102 takes the subsequent data words into temporary storage in the volatile RAM 106.
- the encryption control processor 102 returns the temporarily stored data to the communication register 100 for provision back to the internal processor 12, causing the first character in the second interface RAM 133 to be hexadecimal 50, indicatively of the following data being echoed data.
- the internal processor 12 is commanding the encryption module 30 to encrypt the following block of data by blocks of 64 bits using the session key.
- the session key is recovered from its secure location in the sustained RAM 108 and loaded into the key register 156. Straigh encryption is then performed as earlier described.
- the encryption control processor 102 loads the result thereof from the volatile RAM 106 into the second interface RAM 133, causing the first character therein to be hexadecimal 51 to indicate to the internal processor 12 that the following block of data has been encrypted using the session key.
- Such an instruction and response can be used on data read from a user's card.
- the internal processor 12 is commanding the encryption module 30 to decrypt the following block of data using the session key.by blocks of 64 bits.
- the session key is recovered from its secure location and loaded into the key register 156. Straight decryption is'.then performed as earlier described.
- the encryption control processor 102 loads the result thereof from the volatile RAM 106 into the second interface RAM 133 causing the first character therein to be hexadecimal 52 indicative to the internal processor 12 of the following block of data having been decrypted using the session key.
- the internal processor 12 is commanding the encryption control processor 102 to accept the following eight bytes of data as the session key.
- the encryption control processor 102 loads the eight bytes directly into the secure locations earlier de described in the secure RAM 108.
- the encryption module 30 then signals back to the internal processor 12 that the session key has been loaded by setting a binary digit in a device status register, not shown, whose operation will be apparant to those skilled in the art and which can be interrogated by the internal processor. 12.
- the internal processor 12 is commanding the encryption control processor 102 to accept the following eight bytes of data as a session sub-key and to encrypt them using the master key before storage in the secure RAM 108 as the session key.
- the encryption control processor 102 responds thereto as indicated, and, as before,sets the binary digit in the status register indicative of the session key having been loaded.
- the internal processor 12 is commanding the encryption control processor 102 to accept the following eight bytes of data as a session sub-key and to decrypt them using the master key before storage in the secure RAM 108 as the session key.
- the encryption control processor 102 responds thereto as indicated and, as before, sets the binary digit in the status register indicatively of the the session key having been loaded.
- the internal processor 12 is commanding the encryption control processor 102 to clear the session key.
- the encryption control processor 102 responds by clearing the secure location in the secure RAM 108 whereat the eight 8-bit bytes of the session key are stored and by resetting the binary digit in the status register now indicatively of the session key no longer being loaded.
- the encryption control processor 102 also unloads the predetermined-flag character from the flag comparator 122 so that it no longer provides indication of the session key being loaded.
- the internal processor 12 is commanding the encryption control processor to clear all flags.
- the encryption control processor 102 responds by resetting all status flags, resetting all indications to the flag comparator 122 so that it no longer provides indication of the session or master keys being loaded and by clearing the entire contents of the secure RAM 108, inclusively of the master key, so that fresh keys must be loaded before operation can continue. As will become clear from later description, this can include a plurality of communications keys stored therein.
- the internal processor 12 is commanding the encryption control processor 102 to load the following eight 8-bit characters as the master key, this time supplied by the remote host system 22, directly into the secure RAM 108 location reserved for it and to provide the predetermined character to the flag comparator 122 for it to provide output indication of - the master key having been loaded, and to set an appropriate flag in the device status register (not shown).
- the internal processor 12 is commanding the encryption control processor 102 to provide c yphertext encryption, using the session key, in the manner already described, for the data following.
- the encryption control processor 102 responds by taking the cyphertext encrypted data from temporary storage in the volatile RAM 106 and loading it into the second interface RAM 133, making the first character therein hexadecimal 59 indicatively of the following data having been cyphertext encrypted.
- the internal processor 12 is commanding the encryption control processor 102 to cyphertext decrypt the following block of data in the same manner as the already described cyphertext encryption save that the decryption facility of the encryption circuit 152 is selected.
- the encryption control,processor 102 takes the cyphertext decrypted message from temporary storage in the volatile RAM 106 and places it into the second interface RAM 133 making the first word therein hexadecimal 5A indicatively to the internal processor 12 of the following block of data having been cyphertext decrypted.
- the autoteller system 10 also comprises means for the transmission and reception of secure messages between the external host system 22 and the internal processor 12 using a selectable one out of a plurality of communication keys.
- the internal processor 12 examines the status register, already described but not shown in the drawings, whereby the encryption control processor 102 signals to the internal processor 12 that all has been carried out successfully, and, if all is in order, signals to the external host system 22 that it isiready to receive communications keys or communication sub-keys.
- the internal processor 12 receives an indication from the external host system 22 that the following stream of binary digits represents a serialisation of an ordered succession of one hundred 64-bit communication keys or communication sub-keys.
- the external host 22 also indicates if the following binary digits are actual keys or are sub-keys.
- the internal processor 12 assembles the stream of binary digits into a succession of 8-bit bytes for provision to the encryption control processor. 102.
- the internal processor 12 is commanding the encryption control processor 102 to accept the following eight hundred ordered bytes of data as communications keys.
- the encryption control processor 102 strips out the data in eight-byte blocks i.e. 64 bit blocks and stores each block in a predetermined location in the secure RAM 108 such that each block can be located by the calling up of its serial number. That is to say, by calling up the first block, the block first presented to the first interface RAM 132 is obtained, by calling up the fifteenth block the fifteenth block stored in the first interface RAM is obtained, and so on so that each block can be accessed merely by calling up its number lying between 1 and 100.
- Each stored block of 64 bits becomes a communication key.
- the encryption control processor 102 thereafter sets a binary digit in the device status register, (already mentioned but not shown) indicatively to the internal processor 12 of the communication keys having been loaded.
- the internal processor 12 is commanding the encryption control processor 102 to accept the following succession of eight hundred ordered 8-bit bytes of data as communication sub-keys.
- the encryption control processor 102 strips out the data in eight-byte blocks and encrypts them using the master key, once again storing the result of the encryption as a succession of communication keys in the secure RAM 108, each one being individually recallable by the provision of the number 1 to 100 indicative of the serial order of its receipt among the other communication keys.
- the internal processor 12 is internal processor 12 is commanding the encryption control processor 102 to accept the following succession of eight hundred ordered 8-bit bytes of data as communication sub-keys, to be operated upon in just the same manner as if the first word stored had been hexadecimal 3C, save that the decryption function of the encryption circuit 152 is selected as opposed to the encryption function.
- the internal processor 12 is commanding the encryption control processor 112 to encrypt the following message using an elected communication key.
- the second word stored in the first interface RAM 132 indicates how many data words follow. If the first word is 40 the encryption control processor 102 interprets the third word stored therein as indicating which of the hundred communication keys is to be used. The third word is therefore a number elected by the internal processor 12 via the external host system 12 from 1 to 100 for data communication purposes. The eleceted elected communication key is loaded into the key register 156 and encryption of the remaining contents of the first interface RAM proceeds as before described.
- the encryption control processor 102 deposits the result of the encryption from temporary storage in the volatile RAM 106 into the second interface register 133 making the first word therein 60 to indicate to the internal processor 12 that encryption using a communication key has taken place on the following data, making the second word indicative of the serial number of the communication key employed, and indicating in the third word the number of following data words.
- the internal processor 12 is commanding the encryption control processor 102 to decrypt the following message using an elected communication key. All takes place as before as if the first word had been hexadecimal 40, save that the decryption function of the encryption circuit 152 is selected and the encryption control processor 102 makes the first word in the second interface RAM 133 hexadecimal 61 as opposed to hexadecimal 60, indicating to the internal processor 12 that the following data stored therein has been decrypted using the communication key elected in the third word therein.
- the internal processor 12 is commanding the encryption control processor 102 to cyphertext encrypt the following data using the communication key elected in the third word stored therein.
- Cypheretext encryption takes place as before described with the elected communication key loaded into the key register 156 from the secure RAM 108.
- the encryption control processor 102 deposites the result of the cyphertext encryption into the second interface RAM 133 making the first word therein hexadecimal 63 indicating to internal processor 12 that the following data has been cyphertext encrypted using the communication key indicated by the number stored in the third location therein.
- the internal processor 12 is commanding the encryption control processor 102 to cyphertext decrypt the the following data using the communication key elected in the third word stored therein. All takes place as if the first word were hexadecimal 43 save that the decryption facility of the encryption circuit 152 is selected and that the encryption control processor 102 makes the first word stored in the second interface RAM 133 hexadecimal 64 to indicate to the internal processor 102 that the following data has been cyphertext decrypted using the communication key elected in the third word stored therein.
- the host 22 indicates with each message which of the keys is to be used in what manner, and the internal processor 12 responds by causing the encryption control processor 102 to operate upon the received data in the selected manner to generate the communication text, the internal processor 12 applying the inverse command to the encryption control processor 102 for the rendering t unintelligible of data for transmission from the internal processor 12 to the host 22.
- the monitor 128 causes the first LED 70 to be lit if the master key has not been loaded, causes the second LED 72 to be lit if the master key has not been loaded and the encryption control processor 102 does not detect the presence of the key loader 58, causes the third and fourth LEDS 76, 78 to be lit if the master key has been loaded but the battery terminal voltage is low, and causes the fourth LED 78 alone to be lit if the master key has been successfully loaded and the unit in operational.
- the.security personnel in charge of the key loader 58 can chart the course of the loading of the master key and are provided in some small part with a diagnosis of at least the symptom if not the cause of malfunction in the event of the autoteller system 10 failing to operate.
- monitor circuit 128 While the monitoring operation employed to light the LEDs 72 74 76 78 in response to internal conditions in the encryption module 30 has heretofore been described using a monitor circuit 128, it is to be appreciated that the function of the monitor circuit 128 could be absorbed into the overall operation of the encryption control processor 102 which can set and reset latches and the like in response to its internal states to drive the LEDs 72 70 74 76.
Landscapes
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Storage Device Security (AREA)
- Financial Or Insurance-Related Operations Such As Payment And Settlement (AREA)
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
GB08234568A GB2131586B (en) | 1982-12-03 | 1982-12-03 | Autoteller systems |
GB8234568 | 1982-12-03 |
Publications (3)
Publication Number | Publication Date |
---|---|
EP0111381A2 true EP0111381A2 (fr) | 1984-06-20 |
EP0111381A3 EP0111381A3 (en) | 1986-03-05 |
EP0111381B1 EP0111381B1 (fr) | 1988-11-02 |
Family
ID=10534726
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
EP83304907A Expired EP0111381B1 (fr) | 1982-12-03 | 1983-08-25 | Distributeurs automatiques de billets |
Country Status (4)
Country | Link |
---|---|
EP (1) | EP0111381B1 (fr) |
JP (1) | JPS59170970A (fr) |
DE (1) | DE3378383D1 (fr) |
GB (1) | GB2131586B (fr) |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
GB2194419A (en) * | 1986-08-08 | 1988-03-02 | British Broadcasting Corp | Data encipherment |
EP0285520A1 (fr) * | 1987-04-03 | 1988-10-05 | Bull Cp8 | Procédé pour acheminer des clés secrètes vers des modules de sécurité et des cartes utilisateurs, dans un réseau de traitement d'informations |
FR2616937A1 (fr) * | 1987-06-17 | 1988-12-23 | Bonnaval Lamothe Michel | Transcodeur de controle du processus de lecture-comparaison d'un document code |
EP0305004A1 (fr) * | 1987-08-28 | 1989-03-01 | Koninklijke Philips Electronics N.V. | Système de transactions comprenant un ou plusieurs échangeurs-hôte et un nombre de stations terminales distribuées, pouvant être accouplées à n'importe quel échangeur-hôte via un réseau; concentrateur et station terminale adaptée pour être utilisée dans un tel système de transactions, et élément d'identification d'un opérateur utilisable dans une telle station terminale |
EP0355372A1 (fr) * | 1988-07-20 | 1990-02-28 | SPA Syspatronic AG | Terminal commandé par support de données dans un système d'échange de données |
Families Citing this family (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
DK190784D0 (da) * | 1984-04-12 | 1984-04-12 | Pengeinst Koebe Kreditkort | Fremgangsmaade og apparat til datatransmission |
JPH0814841B2 (ja) * | 1986-03-10 | 1996-02-14 | 株式会社日立製作所 | 画像データ不正防止方法 |
USRE35403E (en) * | 1987-01-07 | 1996-12-17 | Miu Industries Ltd. | Encryption printed circuit board |
GB2376124A (en) * | 2001-05-23 | 2002-12-04 | Yong Hock Lawrence Sim | Currency conversion machine |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US3956615A (en) * | 1974-06-25 | 1976-05-11 | Ibm Corporation | Transaction execution system with secure data storage and communications |
EP0002388A1 (fr) * | 1977-12-05 | 1979-06-13 | International Business Machines Corporation | Terminal pour le traitement de données |
DE3023427A1 (de) * | 1979-06-28 | 1981-01-08 | Gretag Ag | Mobiler datenbehaelter |
WO1981002655A1 (fr) * | 1980-03-10 | 1981-09-17 | M Sendrow | Systeme d'authentification d'usager et dispositifs dans des reseaux de transactions en direct |
-
1982
- 1982-12-03 GB GB08234568A patent/GB2131586B/en not_active Expired
-
1983
- 1983-08-25 EP EP83304907A patent/EP0111381B1/fr not_active Expired
- 1983-08-25 DE DE8383304907T patent/DE3378383D1/de not_active Expired
- 1983-10-20 JP JP58197465A patent/JPS59170970A/ja active Pending
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US3956615A (en) * | 1974-06-25 | 1976-05-11 | Ibm Corporation | Transaction execution system with secure data storage and communications |
EP0002388A1 (fr) * | 1977-12-05 | 1979-06-13 | International Business Machines Corporation | Terminal pour le traitement de données |
DE3023427A1 (de) * | 1979-06-28 | 1981-01-08 | Gretag Ag | Mobiler datenbehaelter |
WO1981002655A1 (fr) * | 1980-03-10 | 1981-09-17 | M Sendrow | Systeme d'authentification d'usager et dispositifs dans des reseaux de transactions en direct |
Non-Patent Citations (2)
Title |
---|
Federal Information, Processing Standards Publication No. 46, "Data Encryption Standard" * |
No relevant documents found * |
Cited By (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
GB2194419A (en) * | 1986-08-08 | 1988-03-02 | British Broadcasting Corp | Data encipherment |
EP0285520A1 (fr) * | 1987-04-03 | 1988-10-05 | Bull Cp8 | Procédé pour acheminer des clés secrètes vers des modules de sécurité et des cartes utilisateurs, dans un réseau de traitement d'informations |
FR2613565A1 (fr) * | 1987-04-03 | 1988-10-07 | Bull Cps | Procede pour acheminer des cles secretes vers des modules de securite et des cartes utilisateurs, dans un reseau de traitement d'informations |
US4910773A (en) * | 1987-04-03 | 1990-03-20 | Cii Honeywell Bull (Societe Anonyme) | Method of dispatching secret keys to security modules and user cards in a data processing network |
FR2616937A1 (fr) * | 1987-06-17 | 1988-12-23 | Bonnaval Lamothe Michel | Transcodeur de controle du processus de lecture-comparaison d'un document code |
EP0305004A1 (fr) * | 1987-08-28 | 1989-03-01 | Koninklijke Philips Electronics N.V. | Système de transactions comprenant un ou plusieurs échangeurs-hôte et un nombre de stations terminales distribuées, pouvant être accouplées à n'importe quel échangeur-hôte via un réseau; concentrateur et station terminale adaptée pour être utilisée dans un tel système de transactions, et élément d'identification d'un opérateur utilisable dans une telle station terminale |
EP0355372A1 (fr) * | 1988-07-20 | 1990-02-28 | SPA Syspatronic AG | Terminal commandé par support de données dans un système d'échange de données |
US5093862A (en) * | 1988-07-20 | 1992-03-03 | Spa Syspatronic Ag | Data carrier-controlled terminal in a data exchange system |
Also Published As
Publication number | Publication date |
---|---|
JPS59170970A (ja) | 1984-09-27 |
DE3378383D1 (en) | 1988-12-08 |
GB2131586B (en) | 1985-11-20 |
EP0111381A3 (en) | 1986-03-05 |
GB2131586A (en) | 1984-06-20 |
EP0111381B1 (fr) | 1988-11-02 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP0138386B1 (fr) | Carte d'identification | |
EP0243873B1 (fr) | Système d'identification à carte à circuit intégré comprenant des moyens d'évaluation du temps de vérification de NIP | |
US5148534A (en) | Hardware cartridge representing verifiable, use-once authorization | |
US4816656A (en) | IC card system | |
US5008936A (en) | Backup/restore technique in a microcomputer-based encryption system | |
US5175766A (en) | Signalling scheme for controlling data encryption device in an electronic fund transaction processing system | |
US4650975A (en) | IC card and an identification system thereof | |
US5016277A (en) | Encryption key entry method in a microcomputer-based encryption system | |
EP0377706B1 (fr) | Systeme de manipulation sans danger de cles de chiffrement | |
EP0932124B1 (fr) | Circuit intégré et carte à puce avec un tel circuit | |
CN1234125A (zh) | 具有多个启用存储区段的数据的灵巧卡读卡机 | |
EP0212615B1 (fr) | Carte à circuit intégré | |
EP0114522A2 (fr) | Dispositif de protection de mémoire morte | |
EP0111381B1 (fr) | Distributeurs automatiques de billets | |
NO311545B1 (no) | Sikkert brukerkort for deling av brukerdata og prosedyrer blant en rekke mikroprosessorer | |
US5636281A (en) | Method and device to authorize access to an instrument comprising a computerized operating system | |
US5128996A (en) | Multichannel data encryption device | |
US4997288A (en) | Power supply arrangement for fault-tolerant operation in a microcomputer-based encryption system | |
GB2321728A (en) | Smart card having separate memory and scrambler for interaction therewith | |
EP0121853A2 (fr) | Système de traitement de données à clé de chiffrement publique et à clé de déchiffrement privée | |
US5123047A (en) | Method of updating encryption device monitor code in a multichannel data encryption system | |
US5796092A (en) | IC card and IC card system | |
EP0298776B1 (fr) | Système de machine à affranchir | |
GB2247551A (en) | Banking terminal | |
CA2327728A1 (fr) | Systeme de transaction de donnees protege |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PUAI | Public reference made under article 153(3) epc to a published international application that has entered the european phase |
Free format text: ORIGINAL CODE: 0009012 |
|
17P | Request for examination filed |
Effective date: 19830907 |
|
AK | Designated contracting states |
Designated state(s): BE CH DE FR LI NL SE |
|
PUAL | Search report despatched |
Free format text: ORIGINAL CODE: 0009013 |
|
AK | Designated contracting states |
Kind code of ref document: A3 Designated state(s): BE CH DE FR LI NL SE |
|
RAP1 | Party data changed (applicant data changed or rights of an application transferred) |
Owner name: BURROUGHS CORPORATION (A DELAWARE CORPORATION) |
|
17Q | First examination report despatched |
Effective date: 19870204 |
|
RAP1 | Party data changed (applicant data changed or rights of an application transferred) |
Owner name: UNISYS CORPORATION |
|
GRAA | (expected) grant |
Free format text: ORIGINAL CODE: 0009210 |
|
AK | Designated contracting states |
Kind code of ref document: B1 Designated state(s): BE CH DE FR LI NL SE |
|
REF | Corresponds to: |
Ref document number: 3378383 Country of ref document: DE Date of ref document: 19881208 |
|
ET | Fr: translation filed | ||
PLBE | No opposition filed within time limit |
Free format text: ORIGINAL CODE: 0009261 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: NO OPPOSITION FILED WITHIN TIME LIMIT |
|
26N | No opposition filed | ||
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: SE Payment date: 19920715 Year of fee payment: 10 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: BE Payment date: 19920909 Year of fee payment: 10 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: CH Payment date: 19920925 Year of fee payment: 10 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: FR Payment date: 19930808 Year of fee payment: 11 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: DE Payment date: 19930825 Year of fee payment: 11 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: SE Effective date: 19930826 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: LI Effective date: 19930831 Ref country code: CH Effective date: 19930831 Ref country code: BE Effective date: 19930831 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: NL Payment date: 19930831 Year of fee payment: 11 |
|
BERE | Be: lapsed |
Owner name: UNISYS CORP. Effective date: 19930831 |
|
REG | Reference to a national code |
Ref country code: CH Ref legal event code: PL |
|
EUG | Se: european patent has lapsed |
Ref document number: 83304907.5 Effective date: 19940310 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: NL Effective date: 19950301 |
|
NLV4 | Nl: lapsed or anulled due to non-payment of the annual fee | ||
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: FR Effective date: 19950428 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: DE Effective date: 19950503 |
|
REG | Reference to a national code |
Ref country code: FR Ref legal event code: ST |