JP4645720B2 - 電子機器 - Google Patents

電子機器 Download PDF

Info

Publication number
JP4645720B2
JP4645720B2 JP2008254035A JP2008254035A JP4645720B2 JP 4645720 B2 JP4645720 B2 JP 4645720B2 JP 2008254035 A JP2008254035 A JP 2008254035A JP 2008254035 A JP2008254035 A JP 2008254035A JP 4645720 B2 JP4645720 B2 JP 4645720B2
Authority
JP
Japan
Prior art keywords
time
count value
count
circuit
current
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.)
Active
Application number
JP2008254035A
Other languages
English (en)
Other versions
JP2010085227A (ja
Inventor
寛 柴田
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.)
Brother Industries Ltd
Original Assignee
Brother Industries Ltd
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 Brother Industries Ltd filed Critical Brother Industries Ltd
Priority to JP2008254035A priority Critical patent/JP4645720B2/ja
Priority to EP20090252244 priority patent/EP2172829B1/en
Priority to US12/566,725 priority patent/US8402299B2/en
Publication of JP2010085227A publication Critical patent/JP2010085227A/ja
Application granted granted Critical
Publication of JP4645720B2 publication Critical patent/JP4645720B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/04Generating or distributing clock signals or signals derived directly therefrom
    • G06F1/14Time supervision arrangements, e.g. real time clock

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Electric Clocks (AREA)

Description

本発明は、電子機器に関する。
従来、電子機器としては、RTC(リアルタイムクロック)回路を備えた電子機器が知られている。RTC回路は、電子機器の電源が切られている間もバッテリからの電源供給を受けて動作し、現在時刻を計時するものである。
この他、電子機器としては、通信により外部装置から時刻情報を取得し、取得した時刻情報を用いて現在時刻を特定し、この時点からの経過時間をソフトウェアにより計時することで、後の現在時刻を求めるものが知られている(例えば、特許文献1参照)。
ソフトウェアクロックは、一般的に、オペレーティングシステム(OS)の機能として実現され、CPUに入力されるクロック信号に基づいてCPUがカウント動作を行うことにより実現される。
また、従来装置としては、ハードウェアクロック(RTC回路)や、ソフトウェアクロックの時刻進度を、外部装置から得られた正しい時刻情報に基づいて補正するものが知られている(例えば、特許文献2,3参照)。
特開2004−188793号公報 特開2003−207586号公報 特開2004−264992号公報
ところで、近年では、インターネットが普及し、ネットワークを通じて外部装置としてのタイムサーバから時刻情報を取得可能な環境が整いつつある。従って、電子機器がネットワークに接続されるものである場合には、RTC回路を電子機器内に設けなくとも、上述したように、タイムサーバから取得した時刻情報を用いて現在時刻を特定し、この特定時点からの経過時間を計測することで、後の現在時刻を求めることができる。
しかしながら、ソフトウェアクロックは、CPUの処理負荷によって時刻進度が変化するため、計時精度が、ハードウェアクロック(RTC回路)と比較して悪い。また、CPUには、水晶振動子からの出力信号が直接入力されず、ノイズ対策のために、SSCGと呼ばれる回路を介して、周波数帯域の広げられた信号が入力される場合もあるため、このような原因でも、水晶振動子からの出力信号を受けて計時動作するRTC回路と比較して、計時精度が悪い。
しかしながら、RTC回路を電子機器に搭載すれば、回路規模が大きくなると共に、電子機器の製造コストが高くなるといった問題がある。
本発明は、こうした問題に鑑みなされたものであり、現在時刻を精度よく求めることが可能な電子機器を、回路規模を抑えて簡易な構成で、安価に製造可能な技術を提供することを目的とする。
かかる目的を達成するためになされた本発明の電子機器は、RTC回路を利用せずに、
外部装置から取得した時刻情報と、ハードウェアで構成されるカウント回路とを用いて、現在時刻を求める。
即ち、本発明の電子機器は、現在時刻を表す時刻情報を、外部装置から取得する時刻情報取得手段と、基準時刻を記憶保持する基準時刻保持手段と、時刻情報取得手段が時刻情報を取得する度に、基準時刻保持手段が記憶保持する基準時刻を、時刻情報取得手段が取得した最新の時刻情報が示す時刻に更新する更新手段と、ハードウェアで構成され、一定周期でカウント値を更新するカウント回路と、カウント回路を用いて、基準時刻が更新された時点からの経過時間を計測する経過時間計測手段と、基準時刻保持手段が記憶保持する基準時刻に、経過時間計測手段により計測された経過時間を加算して、現在時刻を算出する現在時刻算出手段と、現在時刻の出力要求があると、現在時刻算出手段に現在時刻を算出させて、現在時刻算出手段により算出された現在時刻を、出力する応答手段と、を備える。
このように構成された電子機器によれば、ソフトウェア・カウンタではなく、ハードウェアで構成されるカウント回路を用いて現在時刻を求めるので、RTC回路を用いずとも精度よく、現在時刻を求めることができ、結果として、応答手段は、高精度な時刻情報を要求元に提供することができる。
尚、RTC回路とカウント回路とは、ハードウェアで構成される計時手段である点では共通するが、RTC回路は、バッテリで動作し、レギュレータ回路等の周りの回路が必要であることから、回路規模が大きいのに対し、カウント回路は、回路規模が小さいという点で異なる。
従って、本発明によれば、現在時刻を精度よく求めることが可能な電子機器を、回路規模を抑えて、簡易な構成で安価に製造することができる。
また、上述した手段の内、基準時刻保持手段を除く各手段は、ソフトウェア的に実現できるが、マイクロコンピュータには、上記カウント回路が内蔵されているものも多い。
従って、カウント回路を備えるマイクロコンピュータを用いて、上述した各手段を、プログラムによりコンピュータ(CPU)に実現させれば、一層回路規模を抑えて、高精度に現在時刻を求めることができる。
ところで、カウント回路としては、次の種類のカウント回路が知られている。即ち、カウント値が最大値に到達したらカウント値をゼロに戻して、再度、最大値に向けてカウント値を更新していくような、カウント値が一回りすると、カウント値を初期値に戻してカウント動作を継続するタイプのカウント回路(所謂フリーランカウンタ)が知られている。
従って、この種のカウント回路(フリーランカウンタ)を利用する場合、経過時間計測手段は、具体的に、次のように構成されるとよい。
即ち、経過時間計測手段は、基準カウント値を記憶保持する基準カウント値保持手段を備え、更新手段により基準時刻が更新される度に、カウント回路のカウント値を参照して、基準カウント値保持手段が記憶保持する基準カウント値を、参照時点でのカウント回路のカウント値に更新する構成にされるとよい。この経過時間計測手段では、カウント回路のカウント値を参照して、基準カウント値保持手段が記憶保持する基準カウント値と、カウント回路のカウント値との差分を算出することにより、基準時刻が更新された時点からの経過時間を計測することになる。
また、カウント回路は、上述したように、短時間の計測動作しか行うことができないため、単に、カウント回路を用いて、基準時刻が更新された時点からの経過時間を計測するようにしただけでは、カウント回路の最大計測時間が経過するまでの間に、外部装置から再度時刻情報を取得しないと、それ以降、現在時刻を求めることができなくなってしまう。
勿論、カウント回路の最大計測時間が経過するまでの間に、外部装置から再度時刻情報を取得すれば、現在時刻を求めることは可能であるが、このような方法では、外部装置、特にタイムサーバへの負荷が高くなり、好ましくない。
そこで、電子機器は、次のように構成されるのが一層好ましい。即ち、電子機器には、カウント回路のカウント値が一回りする時間であるカウント回路の最大計測時間より短い時間間隔で、カウント回路のカウント値を参照して、基準時刻保持手段が記憶保持する基準時刻を、基準時刻の現在値と参照時点のカウント値とから特定される現在時刻に、更新すると共に、基準カウント値保持手段が記憶保持する基準カウント値を、参照時点でのカウント回路のカウント値に更新する補助更新手段を設けるとよい。
この補助更新手段を備える電子機器によれば、カウント回路のカウント値が一回りする前に、基準時刻及び基準カウント値を更新し、経過時間計測手段に計測させる経過時間の始点を更新するので、時刻情報取得手段が取得した時刻情報に基づき更新手段が基準時刻を更新した時点から最大計測時間を経過した以降も、現在時刻を正確に求めることができる。
また、リセット可能なカウント回路を利用して、基準時刻が更新された時点からの経過時間を計測する場合、経過時間計測手段は、次のように構成することができる。
即ち、経過時間計測手段は、更新手段により基準時刻が更新される度に、カウント回路のカウント値をリセットする構成にすることができる。この経過時間計測手段では、カウント回路のカウント値を参照することによって、基準時刻が更新された時点からの経過時間を計測することになる。
また、カウント回路の最大計測時間より長い時間間隔で、外部装置から時刻情報を取得する場合には、この電子機器に、次の補助更新手段を設けるとよい。
即ち、当該電子機器には、カウント回路のカウント値が始点から終点まで一通り更新されるまでの時間であるカウント回路の最大計測時間より短い時間間隔で、カウント回路のカウント値を参照して、基準時刻保持手段が記憶保持する基準時刻を、基準時刻の現在値と参照時点のカウント値とから特定される現在時刻に、更新すると共に、カウント回路のカウント値をリセットする補助更新手段を設けるとよい。
尚、リセット可能なカウント回路としては、リセット可能なフリーランカウンタの他に、カウント値を始点(最小値または最大値)から終点(最大値または最小値)まで更新すると、カウント動作を停止するカウント回路を挙げることができる。
即ち、上記「カウント回路のカウント値が始点から終点まで一通り更新されるまでの時間」は、カウント回路がフリーランカウンタである場合、「カウント回路のカウント値が一回りするまでの時間」に等しく、カウント回路が上記カウント動作を停止するタイプのカウント回路である場合には、「始点(最小値または最大値)から終点(最大値または最小値)まで、カウント値が更新される時間」に等しい。
この補助更新手段を備える電子機器によれば、最大計測時間の経過前に、基準時刻を更新してカウント値をリセットするので、時刻情報取得手段が取得した時刻情報に基づき更新手段が基準時刻を更新した時点から、最大計測時間を経過した以降も、現在時刻を正確に求めることができる。
また、上述の電子機器において、時刻情報取得手段は、最大計測時間よりも長い時間間隔で周期的に、時刻情報を外部装置から取得する構成にされるのが好ましい。このように電子機器を構成すれば、外部装置にかかる負荷を抑えることができる。
また、本発明は、上述したように、現在時刻を表す時刻情報を提供するタイムサーバと通信可能な通信インタフェースを通じて、タイムサーバから時刻情報を取得する電子機器に適用されると好ましい。このような電子機器に上述の発明を適用すれば、外部装置の負荷低減に関する効果が一層発揮される。
尚、本発明は、電子機器、電子機器の制御方法、電子機器を制御するコンピュータプログラム、このコンピュータプログラムを記録する記録媒体等の種々の態様で実現することもできる。
以下、本発明の実施例について、図面と共に説明する。
図1は、本実施例の通信システム1の構成を表すブロック図である。図1に示すように、本実施例の通信システム1は、ディジタル複合機10と、タイムサーバ20と、パーソナルコンピュータ(PC)40と、がネットワークNTに接続された構成にされている。
この通信システム1を構成するディジタル複合機10は、制御部11と、ネットワークインタフェース13と、記録部15と、読取部17と、表示操作部19とを備える。
制御部11は、各種プログラムを実行するCPU11a、CPU11aが実行するプログラムを記憶するROM11b、CPU11aによるプログラム実行時に作業領域として使用されるRAM11c、各種設定情報記憶用のEEPROM11d、カウンタ11e、及び、水晶振動子11fを備え、CPU11aがROM11bに記憶されたプログラムを実行することにより、装置全体を統括制御し、各種機能を実現する。
尚、水晶振動子11fは、CPU11aの動作に必要なクロック信号を生成するものである。この水晶振動子11fから出力されるクロック信号は、CPU11a及びカウンタ11eに入力される。
但し、CPU11aに入力されるクロック信号は、ノイズ対策のために設けられたSSCG(spread spectrum clock generator)回路11gにより周波数帯域を広げられた後、CPU11aに入力される。一方、カウンタ11eには、SSCG回路11gを介さずに、水晶振動子11fからクロック信号が入力される。
即ち、カウンタ11eに入力されるクロック信号の周波数スペクトルは、単一周波数で鋭いピークを示すが、CPU11aに入力されるクロック信号の周波数スペクトルは、周波数方向に広がりを持ち、カウンタ11eは、CPU11aによってソフトウェア的に実現されるタイマよりも高精度に時間計測を行うことが可能なハードウェア構成の計時手段として機能する。
具体的に、カウンタ11eは、水晶振動子11fから入力されるクロック信号に従う一定時間間隔Rで、カウント値Cをカウントアップすることで、クロック信号に基づき、カウント値Cのカウント動作を行う。
ネットワークインタフェース13は、ネットワークNTに接続されており、ネットワークNTを通じて外部装置(タイムサーバ20、PC40等)と通信可能な構成にされている。
また、記録部15は、用紙に、制御部11から入力されたイメージデータに基づく画像を形成するものであり、読取部17は、ADF装置から供給される原稿や、原稿載置台に載置された読取対象の原稿を光学的に読み取り、その読取画像を表すイメージデータを生成するものである。読取部17により生成されたイメージデータは、制御部11に入力される。
この他、表示操作部19は、情報表示用の液晶モニタ及び各種操作キーを備え、ユーザインタフェースとして機能する。
制御部11は、これら記録部15、読取部17、及び、表示操作部19を用いて、ネットワークプリンタ機能、スキャナ機能、及び、コピー機能を実現する。
例えば、制御部11は、ネットワークインタフェース13を通じてPC40から受信した印刷対象のイメージデータを、記録部15に入力することにより、ネットワークプリンタ機能を実現する。
また、制御部11は、表示操作部19を通じて読取指令が入力されると、読取部17に原稿を読み取らせることで、原稿の読取画像を表すイメージデータを取得し、このイメージデータを、EEPROM11dが記憶する設定情報に従って、予め定められた送信先の外部装置に、ネットワークインタフェース13を通じて送信することにより、スキャナ機能を実現する。
その他、制御部11は、表示操作部19を通じてコピー指令が入力されると、読取部17に原稿を読み取らせることで、原稿の読取画像を表すイメージデータを取得し、このイメージデータを、記録部15に入力することにより、記録部15に、原稿のコピー画像を、用紙に形成させる。この動作により、制御部11は、コピー機能を実現する。
ところで、複合機10は、上記機能の他に、ネットワークインタフェース13を通じてタイムサーバ20から現在時刻(UTC(協定世界時))を表す時刻データを取得し、その時刻データに基づき、現在時刻(UTC)を計時して、提供するUTCクロック機能を有する。尚、タイムサーバ20は、時刻データの要求信号を受信すると、その送信元に、現在時刻(UTC)を表す時刻データを、応答信号として返信するものである。
図2は、UTCクロック機能を実現するために制御部11が実行する処理を、タスクとして表した機能ブロック図である。図2に示すように、制御部11は、ソフトウェアタイマ機能を有したオペレーティングシステム(OS)により運営され、このOS下で、基準時刻更新処理(図4参照)及び内部時刻出力処理(図5参照)を実行することにより、UTCクロック機能を実現する。
このオペレーティングシステム(OS)により実現されるソフトウェアタイマ機能は、要求元からタイマ要求があると、要求された時間の経過後に、要求元を呼び出す動作を行う。このソフトウェアタイマ機能は、カウンタ11eのカウント値Cの参照時刻を決定す
るために、基準時刻更新処理にて利用される。
また、基準時刻更新処理は、タイムサーバ20からネットワークインタフェース13を通じて時刻データを取得すると共に、RAM11cが記憶保持する基準時刻T0を、上記取得した時刻データが示す現在時刻Tsに更新し、更には、基準時刻T0を更新する度に、カウンタ11eのカウント値Cをゼロにリセットすることにより、基準時刻T0の更新時点からの経過時間を、カウンタ11eに計測させるものである。
この基準時刻更新処理では、タイムサーバ20から時刻データを取得した時点だけでなく、図3に示すように、カウンタ11eの最大計測時間MaxC・Rより短い時間間隔MaxTが経過する毎に、RAM11cが記憶保持する基準時刻T0を、当該基準時刻T0とカウンタ11eのカウント値Cとから特定される現在時刻に更新し、カウンタ11eのカウント値Cをゼロにリセットする。
カウンタ11eは、一定時間間隔Rで、ゼロからMaxCまでカウントアップすることにより、リセット時からの経過時間を計測するが、フリーランカウンタではないので、リセット後、時間(MaxC・R)で最大値に到達し、最大値に到達した時点で、図3一点鎖線で示すように、カウント動作を停止する。図3は、基準時刻更新処理によりリセットされるカウンタ11eの動作態様と、基準時刻T0の更新態様を表したグラフである。
従って、基準時刻更新処理では、リセット後、図3に示すように、時間(MaxC・R)よりも短い時間間隔MaxTで、カウンタ11eのカウント値Cをゼロにリセットすることにより、カウント値Cのカウントアップが停止しないようにする。
このようにして、基準時刻更新処理では、基準時刻T0及びカウント値Cに基づき、内部時刻出力処理によって、現在時刻Tnを算出できるようにする。尚、基準時刻更新処理及び内部時刻出力処理は、制御部11により並列実行される。
一方、内部時刻出力処理は、他のタスクから時刻の問合せがあると、その時点でのカウント値CとRAM11cに記憶されている基準時刻T0とから現在時刻Tnを算出し、この情報を、問合せ元のタスクに出力するものである。
他のタスクとしては、ケルベロス認証を行うタスクを挙げることができる。本実施例の複合機10は、ケルベロス認証により、ネットワークNT上のPC40等とセキュリティ性の高い通信を行う構成にされており、UTCクロック機能が提供する時刻(UTC)は、例えば、このケルベロス認証に使用される。
続いて、基準時刻更新処理の詳細を、図4を用いて説明する。図4は、基準時刻更新処理を表すフローチャートである。制御部11は、当該複合機10の開始直後から、図4に示す基準時刻更新処理を実行する。
基準時刻更新処理を開始すると、制御部11は、まず、パラメータの初期化を行う(S110)。具体的には、基準時刻T0の更新間隔MaxTを、最大計測時間(MaxC・R)よりも時間αだけ短い値に初期化する(MaxT←MaxC・R−α)。更に、タイムサーバ20から時刻データを取得するまでの残り時間を表すパラメータである時間NXTを、予め定められた時間INTに初期化する(NXT←INT)。
尚、時間INTは、タイムサーバ20から時刻データを取得する時間間隔を表すパラメータである。時間INTの設定値は、EEPROM11dに予め記憶されている。また、時間αは、ソフトウェアタイマの誤差を考慮して、設計者により、予め定められるもので
ある。詳細は後述するが、時間αは、ソフトウェアタイマで誤差が発生しても、カウンタ11eの最大計測時間が経過する前に、基準時刻T0を更新可能な値に設定される。
このようにしてS110での処理を終えると、制御部11は、ネットワークインタフェース13を通じて、タイムサーバ20から時刻データを取得する(S120)。具体的には、制御部11は、EEPROM11dに記憶されたアドレスに従って、当該アドレスに対応するタイムサーバ20に、時刻データの要求信号を、ネットワークインタフェース13を通じて送信する。そして、このタイムサーバ20から、応答信号として送信されてくる時刻データを、ネットワークインタフェース13を通じて受信する。
また、時刻データの受信後には、RAM11cが記憶する基準時刻T0を、受信した時刻データが示す現在時刻Tsに更新すると共に(S130)、カウンタ11eをリセットし、カウンタ11eに値ゼロからカウント値Cの更新動作を実行させる(S140)。その後、S150に移行する。
S150に移行すると、制御部11は、カウンタ11eのカウント値Cを参照し、参照時点のカウント値Cと、カウンタ11eでのカウントアップ周期である上記時間間隔Rとに基づき、基準時刻T0の更新時点からの経過時間ΔTを算出する。
ΔT←C・R
そして、経過時間ΔTの算出後には、経過時間ΔTが時間NXT以上であるか否かを判断する(S160)。これによって、前回時刻データ取得時点から時間INTが経過したか否かを判断する。
ここで、経過時間ΔTが時間NXT未満であると判断すると(S160でNo)、制御部11は、S170に移行し、経過時間ΔTが時間MaxT以上であるか否かを判断する。これによって、基準時刻T0の更新時点から時間MaxTが経過したか否かを判断する。
そして、経過時間ΔTが時間MaxT未満であると判断すると(S170でNo)、S250に移行する。S250において、制御部11は、カウンタ11eのカウント値Cを参照することにより、次回時刻データ取得時点までの残り時間[NXT−C・R]を算出すると共に、次回基準時刻更新時点までの残り時間[MaxT−C・R]を算出する。そして、算出した時間[NXT−C・R]、及び、時間[MaxT−C・R]、及び、予め定められた最大待機時間βの内、最も短い時間を、待機時間WTに決定し、OSのソフトウェアタイマを利用して、上記決定した待機時間WT分、待機する。
具体的に、基準時刻更新処理タスクは、決定した待機時間WT分の時間経過後に、当該基準時刻更新処理を呼び出すように、ソフトウェアタイマ(OS)に対してタイマ要求し、ソフトウェアタイマ(OS)から、このタイマ要求に対応した呼び出しを受けるまで待機する。
そして、呼び出しを受けると、S150に移行して、新たに、カウンタ11eのカウント値Cを参照し、参照時点のカウント値Cと、カウントアップ周期Rと、に基づき、基準時刻T0の更新時点からの経過時間ΔTを算出する。その後、後続処理を実行する。
尚、最大待機時間βは、ソフトウェアタイマの精度を考慮して、上述の時間αと共に定められる。例えば、ソフトウェアタイマに対して1時間後に呼び出すようにタイマ要求したとする。このときに、要求した時間に対して、ソフトウェアタイマ(OS)からの呼び出しイベントが、最大でも1分より充分低い誤差で発生する場合には、時間βを1時間に
設定し、時間αを1分に設定する。
また、時間βは、時間INT及び時間MaxTより十分小さい値に設定される。例えば、時間INTが24時間程度で、カウンタ11eの最大計測時間(MaxC・R)が8時間程度である場合には、時間βとして、1時間程度に設定されればよい。
さて、このような処理を経て、基準時刻T0の更新時点から時間MaxTが経過すると、S150では、経過時間ΔTとして時間MaxT以上の値が算出されることになり、制御部11は、S170で、経過時間ΔTが時間MaxT以上であると判断して(S170でYes)、S180に移行することになる。
S180に移行すると、制御部11は、カウンタ11eをリセットして、カウンタ11eに値ゼロからカウント値Cの更新動作を実行させると共に、RAM11cが記憶する基準時刻T0を、現在値に経過時間ΔTを加算した値に更新する(S190)。
T0←T0+ΔT
これによって、制御部11は、基準時刻T0を、カウンタリセット時の時刻(UTC)に調整する。更には、タイムサーバ20から時刻データを取得するまでの残り時間NXTを、ΔT減算した値に更新する(S200)。
NXT←NXT−ΔT
尚、このように時間NXTを更新するのは、今後算出される経過時間ΔTの基点がS190の処理により切り替わるためである。
S200での処理を終えると、制御部11は、S250に移行して、上述した手法で時間WT、待機し、その後、S150に移行する。
また、前回時刻データ取得時点から時間INTが経過すると、S150では、経過時間ΔTとして時間NXT以上の値が算出される。従って、制御部11は、S160で、経過時間ΔTが時間NXT以上であると判断して(S160でYes)、S210に移行する。
S210に移行すると、制御部11は、S120の処理と同様に、タイムサーバ20から時刻データを取得する。そして、時刻データの受信後には、RAM11cが記憶する基準時刻T0を、受信した時刻データが示す現在時刻Tsに更新すると共に(S220)、カウンタ11eをリセットし、カウンタ11eに値ゼロからカウント値Cの更新動作を実行させる(S230)。その後、S240に移行して、時間NXTを、時間INTに初期化する。その後、S250に移行する。
このような手順を実行することにより、制御部11は、次回の時刻データ取得時点までの期間、基準時刻T0とカウント値Cとから、現在時刻Tnを求められるようにする。
続いて、上述した内部時刻出力処理の詳細を、図5を用いて説明する。図5は、内部時刻出力処理を表すフローチャートである。制御部11は、複合機10の開始直後から、図5に示す内部時刻出力処理を繰返し実行する。
内部時刻出力処理を開始すると、制御部11は、時刻の問合せがあるまで待機し(S310)、問合せがあると(S310でYes)、カウンタ11eのカウント値Cを参照し、その参照時点のカウント値Cに基づき、基準時刻T0の更新時点からの経過時間ΔTを、算出する(S320)。
ΔT←C・R
そして、RAM11cが記憶する基準時刻T0に、算出した経過時間ΔTを加算することにより、現在時刻Tn(UTC)を算出する(S330)。そして、算出した現在時刻Tnを、問合せ元のタスクに出力する(S340)。その後、当該内部時刻出力処理を一旦終了し、再びS310に移行して、次の問合せがあるまで待機する(S310)。
以上、カウンタ11eとして、リセット可能なカウンタであって、カウント値を始点(最小値)から終点(最大値)まで更新すると、カウント動作を停止するカウンタを備える制御部11で実現されるUTCクロック機能について説明した。しかしながら、カウンタ11eが、リセット不可能なフリーランカウンタである場合には、次のように、複合機10を構成するのが好ましい。
[変形例]
続いて、変形例の複合機10について、図6〜図9を用いて説明する。但し、変形例の複合機10は、カウンタ11eがリセット不可能なフリーランカウンタであること、並びに、制御部11によって実行される基準時刻更新処理及び内部時刻出力処理の一部が上記実施例と異なることを除けば、基本的に、上記実施例の複合機10と同一構成であるので、以下では、同一構成に係る説明を、適宜省略する。
図6は、UTCクロック機能を実現するために制御部11が実行する処理を、タスクにより表した機能ブロック図である。図6に示すように、制御部11は、ソフトウェアタイマ機能を有したオペレーティングシステム(OS)により運営され、このOS下で、図8に示す基準時刻更新処理、及び、図9に示す内部時刻出力処理を実行することにより、UTCクロック機能を実現する。
尚、図7は、変形例のカウンタ11eの動作態様を表したグラフである。変形例のカウンタ11eは、図7に示すように、カウント値が一回りすると、カウント値を初期値に戻してカウント動作を継続するフリーランカウンタである。
従って、基準時刻更新処理では、カウンタ11eをリセットする代わりに、基準時刻T0を更新する時点での、カウンタ11eのカウント値Cを、基準カウント値C0として、RAM11cに記憶保持し、この基準カウント値C0と、カウント値Cとの差分(C−C0)により、基準時刻T0の更新時点からの経過時間ΔTを算出する。
但し、カウント値Cの差分算出は、符号無し数値表現を用いたビット演算にて行う。即ち、C=10でありC0=8であるときには、通常の四則演算と同様に、C−C0=2となるが、C=8でありC0=10であるときには、C−C0=(MaxC+8)−10=MaxC−2となる。
続いて、変形例の基準時刻更新処理の詳細を、図8を用いて説明する。図8は、変形例の基準時刻更新処理を表すフローチャートである。尚、図8においては、図4に示す基準時刻更新処理と同様の処理を実行するステップに対して、同一ステップ番号を付す。
変形例の基準時刻更新処理を開始すると、制御部11は、まず、S110にて、上記実施例と同様に、パラメータの初期化を行う(MaxT←MaxC・R−α,NXT←INT)。尚、時間α,βについては、上記実施例と同様である。
S110での処理を終えると、制御部11は、ネットワークインタフェース13を通じて、タイムサーバ20から時刻データを取得し(S120)、時刻データの受信後には、
RAM11cが記憶する基準時刻T0を、受信した時刻データが示す現在時刻Tsに更新する(S130)。
更に、制御部11は、カウンタ11eをリセットする代わりに、S141にて、カウンタ11eのカウント値Cを参照し、RAM11cが記憶する基準カウント値C0を、参照時点のカウント値Cに更新する(C0←C)。その後、S151に移行する。
S151に移行すると、制御部11は、カウンタ11eのカウント値Cを参照し、RAM11cが記憶する計算用カウント値CFを、参照時点のカウント値Cに更新する(CF←C)。
更に、制御部11は、この計算用カウント値CF、及び、基準カウント値C0、及び、カウントアップ周期Rに基づいて、基準時刻T0の更新時点からの経過時間ΔTを算出する(S153)。尚、差分(CF−C0)の算出については、上述のビット演算で行うものとする。
ΔT←(CF−C0)・R
経過時間ΔTの算出後、制御部11は、S160に移行し、経過時間ΔTが時間NXT以上であるか否かを判断することにより、前回時刻データ取得時点から時間INTが経過したか否かを判断する。
ここで、経過時間ΔTが時間NXT未満であると判断すると(S160でNo)、制御部11は、S170に移行し、経過時間ΔTが時間MaxT以上であるか否かを判断する。即ち、基準時刻T0の更新時点から時間MaxTが経過したか否かを判断する。
そして、経過時間ΔTが時間MaxT未満であると判断すると(S170でNo)、制御部11は、S251に移行し、カウンタ11eのカウント値Cを参照して、次回時刻データ取得時点までの残り時間[NXT−(C−C0)・R]を算出すると共に、次回基準時刻更新時点までの残り時間[MaxT−(C−C0)・R]を算出する。
更に、制御部11は、上記算出した時間[NXT−(C−C0)・R]、及び、時間[MaxT−(C−C0)・R]、及び、最大待機時間βの内、最も短い時間を、待機時間WTに決定し、S250での処理と同様に、OSのソフトウェアタイマを利用して、上記決定した待機時間WT分、待機する。
そして、待機時間WTが終了し、ソフトウェアタイマからの呼び出しを受けると、制御部11は、S151に移行し、新たに、カウンタ11eのカウント値Cを参照して、RAM11cが記憶する計算用カウント値CFを、参照時点のカウント値Cに更新し(CF←C)、この計算用カウント値CFを用いて、経過時間ΔTを算出する(S153)。その後、後続処理を実行する。
尚、基準時刻T0の更新時点から時間MaxTが経過すると、S153では、経過時間ΔTとして時間MaxT以上の値が算出される。従って、制御部11は、S170で、経過時間ΔTが時間MaxT以上であると判断して(S170でYes)、S181に移行する。
S181に移行すると、制御部11は、RAM11cが記憶する基準カウント値C0を、RAM11cが記憶する計算用カウント値CFに更新すると共に(C0←CF)、RAM11cが記憶する基準時刻T0を、現在値に経過時間ΔTを加算した値に更新する(S190)。
T0←T0+ΔT
更に、制御部11は、タイムサーバ20から時刻データを取得するまでの残り時間NXTを、ΔT減算した値に更新する(S200)。
NXT←NXT−ΔT
このようにして、S200での処理を終えると、制御部11は、S251に移行して、上述した手法で時間WT、待機した後、S151以降の処理を実行する。
そして、前回時刻データ取得時点から時間INTが経過すると、S153で経過時間ΔTとして時間NXT以上の値が算出されるので、制御部11は、S160でYesと判断して、S210に移行する。
S210に移行すると、制御部11は、S120の処理と同様に、タイムサーバ20から時刻データを受信する。そして、時刻データの受信後には、制御部11は、RAM11cが記憶する基準時刻T0を、受信した時刻データが示す現在時刻Tsに更新すると共に(S220)、カウンタ11eのカウント値Cを参照して、RAM11cが記憶する基準カウント値C0を、参照時点のカウント値Cに更新する(S231)。この後、制御部11は、S240に移行して、時間NXTを、時間INTに初期化し、S251に移行する。
このような手順を実行することにより、制御部11は、次回の時刻データ取得時点までの期間、基準時刻T0と基準カウント値C0とカウント値Cとから、現在時刻Tnを求められるようにする。
続いて、変形例の内部時刻出力処理の詳細を、図9を用いて説明する。図9は、制御部11が繰返し実行する変形例の内部時刻出力処理を表すフローチャートである。
内部時刻出力処理を開始すると、制御部11は、時刻の問合せがあるまで待機し(S310)、問合せがあると(S310でYes)、カウンタ11eのカウント値Cを参照し、その参照時点のカウント値Cと、RAM11cが記憶する基準カウント値C0との差分(C−C0)に基づいて、基準時刻T0の更新時点からの経過時間ΔTを、算出する(S321)。
ΔT←(C−C0)・R
そして、制御部11は、RAM11cが記憶する基準時刻T0に、算出した経過時間ΔTを加算することにより、現在時刻Tn(UTC)を算出する(S330)。そして、制御部11は、算出した現在時刻Tnを、問合せ元のタスクに出力する(S340)。その後、当該内部時刻出力処理を終了する。
[効果]
以上、変形例を含む本発明の実施例について説明したが、上記実施例によれば、制御部11(マイクロコンピュータ)に内蔵されたカウンタ11eを用いて、現在時刻Tnを求めるので、RTC回路を用いずとも精度よく、現在時刻Tnを求めることができ、結果として、高精度な時刻情報を時刻の問合せ元に提供することができる。
また、RTC回路ではなく、カウンタ11eを利用しているため、回路規模を小さくすることができ、簡易な構成で安価に、高精度な時計機能を有する複合機10を製造することができる。
また、上記実施例の複合機10によれば、カウンタ11eの最大計測時間よりも長い時
間間隔で、時刻データを取得しても、現在時刻Tnを算出することができるので、カウンタ11eの最大計測時間が短いことが原因で、タイムサーバ20に負荷がかかることもない。よって、上記実施例によれば、タイムサーバ20に対しても優しい複合機10を提供することができる。
[対応関係]
尚、本発明の電子機器は、上記実施例の複合機10に相当し、基準時刻保持手段及び基準カウント値保持手段は、RAM11cに相当し、カウント回路は、カウンタ11eに相当し、通信インタフェースは、ネットワークインタフェース13に相当する。
また、本発明の時刻情報取得手段の処理は、上記実施例におけるS120,S160,S200,S210,S240,S250(又はS251)の処理に相当し、更新手段の処理は、S130,S220の処理に相当し、経過時間計測手段の処理は、S140,S230,S320の処理、又は、S141,S231,S321の処理に相当する。
その他、本発明の現在時刻算出手段の処理は、上記実施例におけるS330の処理に相当し、応答手段の処理は、内部時刻出力処理に相当し、補助更新手段の処理は、S150,S170,S180,S190,S250の処理、又は、S151,S153,S170,S181,S190,S251の処理に相当する。
[その他]
また、本発明は、上記実施例に限定されるものではなく、種々の態様を採ることができる。
例えば、上記実施例の複合機10は、表示操作部19に設けられた時刻表示ボタンを、ユーザが押下操作したときに、内部時刻出力処理タスクに、時刻を問合せ、その問合せの結果、内部時刻出力処理タスクから得られた時刻(UTC)を、ローカル時刻に変換して、このローカル時間を、液晶モニタを通じて表示出力する構成にされてもよい。
通信システム1の構成を表すブロック図である。 CPU11aが実行する各処理の関係を表した機能ブロック図である。 カウンタ11eの動作及び基準時刻T0の更新態様を表すグラフである。 制御部11が実行する基準時刻更新処理を表すフローチャートである。 制御部11が実行する内部時刻出力処理を表すフローチャートである。 変形例におけるCPU11aが実行する各処理の関係を表した機能ブロック図である。 変形例におけるカウンタ11eの動作及び基準時刻T0の更新態様を表すグラフである。 変形例の基準時刻更新処理を表すフローチャートである。 変形例の内部時刻出力処理を表すフローチャートである。
符号の説明
1…通信システム、10…複合機、11…制御部、11a…CPU、11b…ROM、11c…RAM、11d…EEPROM、11e…カウンタ、11f…水晶振動子、13…ネットワークインタフェース、15…記録部、17…読取部、19…表示操作部、20…タイムサーバ、40…PC

Claims (3)

  1. 現在時刻を表す時刻情報を、外部装置から取得する時刻情報取得手段と、
    基準時刻を記憶保持する基準時刻保持手段と、
    前記時刻情報取得手段が前記時刻情報を取得する度に、前記基準時刻保持手段が記憶保持する前記基準時刻を、前記時刻情報取得手段が取得した最新の前記時刻情報が示す時刻に更新する更新手段と、
    ハードウェアで構成され、一定周期でカウント値を更新するカウント回路と、
    前記カウント回路を用いて、前記基準時刻が更新された時点からの経過時間を計測する手段であって、基準カウント値を記憶保持する基準カウント値保持手段を備え、前記更新手段により前記基準時刻が更新される度に、前記カウント回路のカウント値を参照して、前記基準カウント値保持手段が記憶保持する前記基準カウント値を、参照時点での前記カウント回路のカウント値に更新する一方、前記カウント回路のカウント値を参照して、前記基準カウント値保持手段が記憶保持する基準カウント値と、前記カウント回路のカウント値との差分を算出することにより、前記基準時刻が更新された時点からの経過時間を計測する経過時間計測手段と、
    前記基準時刻保持手段が記憶保持する前記基準時刻に、前記経過時間計測手段により計測された経過時間を加算して、現在時刻を算出する現在時刻算出手段と、
    現在時刻の出力要求があると、前記現在時刻算出手段に前記現在時刻を算出させて、前記現在時刻算出手段により算出された現在時刻を、出力する応答手段と、
    前記カウント回路のカウント値が一回りする時間である前記カウント回路の最大計測時間より短い時間間隔で、前記カウント回路の前記カウント値を参照して、前記基準時刻保持手段が記憶保持する前記基準時刻を、参照時点での前記カウント回路のカウント値と前記基準カウント値保持手段が記憶保持する基準カウント値との差分及び前記基準時刻の現在値から特定される現在時刻に、更新すると共に、前記基準カウント値保持手段が記憶保持する前記基準カウント値を、参照時点での前記カウント回路のカウント値に更新する補助更新手段と、
    を備えることを特徴とする電子機器。
  2. 前記時刻情報取得手段は、前記最大計測時間よりも長い時間間隔で周期的に、前記時刻情報を外部装置から取得することを特徴とする請求項1記載の電子機器。
  3. 前記時刻情報取得手段は、前記電子機器が備える通信インタフェースであって、現在時刻を表す時刻情報を提供するタイムサーバと通信可能な通信インタフェースを通じて、前記タイムサーバから前記時刻情報を取得することを特徴とする請求項1又は請求項2記載の電子機器。
JP2008254035A 2008-09-30 2008-09-30 電子機器 Active JP4645720B2 (ja)

Priority Applications (3)

Application Number Priority Date Filing Date Title
JP2008254035A JP4645720B2 (ja) 2008-09-30 2008-09-30 電子機器
EP20090252244 EP2172829B1 (en) 2008-09-30 2009-09-22 Electronic device having timekeeping function and computer-readable record medium storing program for timekeeping function
US12/566,725 US8402299B2 (en) 2008-09-30 2009-09-25 Electronics device having timekeeping function and computer-readable record medium storing program for timekeeping function

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2008254035A JP4645720B2 (ja) 2008-09-30 2008-09-30 電子機器

Publications (2)

Publication Number Publication Date
JP2010085227A JP2010085227A (ja) 2010-04-15
JP4645720B2 true JP4645720B2 (ja) 2011-03-09

Family

ID=41529987

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2008254035A Active JP4645720B2 (ja) 2008-09-30 2008-09-30 電子機器

Country Status (3)

Country Link
US (1) US8402299B2 (ja)
EP (1) EP2172829B1 (ja)
JP (1) JP4645720B2 (ja)

Families Citing this family (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2014052747A (ja) * 2012-09-05 2014-03-20 International Business Maschines Corporation 日時フォーマットの生成方法、プログラム及びシステム
FR3046856B1 (fr) * 2016-01-15 2020-06-05 Continental Automotive France Procedes et dispositifs de comptage d’une duree de service pour un signal d’horloge etale ainsi que de determination ou generation d’une duree reelle de temps
CN108573544B (zh) * 2018-05-31 2024-06-28 山东中泳电子股份有限公司 一种多时钟双核同步计时器

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2001080167A (ja) * 1999-09-10 2001-03-27 Seiko Epson Corp 印刷装置、情報処理装置、これらの制御方法、および、情報記録媒体
JP2001289981A (ja) * 2000-04-05 2001-10-19 Nec Corp 2進カウンタを使用したカレンダー付き時計
JP2006172030A (ja) * 2004-12-15 2006-06-29 Meidensha Corp ディジタル処理装置における時刻データ取得方法

Family Cites Families (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6611922B2 (en) * 1999-08-09 2003-08-26 Power Measurement, Ltd. Power system time synchronization device and method for sequence of event recording
US6968473B2 (en) * 2001-11-15 2005-11-22 International Business Machines Corporation Method and apparatus for generating a virtual clock in a data processing system
JP2003207586A (ja) 2002-01-16 2003-07-25 Seiko Epson Corp 電子機器、及び、その内部時刻情報制御方法
JP3933018B2 (ja) 2002-09-17 2007-06-20 セイコーエプソン株式会社 プリンタ及び情報処理装置
JP4400040B2 (ja) 2002-12-04 2010-01-20 セイコーエプソン株式会社 デバイス管理装置
JP4296776B2 (ja) 2002-12-11 2009-07-15 セイコーエプソン株式会社 プリンタ、及び、印刷システム
JP4703102B2 (ja) 2003-02-28 2011-06-15 セイコープレシジョン株式会社 時刻進度を補正するタイムスタンプシステムとその方法及びプログラム
US7461283B2 (en) 2005-03-23 2008-12-02 Texas Instruments Incorporated Skip counter for system timer

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2001080167A (ja) * 1999-09-10 2001-03-27 Seiko Epson Corp 印刷装置、情報処理装置、これらの制御方法、および、情報記録媒体
JP2001289981A (ja) * 2000-04-05 2001-10-19 Nec Corp 2進カウンタを使用したカレンダー付き時計
JP2006172030A (ja) * 2004-12-15 2006-06-29 Meidensha Corp ディジタル処理装置における時刻データ取得方法

Also Published As

Publication number Publication date
US20100083024A1 (en) 2010-04-01
EP2172829A1 (en) 2010-04-07
US8402299B2 (en) 2013-03-19
JP2010085227A (ja) 2010-04-15
EP2172829B1 (en) 2014-04-16

Similar Documents

Publication Publication Date Title
JP4831154B2 (ja) 計時装置
US8347197B2 (en) Terminal device, time adjusting method of terminal device and communication system
JP4645720B2 (ja) 電子機器
JP2020096311A (ja) 画像処理システム、画像処理装置、クラウドサーバおよびプログラム
JP2011018983A (ja) 通信装置
US10602949B2 (en) Image processing apparatus, stress measuring method and non-transitory recording medium
JP2015097080A (ja) 画像形成装置の管理装置及び管理プログラム
JP2020012927A (ja) 画像形成装置、指示受付方法およびコンピュータプログラム
JP3933018B2 (ja) プリンタ及び情報処理装置
US9253355B2 (en) Communication apparatus that reduces power consumption, method of controlling the same, and storage medium
JP2017199062A (ja) 操作入力装置、画像形成装置及び操作入力方法
JP2003248076A (ja) 画像形成装置
JP4692359B2 (ja) ログ管理装置、ログ管理システム、ログ管理方法及びそのプログラム
JP6158621B2 (ja) 画像形成装置及び画像形成方法
JP2012003125A (ja) 画像形成装置、操作端末および制御プログラム
JP2007278873A (ja) 時刻同期装置、時刻同期方法及びそのプログラム
KR20180062235A (ko) 조기 웜업으로 인한 공회전 시간을 최소화 하기 위한 화상 형성 장치, 전자 장치 및 그 동작 방법
JP6508479B2 (ja) 実行制御機器、実行制御プログラムおよびタスク実行システム
JP2024002173A (ja) 情報処理装置、情報処理装置の制御方法、及びプログラム
JP2012013548A (ja) 画像形成装置
JP2013015417A (ja) 電子機器、現在時刻校正方法及びプログラム
JP2007245634A (ja) 画像形成装置
JP7127561B2 (ja) 情報処理装置、制御方法、およびプログラム
JP2022105855A (ja) 画像形成装置及びプログラム
JP2022105810A (ja) 画像形成装置及びプログラム

Legal Events

Date Code Title Description
A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20100729

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20100803

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20100930

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

A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20101122

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20131217

Year of fee payment: 3

R150 Certificate of patent or registration of utility model

Ref document number: 4645720

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

Free format text: JAPANESE INTERMEDIATE CODE: R150