JP2013218510A - 情報処理装置、情報処理装置のプログラム更新方法、及びプログラム - Google Patents

情報処理装置、情報処理装置のプログラム更新方法、及びプログラム Download PDF

Info

Publication number
JP2013218510A
JP2013218510A JP2012088151A JP2012088151A JP2013218510A JP 2013218510 A JP2013218510 A JP 2013218510A JP 2012088151 A JP2012088151 A JP 2012088151A JP 2012088151 A JP2012088151 A JP 2012088151A JP 2013218510 A JP2013218510 A JP 2013218510A
Authority
JP
Japan
Prior art keywords
program
information
update
processing apparatus
stored
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
JP2012088151A
Other languages
English (en)
Other versions
JP2013218510A5 (ja
JP5943681B2 (ja
Inventor
Koji Niwa
広次 丹羽
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.)
Canon Inc
Original Assignee
Canon Inc
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
Application filed by Canon Inc filed Critical Canon Inc
Priority to JP2012088151A priority Critical patent/JP5943681B2/ja
Priority to US13/857,379 priority patent/US9317281B2/en
Publication of JP2013218510A publication Critical patent/JP2013218510A/ja
Publication of JP2013218510A5 publication Critical patent/JP2013218510A5/ja
Application granted granted Critical
Publication of JP5943681B2 publication Critical patent/JP5943681B2/ja
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/65Updates
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/65Updates
    • G06F8/654Updates using techniques specially adapted for alterable solid state memories, e.g. for EEPROM or flash memories

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Security & Cryptography (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Stored Programmes (AREA)
  • Facsimiles In General (AREA)

Abstract

【課題】第1のプログラムと、当該第1のプログラムと協働する第2のプログラムの更新処理時間を短縮する。
【解決手段】保存手段に保存された情報と、特定される更新プログラムに基づいて更新される前記第1のプログラムまたは第2のプログラムに関わる情報とが、整合すると判断した場合は、更新すべき更新プログラムを取得し、整合しないと判断した場合は、保存手段に保存された情報を消去した後、更新すべき更新プログラムを取得する。取得した前記更新プログラムに基づいて、前記第1のプログラムまたは第2のプログラムを更新する。プログラム更新後の再起動時に、保存手段に前記情報が保存されている場合は、初期化処理を実行することなく第1のプログラムを実行可能な状態に遷移させ、保存手段に前記情報が保存されていない場合は、初期化処理を実行させた後、前記第1のプログラムを実行可能な状態に遷移させる。
【選択図】図3

Description

本発明は、ファームウエアを更新してデータ処理を行う情報処理装置、情報処理装置のプログラム更新方法、及びプログラムに関するものである。
従来より、複合機のように複数の情報処理装置が連携して動作するような機器またはシステムにおいては、ファームウエア更新処理を以下のように行う。まず、更新処理時に、一度システムをシャットダウンさせ、同システムをファームウエア更新のために別の起動モードで起動し、同システムや複数デバイスのファームウエア更新を行うものがある(例えば、特許文献1参照)。
これは実行中のシステム自身を更新することができないことに起因している。そこで、複数のOSを持つシステムにおいて、一方のファーム(通常起動ファーム)更新のために、もう一方のファーム(アップデートファーム)で起動するものがある。
このように、複数のシステムで起動する方法では、システム再起動回数が多くなる。そして、システムを構成するソフトウエア規模の肥大化に伴い、再起動が完了するまでの時間(システム起動時間)が増大する傾向にある。このことから、ファームウエア更新の処理時間も増大する傾向にある。
このような起動時間増大に対する解決策の一つとして、ハイバネーション技術が活用されている。ハイバネーションとは、任意の時点におけるシステムの揮発性記憶装置(メモリ)上の情報をHDDやUSBメモリ等の不揮発性記憶装置に退避保存しておき、次回システム起動の際に、退避保存しておいた情報を揮発性記憶装置に書き戻す。これにより、システムの状態を「退避保存時の状態」に復元する技術のことである(例えば、特許文献2参照)。
特開2008−282090 特開2009−146061
システムを複数に分けてファームウエアの更新を行う構成と、ハイバネーションの双方を組み合わせて使用すると、一方のシステムがハイバネーション状態であっても、もう一方のシステムから起動できるという想定外の動作をする。ファームウエアの更新後、更新前に退避保存しておいた情報を揮発性記憶装置に書き戻してしまうと、更新後のファームと不整合を起こし正常に起動できなくなる問題がある。
上記のような不整合を防止するためには、一度ハイバネーションから復帰し、退避保存しておいた情報を消去したうえでシステム全体を再起動してもう一方のシステムで起動する必要がある。そのため、ファームウエア更新の処理時間を短縮するという課題は解決できない。
本発明は、上記の課題を解決するためになされたもので、本発明の目的は、システムの状況に適応して第1のプログラムと、当該第1のプログラムと協働する第2のプログラムとの状態を整合させながら、第1のプログラムと、当該第1のプログラムと協働する第2のプログラムの更新処理時間を短縮できる仕組みを提供することである。
上記目的を達成する本発明の情報処理装置は以下に示す構成を備える。
第1のプログラムと、当該第1のプログラムと協働する第2のプログラムとを実行してデータ処理を行うデータ処理装置であって、前記第1のプログラムに基づいて初期化処理を実行した後の情報を保存する保存手段と、プログラムの更新指示に従いサーバ装置から取得する更新プログラムを特定する特定手段と、前記保存手段に保存された情報と、特定される前記更新プログラムに基づいて更新される前記第1のプログラムまたは第2のプログラムに関わる情報とが整合するかどうかを判断する判断手段と、前記判断手段が整合すると判断した場合は、更新すべき更新プログラムを取得し、前記判断手段が整合しないと判断した場合は、前記保存手段に保存された情報を消去した後、更新すべき更新プログラムを取得する取得手段と、前記取得手段が取得した前記更新プログラムに基づいて、前記第1のプログラムまたは第2のプログラムを更新する更新手段と、前記更新手段によるプログラム更新後の再起動時に、前記保存手段に前記情報が保存されている場合は初期化処理を実行することなく前記第1のプログラムを実行可能な状態に遷移させ、前記保存手段に前記情報が保存されていない場合は、初期化処理で生成される更新されたプログラムに対応づけるべき情報を前記保存手段に保存させた後、前記第1のプログラムを実行可能な状態に遷移させる制御手段と、を備えることを特徴とする。
本発明によれば、システムの状況に適応して第1のプログラムと、当該第1のプログラムと協働する第2のプログラムとの状態を整合させながら、第1のプログラムと、当該第1のプログラムと協働する第2のプログラムの更新処理時間を短縮できる。
本実施形態を示す情報処理装置の構成を示すブロック図の一例である。 図1に示した画像処理装置のファームウエア構成を説明するブロック図である。 本実施形態を示す情報処理装置の制御方法を説明するフローチャートである。
次に本発明を実施するための最良の形態について図面を参照して説明する。
<システム構成の説明>
〔第1実施形態〕
図1は、本実施形態を示す情報処理装置100の構成を示すブロック図の一例である。なお、本実施形態では、情報処理装置の例として、MFP(Multi Function Printer)を例とするが、プリンタ装置やファクシミリ装置であってもよい。
図1において、制御部200は、情報処理装置100全体を制御するための構成である。制御部200は、情報処理装置100を制御するための構成として、以下に示すものを含む。
CPU210は、FlashROM211に記憶された制御部200用のプログラム(第1プログラム)をRAM212に読出して実行する。
HDD(HardDiskDrive)213は、ネットワークI/F218を介してPC225から受信した印刷データを記憶する。なお、CPU210により実行されるプログラムには、後述するプリント用アプリケーションプログラムが含まれる。
そして、このプリント用アプリケーションプログラムにより、HDD(ハードディスク)213に記憶された印刷データがプリンタ部220によるプリントが可能な画像データに変換される。そして、HDD213には、プリンタ部220によるプリントが可能な画像データも記憶される。
また、CPU210により実行されるプログラムには、後述するスキャン用アプリケーションプログラムが含まれる。そして、このスキャン用アプリケーションプログラムにより、スキャナ部221により画像データが読み取られるとともに、読み取られた画像データがHDD213に転送される。そして、HDD213には、読み取られた画像データが記憶される。なお、本実施形態では、FlashROM211またはHDD213が高速起動(ハイバネート)モードに備える情報を保存する手段として用いられる。なお、保存手段としてフラッシュSSDの半導体メモリを用いてもよい。なお、本実施形態を示す情報処理装置では、省電力制御としてハイバネーションンモードを備え、電源投入後、実行された初期化処理後の情報を保存手段に保存しておき、その後の起動要求時に、保存手段に保存された情報に基づいて起動処理を行う。なお、本実施形態では、特許文献2に記載があるので、ハイバネーションンモード処理の詳細については説明を省略する。
操作部I/F214は、操作部219を介して情報処理装置100の操作者により入力される指示をCPU210に伝達するためのI/Fである。また、操作部I/F214は、操作部219に表示される内容を切替えるためのCPU210から受信して操作部219に伝達する。
プリンタI/F215は、制御部200とプリンタ部220を接続するためのインターフェースである。ここで、プリンタ部220は、プリンタI/F215を介してHDD213から転送される画像データに基づいてシート上にプリントを行う。なお、プリンタ部220(プリント手段)は、CPU220aとFlashROM220bを有する。CPU220aは、FlashROM220bに記憶されたプログラムを実行することにより、プリント処理に伴う各種の動作をプリンタ部220に実行させる。
スキャナI/F216は、制御部200とスキャナ部221を接続するためのインターフェースである。ここで、スキャナ部221(画像データを入力する入力手段)は、原稿上の画像をCCD(ChargeCoupledDevice)等により構成されるラインセンサを用いて画像データとして読み取るものである。
そして、スキャナ部221は、読み取った画像データをスキャナI/F216を介してHDD213へ転送する。HDD213へ転送され、記憶された画像データは、前述したプリンタ部220によりプリントすることが可能であり、スキャナ部221により読み取った画像データをプリンタ部220によりプリントすることにより、複写(コピー)処理が可能となる。
なお、スキャナ部221は、CPU221aとFlashROM221bを有する。CPU221aは、FlashROM221bに記憶されたプログラムを実行することにより、スキャン処理に伴う各種の動作をスキャナ部221に実行させる。
USB(UniversalSerialBus)−HostI/F217は、外部USBデバイス223とも接続可能である。外部USBデバイス223は、USBメモリやUSBキーボードなどが例として挙げられる。USBメモリにプログラム(更新情報)を格納し、ダウンロードしてFlashROM211のファイル格納領域に置くケースもある。
ネットワークI/F218は、制御部200をLAN110に接続し、LAN110上のPC225やサーバ装置224との通信を行う。なお、サーバ装置224は、後述する各種のプログラム(情報処理装置100により実行されるもの)をアップデート(更新)するための更新情報が記憶されており、情報処理装置100からの要求に応じて、更新情報を情報処理装置100へ送信する。
次に、制御部200のCPU210(第1制御手段)により実行されるプログラムの構成について図2を用いて説明する。
図2は、図1に示した画像処理装置のファームウエア構成を説明するブロック図である。なお、図2に示されるプログラムは、図1のFlashROM211に記憶されているものとする。また、本実施形態では、第1のプログラムと、当該第1のプログラムと協働する第2のプログラムとを実行してデータ処理を行うデータ処理装置として、図1に示した画像処理装置を例とする。従って、第2のプログラムという場合には、プリンタ部220またはスキャナ部221のファームウエアに対応する。つまり、第2のプログラムは、異なるデータ処理(スキャナ処理、プリント処理)を行うコントローラ(CPU220a。221a)に対応づけられたファームウエアとして構成されている。
FlashROM211に記憶されるプログラムは、FlashROM211上の2つのパーティションに分けて格納されている。1つはメインパーティション401であり、もう1つはサブパーティション402である。
情報処理装置100に通常の動作をさせる際には、メインパーティション401に格納されたオペレーティングシステムプログラム(以下、OS)をCPU210に実行させる。その一方で、情報処理装置100の通常の動作をさせるためのプログラム(後述するメインモジュール410、起動準備モジュール420、およびOS411)を更新する際には、サブパーティションに格納されたOSをCPU210に実行させる。
メインパーティション401には、OS411、メインモジュール410、起動準備モジュール420のプログラムモジュールが含まれている。OS411は、情報処理装置100を制御するためのOSであり、プリンタ部220、スキャナ部221を含む情報処理装置100の各部の動作を制御するためのドライバプログラムを含むものである。
また、サブパーティション402には、OS431及びアップデートモジュール430の2つのプログラムモジュールが含まれている。OS431は、情報処理装置100を制御するためのOSであり、前述したOS411と同様のものである。
ここで、メインパーティション401のメインモジュール410、および起動準備モジュール420に含まれる各プログラムモジュールについて説明する。なお、各プログラムモジュールは、OS411が起動した後に、CPU210によりOS411を介して実行されるアプリケーションプログラムである。
メインモジュール410に含まれる操作部アプリケーションプログラム412は、操作部219を介して情報処理装置100の操作者により入力される指示をCPU210に伝達し、伝達された指示に応じた処理を実行するためのプログラムである。
また、スキャンアプリケーションプログラム413は、前述したスキャナ部221によるスキャン処理を制御するためのプログラムである。また、プリントアプリケーションプログラム414は、前述したプリンタ部220によるプリント処理を制御するためのプログラムである。
ネットワークアプリケーションプログラム415は、LAN110上のPC225やサーバ装置224との通信を行うためのプログラムである。アップデート準備プログラム416は、通常起動モードで動作中の情報処理装置100が、ファームウエアの更新を行うための準備動作を実行するためのプログラムである。
起動準備モジュール420は、メインモジュール410がCPU210により実行される前に実行される。起動準備モジュール420に含まれる起動順制御プログラム421は、プログラムの起動順序を制御するためのプログラムである。ここでは、CPU210がOS411を起動した次に実行されるプログラムである。後述するメインモジュール起動準備プログラム422を実行し、メモリイメージをFlashROM211やHDD213に退避保存し、その後メインモジュール410を実行する等の起動順序を制御するためのプログラムである。
起動準備モジュール420に含まれるメインモジュール起動準備プログラム422は、CPU210がメインモジュール410を実行するために必要な初期化処理等を行うためのプログラムである。
次に、サブパーティション402のアップデートモジュール430に含まれる各プログラムモジュールについて説明する。
なお、各プログラムモジュールは、OS431起動した後に、CPU210によりOS431を介して実行されるアプリケーションプログラムである。
メインパーティションアップデートプログラム432は、メインパーティション401に含まれるメインモジュール410、起動準備モジュール420のプログラム及びOS411を更新するためのプログラムである。
処理部アップデートプログラム433は、FlashROM220bに含まれるプリント処理を実行するためのプログラム、FlashROM221bに含まれるスキャン処理を実行するためのプログラムを更新するためのプログラムである。なお、これらのモジュールは、内部的にはさらに細かいサブモジュール群で構成されていても良い。処理部アップデートプログラム433は、第1のプログラムまたは第2のプログラムをサーバ装置224から取得する更新プログラムで更新する手段を担っている。なお、更新プログラムには、パッチ形式のプログラムも含まれる。
次に、第1実施形態におけるプログラムの更新処理について図3を用いて説明する。
図3は、本実施形態を示す情報処理装置の制御方法を説明するフローチャートである。なお、図3の各ステップにおける処理は、制御部200のCPU210がFlashROM211に記憶されたプログラムを実行することにより行われる。以下、プログラム更新後の再起動時に、CPU210がフラッシュROM211に情報が保存されている場合は、初期化処理を実行することなく第1のプログラムを実行可能な状態に遷移させる制御を説明する。さらに、CPU210がフラッシュROM211に情報が保存されていない場合は、初期化処理で生成される更新されたプログラムに対応づけるべき情報をフラッシュROM211に保存させた後、第1のプログラムを実行可能な状態に遷移させる制御を説明する。
S301で、CPU210は、情報処理装置100をFlashROM211のメインパーティション401にて起動させる。具体的には、CPU210がOS431を起動させ、起動したOS431を介してメインモジュール410、起動準備モジュール420に含まれる各プログラムモジュールを実行する。
S302で、CPU210は、FlashROM211もしくはHDD213に、起動準備モジュール420の実行が完了した時点におけるRAM212上の情報(メモリイメージ)が退避保存されているかどうか判定し、保存されていると判定されなかった場合はS303へ処理を進め、保存されていると判定された場合はS305へ処理を進める。
S303で、CPU210は、OS431を介して起動準備モジュール420に含まれるプログラムを実行する。
S304で、CPU210は、OS431を介して、起動準備モジュール420の実行が完了した時点におけるRAM212上の情報をFlashROM211もしくはHDD213に退避保存する。
S305では、CPU210は、退避保存されている情報(メモリイメージ)を読み込んでRAM212に書き戻し、システムの状態を退避保存時の状態、つまり起動準備モジュール420の実行が完了した状態を復元する。
S306では、CPU210は、OS431を介してメインモジュール410に含まれるプログラムを実行する。なお、CPU210が実行する、プリンタI/F215を介したプリンタ部220との通信、スキャナI/F216を介したスキャナ部221との通信はここで行われる。
S307では、CPU210は、情報処理装置100のプログラムを更新するための更新処理の実行指示がなされたかどうかを判定し、なされたと判定された場合はS308へ処理を進める。ここで、更新処理の実行指示とは、例えば、情報処理装置100の操作者が操作部219を介してなされる更新指示を言う。また、一定期間(例えば、2週間)毎にプログラムを定期的に更新するようにスケジュールを予め設定しておき、定期的に更新処理の実行指示が自動的になされるようにしても良い。
S308で、CPU210は、OS411を介してアップデート準備プログラム416を実行することにより、FlashROM211、FlashROM220b、FlashROM221bに記憶された各プログラムのうち、更新候補となるプログラムを特定する。
例えば、CPU210が各プログラムを指定するための表示画面を操作部219に表示させ、操作部219を介して操作者により指示されたプログラムを更新候補として特定する。なお、操作者による指示に基づくことなく、更新候補となり得る全てのプログラムを更新候補として特定しても良い。
S309で、CPU210は、アップデート準備プログラム416を実行し、情報処理装置100を特定するための機種ID情報とバージョン情報の取得要求をネットワークI/F218を介してサーバ装置224に送信する。そして、情報処理装置100は、サーバ装置224により管理されるバージョン情報を取得する。
ここでバージョン情報とは、前述したメインパーティション401に含まれる各プログラムモジュールのバージョンを示す情報である。なお、サーバ装置224は、情報処理装置100から機種IDとバージョン情報の取得要求を受信した場合、機種IDに対応するバージョン情報を特定し、特定したバージョン情報を情報処理装置100へ送信する。
S310で、CPU210は、アップデート準備プログラム416を実行し、情報処理装置100のバージョン情報を取得する。ここで、情報処理装置100のバージョン情報とは、FlashROM211、FlashROM220b、FlashROM221bに記憶された各プログラムのバージョンを示す情報をいう。
S311で、CPU210は、アップデート準備プログラム416を実行し、更新対象のプログラムを特定する。具体的には、S308で特定された更新候補となるプログラムの中から、サーバ装置224と情報処理装置100とでバージョン情報が異なるものを特定する。これにより、情報処理装置100よりもバージョンの新しいプログラムがサーバ装置224からダウンロードすることが可能であることがわかる。
S312で、CPU210は、S311にて特定された更新対象のプログラムに、S304で保存した退避情報(メモリイメージ)に影響のあるプログラムがあるかどうかを判定する。ここでは、起動準備モジュール420のプログラム、もしくはOS411が含まれるかどうかを判定する。ここで、CPU210が含まれると判定した場合はS313へ処理を進め、含まれないと判定した場合は退避情報(メモリイメージ)を保持したままS314へ処理を進める。
S313では、CPU210は、S304で保存した退避情報(メモリイメージ)を消去する。ここで退避情報(メモリイメージ)を消去することで、更新後のファームで起動する際に、不整合を起こす退避情報の利用を防止する。
S314では、CPU210は、S311で特定された更新対象のプログラム(更新情報)をサーバ装置224から取得する。具体的には、情報処理装置100は、S311で特定された更新対象のプログラムを示すプログラム特定情報をサーバ装置224へ送信する。サーバ装置224は、情報処理装置100からプログラム特定情報を受信した場合、プログラム特定情報に対応するプログラムを情報処理装置100へ送信する。なお、サーバ装置224から受信した更新対象のプログラムは、FlashROM211やHDD213に記憶させるものとする。そして、S315で、CPU210は、システムを再起動させる。具体的には、フラッシュROM211に情報が記憶されている場合には、所定の初期化処理を行うことなく、RAM212に情報を書き込むことによりハイバネモードで第1のプログラムを起動させる。一方、フラッシュROM211に情報が記憶されていない場合には、所定の初期化処理を行って第1のプログラムを起動させる。
S316で、CPU210は、情報処理装置100をサブパーティションにて起動させる。具体的には、CPU210がOS431を起動させ、起動したOS431によりアップデートモジュール430に含まれる各プログラムモジュールを実行する。
S317で、CPU210は、メインパーティションアップデートプログラム432を実行することにより、S314で取得した更新対象のプログラムを使用してメインパーティション401の各プログラムの更新処理を実行する。
S318で、CPU210は、処理部アップデートプログラム433を実行することにより、各処理部(プリンタ部220、スキャナ部221)が実行するプログラムの更新処理を実行する。S319で、CPU210は、システムを再起動させる。
このようにS313でメモリイメージを消去することで、システム再起動後に誤ったメモリイメージを利用する不具合を起こさず、高速なアップデート処理を行うことができる。また、S312の判定により、可能な限りメモリイメージを保存したままファームウエアの更新を行うことで、システム再起動後にメモリイメージを利用し高速に起動できる。
なお、S312の一例として、更新される前記第1のプログラムまたは第2のプログラムに関わる複数のパッケージと、テーブルで特定される前記第1のプログラムまたは第2のプログラムの各パッケージとの差分から特定されるパッケージが初期化処理に関わるパッケージであるかを判断するように構成してもよい。
本発明の各工程は、ネットワーク又は各種記憶媒体を介して取得したソフトウエア(プログラム)をパソコン(コンピュータ)等の処理装置(CPU、プロセッサ)にて実行することでも実現できる。
本発明は上記実施形態に限定されるものではなく、本発明の趣旨に基づき種々の変形(各実施形態の有機的な組合せを含む)が可能であり、それらを本発明の範囲から除外するものではない。
210 CPU
211 フラッシュROM
212 RAM
220 プリンタ部
221 スキャナ部

Claims (9)

  1. 第1のプログラムと、当該第1のプログラムと協働する第2のプログラムとを実行してデータ処理を行うデータ処理装置であって、
    前記第1のプログラムに基づいて初期化処理を実行した後の情報を保存する保存手段と、
    プログラムの更新指示に従いサーバ装置から取得する更新プログラムを特定する特定手段と、
    前記保存手段に保存された情報と、特定される前記更新プログラムに基づいて更新される前記第1のプログラムまたは第2のプログラムに関わる情報とが整合するかどうかを判断する判断手段と、
    前記判断手段が整合すると判断した場合は、更新すべき更新プログラムを取得し、前記判断手段が整合しないと判断した場合は、前記保存手段に保存された情報を消去した後、更新すべき更新プログラムを取得する取得手段と、
    前記取得手段が取得した前記更新プログラムに基づいて、前記第1のプログラムまたは第2のプログラムを更新する更新手段と、
    前記更新手段によるプログラム更新後の再起動時に、前記保存手段に前記情報が保存されている場合は初期化処理を実行することなく前記第1のプログラムを実行可能な状態に遷移させ、前記保存手段に前記情報が保存されていない場合は、初期化処理で生成される更新されたプログラムに対応づけるべき情報を前記保存手段に保存させた後、前記第1のプログラムを実行可能な状態に遷移させる制御手段と、
    を備えることを特徴とする情報処理装置。
  2. 前記第2のプログラムは、異なるデータ処理を行うコントローラに対応づけられたファームウエアであることを特徴とする請求項1記載の情報処理装置。
  3. 前記異なるデータ処理は、プリント処理と、スキャン処理を含むことを特徴とする請求項2記載の情報処理装置。
  4. 前記保存手段は、半導体メモリと、ハードディスクを含むことを特徴とする請求項1記載の情報処理装置。
  5. 前記半導体メモリは、フラッシュSSD、フラッシュROMを含むことを特徴とする請求項4記載の情報処理装置。
  6. 前記第2のプログラムに含まれる複数のパッケージと前記コントローラとの組み合わせを特定するための情報とを対応づけたテーブルを備え、
    前記判断手段は、更新される前記第1のプログラムまたは第2のプログラムの各パッケージと、テーブルで特定される前記第1のプログラムまたは第2のプログラムの各パッケージとの差分から特定されるパッケージが初期化処理に関わるパッケージであるかを判断することを特徴とする請求項1記載の情報処理装置。
  7. 前記保存手段に保存された情報に基づいて起動処理を行う起動手段を備えることを特徴とする請求項1記載の情報処理装置。
  8. 第1のプログラムと、当該第1のプログラムと協働する第2のプログラムとを実行してデータ処理を行うデータ処理装置であって、
    前記第1のプログラムに基づいて初期化処理を実行した後の情報を保存する保存手段に保存工程と、
    プログラムの更新指示に従いサーバ装置から取得する更新プログラムを特定する特定工程と、
    前記保存手段に保存された情報と、特定される前記更新プログラムに基づいて更新される前記第1のプログラムまたは第2のプログラムに関わる情報とが整合するかどうかを判断する判断工程と、
    前記判断工程が整合すると判断した場合は、更新すべき更新プログラムを取得し、前記判断工程が整合しないと判断した場合は、前記保存手段に保存された情報を消去した後、更新すべき更新プログラムを取得する取得工程と、
    前記取得工程が取得した前記更新プログラムに基づいて、前記第1のプログラムまたは第2のプログラムを更新する更新工程と、
    前記更工程によるプログラム更新後の再起動時に、前記保存手段に前記情報が保存されている場合は初期化処理を実行することなく前記第1のプログラムを実行可能な状態に遷移させ、前記保存手段に前記情報が保存されていない場合は、初期化処理で生成される更新されたプログラムに対応づけるべき情報を前記保存手段に保存させた後、前記第1のプログラムを実行可能な状態に遷移させる制御工程と、
    を備えることを特徴とする情報処理装置のプログラム更新方法。
  9. 請求項8に記載の情報処理装置のプログラム更新方法をコンピュータに実行させることを特徴とするプログラム。
JP2012088151A 2012-04-09 2012-04-09 情報処理装置、情報処理装置のファームウエア更新方法及びプログラム Expired - Fee Related JP5943681B2 (ja)

Priority Applications (2)

Application Number Priority Date Filing Date Title
JP2012088151A JP5943681B2 (ja) 2012-04-09 2012-04-09 情報処理装置、情報処理装置のファームウエア更新方法及びプログラム
US13/857,379 US9317281B2 (en) 2012-04-09 2013-04-05 Information processing apparatus, program update method for information processing apparatus, and storage medium

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2012088151A JP5943681B2 (ja) 2012-04-09 2012-04-09 情報処理装置、情報処理装置のファームウエア更新方法及びプログラム

Publications (3)

Publication Number Publication Date
JP2013218510A true JP2013218510A (ja) 2013-10-24
JP2013218510A5 JP2013218510A5 (ja) 2015-05-28
JP5943681B2 JP5943681B2 (ja) 2016-07-05

Family

ID=49293339

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2012088151A Expired - Fee Related JP5943681B2 (ja) 2012-04-09 2012-04-09 情報処理装置、情報処理装置のファームウエア更新方法及びプログラム

Country Status (2)

Country Link
US (1) US9317281B2 (ja)
JP (1) JP5943681B2 (ja)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2016053839A (ja) * 2014-09-03 2016-04-14 キヤノン株式会社 情報処理装置、その制御方法、及びプログラム
JP2016197380A (ja) * 2015-04-06 2016-11-24 キヤノン株式会社 システムおよびその制御方法、並びにプログラム
EP3816796B1 (en) * 2019-10-31 2022-12-21 Ricoh Company, Ltd. Information processing apparatus, information processing apparatus update method, and carrier means

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101992680B1 (ko) * 2013-02-05 2019-06-25 휴렛-팩커드 디벨롭먼트 컴퍼니, 엘.피. 화상형성장치, 추적장치, 관리장치 및 화상형성장치의 펌웨어 업데이트 방법
JP2019049907A (ja) * 2017-09-11 2019-03-28 キヤノン株式会社 情報処理装置、情報処理方法及びプログラム
JP2021002081A (ja) * 2019-06-19 2021-01-07 キヤノン株式会社 情報処理装置、その制御方法、及びプログラム
CN113672260B (zh) * 2021-08-17 2024-04-12 浙江大华技术股份有限公司 一种处理器cpu初始化方法

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH03278126A (ja) * 1990-03-28 1991-12-09 Toshiba Corp 計算機システム立上げ方式
JP2004038546A (ja) * 2002-07-03 2004-02-05 Fuji Xerox Co Ltd 起動制御方法、起動制御装置、画像処理装置
JP2005284491A (ja) * 2004-03-29 2005-10-13 Mitsubishi Electric Corp 計算機の起動時間短縮方式
JP2006344022A (ja) * 2005-06-09 2006-12-21 Ricoh Co Ltd 機器及びプログラム起動方法

Family Cites Families (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7161706B2 (en) * 2001-03-30 2007-01-09 Sharp Laboratories Of America, Inc. System for improving digital coplers and multifunction peripheral devices
US20040030877A1 (en) * 2002-08-06 2004-02-12 Aleksandr Frid Using system BIOS to update embedded controller firmware
KR100744873B1 (ko) * 2002-08-20 2007-08-01 엘지전자 주식회사 컴퓨터 시스템에서의 펌웨어 기록방법
JP4128516B2 (ja) * 2002-11-18 2008-07-30 株式会社リコー 画像形成装置、プログラム更新方法
JP2008282090A (ja) 2007-05-08 2008-11-20 Seiko Epson Corp 電子機器及び電子機器におけるファームウェア更新方法
US8122447B2 (en) * 2007-07-31 2012-02-21 Hewlett-Packard Development Company, L.P. Firmware installation
JP2009146061A (ja) 2007-12-12 2009-07-02 Canon Inc 情報処理装置及び前記装置の起動方法
JP2009259197A (ja) * 2008-03-18 2009-11-05 Ricoh Co Ltd 情報処理装置およびその起動方法
JP5038237B2 (ja) * 2008-06-06 2012-10-03 株式会社リコー 電子機器、画像形成装置、電子機器の起動制御方法、起動制御プログラム及び記録媒体
JP2011170793A (ja) * 2010-02-22 2011-09-01 Ricoh Co Ltd 情報処理装置
JP5146495B2 (ja) * 2010-07-08 2013-02-20 コニカミノルタビジネステクノロジーズ株式会社 画像処理装置およびハイバネーション起動方法
KR20120041384A (ko) * 2010-10-21 2012-05-02 삼성전자주식회사 모바일 디바이스의 펌웨어 업데이트 방법 및 장치
US8788798B2 (en) * 2010-12-06 2014-07-22 Microsoft Corporation Fast computer startup

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH03278126A (ja) * 1990-03-28 1991-12-09 Toshiba Corp 計算機システム立上げ方式
JP2004038546A (ja) * 2002-07-03 2004-02-05 Fuji Xerox Co Ltd 起動制御方法、起動制御装置、画像処理装置
JP2005284491A (ja) * 2004-03-29 2005-10-13 Mitsubishi Electric Corp 計算機の起動時間短縮方式
JP2006344022A (ja) * 2005-06-09 2006-12-21 Ricoh Co Ltd 機器及びプログラム起動方法

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2016053839A (ja) * 2014-09-03 2016-04-14 キヤノン株式会社 情報処理装置、その制御方法、及びプログラム
JP2016197380A (ja) * 2015-04-06 2016-11-24 キヤノン株式会社 システムおよびその制御方法、並びにプログラム
EP3816796B1 (en) * 2019-10-31 2022-12-21 Ricoh Company, Ltd. Information processing apparatus, information processing apparatus update method, and carrier means

Also Published As

Publication number Publication date
US9317281B2 (en) 2016-04-19
US20130268924A1 (en) 2013-10-10
JP5943681B2 (ja) 2016-07-05

Similar Documents

Publication Publication Date Title
JP5943681B2 (ja) 情報処理装置、情報処理装置のファームウエア更新方法及びプログラム
US7380243B2 (en) Image forming apparatus of which programs are remotely updatable
US9229815B2 (en) Information processing apparatus, program update method, and program
CN102045474B (zh) 包括固件的图像形成装置及图像形成装置的控制方法
JP5894495B2 (ja) 情報処理装置、情報処理装置におけるファームウエアの更新方法およびプログラム
US8922805B2 (en) Image processing apparatus having updatable firmware, method for controlling image processing apparatus, and program
US10162649B2 (en) Information processing system, information processing apparatus and start up control method
JP5679714B2 (ja) 画像形成装置
US8799887B2 (en) Information processing apparatus, method for controlling the same, and storage medium
US10019212B2 (en) Printing apparatus that decompresses and updates software installed therein, method of controlling the same, and storage medium
JP2015022681A (ja) 情報処理装置および情報処理装置におけるソフトウェア更新方法
US10656954B2 (en) Information processing apparatus, activation method of information processing apparatus, and storage medium
TWI431530B (zh) 嵌入式系統及其程式更新方法
JP2023068538A (ja) 情報処理装置及びその制御方法、並びにプログラム
US10447886B2 (en) Image processing apparatus for updating a non-volatile memory and method controlling image processing apparatus
JP5932511B2 (ja) 情報処理装置、ソフトウェアの更新方法及びコンピュータプログラム
JP6953828B2 (ja) 情報処理装置及びプログラム
JP2014238647A (ja) 情報処理装置及びそのプログラム更新方法、並びにプログラム
JP2012160112A (ja) 情報処理装置及びその制御方法
US8417927B2 (en) Apparatus for reading a first program, reading and initializing a second program prior to power saving state and executing the second program upon returning to ordinary state
JP2021149191A (ja) 情報処理装置、情報処理方法
JP2012078937A (ja) 画像形成装置
JP2012091460A (ja) 画像形成装置、その制御方法及びプログラム
JP2007045120A (ja) 画像形成装置、画像形成装置起動方法、画像形成装置起動プログラム

Legal Events

Date Code Title Description
A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20150407

A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20150407

RD03 Notification of appointment of power of attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7423

Effective date: 20150407

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20160115

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20160126

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20160318

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20160426

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20160524

R151 Written notification of patent or utility model registration

Ref document number: 5943681

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R151

LAPS Cancellation because of no payment of annual fees