The present application is based on and claims priority under 35 U.S.C. § 119 to Japanese Patent Application No. 2023-110765, filed on Jul. 5, 2023, the contents of which are incorporated herein by reference in their entirety.
The present invention relates to an information processing apparatus, a method, and a recording medium.
Conventionally, in information processing apparatuses, such as multifunction peripherals and printers, in order to correct defects or add functions after the product is put on the market, firmware update is performed. Then, when a defect is mixed in the latest firmware, other functions are unintentionally affected, and in some cases, the quality of the software is degraded compared with that before the change. When it is desired to return to the old version (previous version) in order to avoid such degradation due to the firmware update, it is necessary to perform the firmware update again. In this case, before the program is rewritten to the new version, the program of the old version is backed up in a hard disk drive or the like in advance, and when a problem occurs due to the firmware and the program is to be restored, the program is rewritten to the old version.
On the other hand, there is a technology for easily restoring the old version by having a storage device, such as a flash ROM, having a dual plane storage area for storing the program and switching the plane to be read at the time of startup.
According to one aspect of the present invention, there is provided an information processing apparatus including a first device; a second device; a control unit configured to implement control to update or restore at least one of a first program of the first device or a second program of the second device; and a storage configured to store a first version of the second program of the second device, wherein the first device includes a plurality of storage areas for respectively holding a first version and a second version of the first program, the second device includes a storage area for holding a second version of the second program different from the first version of the second program, when restoring the first program of the first device, the control unit makes a setting in the first device so as to switch a storage area used for startup among the plurality of the storage areas, and when restoring the second program of the second device, the control unit rewrites the storage area of the second device with the first version of the second program stored in the storage.
In the conventional technology for backing up the program of the old version, the program needs to be backed up in advance, and when restoring the program, the program needs to be rewritten to the old version, and, therefore, there is a problem that the restoration takes a long time. This becomes more noticeable especially when the number of devices increases. Further, the technology for making the storage area to be dual plane is not sufficient in that there are devices that cannot have a dual plane storage area because of capacity or cost, and if there is such a device that cannot have a dual plane storage area, the restoration cannot be performed for such a device. In particular, if a device that can have a dual plane storage area and a device that cannot have a dual plane storage area coexist, there is a possibility that the quality of the entire apparatus is degraded due to version mismatch between the devices.
The technology of Patent Document 1 is known in relation to returning to the old version of the firmware. Patent Document 1 discloses a configuration in which restoration from the new version to the old version of the program is accepted either individually or collectively for the purpose of enabling to return to the old version of the program information voluntarily and selectively, and reducing the time required for restoration of the program information. The conventional technology described in Patent Document 1 can make the program return to the old version from the new version. However, the conventional technology described in Patent Document 1 cannot solve the problem that restoration takes time because the program needs to be backed up in advance and the program needs to be rewritten to the old version when restoration is performed.
A problem to be addressed by an embodiment of the present invention is to provide an information processing apparatus capable of preventing mismatching of versions between devices and reducing the time required for restoration while preventing degrading of the quality of the entire apparatus in a configuration where devices having a plurality of storage areas for holding a plurality of versions (versions) of a program and devices having a storage area for holding a version of a program coexist.
Hereinafter, the present embodiment will be described in detail with reference to the drawings, but the embodiment is not limited to the specific embodiment described. Note that the embodiment of the present disclosure is open to various changes and modifications.
Hereinafter, the present embodiment will be described in more detail with reference to the drawings, taking as an example a multifunction peripheral and a controller thereof, as an information processing apparatus and the control device thereof. However, the information processing apparatus and the control device thereof according to the present embodiment are not limited to these. The embodiment of the present disclosure can be applied to any information processing apparatus including a plurality of devices and the control device thereof. Here, the device refers to a device constituting the information processing apparatus together with other devices and serving as a unit for updating software, such as firmware.
Among these, the controller 110 has a CPU 101 which is a main part of a computer, a system memory (MEM-P) 102, a north bridge (NB) 103, a south bridge (SB) 104, an ASIC (Application Specific Integrated Circuit) 106, a local memory (MEM-C) 107 which is a storage unit, an HDD controller 108, an HD 109 which is a storage unit, and a non-volatile memory 111, and the NB 103 and the ASIC 106 are connected by an AGP (Accelerated Graphics Port) bus 121. The controller 110 constitutes a control device in the present embodiment for controlling firmware update and restoration of the entire multifunction peripheral 100.
Of these, the CPU 101 is a control unit for overall control of the multifunction peripheral 100. The NB 103 is a bridge for connecting the CPU 101, the MEM-P 102, the SB 104, and the AGP bus 121, and has a memory controller for controlling reading and writing to and from the MEM-P 102, a PCI (Peripheral Component Interconnect) master, and an AGP target.
The MEM-P 102 includes a ROM 102a, which is a memory for storing programs and data for implementing each function of the controller 110, and a RAM 102b, which is used as a memory for loading programs and data, and for rendering during memory printing. Programs and data stored in the ROM 102a are targets of firmware update and restoration according to the present embodiment.
The SB 104 is a bridge for connecting the NB 103, a PCI device, and peripheral devices. The ASIC 106 is an integrated circuit (IC) for image processing that includes hardware elements for image processing, and serves as a bridge for connecting the AGP bus 121, the PCI bus 122, the HD 109, the MEM-C 107, and the non-volatile memory 111. The ASIC 106 includes a PCI target and an AGP master, an arbiter (ARB) that forms the core of the ASIC 106, a memory controller that controls the MEM-C 107, a plurality of DMACs (Direct Memory Access Controllers) that rotate image data by hardware logic or the like, and a PCI unit that transfers data between the scanner unit 131 and the printer unit 132 via the PCI bus 122. The ASIC 106 may be connected to a USB (Universal Serial Bus) interface or an IEEE1394 (Institute of Electrical and Electronics Engineers 1394) interface.
The MEM-C 107 is a local memory used as a copy image buffer and a code buffer. The HD 109 is a storage for storing image data, font data used at the time of printing, and forms. In the described embodiment, the HD 109 constitutes a storage unit in the present embodiment for storing a backup of firmware (program) of a predetermined version. The HD 109 controls reading or writing of data to or from the HD 109 under the control of the CPU 101. The AGP bus 121 is a bus interface for a graphics accelerator card proposed for speeding up graphics processing, and can speed up the graphics accelerator card by directly accessing the MEM-P 102 at high throughput. The non-volatile memory 111 is a memory for storing various types of data requiring nonvolatility (specification of a storage area to be used for starting up the dual plane ROM of a predetermined device according to the present embodiment, etc.).
The short-range communication circuit 120 includes an antenna 120a. The short-range communication circuit 120 is a communication circuit, such as NFC, Bluetooth (registered trademark), etc.
Further, the engine 130 includes a scanner unit 131, a printer unit 132, a CPU 133, a ROM 134, and a RAM 135. Of these, the CPU 133 is a control unit that performs various kinds of control of the engine 130. The ROM 134 is a memory for storing programs and data that implement the functions of the engine 130. The RAM 135 provides a work area in which programs stored in the ROM 134 are loaded. Programs and data stored in the ROM 134 of the engine 130 are targets of firmware update and restoration according to the present embodiment.
The operation panel 140 includes a central processing unit (CPU) 141, a read-only memory (ROM) 142, a random access memory (RAM) 143, and a panel display unit (not illustrated). The CPU 141 is a control unit that controls the operation panel 140. The ROM 142 is a memory for storing programs and data that implement the functions of the operation panel 140. The RAM 143 provides a work area in which programs stored in the ROM 142 are loaded. The panel display unit includes a touch panel that displays current setting values, selection screens, and the like and receives input from the user, a numeric keypad that receives setting values of conditions related to image formation, such as density setting conditions, and a start key that receives a copy start instruction. Programs and data stored in the ROM 142 of the operation panel 140 are targets of firmware update and restoration according to the present embodiment.
As described above, in the present embodiment, the controller 110, the engine 130, and the operation panel 140 constitute the multifunction peripheral 100 and a “device” as a unit for updating and restoring firmware. The programs (firmware) stored in the ROM 102a of the controller 110, the ROM 134 of the engine 130, and the ROM 142 of the operation panel 140 are targets to be updated and restored.
The controller 110 controls the entire multifunction peripheral 100 and controls, for example, rendering, communication, input from the operation panel 140, and the like. In the described embodiment, the controller 110 controls the entire firmware update and restoration of a plurality of devices, more specifically, the controller 110 itself, the engine 130, and the operation panel 140. The scanner unit 131 or the printer unit 132 includes image processing parts, such as error diffusion and gamma conversion.
An application switch key on the operation panel 140 of the multifunction peripheral 100 can be used to cycle through a document box function, a copy function, a printer function, and a facsimile function to select one of the functions. A document box mode is selected when a document box function is selected, a copy mode is selected when a copy function is selected, a printer mode is selected when a printer function is selected, and a facsimile mode is selected when a facsimile mode is selected.
The network I/F 150 is an interface for data communication using a communication network. The short-range communication circuit 120 and the network I/F 150 are electrically connected to the ASIC 106 via the PCI bus 122.
The hardware configuration illustrated in
The scanner unit 131 may include, for example, a document glass and an automatic document feed device, and a sensor for detecting the size of a document. The configuration of the printer unit 132 is not particularly limited, and may be a printer of any system, such as an electrophotographic system or an inkjet system. The printer unit 132 may further include a post-processing device, such as a stapler and a finisher.
Although the hardware configuration of the multifunction peripheral 100 has been described, by appropriately adding or deleting components (for example, deleting the scanner unit), information processing apparatuses other than image processing apparatuses, such as a printer which is an image forming apparatus other than the multifunction peripheral, a facsimile which is an image transmitting device, a scanner which is an image reading device, an image forming apparatus, an image transmitting device, and an image reading device can be similarly configured.
Referring to
In
The startup control unit 112 executes startup processing of the controller 110. The startup control unit 112 corresponds to the boot loader of the controller 110. In the described embodiment, the ROM 102a of the controller 110 has a sufficient capacity and is dual plane, and the controller 110 has a plurality of storage areas for holding different versions (first version and second version) of a program. These two storage areas are obtained by dividing the storage area of the ROM (storage device) 102a and are rewritable partial storage areas of typically the same capacity. Therefore, even if an unintentional power loss occurs during the rewriting and the rewriting fails, a state in which the rewriting is successful can be maintained. The startup control unit 112 refers to the non-volatile memory 111 when the multifunction peripheral 100 is started up and the controller 110 is started up, and identifies a storage area (plane) to be used (referred to) for starting up the ROM 102a. Next, the startup control unit 112 reads a firmware program from the identified storage area to be used, and loads the program into the RAM 102b. After the program is loaded into the RAM 102b, each program is executed.
The update/restoration control unit 113 performs control to update the firmware stored in the ROM 102a of the controller 110 to the latest version and to restore the firmware to the old version in response to an instruction from a user or the like. The update/restoration control unit 113 performs control to update and restore the firmware of the controller 110 itself, and also performs control to update and restore the firmware of other devices (e.g., the engine 130, the operation panel 140, other facsimile control units, etc.) of the multifunction peripheral 100 by transmitting instructions to other devices via the controller control unit 114. The update/restoration control unit 113 constitutes a control unit in the present embodiment.
The controller control unit 114 performs various kinds of control as the controller 110. When updating another device, the controller control unit 114 transfers update data to the control unit of the corresponding device and requests the update. The HD 109 constitutes a storage unit in the present embodiment for backing up and storing the firmware of the ROM that is not dual plane due to capacity or the like.
Although the startup control unit 112, the update/restoration control unit 113, and the controller control unit 114 are illustrated as separate functional blocks in
When starting up the engine 130, the engine control unit 136 is implemented by the CPU 133 of the engine 130 reading a program from the ROM 134 and loading the program to the RAM 135. The engine control unit 136 performs various kinds of control of the engine 130, and in response to an instruction from the controller 110, updates the firmware of the engine 130 with a program included in the specified update data.
When starting up the operation panel 140, the operation panel control unit 144 is implemented by the CPU 141 of the operation panel 140 reading a program from the ROM 142 and loading the program to the RAM 143. The operation panel control unit 144 performs various kinds of control of the operation panel 140, and in response to an instruction from the controller 110, updates the firmware of the operation panel 140 with a program included in the specified update data.
In the described embodiment, the update/restoration control unit 113 of the controller 110 is assumed to take charge of the firmware update and restoration control. However, the control is not limited to such a configuration, and another device (e.g., the engine 130, the operation panel 140, or other devices) may take charge of the firmware update and restoration control. Hereinafter, the firmware update and restoration processing will be described more specifically on the assumption that the update/restoration control unit 113 of the controller 110 takes charge of the overall control.
Before the update, the first device 210 holds different versions of the firmware for the first device in a plurality of storage areas 218, 220, respectively. In the described embodiment, the number of storage areas is two, but the number is not limited thereto. The non-volatile memory 212 is provided with a specification 214 of an area (startup area) to be referenced or used at startup. According to the specification 214 of the startup area, one of the different versions held in the plurality of storage areas is used.
When updating the first device 210 that supports dual plane storage with the latest version 252 of the firmware for the first device (device 1), the update/restoration control unit 113 (1) reads the latest version 252 of the firmware for the first device from the recording medium 250 and rewrites one of the plurality of storage areas 218, 220 (the first storage area 218 in the example of
On the other hand, when updating the second device 230 that does not support dual plane storage with the latest version 254 of the firmware for the second device (device 2), the update/restoration control unit 113 (1) reads the current version (the old version) of the firmware for the second device held in the single storage area 234 of the ROM 232 of the second device 230 and stores the current version (the old version) in the HD 260 as a backup 262. Next, the update/restoration control unit 113 (2) reads the latest version 254 of the firmware for the second device from the recording medium 250 and rewrites the single storage area 234 of the ROM 232 of the second device 230 with the latest version 254. Note that, in the described embodiment, the firmware of the old version (the one before) held in the single storage area 234 of the ROM 232 is backed up at the time of updating as the latest version of the firmware at that time point, but the embodiment is not limited thereto. In another embodiment, at the time of the update, the latest version of the firmware to be used in the update may be backed up to the HD 260 for future restoration. In this case, before and after the single storage area 234 of the ROM 232 is rewritten, the latest version 254 is stored in the HD 260 as the backup 262.
At the time point before restoration, a plurality of storage areas 218, 220 of the ROM 216 of the first device 210 hold the firmware of the latest version at that time point and the old version (the one before), and information indicating the storage area of the latest version at that time point is held in the specification 214 of the startup area in the non-volatile memory 212. A single storage area 234 of the ROM 232 of the second device 230 holds the firmware of the latest version at that time point, and a backup 262 of the old version (the one before) at that time point of the firmware of the second device 230 is stored in the HD 260.
In the case of restoring the first device 210 supporting dual plane storage to the old version of the firmware, the update/restoration control unit 113 (1) makes a request (sets) the startup control unit of the corresponding device to rewrite the non-volatile memory 212 so as to specify the storage area holding the old version (220 in
On the other hand, in the case of restoring the second device 230, which does not support dual plane storage, to the old version of the firmware, the update/restoration control unit 113 (1) causes the single storage area 234 of the ROM 232 of the second device 230 to be rewritten with the backup 262 of the old version of the firmware for the second device.
In the described embodiment, the first device 210 is described as having a single ROM (storage device) having a plurality of divided storage areas switchable at startup. However, the present embodiment is not limited thereto. In another embodiment, for example, a plurality of physically different ROMs may be provided to switch the ROM to be used.
In step S101, the controller 110 acquires a device information list described later by the update/restoration control unit 113. In step S102, the controller 110 acquires the update destination device information by the update/restoration control unit 113. In step S103, the controller 110 acquires the number of storage areas of the update destination corresponding to the device information of the update destination from a device information list by the update/restoration control unit 113.
In step S104, the controller 110 determines whether the device to be updated has two storage areas by the update/restoration control unit 113. For example, in the example of
If it is determined in step S104 that there are not two storage areas (NO), the process proceeds to step S105. In this case, the second device 230 not supporting the dual plane storage is updated. In step S105, the controller 110 backs up the old version of the program held in the single storage area 234 of the ROM 232 of the second device 230 to the HD 260 by the update/restoration control unit 113. In step S106, the controller 110 rewrites the program of the single storage area 234 of the ROM 232 of the second device 203 to the latest version by the update/restoration control unit 113.
On the other hand, if it is determined in step S104 that there are two storage areas (YES), the process proceeds directly to step S106. In this case, the first device 210 supporting dual plane storage is updated. In step S106, the controller 110 rewrites the program of one of the plurality of storage areas 218, 220 (the opposite plane of the one currently in use) of the ROM 216 of the first device 210 to the latest version (new version) by the update/restoration control unit 113.
In step S107, the controller 110 determines whether or not an unprocessed program exists by the update/restoration control unit 113. If it is determined in step S107 that an unprocessed program exists (YES), the process returns to step S104, and the processes of steps S104 to S107 are repeated until the update processing of all programs is completed. If it is determined in step S107 that there is no unprocessed program (NO), the process proceeds to step S108.
In step S108, the controller 110 determines whether there are two storage areas by the update/restoration control unit 113. If it is determined in step S108 that there are not two storage areas (NO), the process proceeds to step S110. In this case, no particular process is performed. On the other hand, if it is determined in step S108 that there are two storage areas (YES), the process proceeds to step S109. In this case, in step S109, the controller 110 uses the update/restoration control unit 113 to request the startup control unit of the device to be updated to change the storage area to be started up next time. This allows the storage area to be used for the startup of the first device 210 to be switched to the storage area holding the latest version.
In step S110, the controller 110 further uses the update/restoration control unit 113 to determine whether or not an unprocessed device exists. If it is determined in step S110 that there is still a device to be updated (YES), the process is looped to step S102, and the process is repeated with the next device as the device to be updated. On the other hand, if it is determined in step S110 that there is no unprocessed device (NO), the process proceeds to step S111, and the process ends.
The process illustrated in step S106 is performed by instructing each device to rewrite a program through the controller control unit 114 of the controller 110. Therefore, the controller 110 is the subject of the instruction to rewrite the program of each device.
As described above, before updating to the latest version of the firmware, whether or not the target device supports dual plane storage is identified, and if the target device supports dual plane storage, the old version is not backed up to the HD 260, and only if the target device does not support dual plane storage, the old version of the program is backed up to the HD 260. Therefore, it is possible to reduce the hard disk capacity used for the backup of the old version to the HD 260 by the amount of the device supporting the dual plane storage. Regardless of whether or not the target device supports the dual plane storage, the backup of the old version of the program to the HD 260 may be performed. The backup destination is not limited to the HD and may be an SSD (solid state drive) or the like.
In step S201, the controller 110 acquires a device information list as illustrated in
In step S204, the controller 110 uses the update/restoration control unit 113 to determine whether the device to be restored has two storage areas. If it is determined in step S204 that the device to be restored does not have two storage areas (NO), the process proceeds to step S205. In this case, the second device 230 is restored. In step S205, the controller 110 uses the update/restoration control unit 113 to read the backed-up old version program from the HD 260, internally updates the ROM 232 of the second device 230 with the old version program, and rewrites the single storage area 234 of the ROM 232 of the second device 203 with the old version program.
In step S206, the controller 110 uses the update/restoration control unit 113 to determine whether an unprocessed program exists. If it is determined in step S206 that an unprocessed program exists (YES), the process returns to step S204, and steps S204 to S206 are repeated until the update processing of all programs is completed. If it is determined in step S206 that there is no unprocessed program (NO), the process proceeds to step S208.
On the other hand, if it is determined in step S204 that there are two storage areas (YES), the process proceeds to step S207. In this case, the first device 210 is restored. In step S207, the controller 110 uses the update/restoration control unit 113 to request the startup control unit of the device to be restored to change the storage area to be started up next time. As a result, the storage area to be used when the first device 210 is started up is switched to the storage area holding the old version.
In step S208, the controller 110 uses the update/restoration control unit 113 to determine whether or not an unprocessed device exists. If it is determined in step S208 that there is still a device to be restored (YES), the processing is looped to step S202, and the processing is repeated with the next device as the device to be restored. On the other hand, if it is determined in step S208 that there is no unprocessed device (NO), the processing proceeds to step S209, and the processing is ended.
If the device to be restored is identified to support dual plane storage before the restoration to the old version is performed, the rewriting to the old version is not performed and only the information of the storage area to be started up next time is rewritten. On the other hand, only if the device does not support dual plane storage, the program is rewritten to the program of the old version backed up to the HD. Thus, if the device to be restored supports dual plane storage, the rewriting to the old version is not required, and the restoration time to the old version can be greatly reduced.
As illustrated in
On the other hand, as illustrated in
In this way, both the first device 210 which supports dual plane storage and the second device 230 which does not support dual plane storage are started up with the updated or restored version. Therefore, degradation of the quality caused by the mismatch of the versions between the devices 210 and 230 is also prevented.
According to the above-described embodiments, it is possible to provide an information processing apparatus, a method, a program, and a control device in which, in a configuration in which a device having a plurality of storage areas for holding different versions of a program and a device that does not coexist, the time required for restoration can be reduced while preventing the mismatching of versions between devices and thereby preventing the degradation of the quality of the entire apparatus.
The functions of each of the embodiments described above may be implemented by one or more processing circuits. As used herein, a “processing circuit” includes a processor programmed to execute each function by software such as a processor implemented in an electronic circuit; or devices such as an Application Specific Integrated Circuit (ASIC), a digital signal processor (DSP), a field programmable gate array (FPGA), and a conventional circuit module, designed to execute each function as described above.
Aspects of the present invention are, for example, as follows.
According to one embodiment of the present invention, in a configuration in which a device having a plurality of storage areas for holding a plurality of versions of a program and a device having a storage area for holding a version of a program are mixed, it is possible to reduce the time required for restoration while preventing the mismatching of the versions among the devices and thereby preventing the degradation of the quality of the entire apparatus.
The information processing apparatus, the method, and the recording medium are not limited to the specific embodiments described in the detailed description, and variations and modifications may be made without departing from the spirit and scope of the present invention.
Number | Date | Country | Kind |
---|---|---|---|
2023-110765 | Jul 2023 | JP | national |