EP0332117B1 - Portable electronic apparatus - Google Patents

Portable electronic apparatus Download PDF

Info

Publication number
EP0332117B1
EP0332117B1 EP89103927A EP89103927A EP0332117B1 EP 0332117 B1 EP0332117 B1 EP 0332117B1 EP 89103927 A EP89103927 A EP 89103927A EP 89103927 A EP89103927 A EP 89103927A EP 0332117 B1 EP0332117 B1 EP 0332117B1
Authority
EP
European Patent Office
Prior art keywords
area
data
directory
link
indicating
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.)
Expired - Lifetime
Application number
EP89103927A
Other languages
German (de)
French (fr)
Other versions
EP0332117A2 (en
EP0332117A3 (en
Inventor
Yasuo C/O Patent Division Iijima
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Toshiba Corp
Original Assignee
Toshiba Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from JP63055376A external-priority patent/JP3017736B2/en
Priority claimed from JP63200017A external-priority patent/JPH0250286A/en
Application filed by Toshiba Corp filed Critical Toshiba Corp
Publication of EP0332117A2 publication Critical patent/EP0332117A2/en
Publication of EP0332117A3 publication Critical patent/EP0332117A3/en
Application granted granted Critical
Publication of EP0332117B1 publication Critical patent/EP0332117B1/en
Anticipated expiration legal-status Critical
Expired - Lifetime legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K19/00Record carriers for use with machines and with at least a part designed to carry digital markings
    • GPHYSICS
    • G07CHECKING-DEVICES
    • G07FCOIN-FREED OR LIKE APPARATUS
    • G07F7/00Mechanisms actuated by objects other than coins to free or to actuate vending, hiring, coin or paper currency dispensing or refunding apparatus
    • G07F7/08Mechanisms 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/10Mechanisms 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/1008Active credit-cards provided with means to personalise their use, e.g. with PIN-introduction/comparison system
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q20/00Payment architectures, schemes or protocols
    • G06Q20/30Payment architectures, schemes or protocols characterised by the use of specific devices or networks
    • G06Q20/34Payment architectures, schemes or protocols characterised by the use of specific devices or networks using cards, e.g. integrated circuit [IC] cards or magnetic cards
    • G06Q20/341Active cards, i.e. cards including their own processing means, e.g. including an IC or chip
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q20/00Payment architectures, schemes or protocols
    • G06Q20/30Payment architectures, schemes or protocols characterised by the use of specific devices or networks
    • G06Q20/34Payment architectures, schemes or protocols characterised by the use of specific devices or networks using cards, e.g. integrated circuit [IC] cards or magnetic cards
    • G06Q20/357Cards having a plurality of specified features
    • G06Q20/3576Multiple memory zones on card
    • G06Q20/35765Access rights to memory zones
    • GPHYSICS
    • G07CHECKING-DEVICES
    • G07FCOIN-FREED OR LIKE APPARATUS
    • G07F7/00Mechanisms actuated by objects other than coins to free or to actuate vending, hiring, coin or paper currency dispensing or refunding apparatus
    • G07F7/08Mechanisms 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/10Mechanisms 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

Definitions

  • the present invention relates to a portable electronic apparatus, called an IC card, incorporating an IC (Integrated Circuit) chip having a nonvolatile memory and a control element such as a CPU and, more particularly, to an area access method of the memory.
  • IC Integrated Circuit
  • IC card incorporating an IC chip having an erasable nonvolatile memory and a control element such as a CPU has been developed as a new portable data storage medium.
  • ID identification
  • the IC card has a means for permitting an access to its internal memory only when a collating result between an externally input ID number and a registered ID number is affirmative.
  • the IC card is considered as a data storage medium having a high secrecy.
  • a memory In use, a memory is divided into a plurality of areas so as to cope with a variety of applications. Each area is logically accessed as an object to be accessed. Therefore, since a physical data storage position of the memory cannot be externally known, high secrecy can be assured. Since an access is logically made, external memory management can be facilitated.
  • Each area of the memory has inherent ID data, called an area number.
  • the ID data is designated in instruction data, the IC card identifies a destination of area access, and recognizes a physical storage position to access the area.
  • a single IC card may be utilized as a cash card for a bank, a credit card, a leisure card, an electronic memorandum card, and the like.
  • a single IC card is utilized as a cash card for a bank and a credit card
  • a holder of the cash card and the credit card is the same person, it is preferable that a holder's name, address, telephone number, and the like are commonly stored so as to effectively use a memory area.
  • the common holder can be accessed when either the cash or credit card is used.
  • the IC card When a given area in the IC card is used as a bankbook, the IC card must be arranged so that the given area can be accessed by a bank but cannot be accessed by a credit card company for the purpose of keeping secrecy.
  • a problem may be posed in updating processing of a holder.
  • a woman changes her surname upon marriage, she updates a holder's name of the cash card but does not update a holder's name of the credit card.
  • This causes a problem in use of an IC card.
  • a single holder's name common to the cash card and the credit card is preferably registered in a specific area of an IC card.
  • the IC card preferably has a common data field which can be accessed regardless of applications, and an application data field in which an area corresponding to a given application can be accessed and cannot be accessed in other applications.
  • a portable electronic apparatus of the present invention comprises memory means which is divided into a plurality of data area groups, individual identification data being assigned to each area, and at least two different identification numbers being assigned to at least one area, and control means for selecting the area based on external input identification data.
  • memory means which is divided into a plurality of data area groups, individual identification data being assigned to each area, and at least two different identification numbers being assigned to at least one area, and control means for selecting the area based on external input identification data.
  • Fig. 1 shows an arrangement of a terminal apparatus handling an IC card as a portable electronic apparatus according to the present invention. More specifically, the terminal apparatus has an arrangement wherein IC card 1 can be connected to control section 3 comprising, e.g., a CPU through card reader/writer 2, and control section 3 is connected to keyboard 4, CRT display 5, printer 6, and floppy disk device 7.
  • control section 3 comprising, e.g., a CPU through card reader/writer 2
  • control section 3 is connected to keyboard 4, CRT display 5, printer 6, and floppy disk device 7.
  • IC card 1 is held by a user, and performs collating of an ID number which is known by only the user, storage of necessary data, and the like upon purchasing an article at a store or the like.
  • the IC card is constituted by a portion for executing basic functions including read/write section 11, PIN setting/collating section 12, and encrypting/decrypting section 13, and supervisor 14 for managing these basic functions.
  • Read/write section 11 is a function of reading, writing, or erasing data with respect to data memory 16.
  • PIN setting/collating section 12 is a function of performing read/write inhibition processing a PIN (personal identification number) set by the user, and collating the PIN to permit subsequent processing after the user sets the PIN.
  • Encrypting/decrypting section 13 is a function of encrypting data in order to prevent disclosure and counterfeit of communication data when data is transmitted from control section 34 to another terminal apparatus, and decrypting encrypted data in accordance with an algorithm such as the DES (Data Encryption Standard) having a sufficient code strength.
  • Supervisor 14 is a function of decoding a function code input from card reader/writer 2, and selecting and executing a necessary function of the basic functions.
  • IC card 1 comprises control element (control section) 15 such as a CPU, data memory (memory section) 16, program memory 17, and contactor 18 for achieving an electrical contact with card reader/writer 2, as shown in Fig. 3.
  • control element 15, data memory 16, and program memory 17 are constituted by one IC chip (or a plurality of IC chips), and is embedded in an IC card main body.
  • Program memory 17 comprises, e.g., a mask ROM, and stores a control program for control element 15, which has subroutines for realizing the basic functions.
  • Data memory 16 is used for storing various data, and comprises, e.g., an erasable nonvolatile memory such as an EEPROM.
  • Data memory 16 is divided into a plurality of areas, as shown in Fig. 4.
  • the areas can be roughly classified into directory name storage area 21, area definition data storage area 23, area group storage area 25, and area group start address storage area 27.
  • Directory name storage area 21 stores names of directories unique to a particular memory structure used, and consists of directory name data 29 and directory identification (ID) data 31, as shown in Fig. 5.
  • Area definition data storage area 23 stores area definition data 30 for defining positions of areas under the directories defined by the memory structure, and consists of directory ID data 33, area number data 35, area start address data 37, area size data 39, area link data 41, and link destination designation data 43, as shown in Fig. 6.
  • Directory ID data 33 indicates a directory to which an area defined by area definition data 30 belongs, and is associated with directory ID data 31 corresponding to directory name data 29 shown in Fig. 5. Note that when directory ID data 33 is "00", it can be identified that the corresponding area does not belong to any directory.
  • Area number data 35 indicates a number for designating an area when an area under a directory is to be accessed.
  • Area start address data 37 and area size data 39 indicate a physical position of an area defined by area definition data 30 in area group storage area 25 shown in Fig. 7.
  • Area link data 41 is used for identifying whether an area defined by area definition data 30 is area-registered or area-link registered. Note that if the area is area-registered, data 41 is given by "00", and link destination data 43 appended thereafter is made invalid. If the area is area-link registered, data 41 is given by "01”, and the link destination designation data designated thereafter is made invalid. In this case, previous start address data 37 and area size data 39 are made invalid.
  • the link destination designation data is data for indicating an area which is linked with the area defined by area definition data 30, and provides directory ID data 33 and area number data 35 of the designated link destination area.
  • Fig. 6A five areas are defined, and their physical positions are as shown in Fig. 7. For example, area A having area start address data "A01" and area size data "S01" is registered to have an area number "08". Since directory ID data 33 of area A is "00", this indicates that area A does not belong to any directory.
  • area B is an area under a directory named "BBB”, and is registered to have area number "01".
  • area D is an area under a directory named "CCC”, and is registered to have area number "01”.
  • Area group start address storage area 27 stores data indicating areas assigned to an area group. If no areas are assigned, the data in area 27 indicates a final address value of area group storage area 25. After area A is assigned, the data is represented by a value obtained by subtracting "1" from the value "A01", and is updated every time an area is assigned.
  • Figs. 8A and 8B show the relationship between areas and directories. As shown in Figs. 8A and 8B, areas C and E belong to directory "AAA”, and are provided with area numbers "01" and "03", respectively. Area B belongs to directory “BBB”, and has area number "01). Area D belongs to directory "CCC”, and has area number "01". Note that area A does not belong to any directory, and has area number "08".
  • a steady state corresponds to an instruction standby state. If instruction data is input in step 51, control element 15 checks in step 53 if the input instruction data is directory name registration instruction data 52 shown in Fig. 10. If NO in step 53, control element 15 executes another processing.
  • control element 15 refers to directory name storage area 21 shown in Fig. 5 in step 55 so as to check if there is a directory name storage space in area 21. If NO in step 55, control element 15 outputs response data indicating that there is no directory name storage space in step 57, and the flow returns to step 51. If YES in step 55, control element 15 checks in step 59 if a directory name has already been stored in area 21. If NO in step 59, control element 15 registers a directory name as directory ID data "01" in step 61. After registration, control element 15 outputs response data indicating that directory name registration is completed, in step 63, and the flow returns to step 51.
  • control element 15 checks in step 65 if an identical directory name to that in the instruction data has already been stored. If YES in step 65, control element 15 outputs response data indicating that an identical directory name is present, in step 67, and the flow returns to step 51.
  • control element 15 increments, by one, data provided to a directory name, which is previously registered in area 21, appends the incremented data to a directory name in the instruction data, and registers the directory name, in step 69. After registration, control element 15 outputs response data indicating that directory name registration is completed, in step 63. In step 51, control element 15 waits for next instruction data.
  • Fig. 5 shows a registration result when directory names "AAA”, "BBB”, and "CCC" are registered by the registration processing of the directory names described above.
  • control element 15 checks in step 70 if the input data is directory selection instruction data 65 shown in Fig. 11. If NO in step 70, control element 15 executes another processing.
  • control element 15 refers to directory name storage area 21 shown in Fig. 5 in step 72 to check if a directory name has already stored in area 21. If NO in step 72, control element 15 outputs response data indicating that no directory name is registered, in step 71, and waits for next instruction data in step 51.
  • control element 15 checks in step 73 if an identical directory name to that in the input instruction data has already been stored. If NO in step 73, control element 15 outputs response data indicating that a corresponding directory name has not been stored, in step 75, and waits for next instruction data in step 51.
  • control element 15 sets directory ID data appended to the identical directory name found in area 21 in a current buffer (not shown) allocated in the internal RAM in step 79.
  • the content of the current buffer is set to be "00" when control element 15 is started.
  • Control element 15 outputs response data indicating that directory selection is completed, in step 81, and waits for the next instruction data in step 51.
  • control element 15 checks in step 83 if the input data is area registration instruction 85 shown in Fig. 12. If NO in step 83, control element 15 executes another processing.
  • control element 15 refers to area definition data storage area 23 shown in Fig. 6 in step 87 to check if there is an area definition data storage space in area 23. If NO in step 87, control element 15 outputs response data indicating that there is no area definition data storage space, in step 89, and waits for the next instruction data.
  • control element 15 checks in step 91 if area definition data having the present content of the current buffer as directory ID data and an area number in the instruction data as an area number has already been stored. If YES in step 93, control element 15 outputs response data indicating that an area has already been registered, in step 95, and waits for the next instruction data in step 51.
  • control element 15 computes area start address data of an area to be registered in step 97.
  • the area start address can be obtained by substracting area size data in the input instruction data from the storage value in area group start address storage area 25.
  • Control element 15 then compares the area start address data as the computed value and the start address of area group storage area 23 in step 99. As a result of comparison, if the former value is not equal to or larger than the latter value, control element 15 outputs response data indicating that an area size is inadequate, in step 101, and waits for the next instruction data in step 51.
  • control element 15 stores, in area definition data storage area 23, area definition data having the computed value as area start address data, area size data in the instruction data as area size data, an area number in the instruction data as an area number, and the content of the current buffer as directory ID data, in step 103.
  • Control element 15 updates the area group start address using a value obtained by subtracting one from the computed value, in step 105, and outputs response data indicating that area registration is completed, in step 107. Control element 15 then waits for the next instruction data in step 51.
  • control element 15 checks in step 109 if the input data is area link registration instruction data 111 shown in Fig. 13. If NO in step 109, control element 15 executes another processing.
  • control element 15 refers to area definition data storage area 23 shown in Fig. 6 in step 113 to check if there is an area definition data storage space in area 23. If NO in step 113, control element 15 outputs response data indicating that there is no area definition data storage space, in step 115, and waits for the next instruction data in step 51.
  • control element 15 checks in steps 117 and 119 if area definition data having the present content of the current buffer as directory ID data and an area number in the instruction data as an area number has already been stored. If YES in step 119, control element 15 outputs response data indicating that an area has already been registered, in step 121, and waits for the next instruction data.
  • control element 15 sets, as data 1, data obtained by appending an area number to the content of the current buffer in step 117.
  • Control element 15 checks in steps 123 and 125 if there is a target directory name to be linked in the instruction data is present. If NO in step 125, control element 15 outputs response data indicating that a target directory name to be linked has not been registered, in step 127, and waits for the next instruction data.
  • control element 15 checks in steps 129 and 131 if area definition data having directory ID data corresponding to the found directory name and the target area number in the instruction data has already been stored. If NO in step 131, control element 15 outputs response data indicating that the target area has not been registered, in step 133, and waits for the next instruction data in step 51.
  • control element 15 sets these data as data 2 in step 135.
  • Control element 15 stores, in area definition data storage area 23, area definition data having the above-mentioned data 1 as directory ID data, the data 2 as link destination designation data, and "01" as area link data.
  • Control element 15 outputs response data indicating that area link registration is completed, in step 137, and waits for the next instruction data.
  • control element 15 checks in step 139 if the input data is read instruction data 141 shown in Fig. 14 or write instruction data 143 shown in Fig. 15. If NO in step 139, control element 15 outputs response data indicating that an instruction has not been supported, in step 145, and waits for the next instruction data.
  • control element 15 checks in steps 147 and 149 if area definition data 30 having the present content of the current buffer as directory ID data and an area number in the instruction data as an area number has already been stored in area definition data storage area 23. If NO in step 149, control element 15 outputs response data indicating that an area has not been registered, in step 151, and waits for the next instruction data.
  • control element 15 checks in step 153 if area link data in the area definition data is "01". If YES in step 153, control element 15 finds area definition data having the same directory ID data and area number as those of the corresponding link destination designation data in step 155, and the flow returns to step 149. In step 149, control element 149 similarly checks area link data in the found area definition data. This check processing continues until the area definition data having area link data "00" is found.
  • control element 15 checks in step 157 whether the instruction data is read or write instruction data. If the instruction data is the read instruction, control element 15 executes read processing in step 159. On the other hand, if it is determined in step 157 that the instruction data is the write instruction, control element 15 executes write processing in step 161. In step 163, control element 15 outputs a processing result as a response data, and waits for the next instruction data.
  • Fig. 8A shows the idea of Fig. 6A.
  • Fig. 6B shows an area definition data storage state after the following processing.
  • Fig. 8B shows the idea of Fig. 6B.
  • the area definition data also includes data defining an access condition for an area. If this data is also shared, an access condition inherent to individual use of an application cannot be realized. As a method of realizing this, a different access condition may be input when the area definition data is shared. However, in some situations, a user may want to use the same access condition. In consideration of this, an access condition assigned to an area as an object to be shared upon sharing of area definition data must be confirmed by any method, and the same access condition must be set.
  • This embodiment has a function wherein physical position data of one area is shared by a plurality of area number (ID) data, and when these area numbers are accessed, different access enable/disable conditions can be set. Therefore, in an access using different area numbers, an access to an identical area or an access to an identical area among different applications can be performed, and different access conditions can be set.
  • ID area number
  • a function of sharing physical position data of one area by a plurality of areas and setting the same access enable/disable conditions for the area is provided. Therefore, in an access using different area numbers, an access to an identical area or an access to an identical area among different applications can be performed, and the same access conditions can be set.
  • a function of sharing physical position data of one area by a plurality of areas and selecting setting of different or same access enable/disable conditions is provided. Therefore, in an access using different area numbers, an access to an identical area or an access to an identical area among different applications can be performed, and different or same access conditions can be set.
  • data memory 16 has directory control data storage area 171 in place of directory name storage area 27.
  • directory control data storage area 171 consists of directory name data 29, directory ID data 31, and directory access condition data 177.
  • Directory access condition data 177 is used as determination data when area registration or area-link registration is performed. For example, a key data collating state or the like of a service offerer required when area definition data is written in area definition data storage area 179 is used.
  • Area definition data storage area 179 is constituted, as shown in Figs. 18A and 18B.
  • Area definition data consists of directory ID data 33, area number (ID data) 35, area start address data 37, area size data 39, area link data 41, link destination designation data 43, access condition selection data 185, and access condition data 187, as shown in Fig. 18A.
  • Directory ID data 33, area number 40, area start address data 37, area size data 39, area link data 41, and link destination designation data 43 are the same as those in the first embodiment, and a detailed description thereof will be omitted.
  • Access condition selection data 185 takes value "00" or "01". If data 185 is "00”, it is checked based on access condition data in area definition data of a link destination area if an access to the corresponding area is enabled. If data 185 is "01”, it is checked based on access condition data in self area definition data if an access to the corresponding area is enabled. Note that when area definition data is area-registered, data 185 is always set to be “01”. When area definition data is area-link registered, data "00" or "01” can be designated by an area-link registration instruction (to be described later).
  • Access condition data 187 represents an access condition for the corresponding area. For example, a key data collating state of a card holder required when the corresponding area is accessed is used.
  • Each directory name is appended with ID data "01", “02", or "03", and directory access condition data "Y01”, "Y02", or "Y03".
  • directory name "***” is a directory which is forcibly selected after the IC card is started regardless of directory selection instruction 65, and is appended with directory ID data "00" and directory access condition data "Y00".
  • Fig. 18A for example, five areas are defined, and their physical positions are as shown in Fig. 7. For example, area A having "A01" as area start address data and "S01" as area size data is registered to have area number "08". Note that since area A has directory ID data "00", this indicates that area A does not belong to any directory.
  • area B is registered to have area number "01" under a directory named "BBB”
  • area D is registered to have area number "01" under a directory named "CCC”.
  • area A does not belong to any directory (i.e., belongs to directory name "***"), and has area number "08".
  • control element 15 Registration processing of directory control data will first be described. In a steady state, control element 15 is set in an instruction data standby state. If instruction data is input in this state, control element 15 checks in step 193 if the input data is directory control instruction data 195 shown in Fig. 20. If NO in step 193, control element 15 executes another processing.
  • control element 15 refers to directory control data storage area 171 shown in Fig. 16 in step 197 to check if there is a directory storage space in this area. If NO in step 197, control element 15 outputs response data indicating that there is no directory control data storage space, in step 199, and waits for the next instruction data in step 191.
  • control element 15 checks in step 201 if a directory name in the input instruction data is present. If NO in step 201, control element 15 checks in step 203 if directory control data having directory ID data "00" has already been stored.
  • control element 15 If YES in step 203, control element 15 outputs response data indicating that an identical directory name has already been stored, in step 205, and waits for the next instruction data. If NO in step 203, control element 15 sets directory ID data to be "00", and registers directory name "***" together with directory access condition data in the input instruction data, in step 207. After registration, control element 15 outputs response data indicating that registration of directory control data is completed, in step 217, and the flow returns to step 191 to wait for the next instruction data.
  • control element 15 checks in step 209 if directory control data which has already been stored and which is different from the directory control data having directory ID data "00" is present in area 171 excluding directory control data. If NO in step 209, control element 15 registers directory control data by setting directory control data to be "01" in step 211. After registration, control element 15 outputs response data indicating that registration of directory control data is completed, in step 217, and the flow returns to step 191 to wait for the next instruction data.
  • control element 15 checks in step 213 if directory control data having an identical directory name to that in the input instruction data has already been stored. If YES in step 213, control element 15 outputs response data indicating that an identical directory name has already been stored, in step 205, and the flow returns to step 191 to wait for the next instruction data.
  • control element 15 increments, by one, directory ID data of directory control data other than that having directory ID data "00", which is finally registered in area 171, appends the incremented directory ID data to the present directory control data, and registers the directory control data, in step 215.
  • control element 15 outputs response data indicating that registration of directory control data is completed, in step 217, and the flow returns to step 191 to wait for the next instruction data.
  • Fig. 17 shows a result when directory names "***”, "AAA”, “BBB”, and "CCC" are registered in this order in the directory name registration processing described above.
  • Directory selection processing is substantially the same as that shown in the flow chart of Fig. 9B, except that a directory name is replaced with directory control data in the directory selection processing shown in Fig. 9B, and a detailed description thereof will be omitted.
  • Control element 15 checks in step 221 in Fig. 19B if the input instruction data is area registration instruction data 223 shown in Fig. 21. If NO in step 221, control element 15 executes another processing.
  • control element 15 refers to area definition data storage area 179 shown in Fig. 17 in step 225 to check if there is an area definition data storage space in area 179. If NO in step 225, control element 15 outputs response data indicating that there is no area definition data storage space, in step 227, and the flow returns to step 191 to wait for the next instruction data.
  • control element 15 refers to directory control data having the same directory ID data as the content of a current buffer in steps 229 and 231 to determine based on the corresponding access condition data whether or not the corresponding area can be accessed. If it is determined in step 231 that the access condition is not satisfied, control element 15 outputs response data indicating an access condition error in step 233, and the flow returns to step 191 to wait for the next instruction data.
  • control element 15 checks in steps 235 and 237 if area definition data having the present content of the current buffer as directory ID data and an area number in the input instruction data as an area number is present. If YES in step 237, control element 15 outputs response data indicating that an area has already been registered, in step 239, and the flow returns to step 191 to wait for the next instruction data.
  • control element 15 computes area start address data of an area to be registered in step 241.
  • the area start address data is obtained by subtracting area size data in the input instruction data from the storage value of area group start address storage area 183.
  • control element 15 compares the area start address data as the computed value with start address data of area group storage area 181. As a result of comparison, if the former value is not equal to or larger than the latter value, control element 15 outputs response data indicating that an area size is inadequate, in step 245, and the flow returns to step 191 to wait for the next instruction data.
  • control element 15 stores, in the area definition data storage area, area definition data having the computed value as the area start address data, area size data in the input instruction data as area size data, the area number in the input instruction data as an area number, access condition data in the input instruction data as access condition data, the content of the current buffer as directory ID data, and data link data "00", in step 247.
  • Control element 15 updates an area group start address using a value obtained by subtracting one from the computed value, in step 249, and outputs response data indicating that area registration is completed, in step 251. Thereafter, the flow returns to step 191 to wait for the next instruction data.
  • Control element 15 checks in step 254 in Fig. 19D if the input instruction data is area link registration instruction data 253 shown in Fig. 22. If NO in step 254, control element 15 executes another processing.
  • control element 15 refers to area definition data storage area 179 shown in Fig. 16 in step 255 to check if there is an area definition data storage space in area 179. If NO in step 255, control element 15 outputs response data indicating that there is no definition data storage space, in step 257, and the flow returns to step 191 to wait for the next instruction data.
  • control element 15 refers to directory control data having the same directory ID data as the content of the current buffer in step 259, and determines in step 261 based on corresponding access condition data whether or not the corresponding area can be accessed. If it is determined in step 261 that the access condition is not satisfied, control element 15 outputs response data indicating an access condition error, in step 263, and the flow returns to step 191 to wait for the next instruction data.
  • control element 15 checks in steps 265 and 267 if area definition data having the present content of the current buffer as directory ID data and an area number in the input instruction data as an area number is present. If YES in step 267, control element 15 outputs response data indicating that an area has already been registered, in step 269, and the flow returns to step 191 to wait for the next instruction data.
  • control element 15 sets data obtained by appending the area number in the input instruction data to the content of the current buffer as data 1.
  • Control element 15 checks in steps 271 and 273 if a target directory name to be linked in the input instruction data is present in directory control data storage area 171. If NO in step 273, control element 15 outputs response data indicating that a target directory name has not been registered, in step 275, and the flow returns to step 191 to wait for the next instruction data.
  • control element 15 refers to directory control data having the directory name in steps 277 and 279 to determine based on the corresponding access condition data whether or not an access can be performed. If it is determined in step 279 that the access condition is not satisfied, control element 15 outputs response data indicating an access condition error in step 281, and the flow returns to step 191 to wait for the next instruction data.
  • control element 15 checks in steps 283 and 285 if area definition data having directory ID data corresponding to the found directory name and a target area number to be linked in the input instruction data has already been stored. If NO in step 285, control element 15 outputs response data indicating that a target area to be linked has not been registered, in step 287, and the flow returns to step 191 to wait for the next instruction data.
  • control element 15 sets directory ID data corresponding to the directory name and the target area number to be linked in the input instruction data as data 2.
  • Control element 15 then stores, in area definition data storage area 179, area definition data having the data 1 as directory ID data, the data 2 as link destination designation data, access condition selection data in the input instruction data as access condition selection data, access condition data in the input instruction data as access condition data, and area link area "01".
  • Control element 15 outputs response data indicating that area-link registration is completed, in step 291, and the flow returns to step 191 to wait for the next instruction data.
  • control element 15 checks in step 301 in Fig. 19F if the input instruction data is read instruction data shown in Fig. 14 or write instruction data shown in Fig. 15. If NO in step 301, control element 15 outputs response data indicating that an instruction has not been supported, in step 303, and the control returns to an instruction data standby state.
  • control element 15 checks in steps 305 and 307 if area definition data having the present content of the current buffer as directory ID data and the area number in the input instruction data as an area number has already been stored in area definition data storage area 179. If NO in step 307, control element 15 outputs response data indicating that an area has not been registered, in step 309, and the flow returns to step 191 to wait for the next instruction data.
  • control element 15 checks in step 311 if area link data is "01". If YES in step 311, control element 15 refers to access condition selection data in step 313, and checks in step 315 if the selection data is "00". If YES in step 315, control element 15 sets a flag provided in the internal RAM to be "0" in step 317, and finds area definition data having the same directory ID data and area number as those of the corresponding link destination designation data in step 319.
  • control element 15 determines in steps 320 and 324 based on the corresponding access condition data whether or not an access can be performed. If it is determined in step 324 that the access condition is not satisfied, control element 15 outputs response data indicating an access condition error in step 328, and the flow returns to step 191 to wait for the next instruction data.
  • control element 15 sets the flag to be "1", and similarly finds area definition data having the same directory ID data and area number as those of the corresponding link destination designation data in step 319.
  • control element 15 determines in step 321 that the flag is "1"
  • control element 15 outputs response data indicating a processing result, and the flow returns to step 191 to wait for the next instruction data.
  • control element 15 determines in steps 331 and 333 based on the corresponding access condition data whether or not an access can be performed. If it is determined in step 333 that the access condition is not satisfied, control element 15 outputs response data indicating an access condition error in step 335, and the flow returns to step 191 to wait for the next instruction data. On the other hand, if it is determined in step 333 that the access condition is satisfied, control element 15 executes processing in steps 323 through 329 described above.
  • control element 15 advances to step 331.
  • directory ID data and area number data of a link destination area are used as link destination designation data.
  • any data may be used as long as area definition data of a link destination area can be identified.
  • position data at which area definition data of a link destination area is stored may be used.
  • a target directory name to be linked in link registration instruction data may be any data as long as a directory name to be linked can be internally identified.
  • an area for storing application data has been described, and various identification data areas necessary for accessing an IC card such as a PIN, have been described.
  • area numbers are appended to various identification data areas necessary for accessing the IC card, and collating processing for identification data having the same area number is performed using collating instruction data.

Description

  • The present invention relates to a portable electronic apparatus, called an IC card, incorporating an IC (Integrated Circuit) chip having a nonvolatile memory and a control element such as a CPU and, more particularly, to an area access method of the memory.
  • Recently, a so-called IC card incorporating an IC chip having an erasable nonvolatile memory and a control element such as a CPU has been developed as a new portable data storage medium. A plurality of identification (ID) numbers are registered in an IC card of this type. The IC card has a means for permitting an access to its internal memory only when a collating result between an externally input ID number and a registered ID number is affirmative. Thus, the IC card is considered as a data storage medium having a high secrecy.
  • In use, a memory is divided into a plurality of areas so as to cope with a variety of applications. Each area is logically accessed as an object to be accessed. Therefore, since a physical data storage position of the memory cannot be externally known, high secrecy can be assured. Since an access is logically made, external memory management can be facilitated.
  • An IC card having a memory which is divided into a plurality of areas is disclosed in USP 4,734,568 corresponding with JP-A-62028296, for example.
  • Each area of the memory has inherent ID data, called an area number. When the ID data is designated in instruction data, the IC card identifies a destination of area access, and recognizes a physical storage position to access the area.
  • Recently, multi-purpose IC cards have also been developed. For example, a single IC card may be utilized as a cash card for a bank, a credit card, a leisure card, an electronic memorandum card, and the like. For example, when a single IC card is utilized as a cash card for a bank and a credit card, since a holder of the cash card and the credit card is the same person, it is preferable that a holder's name, address, telephone number, and the like are commonly stored so as to effectively use a memory area. Thus, the common holder can be accessed when either the cash or credit card is used. When a given area in the IC card is used as a bankbook, the IC card must be arranged so that the given area can be accessed by a bank but cannot be accessed by a credit card company for the purpose of keeping secrecy.
  • When a holder's name of the cash card and a holder's name of the credit card are registered in different areas, a problem may be posed in updating processing of a holder. For example, assume that when a woman changes her surname upon marriage, she updates a holder's name of the cash card but does not update a holder's name of the credit card. This causes a problem in use of an IC card. From this point of view, a single holder's name common to the cash card and the credit card is preferably registered in a specific area of an IC card. In other words, the IC card preferably has a common data field which can be accessed regardless of applications, and an application data field in which an area corresponding to a given application can be accessed and cannot be accessed in other applications.
  • However, in a conventional IC card, areas physically arranged on a memory have area numbers in one-to-one correspondence. For this reason, it is impossible to access an identical area using different area numbers or to access an identical area in different applications.
  • It is an object of the present invention to provide a portable electronic apparatus which can access an identical area using different area numbers in different applications.
  • In order to achieve the above object, a portable electronic apparatus of the present invention comprises memory means which is divided into a plurality of data area groups, individual identification data being assigned to each area, and at least two different identification numbers being assigned to at least one area, and control means for selecting the area based on external input identification data. With this arrangement, an identical area can be accessed based on at least two different external input identification data.
  • This invention can be more fully understood from the following detailed description when taken in conjunction with the accompanying drawings, in which:
    • Fig. 1 is a block diagram showing an arrangement of a terminal apparatus handling an IC card as a portable electronic apparatus according to the present invention;
    • Fig. 2 is a functional block diagram of the IC card;
    • Fig. 3 is a block diagram showing a basic arrangement of the IC card of the present invention;
    • Fig. 4 is a memory map of a data memory shown in Fig. 3;
    • Fig. 5 is an explanatory view showing in detail directory name storage areas;
    • Fig. 6A is a view showing an area definition data storage area before link registration, and a storage state of area definition data, and Fig. 6B is a view showing the area definition data storage area after link registration and the storage state of the area definition data;
    • Fig. 7 is a memory map of an area group storage area shown in Fig. 4;
    • Fig. 8A is a view showing positions of areas in the area definition data storage state shown in Fig. 6A, and Fig. 8B is a view showing positions of area in the area definition data storage state shown in Fig. 6B;
    • Figs. 9A through 9E are flow charts showing an operation of an embodiment of the portable electronic apparatus of the present invention;
    • Fig. 10 is a view showing a format of directory name registration instruction data;
    • Fig. 11 is a view showing a format of directory selection instruction data;
    • Fig. 12 is a view showing a format of area registration instruction data;
    • Fig. 13 is a view showing a format of area-link registration instruction data;
    • Fig. 14 is a view showing a format of read instruction data from an area;
    • Fig. 15 is a view showing a format of write instruction data in an area;
    • Fig. 16 is a memory map of a data memory in another embodiment of the present invention;
    • Fig. 17 is a view showing a directory control data storage area and a storage state of directly control data in the second embodiment of the present invention;
    • Fig. 18A is a view showing an area definition data storage area before link registration, and a storage state of area definition data, and Fig. 18B is a view showing the area definition data storage area after link registration and the storage state of the area definition data, respectively, in the second embodiment of the present invention;
    • Figs. 19A through 19G are flow charts showing an operation of the second embodiment of the present invention;
    • Fig. 20 shows a format of directory control data registration instruction data used in the second embodiment of the present invention;
    • Fig. 21 shows a format of area registration instruction data used in the second embodiment of the present invention; and
    • Fig. 22 shows a format of area-link registration instruction data used in the second embodiment of the present invention.
  • An embodiment of the present invention will now be described with reference to the accompanying drawings.
  • Fig. 1 shows an arrangement of a terminal apparatus handling an IC card as a portable electronic apparatus according to the present invention. More specifically, the terminal apparatus has an arrangement wherein IC card 1 can be connected to control section 3 comprising, e.g., a CPU through card reader/writer 2, and control section 3 is connected to keyboard 4, CRT display 5, printer 6, and floppy disk device 7.
  • IC card 1 is held by a user, and performs collating of an ID number which is known by only the user, storage of necessary data, and the like upon purchasing an article at a store or the like. As shown in the functional block diagram of Fig. 2, the IC card is constituted by a portion for executing basic functions including read/write section 11, PIN setting/collating section 12, and encrypting/decrypting section 13, and supervisor 14 for managing these basic functions. Read/write section 11 is a function of reading, writing, or erasing data with respect to data memory 16. PIN setting/collating section 12 is a function of performing read/write inhibition processing a PIN (personal identification number) set by the user, and collating the PIN to permit subsequent processing after the user sets the PIN. Encrypting/decrypting section 13 is a function of encrypting data in order to prevent disclosure and counterfeit of communication data when data is transmitted from control section 34 to another terminal apparatus, and decrypting encrypted data in accordance with an algorithm such as the DES (Data Encryption Standard) having a sufficient code strength. Supervisor 14 is a function of decoding a function code input from card reader/writer 2, and selecting and executing a necessary function of the basic functions.
  • In order to effect these functions, IC card 1 comprises control element (control section) 15 such as a CPU, data memory (memory section) 16, program memory 17, and contactor 18 for achieving an electrical contact with card reader/writer 2, as shown in Fig. 3. Of these elements, control element 15, data memory 16, and program memory 17 are constituted by one IC chip (or a plurality of IC chips), and is embedded in an IC card main body.
  • Program memory 17 comprises, e.g., a mask ROM, and stores a control program for control element 15, which has subroutines for realizing the basic functions. Data memory 16 is used for storing various data, and comprises, e.g., an erasable nonvolatile memory such as an EEPROM.
  • Data memory 16 is divided into a plurality of areas, as shown in Fig. 4. The areas can be roughly classified into directory name storage area 21, area definition data storage area 23, area group storage area 25, and area group start address storage area 27.
  • Directory name storage area 21 stores names of directories unique to a particular memory structure used, and consists of directory name data 29 and directory identification (ID) data 31, as shown in Fig. 5.
  • Area definition data storage area 23 stores area definition data 30 for defining positions of areas under the directories defined by the memory structure, and consists of directory ID data 33, area number data 35, area start address data 37, area size data 39, area link data 41, and link destination designation data 43, as shown in Fig. 6.
  • Directory ID data 33 indicates a directory to which an area defined by area definition data 30 belongs, and is associated with directory ID data 31 corresponding to directory name data 29 shown in Fig. 5. Note that when directory ID data 33 is "00", it can be identified that the corresponding area does not belong to any directory.
  • Area number data 35 indicates a number for designating an area when an area under a directory is to be accessed.
  • Area start address data 37 and area size data 39 indicate a physical position of an area defined by area definition data 30 in area group storage area 25 shown in Fig. 7.
  • Area link data 41 is used for identifying whether an area defined by area definition data 30 is area-registered or area-link registered. Note that if the area is area-registered, data 41 is given by "00", and link destination data 43 appended thereafter is made invalid. If the area is area-link registered, data 41 is given by "01", and the link destination designation data designated thereafter is made invalid. In this case, previous start address data 37 and area size data 39 are made invalid.
  • The link destination designation data is data for indicating an area which is linked with the area defined by area definition data 30, and provides directory ID data 33 and area number data 35 of the designated link destination area.
  • The principle of the memory structure will be explained below with reference to Figs. 4, 5, 6A, and 6B. Assume that three directories are defined, and their directory name data 29 are "AAA", "BBB", and "CCC", respectively, as shown in Fig. 5. As will be described later, directory name data 29 are respectively appended with "01", "02", and "03" as directory ID data 33.
  • In Fig. 6A, five areas are defined, and their physical positions are as shown in Fig. 7. For example, area A having area start address data "A01" and area size data "S01" is registered to have an area number "08". Since directory ID data 33 of area A is "00", this indicates that area A does not belong to any directory.
  • Since area C having "A03" as area start address data 37 and "S03" as area size data 39, and area E having "A05" as area start address data 37 and "S05" as area size data 39 have the same data "01" as directory ID data 33, these two areas are areas under a directory named "AAA". Note that individual area numbers are "01" for the former area, and "03" for the latter area, respectively.
  • Similarly, area B is an area under a directory named "BBB", and is registered to have area number "01". Area D is an area under a directory named "CCC", and is registered to have area number "01".
  • Area group start address storage area 27 stores data indicating areas assigned to an area group. If no areas are assigned, the data in area 27 indicates a final address value of area group storage area 25. After area A is assigned, the data is represented by a value obtained by subtracting "1" from the value "A01", and is updated every time an area is assigned.
  • Figs. 8A and 8B show the relationship between areas and directories. As shown in Figs. 8A and 8B, areas C and E belong to directory "AAA", and are provided with area numbers "01" and "03", respectively. Area B belongs to directory "BBB", and has area number "01". Area D belongs to directory "CCC", and has area number "01". Note that area A does not belong to any directory, and has area number "08".
  • An operation of this embodiment with the above arrangement will be described with reference to the flow charts shown in Figs. 9A through 9E. Registration processing of a directory name will first be described. In the flow chart shown in Fig. 9A, a steady state corresponds to an instruction standby state. If instruction data is input in step 51, control element 15 checks in step 53 if the input instruction data is directory name registration instruction data 52 shown in Fig. 10. If NO in step 53, control element 15 executes another processing.
  • If YES in step 53, control element 15 refers to directory name storage area 21 shown in Fig. 5 in step 55 so as to check if there is a directory name storage space in area 21. If NO in step 55, control element 15 outputs response data indicating that there is no directory name storage space in step 57, and the flow returns to step 51. If YES in step 55, control element 15 checks in step 59 if a directory name has already been stored in area 21. If NO in step 59, control element 15 registers a directory name as directory ID data "01" in step 61. After registration, control element 15 outputs response data indicating that directory name registration is completed, in step 63, and the flow returns to step 51.
  • If YES in step 59, control element 15 checks in step 65 if an identical directory name to that in the instruction data has already been stored. If YES in step 65, control element 15 outputs response data indicating that an identical directory name is present, in step 67, and the flow returns to step 51.
  • If NO in step 65, control element 15 increments, by one, data provided to a directory name, which is previously registered in area 21, appends the incremented data to a directory name in the instruction data, and registers the directory name, in step 69. After registration, control element 15 outputs response data indicating that directory name registration is completed, in step 63. In step 51, control element 15 waits for next instruction data.
  • Fig. 5 shows a registration result when directory names "AAA", "BBB", and "CCC" are registered by the registration processing of the directory names described above.
  • Directory selection processing will now be described. If it is determined that the input instruction data is not the directory name registration instruction data, control element 15 checks in step 70 if the input data is directory selection instruction data 65 shown in Fig. 11. If NO in step 70, control element 15 executes another processing.
  • If YES in step 70, control element 15 refers to directory name storage area 21 shown in Fig. 5 in step 72 to check if a directory name has already stored in area 21. If NO in step 72, control element 15 outputs response data indicating that no directory name is registered, in step 71, and waits for next instruction data in step 51.
  • If YES in step 72, control element 15 checks in step 73 if an identical directory name to that in the input instruction data has already been stored. If NO in step 73, control element 15 outputs response data indicating that a corresponding directory name has not been stored, in step 75, and waits for next instruction data in step 51.
  • If YES in step 73, control element 15 sets directory ID data appended to the identical directory name found in area 21 in a current buffer (not shown) allocated in the internal RAM in step 79. The content of the current buffer is set to be "00" when control element 15 is started. Control element 15 outputs response data indicating that directory selection is completed, in step 81, and waits for the next instruction data in step 51.
  • Area registration processing will be described below.
  • If it is determined that the input instruction data is not the directory selection instruction data, control element 15 checks in step 83 if the input data is area registration instruction 85 shown in Fig. 12. If NO in step 83, control element 15 executes another processing.
  • If YES in step 83, control element 15 refers to area definition data storage area 23 shown in Fig. 6 in step 87 to check if there is an area definition data storage space in area 23. If NO in step 87, control element 15 outputs response data indicating that there is no area definition data storage space, in step 89, and waits for the next instruction data.
  • If YES in step 87, control element 15 checks in step 91 if area definition data having the present content of the current buffer as directory ID data and an area number in the instruction data as an area number has already been stored. If YES in step 93, control element 15 outputs response data indicating that an area has already been registered, in step 95, and waits for the next instruction data in step 51.
  • If NO in step 93, control element 15 computes area start address data of an area to be registered in step 97. In pactice, the area start address can be obtained by substracting area size data in the input instruction data from the storage value in area group start address storage area 25. Control element 15 then compares the area start address data as the computed value and the start address of area group storage area 23 in step 99. As a result of comparison, if the former value is not equal to or larger than the latter value, control element 15 outputs response data indicating that an area size is inadequate, in step 101, and waits for the next instruction data in step 51.
  • As a result of comparison in step 99, if the former value is equal to or larger than the latter value, control element 15 stores, in area definition data storage area 23, area definition data having the computed value as area start address data, area size data in the instruction data as area size data, an area number in the instruction data as an area number, and the content of the current buffer as directory ID data, in step 103. Control element 15 updates the area group start address using a value obtained by subtracting one from the computed value, in step 105, and outputs response data indicating that area registration is completed, in step 107. Control element 15 then waits for the next instruction data in step 51.
  • Area link registration processing will now be described.
  • If it is determined that the input instruction data is not the area registration instruction data, control element 15 checks in step 109 if the input data is area link registration instruction data 111 shown in Fig. 13. If NO in step 109, control element 15 executes another processing.
  • If YES in step 109, control element 15 refers to area definition data storage area 23 shown in Fig. 6 in step 113 to check if there is an area definition data storage space in area 23. If NO in step 113, control element 15 outputs response data indicating that there is no area definition data storage space, in step 115, and waits for the next instruction data in step 51.
  • If YES in step 113, control element 15 checks in steps 117 and 119 if area definition data having the present content of the current buffer as directory ID data and an area number in the instruction data as an area number has already been stored. If YES in step 119, control element 15 outputs response data indicating that an area has already been registered, in step 121, and waits for the next instruction data.
  • If NO in step 119, control element 15 sets, as data 1, data obtained by appending an area number to the content of the current buffer in step 117. Control element 15 checks in steps 123 and 125 if there is a target directory name to be linked in the instruction data is present. If NO in step 125, control element 15 outputs response data indicating that a target directory name to be linked has not been registered, in step 127, and waits for the next instruction data.
  • If YES in step 125, control element 15 checks in steps 129 and 131 if area definition data having directory ID data corresponding to the found directory name and the target area number in the instruction data has already been stored. If NO in step 131, control element 15 outputs response data indicating that the target area has not been registered, in step 133, and waits for the next instruction data in step 51.
  • If YES in step 131, control element 15 sets these data as data 2 in step 135. Control element 15 stores, in area definition data storage area 23, area definition data having the above-mentioned data 1 as directory ID data, the data 2 as link destination designation data, and "01" as area link data. Control element 15 outputs response data indicating that area link registration is completed, in step 137, and waits for the next instruction data.
  • Data write and read processing to/from area data will be described below.
  • If it is determined that the input instruction data is not the area link registration instruction, control element 15 checks in step 139 if the input data is read instruction data 141 shown in Fig. 14 or write instruction data 143 shown in Fig. 15. If NO in step 139, control element 15 outputs response data indicating that an instruction has not been supported, in step 145, and waits for the next instruction data.
  • If either instruction is detected in step 139, control element 15 checks in steps 147 and 149 if area definition data 30 having the present content of the current buffer as directory ID data and an area number in the instruction data as an area number has already been stored in area definition data storage area 23. If NO in step 149, control element 15 outputs response data indicating that an area has not been registered, in step 151, and waits for the next instruction data.
  • If YES in step 149, control element 15 checks in step 153 if area link data in the area definition data is "01". If YES in step 153, control element 15 finds area definition data having the same directory ID data and area number as those of the corresponding link destination designation data in step 155, and the flow returns to step 149. In step 149, control element 149 similarly checks area link data in the found area definition data. This check processing continues until the area definition data having area link data "00" is found.
  • If it is determined in step 153 that area definition data having area link data "00" is found, control element 15 checks in step 157 whether the instruction data is read or write instruction data. If the instruction data is the read instruction, control element 15 executes read processing in step 159. On the other hand, if it is determined in step 157 that the instruction data is the write instruction, control element 15 executes write processing in step 161. In step 163, control element 15 outputs a processing result as a response data, and waits for the next instruction data. The case of Fig. 6A exemplifies an area definition data storage state after the following processing. That is, area A (area number = 08, area size data = S01) is assigned based on the area registration instruction data without performing directory selection. After a directory having directory name "BBB" is selected, area B (area number = 01, area size data = S02) is assigned based on the area registration instruction data. After a directory having directory name "AAA" is selected, area C (area number 01, area size data = S03) is assigned based on the area registration instruction data. After a directory having directory name "CCC" is selected, area D (area number = 01, area size data = S04) is assigned based on the area registration instruction data. Finally, after the directory having directory name "AAA" is selected, area E (area number 03, area size data = S05) is assigned based on the area registration instruction data. Fig. 8A shows the idea of Fig. 6A. Fig. 6B shows an area definition data storage state after the following processing. That is, after a directory having directory name "BBB" is selected, areas are linked based on the area link registration instruction data using area number = 02, target directory name "AAA" to be linked, and target area number to be linked = 01. After a directory having directory name "CCC" is selected, areas are linked based on the area link registration instruction data using area number = 02, target directory name "AAA" to be linked, and target area number to be linked = 03. Fig. 8B shows the idea of Fig. 6B.
  • Thus, when read and write instructions are executed using area number "08" before a directory is selected, read and write processing operations are executed for area A.
  • When read and write instructions are executed using area number "01" after directory "AAA" is selected, the read and write processing operations are executed for area C. In this case, if area number "03" is used, read and write processing operations are executed for area E.
  • When read and write instructions are executed using area number "01" after directory "BBB" is selected, the read and write processing operations are executed for area B. In this case, if area number "02" is used, read and write processing operations are executed for area C identical to an area when area number "01" is used after directory name "AAA" is selected.
  • When read and write instructions are executed using area number "01" after directory "CCC" is selected, the read and write processing operations are executed for area D. In this case, if area number "02" is used, read and write processing operations are executed for area E identical to an area when area number "03" is used after directory name "AAA" is selected.
  • In this state, a value obtained by subtracting one from area start address data "A05" is stored in area group start address storage area 164.
  • In this manner, since a function of sharing physical position data of one area by a plurality of area numbers is provided, an identical area can be accessed using different area numbers.
  • In this manner, with the method of sharing area definition data, even if an area number or application is varied, an access to an identical area can be performed. However, the area definition data also includes data defining an access condition for an area. If this data is also shared, an access condition inherent to individual use of an application cannot be realized. As a method of realizing this, a different access condition may be input when the area definition data is shared. However, in some situations, a user may want to use the same access condition. In consideration of this, an access condition assigned to an area as an object to be shared upon sharing of area definition data must be confirmed by any method, and the same access condition must be set.
  • Another embodiment of a portable electronic apparatus of the present invention will be described below, wherein in an access using different area numbers, an access to an identical area or an access to an identical area among different applications can be performed, and access conditions can be individually set.
  • This embodiment has a function wherein physical position data of one area is shared by a plurality of area number (ID) data, and when these area numbers are accessed, different access enable/disable conditions can be set. Therefore, in an access using different area numbers, an access to an identical area or an access to an identical area among different applications can be performed, and different access conditions can be set.
  • In addition, a function of sharing physical position data of one area by a plurality of areas and setting the same access enable/disable conditions for the area is provided. Therefore, in an access using different area numbers, an access to an identical area or an access to an identical area among different applications can be performed, and the same access conditions can be set.
  • Moreover, a function of sharing physical position data of one area by a plurality of areas and selecting setting of different or same access enable/disable conditions is provided. Therefore, in an access using different area numbers, an access to an identical area or an access to an identical area among different applications can be performed, and different or same access conditions can be set.
  • The embodiment of the present invention will now be described with reference to Figs. 16 through 22.
  • The same reference numerals in this embodiment denote the same parts as in the first embodiment, and a detailed description thereof will be omitted. In this embodiment, data memory 16 has directory control data storage area 171 in place of directory name storage area 27. As shown in Fig. 17, directory control data storage area 171 consists of directory name data 29, directory ID data 31, and directory access condition data 177. Directory access condition data 177 is used as determination data when area registration or area-link registration is performed. For example, a key data collating state or the like of a service offerer required when area definition data is written in area definition data storage area 179 is used.
  • Area definition data storage area 179 is constituted, as shown in Figs. 18A and 18B. Area definition data consists of directory ID data 33, area number (ID data) 35, area start address data 37, area size data 39, area link data 41, link destination designation data 43, access condition selection data 185, and access condition data 187, as shown in Fig. 18A. Directory ID data 33, area number 40, area start address data 37, area size data 39, area link data 41, and link destination designation data 43 are the same as those in the first embodiment, and a detailed description thereof will be omitted.
  • Access condition selection data 185 takes value "00" or "01". If data 185 is "00", it is checked based on access condition data in area definition data of a link destination area if an access to the corresponding area is enabled. If data 185 is "01", it is checked based on access condition data in self area definition data if an access to the corresponding area is enabled. Note that when area definition data is area-registered, data 185 is always set to be "01". When area definition data is area-link registered, data "00" or "01" can be designated by an area-link registration instruction (to be described later).
  • Access condition data 187 represents an access condition for the corresponding area. For example, a key data collating state of a card holder required when the corresponding area is accessed is used.
  • Each directory name is appended with ID data "01", "02", or "03", and directory access condition data "Y01", "Y02", or "Y03".
  • In particular, directory name "***" is a directory which is forcibly selected after the IC card is started regardless of directory selection instruction 65, and is appended with directory ID data "00" and directory access condition data "Y00".
  • In Fig. 18A, for example, five areas are defined, and their physical positions are as shown in Fig. 7. For example, area A having "A01" as area start address data and "S01" as area size data is registered to have area number "08". Note that since area A has directory ID data "00", this indicates that area A does not belong to any directory.
  • Since area C having "A03" as area start address data and "S03" as area size data and area E having "A05" as area start address data and "S05" as area size data have the same directory ID data "01", this indicates that these two areas are areas under a directory named "AAA". Note that their area numbers are respectively "01" for the former area and "03" for the latter area.
  • Similarly, area B is registered to have area number "01" under a directory named "BBB", and area D is registered to have area number "01" under a directory named "CCC".
  • Note that these five area definition data are area-registered. Therefore, their access condition selection data are all "01", and individual access conditions "X01" through "X05" are appended in correspondence thereto.
  • In the relationship between areas and directories shown in Figs. 8A and 8B, area A does not belong to any directory (i.e., belongs to directory name "***"), and has area number "08".
  • An operation of this embodiment with the above arrangement will now be described with reference to the flow charts shown in Figs. 19A through 19G.
  • Registration processing of directory control data will first be described. In a steady state, control element 15 is set in an instruction data standby state. If instruction data is input in this state, control element 15 checks in step 193 if the input data is directory control instruction data 195 shown in Fig. 20. If NO in step 193, control element 15 executes another processing.
  • If YES in step 193, control element 15 refers to directory control data storage area 171 shown in Fig. 16 in step 197 to check if there is a directory storage space in this area. If NO in step 197, control element 15 outputs response data indicating that there is no directory control data storage space, in step 199, and waits for the next instruction data in step 191.
  • If YES in step 197, control element 15 checks in step 201 if a directory name in the input instruction data is present. If NO in step 201, control element 15 checks in step 203 if directory control data having directory ID data "00" has already been stored.
  • If YES in step 203, control element 15 outputs response data indicating that an identical directory name has already been stored, in step 205, and waits for the next instruction data. If NO in step 203, control element 15 sets directory ID data to be "00", and registers directory name "***" together with directory access condition data in the input instruction data, in step 207. After registration, control element 15 outputs response data indicating that registration of directory control data is completed, in step 217, and the flow returns to step 191 to wait for the next instruction data.
  • If NO in step 201, control element 15 checks in step 209 if directory control data which has already been stored and which is different from the directory control data having directory ID data "00" is present in area 171 excluding directory control data. If NO in step 209, control element 15 registers directory control data by setting directory control data to be "01" in step 211. After registration, control element 15 outputs response data indicating that registration of directory control data is completed, in step 217, and the flow returns to step 191 to wait for the next instruction data.
  • If YES in step 209, control element 15 checks in step 213 if directory control data having an identical directory name to that in the input instruction data has already been stored. If YES in step 213, control element 15 outputs response data indicating that an identical directory name has already been stored, in step 205, and the flow returns to step 191 to wait for the next instruction data.
  • If NO in step 213, control element 15 increments, by one, directory ID data of directory control data other than that having directory ID data "00", which is finally registered in area 171, appends the incremented directory ID data to the present directory control data, and registers the directory control data, in step 215. After registration, control element 15 outputs response data indicating that registration of directory control data is completed, in step 217, and the flow returns to step 191 to wait for the next instruction data.
  • Fig. 17 shows a result when directory names "***", "AAA", "BBB", and "CCC" are registered in this order in the directory name registration processing described above.
  • Directory selection processing is substantially the same as that shown in the flow chart of Fig. 9B, except that a directory name is replaced with directory control data in the directory selection processing shown in Fig. 9B, and a detailed description thereof will be omitted.
  • Area registration processing will now be described. Control element 15 checks in step 221 in Fig. 19B if the input instruction data is area registration instruction data 223 shown in Fig. 21. If NO in step 221, control element 15 executes another processing.
  • If YES in step 221, control element 15 refers to area definition data storage area 179 shown in Fig. 17 in step 225 to check if there is an area definition data storage space in area 179. If NO in step 225, control element 15 outputs response data indicating that there is no area definition data storage space, in step 227, and the flow returns to step 191 to wait for the next instruction data.
  • If YES in step 225, control element 15 refers to directory control data having the same directory ID data as the content of a current buffer in steps 229 and 231 to determine based on the corresponding access condition data whether or not the corresponding area can be accessed. If it is determined in step 231 that the access condition is not satisfied, control element 15 outputs response data indicating an access condition error in step 233, and the flow returns to step 191 to wait for the next instruction data.
  • If it is determined in step 231 that the access condition is satisfied, control element 15 checks in steps 235 and 237 if area definition data having the present content of the current buffer as directory ID data and an area number in the input instruction data as an area number is present. If YES in step 237, control element 15 outputs response data indicating that an area has already been registered, in step 239, and the flow returns to step 191 to wait for the next instruction data.
  • If NO in step 237, control element 15 computes area start address data of an area to be registered in step 241. In practice, the area start address data is obtained by subtracting area size data in the input instruction data from the storage value of area group start address storage area 183. In step 243, control element 15 compares the area start address data as the computed value with start address data of area group storage area 181. As a result of comparison, if the former value is not equal to or larger than the latter value, control element 15 outputs response data indicating that an area size is inadequate, in step 245, and the flow returns to step 191 to wait for the next instruction data. As a result of comparison, if the former value is equal to or larger than the latter value, control element 15 stores, in the area definition data storage area, area definition data having the computed value as the area start address data, area size data in the input instruction data as area size data, the area number in the input instruction data as an area number, access condition data in the input instruction data as access condition data, the content of the current buffer as directory ID data, and data link data "00", in step 247. Control element 15 updates an area group start address using a value obtained by subtracting one from the computed value, in step 249, and outputs response data indicating that area registration is completed, in step 251. Thereafter, the flow returns to step 191 to wait for the next instruction data.
  • Area link registration processing will be described below.
  • Control element 15 checks in step 254 in Fig. 19D if the input instruction data is area link registration instruction data 253 shown in Fig. 22. If NO in step 254, control element 15 executes another processing.
  • If YES in step 254, control element 15 refers to area definition data storage area 179 shown in Fig. 16 in step 255 to check if there is an area definition data storage space in area 179. If NO in step 255, control element 15 outputs response data indicating that there is no definition data storage space, in step 257, and the flow returns to step 191 to wait for the next instruction data.
  • If YES in step 255, control element 15 refers to directory control data having the same directory ID data as the content of the current buffer in step 259, and determines in step 261 based on corresponding access condition data whether or not the corresponding area can be accessed. If it is determined in step 261 that the access condition is not satisfied, control element 15 outputs response data indicating an access condition error, in step 263, and the flow returns to step 191 to wait for the next instruction data.
  • If it is determined in step 261 that the access condition is satisfied, control element 15 checks in steps 265 and 267 if area definition data having the present content of the current buffer as directory ID data and an area number in the input instruction data as an area number is present. If YES in step 267, control element 15 outputs response data indicating that an area has already been registered, in step 269, and the flow returns to step 191 to wait for the next instruction data.
  • If NO in step 267, control element 15 sets data obtained by appending the area number in the input instruction data to the content of the current buffer as data 1. Control element 15 checks in steps 271 and 273 if a target directory name to be linked in the input instruction data is present in directory control data storage area 171. If NO in step 273, control element 15 outputs response data indicating that a target directory name has not been registered, in step 275, and the flow returns to step 191 to wait for the next instruction data.
  • If YES in step 273, control element 15 refers to directory control data having the directory name in steps 277 and 279 to determine based on the corresponding access condition data whether or not an access can be performed. If it is determined in step 279 that the access condition is not satisfied, control element 15 outputs response data indicating an access condition error in step 281, and the flow returns to step 191 to wait for the next instruction data.
  • If it is determined in step 279 that the access condition is satisfied, control element 15 checks in steps 283 and 285 if area definition data having directory ID data corresponding to the found directory name and a target area number to be linked in the input instruction data has already been stored. If NO in step 285, control element 15 outputs response data indicating that a target area to be linked has not been registered, in step 287, and the flow returns to step 191 to wait for the next instruction data.
  • If YES in step 285, control element 15 sets directory ID data corresponding to the directory name and the target area number to be linked in the input instruction data as data 2. Control element 15 then stores, in area definition data storage area 179, area definition data having the data 1 as directory ID data, the data 2 as link destination designation data, access condition selection data in the input instruction data as access condition selection data, access condition data in the input instruction data as access condition data, and area link area "01". Control element 15 outputs response data indicating that area-link registration is completed, in step 291, and the flow returns to step 191 to wait for the next instruction data.
  • Read/write processing to/from an area will be described below. If it is determined in step 251 that the input instruction data is not the area link registration instruction, control element 15 checks in step 301 in Fig. 19F if the input instruction data is read instruction data shown in Fig. 14 or write instruction data shown in Fig. 15. If NO in step 301, control element 15 outputs response data indicating that an instruction has not been supported, in step 303, and the control returns to an instruction data standby state.
  • If it is determined in step 301 that the input instruction data is one of the read and write instructions, control element 15 checks in steps 305 and 307 if area definition data having the present content of the current buffer as directory ID data and the area number in the input instruction data as an area number has already been stored in area definition data storage area 179. If NO in step 307, control element 15 outputs response data indicating that an area has not been registered, in step 309, and the flow returns to step 191 to wait for the next instruction data.
  • If YES in step 307, control element 15 checks in step 311 if area link data is "01". If YES in step 311, control element 15 refers to access condition selection data in step 313, and checks in step 315 if the selection data is "00". If YES in step 315, control element 15 sets a flag provided in the internal RAM to be "0" in step 317, and finds area definition data having the same directory ID data and area number as those of the corresponding link destination designation data in step 319.
  • If it is determined in step 315 that the selection data is "01", control element 15 determines in steps 320 and 324 based on the corresponding access condition data whether or not an access can be performed. If it is determined in step 324 that the access condition is not satisfied, control element 15 outputs response data indicating an access condition error in step 328, and the flow returns to step 191 to wait for the next instruction data.
  • If it is determined in step 324 that the access condition is satisfied, control element 15 sets the flag to be "1", and similarly finds area definition data having the same directory ID data and area number as those of the corresponding link destination designation data in step 319.
  • If control element 15 determines in step 321 that the flag is "1", it determines in step 323 if the input instruction is a write instruction. If YES in step 323, control element 15 executes write processing in step 327; otherwise, executes read processing in step 325. In step 329, control element 15 outputs response data indicating a processing result, and the flow returns to step 191 to wait for the next instruction data.
  • If it is determined in step 321 that the flag is "0", control element 15 determines in steps 331 and 333 based on the corresponding access condition data whether or not an access can be performed. If it is determined in step 333 that the access condition is not satisfied, control element 15 outputs response data indicating an access condition error in step 335, and the flow returns to step 191 to wait for the next instruction data. On the other hand, if it is determined in step 333 that the access condition is satisfied, control element 15 executes processing in steps 323 through 329 described above.
  • If it is determined in step 311 that the area link data is "00", control element 15 advances to step 331.
  • In this manner, physical position data of one area is shared by a plurality of area numbers, and a function of setting different access enable/disable conditions when these area numbers are accessed, a function of setting the same access enable/disable conditions, and a function of selecting one of these functions are provided. Thus, in an access using different area numbers, an access to an identical area or an access to an identical area among different applications can be performed, and different or same access conditions can be arbitrarily set.
  • In the above embodiment, directory ID data and area number data of a link destination area are used as link destination designation data. However, any data may be used as long as area definition data of a link destination area can be identified. For example, position data at which area definition data of a link destination area is stored may be used.
  • A target directory name to be linked in link registration instruction data may be any data as long as a directory name to be linked can be internally identified.
  • In the above embodiment, an area for storing application data has been described, and various identification data areas necessary for accessing an IC card such as a PIN, have been described. For example, area numbers are appended to various identification data areas necessary for accessing the IC card, and collating processing for identification data having the same area number is performed using collating instruction data.

Claims (17)

  1. A portable electronic apparatus for selectively inputting/outputting data with an external device, comprising:
       memory means (16) for storing data, said memory means being divided into a plurality of data area groups each data area group having at least one data area, individual identification data being assigned to each area, and at least two different identification numbers being assigned to at least one data area; and
       control means (15, 17) for selecting the data area based on external input identification data and identification number, thereby selecting an identical area based on at least two different external input identification data and identification number.
  2. An apparatus according to claim 1, characterized in that said memory means includes a directory name storage area (21), an area definition data storage area (23), and an area group start address storage area (27) indicating an area which is assigned to the data area groups.
  3. An apparatus according to claim 2, characterized in that the directory name storage area includes area for storing a plurality of directory names (29) and directory identification data (31).
  4. An apparatus according to claim 2, characterized in that area definition data (23) storage area includes an area for storing directory identification data (33) indicating a directory to which an area defined by the area definition data belongs, an area number (35) for designating an area which belongs to a directory designated by the directory identification data, area start address data (37) indicating a position where an area designated by the area number is allocated in the area group storage area, area size data (39), area link data (41) indicating whether an area is area-registered or area-link registered, and link destination designation data (43) indicating a destination of area link.
  5. An apparatus according to claim 4, characterized in that the directory identification data has specific data indicating that the area does not belong to any directory.
  6. An apparatus according to claim 4, characterized in that when the area link data indicates that the area defined by the area definition data is area-registered, the link destination designation data is made invalid, and when the area link data indicates that the area defined by the area definition data is area-link registered, the area start address data and the area size data are made invalid.
  7. An apparatus according to claim 2, characterized by further comprising:
       means (52) for registering a directory name in the directory name storage area in accordance with registration instrucction, said registration instruction includes an operation code indicating a function of registering the directory name and an operand indicating the directory name.
  8. An apparatus according to claim 4, characterized by further comprising:
       directory selection instruction means (65) for selecting a directory name stored in the directory name storage area, said directory selection instruction means including an operation code having a function of selecting identification data corresponding to the directory name, and an operand indicating the directory name.
  9. An apparatus according to claim 8, characterized by further comprising:
       area registration instruction means (85) for registering an area in the area definition data storage area, said area registration instruction means including an operation code indicating a function of registering the area, and an operand indicating an area number and area size, checking whether or not area definition data having the directory identification data selected by said directory selection instruction means and the area number in said area registration instruction means has already been stored, if it is determined that the area definition data has not been stored, computing a start address of an area, and storing in the area definition data storage area, area definition data including the directory identification data selected by said directory selection instruction means, the area number and area size designated by the area registration instruction means, the computed area start address, and area link data indicating that the corresponding area is not linked with another area.
  10. An apparatus according to claim 4, characterized by further comprising:
       means (111) for registering area link data in the area definition data storage area in accordance with an area link registration instruction, said area link registration instruction including an operation code indicating a function of registering the area link data, and an operand including an area number, an area number to be linked with the area number, and a target directory name to be linked to which the area number to be linked belongs, finding the target directory name to be linked from the directory name storage area, finding area definition data having identification data of the found directory name and the target area number to be linked from the area definition data storage area, setting, as area link data, data indicating that an area is linked, and storing area definition data in which directory identification data of an area to be linked as link destination designation data and an area number are set in the area definition data storage area.
  11. An apparatus according to claim 2, characterized in that the area definition data storage area includes an area for storing access condition data indicating an access condition for a corresponding area, and access condition selection data indicating whether or not the access conditon data is used.
  12. An apparatus according to claim 11, characterized in that said control means further includes means for referring destination designation data of the area definition data when the access condition data indicates that the access condition for the corresponding area is not used, and uses access condition data of area definition data of a link destination area as an access condition for the corresponding area.
  13. An apparatus according to claim 1, characterized by setting means (43) for setting an access enable/disable condition indicating that an access is made by said control means (15, 17) in accordance with the two identification means.
  14. An apparatus according to claim 13, characterized in that said setting means sets the same access enable/disable condition.
  15. An apparatus according to claim 13, characterized in that said setting means sets the different access enable/disable condition.
  16. An apparatus according to claim 13, characterized in that said setting means includes:
       first setting unit for setting the same access enable/disable condition;
       second setting unit for setting the different access enable/disable condition; and
       means for selecting whether said first setting unit or said second setting unit is used.
  17. An apparatus according to claim 13, characterized by storage means (185) for storing sharing definition enable/disable data for discriminating whether or not sharing definition of first area groups defined by said setting means is enabled; and
       second area definition means (187) for defining a plurality of second area groups for said memory means (16);
       wherein said control means (15, 17) discriminates based on the sharing enable/disable data stored in said storage means (185) whether or not the sharing definition is enabled, when the first area groups defined by said setting means are sharing-defined.
EP89103927A 1988-03-09 1989-03-06 Portable electronic apparatus Expired - Lifetime EP0332117B1 (en)

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
JP63055376A JP3017736B2 (en) 1988-03-09 1988-03-09 Portable electronic devices
JP55376/88 1988-03-09
JP63200017A JPH0250286A (en) 1988-08-12 1988-08-12 Portable electronic device
JP200017/88 1988-08-12

Publications (3)

Publication Number Publication Date
EP0332117A2 EP0332117A2 (en) 1989-09-13
EP0332117A3 EP0332117A3 (en) 1990-05-30
EP0332117B1 true EP0332117B1 (en) 1994-05-11

Family

ID=26396276

Family Applications (1)

Application Number Title Priority Date Filing Date
EP89103927A Expired - Lifetime EP0332117B1 (en) 1988-03-09 1989-03-06 Portable electronic apparatus

Country Status (5)

Country Link
US (1) US5097118A (en)
EP (1) EP0332117B1 (en)
KR (1) KR970006646B1 (en)
DE (1) DE68915186T2 (en)
HK (1) HK1002922A1 (en)

Families Citing this family (26)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5226010A (en) * 1990-04-05 1993-07-06 Micro Technology, Inc. Method and apparatus for simultaneous, interleaved access of multiple memories by multiple ports
JP2854680B2 (en) * 1990-06-15 1999-02-03 株式会社東芝 IC memory card
US5235551A (en) * 1991-01-08 1993-08-10 Pacific Data Products, Inc. Memory addressing scheme
JPH06274397A (en) * 1993-03-24 1994-09-30 Toshiba Corp File control system
BR9702167A (en) * 1996-03-11 1999-12-28 Kaba Schiessysteme Ag Means of identification with a passive electronic data carrier
PT798674E (en) * 1996-03-29 2002-08-30 Toshiba Kk METHOD OF FILTER MANAGEMENT THAT REQUIRES THE CHANGE OF KEY DATA AND IC CARD DEVICE FOR USING THE METHOD
TW357298B (en) * 1996-09-12 1999-05-01 Toshiba Corp IC card portable terminal
FR2765362B1 (en) * 1997-06-26 2001-08-17 Bull Cp8 SECURITY MODULE COMPRISING MEANS OF CREATING LINKS BETWEEN MAIN FILES AND AUXILIARY FILES
JPH1153482A (en) * 1997-07-31 1999-02-26 Fujitsu Ltd Card reader
JP4051510B2 (en) 1998-07-16 2008-02-27 ソニー株式会社 Data storage device and data storage method
DE19847414A1 (en) * 1998-10-14 2000-04-20 Orga Consult Gmbh System for processing information and information carriers
FR2785424B1 (en) * 1998-10-30 2000-12-15 Schlumberger Ind Sa DEVICE FOR MANAGING ACCESS IN AN INTEGRATED CIRCUIT CARD
DE19852533C2 (en) * 1998-11-08 2002-05-29 Florian Hoeffle Device for providing data and / or applications in at least one data memory and / or microprocessor of a mobile data carrier
JP2000231608A (en) 1999-02-10 2000-08-22 Hitachi Ltd Mobile object identification device and ic card
JP4204133B2 (en) * 1999-02-26 2009-01-07 ローム株式会社 Communications system
US20040025035A1 (en) * 2000-10-23 2004-02-05 Rais Jean-Claude Contactless electronic identification system
JP4393733B2 (en) * 2001-11-27 2010-01-06 大日本印刷株式会社 Portable information recording medium
US6892985B2 (en) * 2002-07-25 2005-05-17 The Boeing Company Store ejection system with disposable pressure vessel and associated method of operation
US7844961B2 (en) * 2004-12-22 2010-11-30 Sap Ag Automatic field linking
US7788438B2 (en) 2006-10-13 2010-08-31 Macronix International Co., Ltd. Multi-input/output serial peripheral interface and method for data transmission
US9378142B2 (en) 2011-09-30 2016-06-28 Intel Corporation Apparatus and method for implementing a multi-level memory hierarchy having different operating modes
EP2761469B1 (en) 2011-09-30 2019-11-13 Intel Corporation Non-volatile random access memory (nvram) as a replacement for traditional mass storage
CN103946814B (en) 2011-09-30 2017-06-06 英特尔公司 The autonomous initialization of the nonvolatile RAM in computer system
WO2013048491A1 (en) 2011-09-30 2013-04-04 Intel Corporation Apparatus, method and system that stores bios in non-volatile random access memory
EP2761468B1 (en) * 2011-09-30 2019-12-11 Intel Corporation Platform storage hierarchy with non-volatile random access memory having configurable partitions
TW201427366A (en) * 2012-12-28 2014-07-01 Ibm Method and appliance of decrypting files for data leakage protection in an enterprise network

Family Cites Families (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3829837A (en) * 1971-06-24 1974-08-13 Honeywell Inf Systems Controller for rotational storage device having linked information organization
US3828320A (en) * 1972-12-29 1974-08-06 Burroughs Corp Shared memory addressor
FR2523745B1 (en) * 1982-03-18 1987-06-26 Bull Sa METHOD AND DEVICE FOR PROTECTING SOFTWARE DELIVERED BY A SUPPLIER TO A USER
US4575827A (en) * 1984-05-18 1986-03-11 International Business Machines Corporation Self-archiving data recording
JPH0818473B2 (en) * 1985-07-31 1996-02-28 トッパン・ムーア株式会社 IC card that can set confidentiality level
JPH0635227B2 (en) * 1985-07-31 1994-05-11 トツパン・ム−ア株式会社 IC card having means for reading update information and history information
US4742215A (en) * 1986-05-07 1988-05-03 Personal Computer Card Corporation IC card system

Also Published As

Publication number Publication date
HK1002922A1 (en) 1998-09-25
US5097118A (en) 1992-03-17
DE68915186T2 (en) 1994-08-25
KR970006646B1 (en) 1997-04-29
EP0332117A2 (en) 1989-09-13
DE68915186D1 (en) 1994-06-16
KR890015151A (en) 1989-10-28
EP0332117A3 (en) 1990-05-30

Similar Documents

Publication Publication Date Title
EP0332117B1 (en) Portable electronic apparatus
US4985615A (en) Portable electronic apparatus having key data for limiting memory access
JP2537199B2 (en) IC card
US4988855A (en) Portable electronic apparatus
JP3015377B2 (en) IC card
KR910002257B1 (en) Portable electronic device
US4983816A (en) Portable electronic device
JPH06274397A (en) File control system
JPH022475A (en) Ic card
JPS62190584A (en) Portable electronic device
US5828053A (en) Portable storage medium and portable storage medium issuing system
EP0559170B1 (en) Portable electronic apparatus
JP2671213B2 (en) IC card
JPH0250286A (en) Portable electronic device
JP3017736B2 (en) Portable electronic devices
JP2677589B2 (en) Portable electronic device and IC chip
JPH0654507B2 (en) Portable electronic device
JP2537200B2 (en) Portable electronic devices
US7296289B2 (en) Setting or changing an access condition for an access management apparatus and method of a portable electronic device
JP3209994B2 (en) Portable electronic devices
JPH02140892A (en) Ic card system
JPH0746376B2 (en) IC card
JP2537198B2 (en) Portable electronic devices
JP2656272B2 (en) Portable electronic devices
JP4177642B2 (en) Portable electronic device

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: 19890403

AK Designated contracting states

Kind code of ref document: A2

Designated state(s): DE FR GB

PUAL Search report despatched

Free format text: ORIGINAL CODE: 0009013

AK Designated contracting states

Kind code of ref document: A3

Designated state(s): DE FR GB

17Q First examination report despatched

Effective date: 19920803

GRAA (expected) grant

Free format text: ORIGINAL CODE: 0009210

AK Designated contracting states

Kind code of ref document: B1

Designated state(s): DE FR GB

REF Corresponds to:

Ref document number: 68915186

Country of ref document: DE

Date of ref document: 19940616

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
REG Reference to a national code

Ref country code: GB

Ref legal event code: IF02

PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: GB

Payment date: 20080305

Year of fee payment: 20

PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: FR

Payment date: 20080311

Year of fee payment: 20

Ref country code: DE

Payment date: 20080228

Year of fee payment: 20

REG Reference to a national code

Ref country code: GB

Ref legal event code: PE20

Expiry date: 20090305

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: GB

Free format text: LAPSE BECAUSE OF EXPIRATION OF PROTECTION

Effective date: 20090305