US20100083024A1 - Electronics Device Having Timekeeping Function and Computer-Readable Record Medium Storing Program for Timekeeping Function - Google Patents
Electronics Device Having Timekeeping Function and Computer-Readable Record Medium Storing Program for Timekeeping Function Download PDFInfo
- Publication number
- US20100083024A1 US20100083024A1 US12/566,725 US56672509A US2010083024A1 US 20100083024 A1 US20100083024 A1 US 20100083024A1 US 56672509 A US56672509 A US 56672509A US 2010083024 A1 US2010083024 A1 US 2010083024A1
- Authority
- US
- United States
- Prior art keywords
- time
- count value
- counter circuit
- unit
- update
- 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
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F1/00—Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
- G06F1/04—Generating or distributing clock signals or signals derived directly therefrom
- G06F1/14—Time supervision arrangements, e.g. real time clock
Definitions
- an electronics device which acquires time information from an external device by communication, determines the present time (at the point of the acquisition of the time information) using the acquired time information, and thereafter keeps (determines) the present time (after the acquisition of the time information) by counting the elapsed time since the acquisition of the time information by software.
- the timekeeping accuracy of a software clock is lower than that of a hardware clock (RTC circuit) since the progress of the time kept by the software clock changes depending on the processing load on the CPU. Further, there area cases where a signal outputted by the quartz oscillator is inputted to the CPU not directly but via a circuit for noise reduction called an “SSCG (Spread Spectrum Clock Generator)” which extends the frequency range of the signal. Also for this reason, the timekeeping accuracy of a software clock is lower than that of an RTC circuit performing the timekeeping operation by receiving the signal outputted by the quartz oscillator.
- RTC circuit hardware clock
- FIG. 1 is a block diagram showing the configuration of a communication system (including a digital MFP as an electronics device) in accordance with an embodiment of the present invention.
- a communication system 1 in accordance with an embodiment of the present invention includes a digital MFP (Multi-Function Peripheral) 10 , a time server 20 and PCs (Personal Computers) 40 which are connected to a network NT.
- a digital MFP Multi-Function Peripheral
- PCs Personal Computers
- the counter 11 e performs the counting operation by successively incrementing its count value C at fixed time intervals R according to the clock signal inputted from the quartz oscillator 11 f.
- the control unit 11 acquires image data (representing an image on a document) by making the scanner unit 17 scan the document and then inputs the acquired image data to the printer unit 15 to make the printer unit 15 form the copy image of the document on a sheet, by which the copy function is implemented.
- the counter 11 e measures the elapsed time since the resetting of the count value C by successively incrementing the count value C from 0 to MaxC at fixed time intervals R. Since the counter 11 e is not a free-running counter, the counter 11 e (count value C) generally reaches its maximum value when the maximum measurement time MaxC ⁇ R has passed since the resetting and then stops the counting operation at the point of the maximum value as indicated by a chain line in FIG. 3 . The operation of the counter 11 e being reset by the reference time update process and the update of the reference time T 0 are shown in FIG. 3 .
- the internal time output process is executed when a time inquiry is issued by a different task.
- the present time Tn is calculated based on the count value C at the point of the time inquiry and the present time Tn stored in the RAM 11 c, and information on the calculated present time Tn is outputted to the task (inquirer).
- the control unit 11 initializes parameters (S 110 ). Specifically, the control unit 11 initializes the time interval MaxT of the update of the reference time T 0 to a value that is a time ⁇ shorter than the maximum measurement time MaxC ⁇ R (MaxT ⁇ MaxC ⁇ R ⁇ ) while also initializing a parameter NXT (representing a remaining time before the next time data acquisition from the time server 20 ) to a preset time INT (NXT ⁇ INT).
- control unit 11 After receiving the time data (S 120 ), the control unit 11 updates the reference time T 0 stored in the RAM 11 c to the present time Ts represented by the received time data (S 130 ), resets the counter 11 e and makes the counter 11 e start the update of the count value C from 0 (S 140 ), and thereafter advances to step S 150 .
- step S 250 the control unit 11 refers to the count value C of the counter 11 e, calculates a remaining time (NXT ⁇ C ⁇ R) before the next time data acquisition, calculates a remaining time (MaxT ⁇ C ⁇ R) before the next update of the reference time T 0 , determines a waiting time WT as the shortest one selected from the calculated remaining time (NXT ⁇ C ⁇ R), the calculated remaining time (MaxT ⁇ C ⁇ R) and a preset maximum waiting time ⁇ , and thereafter waits for the determined waiting time WT by use of the software timer of the OS.
- the reference time update process requests (i.e. issues the timer request to) the software timer (OS) to call up the reference time update process when the determined waiting time WT has passed, and thereafter waits until a call corresponding to the timer request is received from the software timer (OS).
- the maximum waiting time ⁇ is set at a value sufficiently less than the time INT and the time MaxT. For example, when the time INT is approximately twenty-four hours and the maximum measurement time MaxC ⁇ R of the counter 11 e is approximately eight hours, the maximum waiting time may be set at approximately one hour.
- step S 180 the control unit 11 resets the counter 11 e and makes the counter 11 e start the update of the count value C from 0.
- step S 190 the control unit 11 updates the reference time T 0 stored in the RAM 11 c by adding the elapsed time ⁇ T to the current value of the reference time T 0 as below.
- the remaining time NXT is updated as above because the starting point of the elapsed time ⁇ T (to be calculated thereafter) has been shifted by the step S 190 .
- the control unit 11 acquires the time data from the time server 20 similarly to the step S 120 .
- the control unit 11 updates the reference time T 0 stored in the RAM 11 c to the present time Ts represented by the received time data (S 220 ), resets the counter 11 e and makes the counter 11 e start the update of the count value C from 0 (S 230 ), initializes the remaining time NXT to the time INT (S 240 ), and thereafter advances to the step S 250 .
- control unit 11 makes it possible to determine the present time Tn based on the reference time T 0 and the count value C until the next time data acquisition.
- the control unit 11 starts repeatedly executing the internal time output process ( FIG. 5 ) immediately after startup of the MFP 10 .
- the control unit 11 waits until the time inquiry is issued by a task (S 310 ).
- the control unit 11 refers to the count value C of the counter 11 e and calculates the elapsed time ⁇ T since the update of the reference time T 0 based on the count value C at the point of the reference and the incrementation cycle R of the counter 11 e as below (S 320 ).
- the MFP 10 as the modification is configured basically in the same way as the MFP 10 in the above embodiment except that the counter 11 e is a free-running counter (non-resettable) and the reference time update process and the internal time output process executed by the control unit 11 are slightly different from those in the above embodiment. Thus, repeated explanation of common elements (already explained in the above embodiment) will be omitted properly.
- the control unit 11 stores the count value C at the point of the update of the reference time T 0 in the RAM 11 c as a reference count value C 0 and calculates the elapsed time ⁇ T since the update of the reference time T 0 by calculating the difference (C ⁇ C 0 ) between the (current) count value C and the reference count value C 0 .
- FIG. 8 steps identical with those in FIG. 4 are assigned the same step numbers.
- control unit 11 After calculating the elapsed time ⁇ T (S 153 ), the control unit 11 advances to the step S 160 and judges whether the time INT has passed since the previous time data acquisition or not by judging whether or not the elapsed time ⁇ T is the remaining time NXT or more.
- the control unit 11 waits until the time inquiry is issued by a task (S 310 ).
- a time inquiry is issued (S 310 : YES)
- the control unit 11 refers to the count value C of the counter 11 e and calculates the elapsed time ⁇ T since the update of the reference time T 0 based on the incrementation cycle R of the counter 11 e and the difference (C ⁇ C 0 ) between the count value C at the point of the reference and the reference count value C 0 stored in the RAM 11 c as below (S 321 ).
- control unit 11 calculates the present time Tn (UTC) by adding the calculated elapsed time ⁇ T to the reference time T 0 stored in the RAM 11 c (S 330 ) and outputs the calculated present time Tn to the inquiring task (S 340 ). Thereafter, the control unit 11 which has finished the above internal time output process returns to the step S 310 and waits until the next time inquiry is issued by a task.
- the MFP 10 in the above embodiment may also be configured to inquire of the internal time output process (task) the time (UTC) when a time display button of the display/operation unit 19 is pressed by the user, convert the time (UTC) (obtained from the internal time output process (task) in response to the inquiry) into the local time, and display the local time on the LCD monitor.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Electric Clocks (AREA)
Abstract
Description
- This application claims priority under 35 U.S.C. §119 from Japanese Patent Application No. 2008-254035 filed on Sep. 30, 2008. The entire subject matter of the application is incorporated herein by reference.
- 1. Technical Field
- The present invention relates to an electronics device having a timekeeping function (clock function) and a computer-readable record medium storing a program for implementing the timekeeping function.
- 2. Related Art
- Electronics devices equipped with an RTC (Real Time Clock) circuit are widely known and used today. The RTC circuit, which is supplied with electric power from a battery and keeps on operating even when the power of the electronics device is OFF, is a circuit for keeping the present time.
- Further, there exists an electronics device which acquires time information from an external device by communication, determines the present time (at the point of the acquisition of the time information) using the acquired time information, and thereafter keeps (determines) the present time (after the acquisition of the time information) by counting the elapsed time since the acquisition of the time information by software.
- Such a software clock is generally implemented as a function of an operating system (OS), that is, implemented by a CPU (operated by the operating system) by executing the counting operation according to a clock signal inputted to the CPU.
- There also exist electronics devices capable of correcting the progress of the time kept by a hardware clock (RTC circuit) or software clock based on correct time information acquired from an external device.
- In recent years, environments enabling the acquisition of the time information from a time server (as the external device) via a network are being established with the prevalence of the Internet. Thus, for an electronics device connectable to a network, it is possible to keep on obtaining (determining) the present time (after the acquisition of the time information) by first determining the present time (at the point of the acquisition of the time information) using the time information acquired from the time server and thereafter measuring the elapsed time since the point of the determination as mentioned above, even without the need of being equipped with an RTC circuit.
- The timekeeping accuracy of a software clock is lower than that of a hardware clock (RTC circuit) since the progress of the time kept by the software clock changes depending on the processing load on the CPU. Further, there area cases where a signal outputted by the quartz oscillator is inputted to the CPU not directly but via a circuit for noise reduction called an “SSCG (Spread Spectrum Clock Generator)” which extends the frequency range of the signal. Also for this reason, the timekeeping accuracy of a software clock is lower than that of an RTC circuit performing the timekeeping operation by receiving the signal outputted by the quartz oscillator.
- However, equipping an electronics device with an RTC circuit involves problems such as enlargement of the circuit scale and increase in the manufacturing cost of the electronics device.
- The present invention, which has been made in consideration of the above problems, is advantageous in that a technology which makes it possible to implement an electronics device having an accurate timekeeping function (capable of accurately determining the present time) in a simple configuration, in a reduced circuit scale and at a low cost can be provided.
- An electronics device in accordance with the present invention (which has been made to achieve the above objective) determines the present time not by using an RTC circuit but by using the time information acquired from an external device and a counter circuit which is formed by hardware.
- In accordance with an aspect of the present invention, there is provided an electronics device comprising a time information acquisition unit which acquires time information representing present time from an external device, a reference time storage unit which stores and holds reference time, an update unit which updates the reference time stored in the reference time storage unit to time represented by the latest time information acquired by the time information acquisition unit each time the time information is acquired by the time information acquisition unit, a counter circuit which is formed by hardware and updates its count value at fixed cycles, an elapsed time measurement unit which measures an elapsed time since the update of the reference time by use of the counter circuit, a present time calculation unit which calculates present time by adding the elapsed time measured by the elapsed time measurement unit to the reference time stored in the reference time storage unit, and a response unit which makes the present time calculation unit calculate the present time and outputs the calculated present time if a present time output request is issued.
- In accordance with other aspects of the present invention, there is provided a computer-readable record medium storing computer-readable instructions that cause a computer to execute a time information acquisition step of acquiring time information representing present time from an external device, an update step of updating reference time stored in a reference time storage unit to time represented by the latest time information acquired by the time information acquisition step each time the time information is acquired by the time information acquisition step, an elapsed time measurement step of measuring an elapsed time since the update of the reference time by use of a counter circuit which is formed by hardware and updates its count value at fixed cycles, a present time calculation step of calculating present time by adding the elapsed time measured by the elapsed time measurement step to the reference time stored in the reference time storage unit, and a response step of calculating the present time by executing the present time calculation step and outputting the calculated present time if a present time output request is issued.
- Incidentally, the present invention can be implemented in various forms, such as an electronics device, an electronics device control method, a computer program for controlling an electronics device, a storage medium storing the computer program, etc.
- Other objects, features and advantages of the present invention will become more apparent from the consideration of the following detailed description taken in conjunction with the accompanying drawings.
-
FIG. 1 is a block diagram showing the configuration of a communication system (including a digital MFP as an electronics device) in accordance with an embodiment of the present invention. -
FIG. 2 is a functional block diagram showing the relationship among processes (tasks) executed by a control unit of the MFP for implementing a UTC clock function. -
FIG. 3 is a graph showing the operation of a counter of the control unit and the update of reference time T0. -
FIG. 4 is a flow chart showing a reference time update process which is executed by the control unit. -
FIG. 5 is a flow chart showing an internal time output process which is executed by the control unit. -
FIG. 6 is a functional block diagram showing processes (tasks) executed by a control unit of an MFP as a modification for implementing the UTC clock function. -
FIG. 7 is a graph showing the operation of a counter of the MFP as the modification. -
FIG. 8 is a flow chart showing a reference time update process which is executed by the control unit of the MFP as the modification. -
FIG. 9 is a flow chart showing an internal time output process which is executed by the control unit of the MFP as the modification. - Referring now to the drawings, a description will be given in detail of a preferred embodiment in accordance with the present invention.
- Referring to
FIG. 1 , a communication system 1 in accordance with an embodiment of the present invention includes a digital MFP (Multi-Function Peripheral) 10, atime server 20 and PCs (Personal Computers) 40 which are connected to a network NT. - The
digital MFP 10 in the communication system 1 includes acontrol unit 11, anetwork interface 13, aprinter unit 15, ascanner unit 17 and a display/operation unit 19. - The
control unit 11 includes a CPU (Central Processing Unit) 11 a which executes various programs, aROM 11 b storing the programs to be executed by theCPU 11 a, aRAM 11 c which is used as a work area during the program execution by theCPU 11 a, an EEPROM (Electrically Erasable Programmable ROM) 11 d which is used for storing a variety of setting information, acounter 11 e, and a quartz oscillator 11 f. TheCPU 11 a has centralized control of the whole device (MFP 10) by executing the programs stored in theROM 11 b, by which various functions of theMFP 10 are implemented. - The quartz oscillator 11 f generates a clock signal which is necessary for the operation of the
CPU 11 a. The clock signal outputted by the quartz oscillator 11 f is inputted to theCPU 11 a and thecounter 11 e. - Incidentally, the clock signal for the
CPU 11 a is inputted to theCPU 11 a after its frequency range has been extended by an SSCG (Spread Spectrum Clock Generator)circuit 11 g as a circuit for noise reduction. On the other hand, to thecounter 11 e, the clock signal from the quartz oscillator 11 f is inputted directly (not via theSSCG circuit 11 g). - Thus, the frequency spectrum of the clock signal inputted to the
counter 11 e has a sharp peak at a single frequency, while that of the clock signal inputted to theCPU 11 a has a certain width in frequency. For this reason, thecounter 11 e functions as a hardware clock unit capable of keeping the time more accurately than a software timer implemented by theCPU 11 a. - Specifically, the
counter 11 e performs the counting operation by successively incrementing its count value C at fixed time intervals R according to the clock signal inputted from the quartz oscillator 11 f. - The
network interface 13, which is connected to the network NT, is configured to be capable of communicating with external devices (time server 20, PC 40, etc.) via the network NT. - The
printer unit 15 forms (prints) an image on a sheet (e.g. paper) according to image data supplied from thecontrol unit 11. - The
scanner unit 17 optically scans a document (target of scanning) placed on a document table or fed from an ADF (Automatic Document Feeder) and thereby generates image data representing the scanned image. The image data generated by thescanner unit 17 is inputted to thecontrol unit 11. - The display/
operation unit 19, including an LCD (Liquid Crystal Display) monitor for displaying information and various operation keys, functions as a user interface. - The
control unit 11 implements the so-called network printer function, scanner function and copy function by use of theprinter unit 15, thescanner unit 17 and the display/operation unit 19. - For example, the
control unit 11 implements the network printer function by receiving image data (target of printing) from a PC 40 on the network NT via thenetwork interface 13 and inputting the received image data to theprinter unit 15. - When a scan instruction is inputted by the user through the display/
operation unit 19, thecontrol unit 11 acquires image data (representing an image on a document) by making thescanner unit 17 scan the document and then transmits the acquired image data to a preset external device (destination) via thenetwork interface 13 according to the setting information stored in theEEPROM 11 d, by which the scanner function is implemented. - When a copy instruction is inputted by the user through the display/
operation unit 19, thecontrol unit 11 acquires image data (representing an image on a document) by making thescanner unit 17 scan the document and then inputs the acquired image data to theprinter unit 15 to make theprinter unit 15 form the copy image of the document on a sheet, by which the copy function is implemented. - Besides the above functions, the MFP 10 has a UTC clock function of acquiring time data representing the present time (UTC (Universal Time Coordinated)) from the
time server 20 via thenetwork interface 13, keeping the present time (UTC) based on the time data, and supplying the present time (UTC). Incidentally, thetime server 20 receiving a time data request signal sends back the time data (representing the present time (UTC)) as a reply signal to the sender of the request signal. - Processes executed by the
control unit 11 for implementing the UTC clock function are shown inFIG. 2 as tasks. As shown inFIG. 2 , the control unit 11 (operated by an operating system (OS) having a software timer function) implements the UTC clock function by executing a reference time update process (seeFIG. 4 ) and an internal time output process (seeFIG. 5 ) under the control of the OS. - In cases where a timer request is issued by a requester, the software timer function (implemented by the OS) calls up the requester when a time period specified by the timer request has passed since the issuance of the request. The software timer function is used in the reference time update process for determining the time for referring to the count value C of the
counter 11 e (i.e. for waiting for a waiting time before the reference to the count value C). - In the reference time update process, the time data is acquired from the
time server 20 vianetwork interface 13, reference time T0 held by theRAM 11 c is updated to present time Ts represented by the acquired time data, and the elapsed time since the update of the reference time T0 is measured by thecounter 11 e by resetting its count value C to 0 on each update of the reference time T0. - As shown in
FIG. 3 , in the reference time update process, the reference time T0 held by theRAM 11 c is updated to the present time (determined by the reference time T0 and the count value C of the counter 11 e) and the count value C is reset to 0 not only when the time data is acquired from thetime server 20 but also each time a time interval MaxT (shorter than a maximum measurement time MaxC·R of the counter 11 e) has passed. - The counter 11 e measures the elapsed time since the resetting of the count value C by successively incrementing the count value C from 0 to MaxC at fixed time intervals R. Since the
counter 11 e is not a free-running counter, thecounter 11 e (count value C) generally reaches its maximum value when the maximum measurement time MaxC·R has passed since the resetting and then stops the counting operation at the point of the maximum value as indicated by a chain line inFIG. 3 . The operation of the counter 11 e being reset by the reference time update process and the update of the reference time T0 are shown inFIG. 3 . - As shown in
FIG. 3 , thecounter 11 e is prevented from stopping the counting operation (incrementation of the count value C) in the reference time update process by successively resetting the count value C to 0 at the time intervals MaxT (shorter than the maximum measurement time MaxC·R). - By the reference time update process described above, the internal time output process is allowed to consistently calculate the present time Tn based on the reference time T0 and the count value C. Incidentally, the reference time update process and the internal time output process are executed in parallel by the
control unit 11. - The internal time output process is executed when a time inquiry is issued by a different task. In the internal time output process, the present time Tn is calculated based on the count value C at the point of the time inquiry and the present time Tn stored in the
RAM 11 c, and information on the calculated present time Tn is outputted to the task (inquirer). - As the “different task”, a task that performs Kerberos authentication can be taken as an example. The
MFP 10 in this embodiment is configured to execute high-security communication with an external device (e.g. PC 40) on the network NT by performing the Kerberos authentication. The time (UTC) supplied by the UTC clock function is used for the Kerberos authentication, for example. - Next, the details of the reference time update process will be explained below referring to a flow chart of
FIG. 4 . Thecontrol unit 11 starts the reference time update process (FIG. 4 ) immediately after startup of theMFP 10. - At the start of the reference time update process, the
control unit 11 initializes parameters (S110). Specifically, thecontrol unit 11 initializes the time interval MaxT of the update of the reference time T0 to a value that is a time α shorter than the maximum measurement time MaxC·R (MaxT←MaxC·R−α) while also initializing a parameter NXT (representing a remaining time before the next time data acquisition from the time server 20) to a preset time INT (NXT←INT). - Incidentally, the time INT is a parameter representing the time interval of the time data acquisition from the
time server 20. The set value of the time INT has previously been stored in theEEPROM 11 d. The time a is previously set by a designer in consideration of the error of the software timer. While details will be explained later, the time α is set at a value with which the reference time T0 can be updated before the elapse of the maximum measurement time MaxC·R of the counter 11 e even when an error has occurred in the software timer. - After finishing the initialization (S110) as above, the
control unit 11 acquires the time data from thetime server 20 via the network interface 13 (S120). Specifically, thecontrol unit 11 transmits a time data request signal to the address of thetime server 20 stored in theEEPROM 11 d via thenetwork interface 13 and thereafter receives the time data (sent back from thetime server 20 as a reply signal) via thenetwork interface 13. - After receiving the time data (S120), the
control unit 11 updates the reference time T0 stored in theRAM 11 c to the present time Ts represented by the received time data (S130), resets thecounter 11 e and makes the counter 11 e start the update of the count value C from 0 (S140), and thereafter advances to step S150. - In the step S150, the
control unit 11 refers to the count value C of the counter 11 e and calculates the elapsed time ΔT since the update of the reference time T0 based on the count value C at the point of the reference and the aforementioned time interval R (incrementation cycle of the counter 11 e) as below. -
ΔT←C·R - Subsequently, the
control unit 11 judges whether or not the elapsed time ΔT is the remaining time NXT or more (S160). By this judgment, whether the time INT has passed since the previous time data acquisition or not can be judged. - If the elapsed time ΔT is less than the time NXT (S160: NO), the
control unit 11 judges whether or not the elapsed time ΔT is the time MaxT or more (S170). By this judgment, whether the time MaxT has passed since the update of the reference time T0 or not can be judged. - If the elapsed time ΔT is less than the time MaxT (S170: NO), the
control unit 11 advances to step S250. In the step S250, thecontrol unit 11 refers to the count value C of the counter 11 e, calculates a remaining time (NXT−C·R) before the next time data acquisition, calculates a remaining time (MaxT−C·R) before the next update of the reference time T0, determines a waiting time WT as the shortest one selected from the calculated remaining time (NXT−C·R), the calculated remaining time (MaxT−C·R) and a preset maximum waiting time β, and thereafter waits for the determined waiting time WT by use of the software timer of the OS. - Specifically, the reference time update process (task) requests (i.e. issues the timer request to) the software timer (OS) to call up the reference time update process when the determined waiting time WT has passed, and thereafter waits until a call corresponding to the timer request is received from the software timer (OS).
- When the call from the software timer (OS) is received, the
control unit 11 returns to the step S150, in which thecontrol unit 11 newly refers to the count value C of the counter 11 e and calculates the elapsed time ΔT since the update of the reference time T0 based on the count value C at the point of the reference and the incrementation cycle R of the counter 11 e. Thereafter, thecontrol unit 11 executes the subsequent steps. - Incidentally, the maximum waiting time β is set together with the aforementioned time α in consideration of the accuracy of the software timer. For example, assuming that a timer request requesting the software timer to call up the reference time update process in one hour is issued, the maximum waiting time β is set at one hour and the time α is set at one minute in cases where the calling event from the software timer (OS) occurs with a permissibly small error (with respect to the time (one hour) specified by the timer request) sufficiently less than one minute.
- The maximum waiting time β is set at a value sufficiently less than the time INT and the time MaxT. For example, when the time INT is approximately twenty-four hours and the maximum measurement time MaxC·R of the counter 11 e is approximately eight hours, the maximum waiting time may be set at approximately one hour.
- When the time MaxT has passed (while the above process is executed) since the update of the reference time T0, the elapsed time ΔT is calculated in S150 as a time longer or equal to the time MaxT. Thus, the
control unit 11 judges in S170 that the elapsed time ΔT is the time MaxT or more (S170: YES) and advances to step S180. - In the step S180, the
control unit 11 resets thecounter 11 e and makes the counter 11 e start the update of the count value C from 0. In the next step S190, thecontrol unit 11 updates the reference time T0 stored in theRAM 11 c by adding the elapsed time ΔT to the current value of the reference time T0 as below. -
T0←T0+ΔT - By the step S190, the
control unit 11 adjusts the reference time T0 to the time (UTC) of the resetting of the counter 11 e. - Further, the
control unit 11 updates the remaining time NXT (before the next time data acquisition from the time server 20) by subtracting the elapsed time ΔT from the current value of the remaining time NXT as below (S200). -
NXT←NXT−ΔT - The remaining time NXT is updated as above because the starting point of the elapsed time ΔT (to be calculated thereafter) has been shifted by the step S190.
- After finishing the step S200, the
control unit 11 advances to the step S250 (waits for the waiting time WT as explained above) and thereafter returns to the step S150. - When the time NT has passed since the previous time data acquisition, the elapsed time ΔT is calculated in S150 as a time longer or equal to the remaining time NXT. Thus, the
control unit 11 judges in S160 that the elapsed time ΔT is the remaining time NXT or more (S160: YES) and advances to step S210. - In the step S210, the
control unit 11 acquires the time data from thetime server 20 similarly to the step S120. After receiving the time data (S210), thecontrol unit 11 updates the reference time T0 stored in theRAM 11 c to the present time Ts represented by the received time data (S220), resets thecounter 11 e and makes the counter 11 e start the update of the count value C from 0 (S230), initializes the remaining time NXT to the time INT (S240), and thereafter advances to the step S250. - By executing the above procedure, the
control unit 11 makes it possible to determine the present time Tn based on the reference time T0 and the count value C until the next time data acquisition. - Next, the details of the internal time output process will be explained below referring to a flow chart of
FIG. 5 . Thecontrol unit 11 starts repeatedly executing the internal time output process (FIG. 5 ) immediately after startup of theMFP 10. - At the start of the internal time output process, the
control unit 11 waits until the time inquiry is issued by a task (S310). When a time inquiry is issued (S310: YES), thecontrol unit 11 refers to the count value C of the counter 11 e and calculates the elapsed time ΔT since the update of the reference time T0 based on the count value C at the point of the reference and the incrementation cycle R of the counter 11 e as below (S320). -
ΔT←C—R - Subsequently, the
control unit 11 calculates the present time Tn (UTC) by adding the calculated elapsed time ΔT to the reference time T0 stored in theRAM 11 c (S330) and outputs the calculated present time Tn to the inquiring task (S340). Thereafter, thecontrol unit 11 which has finished the above internal time output process returns to the step S310 and waits until the next time inquiry is issued by a task. - Incidentally, while the UTC clock function implemented by the
control unit 11 equipped with the counter 11 e has been explained above assuming that the counter 11 e is a resettable counter which stops the counting operation when its count value C (successively updated from the starting point (minimum value) to the endpoint (maximum value)) has reached the endpoint, theMFP 10 having the UTC clock function is desired to be configured as below in cases where thecounter 11 e is a free-running counter (non-resettable). - In the following, an
MFP 10 in accordance with a modification of the above embodiment will be described referring toFIGS. 6-9 . TheMFP 10 as the modification is configured basically in the same way as theMFP 10 in the above embodiment except that the counter 11 e is a free-running counter (non-resettable) and the reference time update process and the internal time output process executed by thecontrol unit 11 are slightly different from those in the above embodiment. Thus, repeated explanation of common elements (already explained in the above embodiment) will be omitted properly. - Processes (tasks) executed by the
control unit 11 of theMFP 10 as the modification for implementing the UTC clock function are shown inFIG. 6 . As shown inFIG. 6 , the control unit 11 (operated by the operating system (OS) having the software timer function) implements the UTC clock function by executing a reference time update process shown inFIG. 8 and an internal time output process shown inFIG. 9 under the control of the OS. - The operation of the counter 11 e of the
MFP 10 as the modification is shown inFIG. 7 . As shown inFIG. 7 , thecounter 11 e in the modification is a free-running counter which initializes its count value C to the initial value when the count value C has run through its entire range and thereafter continues the counting operation. - Thus, instead of resetting the
counter 11 e in the reference time update process, thecontrol unit 11 stores the count value C at the point of the update of the reference time T0 in theRAM 11 c as a reference count value C0 and calculates the elapsed time ΔT since the update of the reference time T0 by calculating the difference (C−C0) between the (current) count value C and the reference count value C0. - The calculation of the difference (C−C0) is executed by a bit operation using numeric representation without the negative sign “−”. For example, although the difference (C−C0) equals 2 similarly to the normal arithmetic operation when C=10 and C0=8, the difference (C−C0) equals (MaxC+8)−10=MaxC−2 when C=8 and C0=10.
- Next, the details of the reference time update process in the modification will be explained below referring to a flow chart of
FIG. 8 . InFIG. 8 , steps identical with those inFIG. 4 are assigned the same step numbers. - At the start of the reference time update process (modification), the
control unit 11 initializes the parameters (MaxT←MaxC·R−α, NXT←INT) similarly to the above embodiment (S110). The time a and the maximum waiting time β are identical with those in the above embodiment. - After finishing the initialization (S110), the
control unit 11 acquires the time data from thetime server 20 via the network interface 13 (S120) and thereafter updates the reference time T0 stored in theRAM 11 c to the present time Ts represented by the received time data (S130). - Subsequently, instead of resetting the
counter 11 e, thecontrol unit 11 refers to the count value C of the counter 11 e and updates the reference count value C0 stored in theRAM 11 c to the count value C at the point of the reference (C0←C) (S141). Thereafter, thecontrol unit 11 advances to step S151. - In the step S151, the
control unit 11 refers to the count value C of the counter 11 e and updates a calculation count value CF (to be used for calculation) stored in theRAM 11 c to the count value C at the point of the reference (CF←C). - Subsequently, the
control unit 11 calculates the elapsed time ΔT since the update of the reference time T0 based on the calculation count value CF, the reference count value C0 and the incrementation cycle R of the counter 11 e as below (S153). Incidentally, the difference (CF−C0) is calculated by the aforementioned bit operation. -
ΔT←(CF−C0)·R - After calculating the elapsed time ΔT (S153), the
control unit 11 advances to the step S160 and judges whether the time INT has passed since the previous time data acquisition or not by judging whether or not the elapsed time ΔT is the remaining time NXT or more. - If the elapsed time ΔT is less than the time NXT (S160: NO), the
control unit 11 advances to the step S170 and judges whether or not the elapsed time ΔT is the time MaxT or more, that is, whether or not the time MaxT has passed since the update of the reference time T0. - If the elapsed time ΔT is less than the time MaxT (S170: NO), the
control unit 11 advances to step S251. In the step S251, thecontrol unit 11 refers to the count value C of the counter 11 e, calculates a remaining time (NXT−(C−C0)·R) before the next time data acquisition, calculates a remaining time (MaxT−(C−C0)·R) before the next update of the reference time T0, determines a waiting time WT as the shortest one selected from the calculated remaining time (NXT−(C−C0)·R), the calculated remaining time (MaxT−(C−C0)·R) and the maximum waiting time β, and thereafter waits for the determined waiting time WT by use of the software timer of the OS similarly to the step S250 inFIG. 4 . - When a call from the software timer is received (i.e. when the waiting time WT has passed), the
control unit 11 returns to the step S151, in which thecontrol unit 11 newly refers to the count value C of the counter 11 e and updates the calculation count value CF stored in theRAM 11 c to the count value C at the point of the reference (CF←C). Thereafter, thecontrol unit 11 calculates the elapsed time ΔT using the calculation count value CF (S153) and executes the subsequent steps. - When the time MaxT has passed since the update of the reference time T0, the elapsed time ΔT is calculated in S153 as a time longer or equal to the time MaxT. Thus, the
control unit 11 judges in S170 that the elapsed timeΔAT is the time MaxT or more (S170: YES) and advances to step S181. - In the step S181, the
control unit 11 updates the reference count value C0 stored in theRAM 11 c to the calculation count value CF stored in theRAM 11 c (C0←CF). Subsequently, thecontrol unit 11 updates the reference time T0 stored in theRAM 11 c by adding the elapsed time ΔT to the current value of the reference time T0 as below (S190). -
T0←T0+ΔT - Subsequently, the
control unit 11 updates the remaining time NXT (before the next time data acquisition from the time server 20) by subtracting the elapsed time ΔT from the current value of the remaining time NXT as below (S200). -
NXT←NXT−ΔT - After finishing the step S200, the
control unit 11 advances to the step S251 (waits for the waiting time WT as explained above) and thereafter returns to the step S151. - When the time INT has passed since the previous time data acquisition, the elapsed time ΔT is calculated in S153 as a time longer or equal to the remaining time NXT. Thus, the
control unit 11 judges “YES” in S160 and advances to the step S210. - In the step S210, the
control unit 11 acquires the time data from thetime server 20 similarly to the step S120. After receiving the time data (S210), thecontrol unit 11 updates the reference time T0 stored in theRAM 11 c to the present time Ts represented by the received time data (S220), refers to the count value C of the counter 11 e and updates the reference count value C0 stored in theRAM 11 c to the count value C at the point of the reference (S231), initializes the remaining time NXT to the time INT (S240), and thereafter advances to the step S251. - By executing the above procedure, the
control unit 11 makes it possible to determine the present time Tn based on the reference time T0, the reference count value C0 and the count value C until the next time data acquisition. - Next, the details of the internal time output process in the modification will be explained below referring to a flow chart of
FIG. 9 . Thecontrol unit 11 starts repeatedly executing the internal time output process (FIG. 9 ) immediately after startup of theMFP 10. - At the start of the internal time output process, the
control unit 11 waits until the time inquiry is issued by a task (S310). When a time inquiry is issued (S310: YES), thecontrol unit 11 refers to the count value C of the counter 11 e and calculates the elapsed time ΔT since the update of the reference time T0 based on the incrementation cycle R of the counter 11 e and the difference (C−C0) between the count value C at the point of the reference and the reference count value C0 stored in theRAM 11 c as below (S321). -
ΔT←(C−C0)·R - Subsequently, the
control unit 11 calculates the present time Tn (UTC) by adding the calculated elapsed time ΔT to the reference time T0 stored in theRAM 11 c (S330) and outputs the calculated present time Tn to the inquiring task (S340). Thereafter, thecontrol unit 11 which has finished the above internal time output process returns to the step S310 and waits until the next time inquiry is issued by a task. - In the embodiment (including the modification) explained above, the present time Tn is obtained (determined) using the
counter 11 e built in the control unit 11 (microcomputer). Therefore, the present time Tn can be obtained with high accuracy and consequently highly accurate time information can be supplied to the inquirer of the time even without using an RTC (Real Time Clock) circuit. - Thanks to the use of the counter 11 e instead of an RTC circuit, the circuit scale can be reduced and an
MFP 10 having a highly accurate clock function (timekeeping function) can be manufactured in a simple configuration and at a low cost. - Further, since the
MFP 10 in the above embodiment is capable of calculating the present time Tn even when the time data is acquired at time intervals longer than the maximum measurement time of the counter 11 e, no excessive load on thetime server 20 is caused by a short maximum measurement time of the counter 11 e. Thus, anMFP 10 that is also easy on thetime server 20 can be provided by the above embodiment. - While a description has been given above of a preferred embodiment in accordance with the present invention, the present invention is not to be restricted by the particular illustrative embodiment and a variety of modifications, design changes, etc. are possible without departing from the scope and spirit of the present invention described in the appended claims.
- For example, the
MFP 10 in the above embodiment may also be configured to inquire of the internal time output process (task) the time (UTC) when a time display button of the display/operation unit 19 is pressed by the user, convert the time (UTC) (obtained from the internal time output process (task) in response to the inquiry) into the local time, and display the local time on the LCD monitor.
Claims (16)
Applications Claiming Priority (2)
| Application Number | Priority Date | Filing Date | Title |
|---|---|---|---|
| JP2008-254035 | 2008-09-30 | ||
| JP2008254035A JP4645720B2 (en) | 2008-09-30 | 2008-09-30 | Electronics |
Publications (2)
| Publication Number | Publication Date |
|---|---|
| US20100083024A1 true US20100083024A1 (en) | 2010-04-01 |
| US8402299B2 US8402299B2 (en) | 2013-03-19 |
Family
ID=41529987
Family Applications (1)
| Application Number | Title | Priority Date | Filing Date |
|---|---|---|---|
| US12/566,725 Active 2031-09-21 US8402299B2 (en) | 2008-09-30 | 2009-09-25 | Electronics device having timekeeping function and computer-readable record medium storing program for timekeeping function |
Country Status (3)
| Country | Link |
|---|---|
| US (1) | US8402299B2 (en) |
| EP (1) | EP2172829B1 (en) |
| JP (1) | JP4645720B2 (en) |
Cited By (3)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US20140067876A1 (en) * | 2012-09-05 | 2014-03-06 | International Business Machines Corporation | Date and time format generation method, program, and system |
| WO2017121446A1 (en) * | 2016-01-15 | 2017-07-20 | Continental Automotive France | Methods and devices for counting a service duration for a spread clock signal and determining or generating an actual time duration |
| CN108573544A (en) * | 2018-05-31 | 2018-09-25 | 山东中泳体育股份有限公司 | A kind of multi-clock double-core synchrotimer |
Citations (5)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US20030014678A1 (en) * | 1999-08-09 | 2003-01-16 | H. Kurtulus Ozcetin | Power system time synchronization device and method for sequence of event recording |
| US20030093705A1 (en) * | 2001-11-15 | 2003-05-15 | International Business Machines Corporation | Method and apparatus for generating a virtual clock in a data processing system |
| US20040114156A1 (en) * | 2002-09-17 | 2004-06-17 | Osamu Azami | Printer and information processing apparatus |
| US20040141201A1 (en) * | 2002-12-04 | 2004-07-22 | Toshihiro Shima | Device management method |
| US20060217918A1 (en) * | 2005-03-23 | 2006-09-28 | Vitaly Andrianov | Skip counter for system timer |
Family Cites Families (6)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| JP2001080167A (en) * | 1999-09-10 | 2001-03-27 | Seiko Epson Corp | Printing apparatus, information processing apparatus, control method thereof, and information recording medium |
| JP3546427B2 (en) * | 2000-04-05 | 2004-07-28 | 日本電気株式会社 | Clock with calendar using binary counter |
| JP2003207586A (en) | 2002-01-16 | 2003-07-25 | Seiko Epson Corp | Electronic device and its internal time information control method |
| JP4296776B2 (en) | 2002-12-11 | 2009-07-15 | セイコーエプソン株式会社 | Printer and printing system |
| JP4703102B2 (en) | 2003-02-28 | 2011-06-15 | セイコープレシジョン株式会社 | Time stamp system and method and program for correcting time progress |
| JP2006172030A (en) * | 2004-12-15 | 2006-06-29 | Meidensha Corp | Method for obtaining time data in digital processing device |
-
2008
- 2008-09-30 JP JP2008254035A patent/JP4645720B2/en active Active
-
2009
- 2009-09-22 EP EP20090252244 patent/EP2172829B1/en not_active Not-in-force
- 2009-09-25 US US12/566,725 patent/US8402299B2/en active Active
Patent Citations (5)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US20030014678A1 (en) * | 1999-08-09 | 2003-01-16 | H. Kurtulus Ozcetin | Power system time synchronization device and method for sequence of event recording |
| US20030093705A1 (en) * | 2001-11-15 | 2003-05-15 | International Business Machines Corporation | Method and apparatus for generating a virtual clock in a data processing system |
| US20040114156A1 (en) * | 2002-09-17 | 2004-06-17 | Osamu Azami | Printer and information processing apparatus |
| US20040141201A1 (en) * | 2002-12-04 | 2004-07-22 | Toshihiro Shima | Device management method |
| US20060217918A1 (en) * | 2005-03-23 | 2006-09-28 | Vitaly Andrianov | Skip counter for system timer |
Cited By (9)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US20140067876A1 (en) * | 2012-09-05 | 2014-03-06 | International Business Machines Corporation | Date and time format generation method, program, and system |
| US9646011B2 (en) * | 2012-09-05 | 2017-05-09 | International Business Machines Corporation | Date and time format generation method, program, and system for reference and elapsed timestamps to produce a formatted target timestamp for use in stream processing |
| US9665579B2 (en) * | 2012-09-05 | 2017-05-30 | International Business Machines Corporation | Date and time format generation method, program, and system for reference and elapsed timestamps to produce a formatted target timestamp for use in stream processing |
| WO2017121446A1 (en) * | 2016-01-15 | 2017-07-20 | Continental Automotive France | Methods and devices for counting a service duration for a spread clock signal and determining or generating an actual time duration |
| FR3046856A1 (en) * | 2016-01-15 | 2017-07-21 | Continental Automotive France | METHODS AND DEVICES FOR COUNTING SERVICE TIME FOR A CLOCKWISE CLOCK SIGNAL AND FOR DETERMINING OR GENERATING REAL TIME DURATION |
| CN109074121A (en) * | 2016-01-15 | 2018-12-21 | 法国大陆汽车公司 | The method and apparatus counted and for determining or generating actual duration are carried out for the Service Duration to expanding clock signal |
| US10795405B2 (en) | 2016-01-15 | 2020-10-06 | Continental Automotive France | Methods and devices for counting a service duration for a spread clock signal and determining or generating an actual time duration |
| US10969823B2 (en) | 2016-01-15 | 2021-04-06 | Continental Automotive France | Methods and devices for counting a service duration for a spread clock signal and determining or generating an actual time duration |
| CN108573544A (en) * | 2018-05-31 | 2018-09-25 | 山东中泳体育股份有限公司 | A kind of multi-clock double-core synchrotimer |
Also Published As
| Publication number | Publication date |
|---|---|
| EP2172829A1 (en) | 2010-04-07 |
| JP2010085227A (en) | 2010-04-15 |
| US8402299B2 (en) | 2013-03-19 |
| JP4645720B2 (en) | 2011-03-09 |
| EP2172829B1 (en) | 2014-04-16 |
Similar Documents
| Publication | Publication Date | Title |
|---|---|---|
| JP4831154B2 (en) | Timing device | |
| US9930202B2 (en) | Information processing apparatus ensuring temporal matching with server, method of controlling the information processing apparatus, information processing system, and storage medium | |
| US20120191601A1 (en) | Image processing system, image processing device, billing processing method and computer readable recording medium | |
| US8402299B2 (en) | Electronics device having timekeeping function and computer-readable record medium storing program for timekeeping function | |
| JP2017229035A (en) | Information processing apparatus, information processing system, and program | |
| JP2015097080A (en) | Image forming apparatus management apparatus and management program | |
| JP3933018B2 (en) | Printer and information processing apparatus | |
| EP1816781A1 (en) | Network terminal device, and timestamp correcting method of the same | |
| JP2013015417A (en) | Electronic apparatus, current time calibration method and program | |
| JP2003248076A (en) | Image forming apparatus | |
| JP4952406B2 (en) | Time correction method, microcomputer internal clock, electronic control unit | |
| JP6158621B2 (en) | Image forming apparatus and image forming method | |
| JP4703102B2 (en) | Time stamp system and method and program for correcting time progress | |
| KR20180062235A (en) | Image forming apparatus, electronic device and method thereof for minimizing idling time of image forming apparatus caused by early warm-up | |
| JP2004287686A (en) | Time appointment processing device, method and system | |
| JP2012013548A (en) | Image forming device | |
| JP2017199062A (en) | Operation input device, image forming apparatus, and operation input method | |
| CN108398877A (en) | The control method of time set and image forming apparatus | |
| JP5153497B2 (en) | Clock device, electronic equipment | |
| JP2022105855A (en) | Image forming device and program | |
| JP2007279781A (en) | Log management device, log management system, log management method and program thereof | |
| JP2020066191A (en) | Electronic apparatus, method for recording log electronic apparatus, and program | |
| JP2002341072A (en) | Time correction method | |
| JP2022105810A (en) | Image forming device and program | |
| JP2011035696A (en) | Slave terminal, and method for correcting clock of the same |
Legal Events
| Date | Code | Title | Description |
|---|---|---|---|
| AS | Assignment |
Owner name: BROTHER KOGYO KABUSHIKI KAISHA,JAPAN Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:SHIBATA, HIROSHI;REEL/FRAME:023281/0677 Effective date: 20090907 Owner name: BROTHER KOGYO KABUSHIKI KAISHA, JAPAN Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:SHIBATA, HIROSHI;REEL/FRAME:023281/0677 Effective date: 20090907 |
|
| STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
| FPAY | Fee payment |
Year of fee payment: 4 |
|
| MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY Year of fee payment: 8 |
|
| MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 12TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1553); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY Year of fee payment: 12 |