The present invention relates to a USB portable device.
Rewritable portable media such as a USB (Universal Serial Bus) memory have been widely used. A portable medium is connected to a PC (Personal Computer) as a host, is recognized by the PC, and receives a rewrite access from the PC for rewriting data stored in a storage area of the portable medium.
A single portable medium can physically have therein a plurality of storage areas.
Patent Document 1 discloses that a storage area of a mass storage medium is effectively used by logically dividing the storage area into a plurality of divided areas and using a logical unit number for each of a plurality of the divided areas.
Patent Document 2 discloses that an access into an access limit area is limited by conducting authentication for the access.
Patent Document 3 discloses that, if a storage area is not suitable for specifications of an OS (Operating System), the storage area can be hidden.
Patent Documents 4 and 5 disclose that connection of a virtual device in a portable medium is controlled such that a privileged user can use the virtual device but the others cannot.
Patent Document 1: Japanese Laid-Open Patent Application, Publication No. H07-234759
Patent Document 2: Japanese Laid-Open Patent Application, Publication No. H10-289159
Patent Document 3: Japanese Laid-Open Patent Application, Publication No. 2005-115636
Patent Document 4: Japanese Laid-Open Patent Application, Publication No. 2006-202339
Patent Document 5: Japanese Laid-Open Patent Application, Publication No. 2006-286008
Some portable media store therein an automatic execution program. If the automatic execution program is connected to a host, the program is read and executed by the host. The automatic execution program is preinstalled in a portable medium by, for example, a distributor before the portable medium is distributed. It is not desirable for the distributor that the automatic execution program is fraudulently deleted or falsified. The technique of Patent Document 2 thus deals with such a fraudulent access into an access limit area by authentication for the access. However, if a portable medium receives a large number of accesses, its performance is deteriorated accompanied by necessary processing for the authentication (for example, a decrease in transfer rate).
Moreover, in the techniques according to the related art, an OS recognizes a plurality of drives, which is not convenient for a user.
The present invention has been made in an attempt to solve the above described problems and to provide a portable medium with an automatic execution program stored therein, capable of preventing a fraudulent access while enhancing convenience of a user.
To solve the above described problems, the present invention provides a USB portable device storing therein a switching program which is executed by being connected to a host apparatus, including:
an activating USB functioning unit that stores therein the switching program;
a storing USB functioning unit that permits a read and a write from the host apparatus; and
a controlling USB functioning unit that switches a device to be recognized by the host apparatus,
wherein the controlling USB functioning unit
Other means for solving the problems will be described hereinafter.
The present invention enables a portable medium storing therein an automatic execution program to be prevented from a fraudulent access while enhancing convenience of a user.
Below is described in detail an embodiment of a program distribution system to which the present invention is applied, with reference to related drawings.
The USB portable device 1 is configured as, for example, a USB memory at least including: a flash memory as a storage unit; and a control circuit chip (such as a CPU 17 shown in
The host apparatus 2 is configured as a computer at least including: a memory 23 as a storage unit which is used in performing an arithmetic processing; and an arithmetic processing unit which performs the arithmetic processing. The memory 23 may be a RAM (Random Access Memory) or the like. The arithmetic processing unit configured by a CPU (Central Processing Unit) 24 performs the arithmetic processing by executing a program in the memory 23.
The host apparatus 2 has a display device 25 on which data or the like is displayed.
The host apparatus 2 receives a data input via the USB port 29 from the input device 3 which is connected thereto, such as a keyboard and a mouse.
If the USB host driver unit 21 detects that the USB portable device 1 has been connected to the USB port 29, the USB host driver unit 21 performs recognition (enumeration) such that an OS (Operating System) of the host apparatus 2 can use hardware resources of the detected USB portable device 1. That is, the USB host driver unit 21 serves as a HCD (Host Controller Driver) in USB Standard.
The switching program execution unit 22 operates upon a read and an execution of the switching program 11 stored in a storage unit of the USB portable device 1 by the CPU 24 of the host apparatus 2 in the memory according to instructions from an OS thereof.
The switching program execution unit 22 selects one storage unit to be recognized as a mass storage device from among a plurality of storage units (an activating storage unit 1a and a storing storage unit 1b) present in the USB portable device 1. The storage unit recognized as the mass storage device is a storage unit accessible from the OS of the host apparatus 2.
If the activating storage unit 1a is recognized as a readable device, the CPU 17 makes the host apparatus 2 read the switching program 11 stored in the activating storage unit 1a.
If the storing storage unit 1b is recognized as a readable and writable device, the CPU 17 executes a read or a write of data stored in the storing storage unit 1b according to an access instruction from the host apparatus 2.
The switching program execution unit 22 switches storage units such that an already-recognized storage unit is first unmounted and another storage unit is then recognized. This eliminates need for a user to manually enter an input of unmounting the already-recognized mass storage device, which is convenient.
The aforementioned configuration of the USB system is commonly used in first to third embodiments to be described hereinafter. Next are described detailed configurations and operations in each of the embodiments. Features of the respective embodiments are as follows:
Next is described the first embodiment.
Port numbers (0, 1, and 2 shown in square-like shaped frames of
In this embodiment, the controlling USB peripheral 12c connected to the port “0” is assumed to be always in the “ON” state.
The activating USB peripheral 12a connected to the port “1” and the storing USB peripheral 12b connected to the port “2” are alternately switchable between the “ON” state and the “OFF” state. If one of the peripherals 12a, 12b is in the “ON” state, the other is always in the “OFF state”, and vice versa. In other words, it is not possible in this embodiment that both of the peripherals 12a, 12b are for example in the “ON” state at the same time.
The activating USB peripheral 12a includes a memory chip 13 as a storage unit, and a controller 15 controlling a read and a write of data from and into the memory chip 13. The memory chip 13 of the activating USB peripheral 12a stores therein the switching program 11. The switching program 11 is to be automatically run.
The storing USB peripheral 12b also includes a memory chip 13 as a storage unit, and a controller 15 controlling a read and a write of data from and into the memory chip 13.
The controlling USB peripheral 12c includes an interface unit 16 and a controller 15.
The interface unit 16 receives, from the switching program execution unit 22 via the USB interface 19, an instruction to designate one USB peripheral for being connected to the port switch 18b, from either the activating USB peripheral 12a or the storing USB peripheral 12b.
The controller 15 operates the port switch 18b according to the instruction received by the interface unit 16.
The interface unit 16 is recognized as, for example, a HID (Human Interface Device) class in USB standard by the USB host driver unit 21 so as to perform control communication with the host apparatus 2.
The USB portable device 1, before inserted in the host apparatus 2, initializes a mode thereof at an activating mode (S11). In the activating mode, the controlling USB peripheral 12c connected to the port “0” and the activating USB peripheral 12a connected to the port “1” are in the “ON” state. The storing USB peripheral 12b connected to the port “2” is in the “OFF” state.
If the USB interface 19 of the USB portable device 1 is inserted into the USB port 29 of the host apparatus 2 (S12c), the USB host driver unit 21 detects the inserted USB portable device 1 (S12b). Upon the detection, the USB host driver unit 21 performs recognition (enumeration) of the detected USB portable device 1. More specifically, the USB host driver unit 21 inquires of the USB portable device 1 which device is available. In response to the inquiry, the USB portable device 1 notifies the USB host driver unit 21 that the activating USB peripheral 12a, which is in the “ON” state, is a readable device (S13c) and that the switching program 11 stored in the readable device is an auto-run (automatic execution) program.
Upon receiving the response, the USB host driver unit 21 recognizes the activating USB peripheral 12a as the readable device (S13b). The USB host driver unit 21 transmits, to the USB portable device 1, a transfer instruction to activate the recognized switching program 11 in the readable device as the automatic execution program (S14b). The USB portable device 1 transfers the switching program 11 to the host apparatus 2 (S14c). The host apparatus 2 starts execution of the switching program 11, which makes the switching program execution unit 22 operate.
The switching program execution unit 22 transmits an instruction to unmount the readable device to the USB host driver unit 21 (S15a). Upon receiving the instruction, the USB host driver unit 21 unmounts the readable device recognized in S13b (S15b). Note that the switching program 11 has already been transferred to the host apparatus 2 and executed as the switching program execution unit 22. Thus, the unmount does not interrupt the execution of the switching program 11.
If the switching program execution unit 22 is notified that the unmount in S15b has been completed, the switching program execution unit 22 gives the USB portable device 1 an instruction to switch modes thereof from the activating mode in S11 to the storing mode (S16a). Following the instruction, the USB portable device 1 switches the modes to the storing mode (S16c). In the storing mode, the controlling USB peripheral 12c connected to the port “0” and the storing USB peripheral 12b connected to the port “2” are in the “ON” state. The activating USB peripheral 12a connected to the port “1” is in the “OFF” state.
Upon switching to the storing mode, the controller 15 of the controlling USB peripheral 12c gives the port switch 18b an instruction to change connections from the activating USB peripheral 12a to the storing USB peripheral 12b.
The switching program execution unit 22 generates a detection event similar to an event generated when the USB portable device 1 is inserted into the USB port 29 (S12c) in order for the USB host driver unit 21 to recognize another device of the USB portable device 1 (S17a). The USB host driver unit 21 receives the detection event and detects the already-inserted USB portable device 1 once again (S17b, S17c). In response to the detection, the USB host driver unit 21 performs recognition (enumeration) of the detected USB portable device 1 for a second time.
In the second recognition (enumeration), the USB host driver unit 21 inquires of the USB portable device 1 which device is available. In response to the inquiry, the USB portable device 1 notifies the USB host driver unit 21 that the storing USB peripheral 12b, which is in the “ON” state, is a readable and writable device (S18c). Upon receiving the response, the USB host driver unit 21 recognizes the storing USB peripheral 12b as the readable and writable device (S18b).
Then, the host apparatus 2 can read and write data in the storing USB peripheral 12b which has already been recognized. Meanwhile, the unmounted activating USB peripheral 12a is not at all visible from the USB host driver unit 21 at this time. This conveniently eliminates need for reading or writing data in the activating USB peripheral 12a.
In this embodiment as described above, two areas, one which is readable in the activating USB peripheral 12a and the other which is readable and writable in the storing USB peripheral 12b can be efficiently used by switching over the two areas, while reducing fraudulent access to the activating USB peripheral 12a.
Next is described the second embodiment.
The controller 15 connects either one of the activating memory chip 13a and the storing memory chip 13b, to the USB interface 19. The controller 15 thus sets each of the memory chips at either the “ON” state or the “OFF” state.
The activating memory chip 13a and the storing memory chip 13b are alternately switchable between the “ON” state and the “OFF” state. If one of the memory chips 13a, 13b is in the “ON” state, the other is always in the “OFF state”, and vice versa. In other words, it is not possible in this embodiment that both of the peripherals 12a, 12b are for example in the “ON” state at the same time.
The activating memory chip 13a stores therein the switching program 11. The switching program 11 is to be automatically run.
The interface unit 16 receives, from the switching program execution unit 22 via the USB interface 19, an instruction to designate one memory chip for being connected, from either the activating memory chip 13a or the storing memory chip 13b and operates the controller 15 according to the instruction. The interface unit 16 is recognized as a HID (Human Interface Device) class in USB standard by the USB host driver unit 21 so as to perform control communication with the host apparatus 2.
The USB portable device 1, before inserted in the host apparatus 2, initializes a mode thereof at an activating mode (S11). In the activating mode, the activating memory chip 13a is in the “ON” state, and the storing memory chip 13b is in the “OFF” state.
If the USB interface 19 of the USB portable device 1 is inserted into the USB port 29 of the host apparatus 2, (S12c), USB host driver unit 21 detects the inserted USB portable device 1 (S12b). Upon the detection, the USB host driver unit 21 performs recognition (enumeration) of the detected USB portable device 1. More specifically, the USB host driver unit 21 inquires of the USB portable device 1 which device is available. In response to the inquiry, the USB portable device 1 notifies the USB host driver unit 21 that the activating memory chip 13a, which is in the “ON” state, is a readable device (S23c) and that the switching program 11 stored in the readable device is an auto-run (automatic execution) program.
Upon receiving the response, the USB host driver unit 21 recognizes the activating memory chip 13a as the readable device (S23b). The USB host driver unit 21 transmits, to the USB portable device 1, a transfer instruction to activate the recognized switching program 11 in the readable device as the automatic execution program (S14b). The USB portable device 1 transfers the switching program 11 to the host apparatus 2 (S14c). The host apparatus 2 starts execution of the switching program 11, which makes the switching program execution unit 22 operate.
The switching program execution unit 22 transmits an instruction to unmount the readable device to the USB host driver unit 21 (S15a). Upon receiving the instruction, the USB host driver unit 21 unmounts the readable device recognized in S23b (S15b). Note that the switching program 11 has already been transferred to the host apparatus 2 and executed as the switching program execution unit 22. Thus, the unmount does not interrupt the execution of the switching program 11.
If the switching program execution unit 22 is notified that the unmount in S15b has been completed, the switching program execution unit 22 gives the USB portable device 1 an instruction to switch modes thereof from the activating mode in S11 to the storing mode (S16a). Following the instruction, the USB portable device 1 switches the modes to the storing mode (S16c). In the storing mode, the storing memory chip 13b is in the “ON” state, and the activating memory chip 13a is in the “OFF” state.
Upon switching to the storing mode, the controller 15 switches connections from the activating memory chip 13a to the storing memory chip 13b.
The switching program execution unit 22 generates a detection event similar to an event inserted into the USB port 29 (S12c) in order for the USB host driver unit 21 to recognize another device of the USB portable device 1 (S17a). The USB host driver unit 21 receives the detection event and detects the already-inserted USB portable device 1 once again (S17b, S17c). In response to the detection, the USB host driver unit 21 performs recognition (enumeration) of the detected USB portable device 1 for a second time.
In the second recognition (enumeration), the USB host driver unit 21 inquires of the USB portable device 1 which device is available. In response to the inquiry, the USB portable device 1 notifies the USB host driver unit 21 that the storing memory chip 13b, which is in the “ON” state, is a readable and writable device (S28c). Upon receiving the response, the USB host driver unit 21 recognizes the storing memory chip 13b as the readable and writable device (S28b).
Then, the host apparatus 2 can read and write data in the storing memory chip 13b which has already been recognized. Meanwhile, the unmounted activating memory chip 13a is not at all visible from the USB host driver unit 21 at this time. This conveniently eliminates need for reading or writing data in the activating USB peripheral 12a.
In this embodiment as described above, two areas, one which is readable in the activating memory chip 13a and the other which is readable and writable in the storing memory chip 13b can be efficiently used by switching over the two areas, while reducing fraudulent access to the activating memory chip 13a.
Next is described the third embodiment.
The controller 15 connects either one of the activating virtual area 14a or the storing virtual area 14b, to the USB interface 19. The controller 15 thus sets each of the virtual areas at either the “ON” state or the “OFF” state.
The activating virtual area 14a and the storing virtual area 14b are alternately switchable between the “ON” state and the “OFF” state. If one of the virtual areas 14a, 14b is in the “ON” state, the other is always in the “OFF state”, and vice versa. In other words, it is not possible in this embodiment that both of the peripherals 12a, 12b are for example in the “ON” state at the same time.
The activating virtual area 14a stores therein the switching program 11. The switching program 11 is to be automatically run.
The interface unit 16 receives, from the switching program execution unit 22 via the USB interface 19, an instruction to designate one virtual area for being connected, from either the activating virtual area 14a or the storing virtual area 14b and operates the controller 15 according to the instruction. The interface unit 16 is recognized as, for example, a HID (Human Interface Device) class in USB standard by the USB host driver unit 21 so as to perform control communication with the host apparatus 2.
The USB portable device 1, before inserted in the host apparatus 2, initializes a mode thereof at an activating mode (S11). In the activating mode, the activating virtual area 14a is in the “ON” state, and the storing virtual area 14b is in the “OFF” state.
If the USB interface 19 of the USB portable device 1 is inserted into the USB port 29 of the host apparatus 2, (S12c), USB host driver unit 21 detects the inserted USB portable device 1 (S12b). Upon the detection, the USB host driver unit 21 performs recognition (enumeration) of the detected USB portable device 1. More specifically, the USB host driver unit 21 inquires of the USB portable device 1 which device is available. In response to the inquiry, the USB portable device 1 notifies the USB host driver unit 21 that the activating virtual area 14a, which is in the “ON” state, is a readable device (S33c) and that the switching program 11 stored in the readable device is an auto-run (automatic execution) program.
Upon receiving the response, the USB host driver unit 21 recognizes the activating virtual area 14a as the readable device (S33b). The USB host driver unit 21 transmits, to the USB portable device 1, a transfer instruction to activate the recognized switching program 11 in the readable device as the automatic execution program (S14b). The USB portable device 1 transfers the switching program 11 to the host apparatus 2 (S14c). The host apparatus 2 starts execution of the switching program 11, which makes the switching program execution unit 22 operate.
The switching program execution unit 22 transmits an instruction to unmount the readable device to the USB host driver unit 21 (S15a). Upon receiving the instruction, the USB host driver unit 21 unmounts the readable device recognized in S23b (S15b). Note that the switching program 11 has already been transferred to the host apparatus 2 and executed as the switching program execution unit 22. Thus, the unmount does not interrupt the execution of the switching program 11.
If the switching program execution unit 22 is notified that the unmount in S15b has been completed, the switching program execution unit 22 gives the USB portable device 1 an instruction to switch modes thereof from the activating mode in S11 to the storing mode (S16a). Following the instruction, the USB portable device 1 switches the modes to the storing mode (S16c). In the storing mode, the storing virtual area 14b is in the “ON” state, and the activating virtual area 14a is in the “OFF” state.
Upon switching to the storing mode, the controller 15 switches connections from the activating virtual area 14a to the storing virtual area 14b.
The switching program execution unit 22 generates a detection event similar to an event generated when the USB portable device 1 is inserted into the USB port 29 (S12c) in order for the USB host driver unit 21 to recognize another device of the USB portable device 1 (S17a). The USB host driver unit 21 receives the detection event and detects the already-inserted USB portable device 1 once again (S17b, S17c). In response to the detection, the USB host driver unit 21 performs recognition (enumeration) of the detected USB portable device 1 for a second time.
In the second recognition (enumeration), the USB host driver unit 21 inquires of the USB portable device 1 which device is available. In response to the inquiry, the USB portable device 1 notifies the USB host driver unit 21 that the storing virtual area 14b, which is in the “ON” state, is a readable and writable device (S38c). Upon receiving the response, the USB host driver unit 21 recognizes the storing virtual area 14b as the readable and writable device (S38b).
Then, the host apparatus 2 can read and write data in the storing virtual area 14b which has already been recognized. Meanwhile, the unmounted activating virtual area 14a is not at all visible from the USB host driver unit 21 at this time. This conveniently eliminates need for reading or writing data in the activating USB peripheral 12a.
In this embodiment as described above, two areas, one which is readable in the activating virtual area 14a and the other which is readable and writable in the storing virtual area 14b can be efficiently used by switching over the two areas, while reducing fraudulent access to the activating virtual area 14a.
In a configuration in which respective virtual areas have their dedicated memory chips 13 as in
The first to third embodiments have been explained above. Features of respective embodiments are described below.
In all of the embodiments, the switching program 11 selects and switches to one storage unit to be recognized by the USB host driver unit 21 from among a plurality of storage units. A storage unit in the OFF state is thus invisible from the USB host driver unit 21. This eliminates need of constantly controlling a fraudulent access to a storage unit in the OFF state, otherwise, for example, by means of a control of excluding an unauthorized write instruction to a readable device. As a result, fraudulent access can be prevented and security is improved without causing performance deterioration accompanied by such a constant control.
As a storage unit to be switched, the first embodiment has a plurality of USB peripherals. The second embodiment has a plurality of memory chips. And, the third embodiment has a plurality of virtual areas. Next is described a difference of advantageous effects according to a hardware configuration of each embodiment, especially focusing on manufacturing cost and reliability.
In terms of manufacturing cost of the USB portable device 1, the third embodiment costs the least of the three because a virtual area does not require additional hardware. The second embodiment costs the second least because an additional USB peripheral is not necessary but an additional memory chip is necessary. The first embodiment costs the third because both an additional peripheral and an additional memory chip thereof are necessary.
In terms of reliability of the USB portable device 1, the first embodiment is the most reliable because a hardware failure of one USB peripheral does not affect the other USB peripherals. The second embodiment is the second most reliable because a hardware failure of one memory chip does not affect the other memory chips. The third embodiment is the third because a failure of one memory chip makes all virtual areas in the memory chip unusable.
The present invention as described above can be modified and carried out in a wide range without departing from the spirit and scope of the invention as described below.
For example, an activating storage unit is a possible target for a fraudulent write, to which a prevention measure is necessary. This is because the activating storage can be recognized as a readable device by the USB host driver unit 21, though just during a very short period of time which is required for activating the switching program 11 (in
Another measure for preventing a fraudulent write from being inputted into an activating storage unit is that the storage unit is configured to be a ROM (Read Only Memory) which has an attribute of being readable but unwritable. This ensures that the switching program 11 is prevented from being falsified, though making it impossible for the switching program 11 written in the ROM to be updated.
The switching program 11 switches, as a basic function thereof, a storage unit to be recognized as described above. In addition to the basic function, the switching program 11 can be configured to realize functions of various applications suitable for usage of the USB portable device 1. For example, the switching program 11 is configured to authenticate a user of the USB portable device 1 with a password entry or the like as a requirement of switching a storage unit. This can prevent those other than the user of the USB portable device 1 from inappropriately looking at data in the USB portable device 1 even if somehow obtained.
Referring to a communication path between the USB portable device 1 and the host apparatus 2, a path for controlling via the interface unit 16 and a path for data communication not via the interface unit 16 may be disposed separately. Or, the interface unit 16 may be omitted, and only the path for data communication may be used.
In the latter case, both a communication packet for controlling and a communication packet for data communication are in one path. This requires information for distinguish one communication packet from the other. The two communication packets can be distinguished by, for example, setting a prescribed flag on a communication packet for controlling and not setting the prescribed flag on a communication packet for data communication.
In the first embodiment, the controller 15 of the controlling USB peripheral 12c constantly monitors a communication packet communicated via the USB interface 19. The controller 15 receives a communication packet with the prescribed flag as the communication packet for controlling and transfers another communication packet without the prescribed flag to a USB peripheral which is connected to the port switch 18b and is in the “ON” state.
On the other hand, in the second and third embodiments, the controller 15 constantly monitors a communication packet communicated via the USB interface 19. The controller 15 receives a communication packet with a prescribed flag as the communication packet for controlling. The controller 15 receives another communication packet without the prescribed flag as a communication packet for data communication.
Referring to the storing storage unit 1b, one or a plurality of the storing storage units 1b may be used as explained in the above embodiments. If a plurality of the storing storage units 1b are used, only one of those storing storage units 1b is recognized.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/JP2008/050415 | 1/16/2008 | WO | 00 | 9/28/2010 |