EP1950629A1 - Image forming apparatus adapted for counting images formed by the apparatus - Google Patents

Image forming apparatus adapted for counting images formed by the apparatus Download PDF

Info

Publication number
EP1950629A1
EP1950629A1 EP08100628A EP08100628A EP1950629A1 EP 1950629 A1 EP1950629 A1 EP 1950629A1 EP 08100628 A EP08100628 A EP 08100628A EP 08100628 A EP08100628 A EP 08100628A EP 1950629 A1 EP1950629 A1 EP 1950629A1
Authority
EP
European Patent Office
Prior art keywords
count value
counter
count values
memory
count
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
EP08100628A
Other languages
German (de)
French (fr)
Other versions
EP1950629B1 (en
Inventor
Antonius C.M. Van Buren
Alexander H. Venema
Johannes T.M. Neggers
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 Production Printing Netherlands BV
Original Assignee
Oce Technologies BV
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 Oce Technologies BV filed Critical Oce Technologies BV
Priority to EP08100628A priority Critical patent/EP1950629B1/en
Publication of EP1950629A1 publication Critical patent/EP1950629A1/en
Application granted granted Critical
Publication of EP1950629B1 publication Critical patent/EP1950629B1/en
Not-in-force legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G03PHOTOGRAPHY; CINEMATOGRAPHY; ANALOGOUS TECHNIQUES USING WAVES OTHER THAN OPTICAL WAVES; ELECTROGRAPHY; HOLOGRAPHY
    • G03GELECTROGRAPHY; ELECTROPHOTOGRAPHY; MAGNETOGRAPHY
    • G03G21/00Arrangements not provided for by groups G03G13/00 - G03G19/00, e.g. cleaning, elimination of residual charge
    • G03G21/02Counting the number of copies; Billing

Definitions

  • the invention relates to an image forming apparatus, e. g. a copier or printer, implementing a method for counting the number of "clicks", i. e. the number copies that have been made, as specified in the preamble of claim 1.
  • US 4 774 544 discloses an image forming apparatus wherein the "clicks" are counted by a CPU of the machine control which comprises a non-volatile memory.
  • An EEPROM Electrical Erasable Programmable Read Only Memory
  • An EEPROM is provided as a non-volatile memory for saving the count values to make them persistent during those times when the power supply for the CPU is turned down.
  • the contents of an EEPROM can be read as often as desired, but can be erased and re-written only a limited number of times.
  • this EEPROM is subdivided into a plurality of memory areas each of which can store a complete count value, so that the storage capacity of the EEPROM is multiplied.
  • the new count value is written in one of the memory areas of the EEPROM, and when the number of erase and write cycles of that memory area becomes exhausted, the future count values will be written into another memory area.
  • EP-A-0 412 039 , US 5 568 626 and US 5 450 460 disclose other counting methods dealing with the problem of the limited number of write cycles of an EEPROM.
  • US-A-4 665 497 describes an odometer wherein a travelled distance is counted in a volatile counter, and certain increments of that distance, e. g. 100 m, are saved in a non-volatile memory having a plurality of memory areas. Another count value is saved when the power is switched off. When power is switched on again, the counter is initialized with the maximum of the count values read from the memory areas.
  • the counting system as a whole will be robust against events of damage or destruction even if some of the EEPROM's are affected.
  • a write procedure in the non-volatile memory will not be required for each event that is to be counted, but instead, such a write procedure will be required only every M-th count, so that, for a given storage capacity of the non-volatile memory, the member of counts that can be stored persistently is multiplied by M.
  • the count value in the volatile counter will get lost, the count value will be saved in the non-volatile memory and will later be used for re-initialising the volatile counter with that count value when the apparatus passes again into the operative mode.
  • the method according to the invention is capable of keeping track of the exact count value.
  • an unexpected power shutdown occurs, e. g. because of an error, there will be no time to save the current count value before the contents of the volatile counter get lost, and the count value that is stored persistently will then be the count value that has been saved last time when an integral multiple of M had been reached.
  • the method according to the invention will lead to a loss of up to M counts in the worst case.
  • the method wherein, in a cycle of N consecutive saving steps each memory area is written once, comprises a step of checking the validity of the count values stored in the non-volatile memory by checking whether the difference between two of the count values in the memory areas (0, 1, 2, 3) is not larger than M * N.
  • the N memory areas of the non-volatile memory will always store the N count values that have been saved in the last N save operations, and the difference between any two of these count values will always be smaller than N*M, if all count values have been saved correctly.
  • the condition that the difference between any pair of count values that are stored in the non-volatile memory must be smaller than N*M provides a simple criterion for checking the validity of these count values. In other words, if this criterion is not met for a specific pair of count values, it must be concluded that one of the two count values is invalid, e. g. because of an error that has occurred during the write procedure.
  • the step of step of checking the validity includes a step of identifying valid count values on the basis of the criterion that the difference between any two of the valid count values is not larger than N * M, and identifying an invalid count value on the basis of the criterion that the difference between that count value and any of the valid count values is larger than N * M. Since, normally, an error occurring during the write procedure will corrupt only one of the N count values, all pairs of count values that do not involve the one corrupted value will still fulfill the above criterion, so that it is even possible to identify the invalid one among the N count values.
  • step (c) it is possible to identify a memory area of the non-volatile memory that has become defective. Then, it is possible to automatically continue with a modified counting procedure which leaves out the defective memory area (with M being changed to M-1).
  • the method according to the invention is also robust in the sense that it tolerates a failure of one or more of the N memory areas. So the system will remain robust against events of damage or failure as long as at least two EEPROM's are operating properly.
  • the step of checking the validity is included in the step (a), and the initialisation of the counter (109) is based only on the maximum of the valid count values.
  • step (c) the count value is saved in the memory area that has produced the count value with which the counter (109) has been initialised.
  • the first count value to be saved after an increment of M counts may be written into any of the N memory areas of the non-volatile memory. In a preferred embodiment, however, this count value is written into the memory area that has shown the largest count value in the initialisation step.
  • an apparatus comprises more than one counter, e. g. counters for separately counting sheets of different formats and/or for distinguishing between simplex and duplex copies
  • the above method may be performed individually for each of these counters which will then have a suitable number of memory areas in the non-volatile memory associated therewith. Then, it will also be possible to count and save also the total number of copies that have been made, irrespective of the format or type (simplex or duplex), and another validity check may be made by comparing the sum of the count values of the individual counters to the total count value.
  • An image forming apparatus implementing the above method is claimed in the independent apparatus claim.
  • the EEPROM's are distributed over various locations within the apparatus. This will ameliorate the robustness against failures and damages.
  • the control system of the image forming apparatus may further comprise a counting control module that manages a local user interface (LUI) and/or networking with a remote accounting facility, so that the actual count values may at any time be called-up from the remote facility for billing purposes and/or may be viewed by a local user.
  • this control module has access to a hard disk device which will serve as a second non-volatile memory for the count values, thereby to provide more redundancy.
  • a hard disk device may be subject to damage and data loss, it is preferable that the "non-volatile memory" in the meaning of this invention is in the first place formed by EEPROM's.
  • the control unit and the hard disk may act as a server for making the count values available for the local user and the remote facility, even in periods in which the apparatus is in the non-operative mode and the power supply for the embedded software is cut off. If a reset of the control module becomes necessary, updated and correct count values may be downloaded from the EEPROM's.
  • Fig. 1 shows a block diagram of an image forming apparatus 101 which will briefly be called “printer” hereinafter, although the apparatus may also be a copier, e. g. a digital copier, or a multi-purpose copier/printer combining the functions of scanning, copying and printing. Since the general construction and function of such an image forming apparatus are known in the art, they will not be described herein, and the printer 101 has only been shown as a single block in Fig. 1 . Likewise, Fig. 1 shows only those parts that are relevant to explain the present invention.
  • the control system 102 of the printer 101 comprises a Local User interface (LUI) 103, a network interface 104 for connection to a remote accounting facility (not shown), a hard disk device 105, a counting control module 106 connected with a volatile storage location 107 and a non-volatile memory 108.
  • Hardware components making up the control system may be distributed over various locations in the apparatus.
  • Volatile storage location 107 is provided with four counters 109 each of which has a volatile memory (of e. g. four byte) for storing a current count value for the number of sheets that has been printed with the printer 101.
  • each counter 109 receives a count signal via the counting control module from a fuse unit 110 of the printer 101 each time an image has been fused on a copy sheet.
  • the four counters 109 serve for counting small format simplex sheets, small format duplex sheets, large format simplex sheets and large format duplex sheets, respectively, on which an image has been fused on one side (simplex) or both sides (duplex) in the fuse unit 110.
  • the storage location 107 may further comprise an additional counter (not shown) for counting the total number of sheets, which should always correspond to the sum of the count values of the counters 109.
  • a non-volatile memory 108 which is specifically dedicated the purpose of storing the count values of the counters 109 is formed here by a plurality of EEPROM's 111. Each EEPROM provides four 4-byte memory areas, one for each of the counters 109.
  • a 4-byte memory area is capable of storing a count value that may be larger than 750 million counts, which is more than enough for counting all the copies made during the lifetime of the printer 101.
  • a count value stored in one of the memory areas is to be replaced by a new count value, the corresponding memory area of the EEPROM has to be erased, so that the new contents can be written therein.
  • the lifetime of state of the art EEPROM's is limited to about one million erase and write cycles. Thus, if each count signal issued by the fuse unit 110 would be counted on the EEPROM's 111, the lifetime of the EEPROM's would expire long before the printer 101 reaches the end of its life.
  • each of the four counters 109 in the volatile storage area 107 cooperates with a total of four EEPROM's 111.
  • this 4-fold storage capacity would be far to little to store each individual count in the EEPROM'Ss
  • the hard disk device 105 storing the count values that are updated once per minute is also a non-volatile memory, it will be understood, that, if these count values were stored only on the hard disk device 105, they would be lost and could no longer be billed for in case of a crash of the hard disk device 105.
  • the non-volatile memory formed by the EEPROM's 111 provides a storage facility that will be safer and more robust.
  • the first row (a) in Fig. 2 illustrates a condition in which the embedded software is initialised, i.e. when the printer 101 passes from the sleep mode to the operative mode.
  • the last count value that had been reached before the printer went into the sleep mode was 892 and is stored in area 2 in this example.
  • the row (b) shows the situation 13 clicks later, when the counter has counted up to 905. It can be seen that the values in the memory areas are not changed, i. e. no save operation has been performed.
  • the counter has reached 972, which is after an increment of 80 from 892, and this triggers the next one of the periodic save operations.
  • the count value 972 is saved in the memory area 2, i. e. the one from which the last (highest) count value 892 had been read.
  • the row (d) shows the situation yet another 80 clicks later, when the count value in the counter has reached 1052 and the next periodic save operation is performed. As can be seen, this count value 1052 is stored in the next memory area 3, replacing the value 720 that had previously been stored in that area.
  • the row (e) illustrates the situation when the printer passes again into the sleep mode while a count value of 1167 has been reached in the counter 109.
  • the count values 1052 and 1132 have been saved in the areas 3 and 0 in the periodic save operations.
  • the current count value 1167 is saved in memory area 1.
  • the counter 109 will be initialised with the value of 1167 stored in area 1, i. e. with the maximum of the four count values stored in the memory areas.
  • Row (f) illustrates a situation in which an unexpected power shutdown has occurred when the count value in the counter 109 had reached 1679.
  • This unexpected power shutdown may have occurred because of an error, e. g. because the user has turned down the printer by pressing an emergency button or because of a breakdown of the line power.
  • the value 1600 had been stored in memory area 0.
  • the next periodic save operation would have taken place at a count value of 1680, and this value would have been saved in area 1.
  • this save operation could not be reached because the power shutdown occurred already at 1679.
  • the counting control module has attempted to save this value of 1679 in the memory area 1, but the save operation has failed because of power shortage. Due to this failure, a senseless or random value 19631 has been stored in memory area 1.
  • the row (g) illustrates the situation when the printer 101 passes again into the operative mode after the unexpected power shutdown mentioned in conjunction with row (f).
  • the largest of the count values stored in the memories areas 0-3 is the value 19631 stored in area 1.
  • the counting control module finds that the value of 19631 can not be valid and initialises with the next largest values.
  • the erroneous count value stored in area 1 is randomly selected from among the possible count values which range from 0 to 750 million, so that there is only a negligible probability that this count value accidentally meets the above difference criterion, i. e. happens to fall within the interval between 1200 (1600 - 400 ) and 1760 (1360 + 400).
  • the row (h) illustrates the situation that is reached another 160 clicks later.
  • the count value in the counter (which is still 79 counts too small) has reached 1760.
  • this count value has again been stored in the memory area 0 form which the value of 1600 for initialisation had been read, as was described above.
  • the erroneous value in area 1 is overwritten with 1760, so that all traces of the error are removed.
  • the validity check and (approximate) error correction procedure described above does not depend upon the specific type of error that has caused the wrong storage value in one or more of the memory areas. For example, this procedure will also be effective if a wrong result is stored in one of the memory areas because the corresponding EEPROM has reached the end of its lifetime. Since the five memory areas associated with an individual counter 109 are formed by or located on different EEPROM's, the failure of one EEPROM will not affect the results stored in the other EEPROM's.
  • a normal user will of course not have the possibility to reset the EEPROM's.
  • authorised personnel e. g. a service engineer, may have appropriate tools for resetting the EEPROM's, for example in a case that the printer 101 is refurbished and thus has a "second life".
  • the lifetimes of the EEPROM's will be sufficient for a second or even a third life of the printer without exceeding the maximum number of erase/write cycles.
  • Fig. 3 is a flow diagram for an initialising routine that will be performed each time the printer 101 passes from the sleep mode to the operative mode.
  • the count values C i are read from the four memory areas 0 -3.
  • Step S2 is the validity check, wherein each of the count values C i is compared to each of the other three count values C j , to check whether their difference is smaller than 320.
  • a count value C i is considered to be valid if there exists at least one other count value C j for which the difference criterion is met.
  • the system would still be operative if three of the five EEPROM's are defective.
  • a subsequent step S3 searches for the maximum C among the valid count values C i and stores an index k which points to the memory area in which the highest count value had been stored. Then, in step S4, the counter 109 is initialised with the maximum C found in step S3, and the routine passes on to the count procedure that is illustrated in Fig. 4 .
  • step S5 it is checked whether a shutdown condition is met, i. e. whether a command for starting a regular shutdown procedure has occurred, so that the printer will pass into the sleep mode or will be switched off completely.
  • a command for entering into the sleep mode may for example be generated automatically when the printer has not been used for a predetermined time interval.
  • step S6 If no shutdown condition is met, it is checked in step S6 whether a new click has occurred, i. e. whether a count signal has been received from the fuse unit 110.
  • the steps S5 and S6 are repeated cyclically as long as the printer remains in the operative state and no new click occurs.
  • the loop is left via step S7, where the previous count value C in the volatile memory of the counter 109 is increased by one.
  • step S8 it is checked in step S8 whether the count value has been incremented in step S7 with a multiple of 80. If this is not the case, the routine loops back to step S5.
  • step S9 this count value is written into the EEPROM memory area with the index k (which was initialised in step S3), and the former value of k is replaced by (k + 1) mod3. This assures the cyclic switching of the memory areas 0 - 3 to which the count values are written, as was described in conjunction with Fig. 2 .
  • step S5 the routine loops back to step S5 via step S10, and the count procedure is continued.
  • step S5 If a shutdown condition is detected in step S5, the routine branches directly to step S9 to store the current count value, as in row (e) in Fig. 2 . Then, the procedure is ended via step S10, and it will be only then that the shutdown procedure leads to the power supply for the embedded software being cut off. Thus, under normal conditions, it is assured that the save operation will be performed correctly.
  • step S8 will then check the condition "has the counter reached a value that is a multiple of 80?". If yes the method proceeds with step S9, if no the method returns to step S5.
  • Row (h) represents a typical configuration in which the differences between all the count values stored in the memory areas 0-3 are multiples of 80. It is an advantage of this embodiment that the differences between all count values are multiples of 80. This condition must always be fulfilled if the number of counts that has occurred since the last power start-up of the embedded software becomes larger than 320. This can be used as a criterion that is easy to check and therefore permits a simple and fast validity check that may replace a more complex checksum or other validity check procedure.
  • the embedded software may not attempt to save a current count value if an unexpected shutdown occurs. Then, unlike the example illustrated in row (f) in Fig. 2 , the contents of the pertinent memory area 1 would be left as it is (at1360), but in the next initialisation step (row (g)) the value 1600 would still be highest valid count value, and the further procedure would be the same as in row (h). The only difference would be, that it would not be possible to conclude from the invalidity of at least one count value that a loss of up to 80 counts has occurred. Of course, such a condition which implies a possible loss of counts may be detected by other means, as is well known in the art. A situation comparable to the one shown in rows (f) and (g) in Fig. 2 may however occur when the pertinent EEPROM is defective or when the power supply happens to be cut off in the very moment in which the save operation (step S9) is performed.
  • step S2 in Fig. 3 may be extended to include a procedure for identifying the memory area that has produced an invalid count value, and this information may be passed on to the control module 106 where the error may be recorded in a log file.
  • the control module may disable that EEPROM or memory area and continue with a modified count procedure utilising only the remaining, non-defective memory areas.
  • the control module 106 may further be used for performing additional checks. For example, if the printer has a maximum production rate of 180 copies per minute (summed over all sheet formats), then the difference between the last count value stored in the hard disk device 105 for a specific counter 109 and the next update for that counter cannot be larger than180, since the count values are updated in the control module 106 once per minute. Thus, if an unreasonably large difference is detected or if the count value appears to have decreased, this is an indication that an error has occurred in the counting system. If the printer has been in the sleep mode in the interval between the last and the last but one update, it is likely that the error has occurred in the EEPROM write procedure or the initialisation procedure. Such events may be recorded on the log file and/or may cause the control module 106 to send an error message to the accounting facility via the network interface 104.

Abstract

A method for counting events with a volatile counter (109) and a non-volatile electronic memory comprising a number N of memory areas (111), in an apparatus (101) having an operative mode and a non-operative mode, comprising the steps of:
a) counting events with the volatile counter (109),
b) when the count value has been incremented by a predetermined number M or when the apparatus (101) passes into the non-operative mode, saving the count value to one of the memory areas, with cycling switching of the memory area into which the count value is written; and
c) when the apparatus (101) passes into the operative mode, initialising the counter (109) with the maximum of the count values stored in the N memory areas.

Description

  • The invention relates to an image forming apparatus, e. g. a copier or printer, implementing a method for counting the number of "clicks", i. e. the number copies that have been made, as specified in the preamble of claim 1.
  • In image forming apparatuses such as printers, copiers and multipurpose reproduction devices, it is frequently required to count the number of hard copies that have been made, e. g. for the purpose of determining suitable maintenance intervals, or, more importantly, for billing purposes. In conventional apparatus, mechanical counters are used for that purpose because such counters are known to be very robust and reliable. In particular, mechanical counters will retain their count values even in case of an unexpected power breakdown of the machine. On the other hand, since mechanical counters are relatively expensive, it would be desirable to replace them with electronic counters while preserving a comparable level of robustness.
  • US 4 774 544 discloses an image forming apparatus wherein the "clicks" are counted by a CPU of the machine control which comprises a non-volatile memory. An EEPROM (Electrically Erasable Programmable Read Only Memory) is provided as a non-volatile memory for saving the count values to make them persistent during those times when the power supply for the CPU is turned down. The contents of an EEPROM can be read as often as desired, but can be erased and re-written only a limited number of times. Since this number is significantly smaller than the number of copies that is expected to be made and to be counted during the total lifetime of the image forming apparatus, this EEPROM is subdivided into a plurality of memory areas each of which can store a complete count value, so that the storage capacity of the EEPROM is multiplied. In each time when a "click" is counted, the new count value is written in one of the memory areas of the EEPROM, and when the number of erase and write cycles of that memory area becomes exhausted, the future count values will be written into another memory area.
  • EP-A-0 412 039 , US 5 568 626 and US 5 450 460 disclose other counting methods dealing with the problem of the limited number of write cycles of an EEPROM.
  • However, all these methods require a considerable amount of storage capacity of the non-volatile memory, which increases the costs for these memory devices. Moreover, these known methods address the problem that the count values that are stored in the non-volatile memory may become corrupted only to a limited extent. E.g. when a machine error leads to an unexpected shutdown or when a power failure of the machine control system takes place at the very moment when new data are written into the EEPROM. In such a case, the write procedure will be disturbed and the value that will be written into the memory area of the EEPROM becomes unpredictable. A similar problem will occur when an EEPROM or a specific memory area thereof reaches the end of its lifetime (earlier than expected).
  • US-A-4 665 497 describes an odometer wherein a travelled distance is counted in a volatile counter, and certain increments of that distance, e. g. 100 m, are saved in a non-volatile memory having a plurality of memory areas. Another count value is saved when the power is switched off. When power is switched on again, the counter is initialized with the maximum of the count values read from the memory areas.
  • It is an object of the invention to provide an apparatus according to the preamble of claim 1 which permits to reduce the costs for non-volatile memory devices and nevertheless is robust against various types of failure.
  • According to the invention, this object is achieved by an appartus as specified in claim 1.
  • Since the various memory areas of the non-volatile memory are located in distinct EEPROM's, the counting system as a whole will be robust against events of damage or destruction even if some of the EEPROM's are affected.
  • Further, according to this method, a write procedure in the non-volatile memory will not be required for each event that is to be counted, but instead, such a write procedure will be required only every M-th count, so that, for a given storage capacity of the non-volatile memory, the member of counts that can be stored persistently is multiplied by M. In case of a regular shutdown of the apparatus, i. e. when the apparatus passes from the operative mode into the non-operative mode, in which case the count value in the volatile counter will get lost, the count value will be saved in the non-volatile memory and will later be used for re-initialising the volatile counter with that count value when the apparatus passes again into the operative mode. Thus, in absence of any error events, the method according to the invention is capable of keeping track of the exact count value. In the exceptional case that an unexpected power shutdown occurs, e. g. because of an error, there will be no time to save the current count value before the contents of the volatile counter get lost, and the count value that is stored persistently will then be the count value that has been saved last time when an integral multiple of M had been reached. Thus, in such an error scenario, the method according to the invention will lead to a loss of up to M counts in the worst case. However, such a loss of a limited number of counts is acceptable because, if the number M has been selected appropriately, the commercial loss caused by the loss of at most M counts on the rare occasion of an error event is significantly smaller than the costs that would be required for providing sufficient storage capacity for persistently storing each individual count value.
  • In a next embodiment the method, wherein, in a cycle of N consecutive saving steps each memory area is written once, comprises a step of checking the validity of the count values stored in the non-volatile memory by checking whether the difference between two of the count values in the memory areas (0, 1, 2, 3) is not larger than M * N. As a consequence, the N memory areas of the non-volatile memory will always store the N count values that have been saved in the last N save operations, and the difference between any two of these count values will always be smaller than N*M, if all count values have been saved correctly. Thus, the condition that the difference between any pair of count values that are stored in the non-volatile memory must be smaller than N*M provides a simple criterion for checking the validity of these count values. In other words, if this criterion is not met for a specific pair of count values, it must be concluded that one of the two count values is invalid, e. g. because of an error that has occurred during the write procedure.
  • In a further embodiment, the step of step of checking the validity includes a step of identifying valid count values on the basis of the criterion that the difference between any two of the valid count values is not larger than N * M, and identifying an invalid count value on the basis of the criterion that the difference between that count value and any of the valid count values is larger than N * M. Since, normally, an error occurring during the write procedure will corrupt only one of the N count values, all pairs of count values that do not involve the one corrupted value will still fulfill the above criterion, so that it is even possible to identify the invalid one among the N count values. It will be clear that, by performing the method according to the invention, including the validity check in step (c), it is possible to identify a memory area of the non-volatile memory that has become defective. Then, it is possible to automatically continue with a modified counting procedure which leaves out the defective memory area (with M being changed to M-1). Thus, the method according to the invention is also robust in the sense that it tolerates a failure of one or more of the N memory areas. So the system will remain robust against events of damage or failure as long as at least two EEPROM's are operating properly.
  • In a next embodiment the step of checking the validity is included in the step (a), and the initialisation of the counter (109) is based only on the maximum of the valid count values. Thus, when the apparatus passes to the operative mode again, it will in most cases be possible to initialise the counter with the correct count value, and even in the case that the corrupted count value happens to be the one that had been stored last, the worst-case loss of counts will not be larger than M.
  • In a further embodiment, in step (c), the count value is saved in the memory area that has produced the count value with which the counter (109) has been initialised. In principle, when the apparatus has passed into the operative mode and the counting procedure has been resumed, the first count value to be saved after an increment of M counts may be written into any of the N memory areas of the non-volatile memory. In a preferred embodiment, however, this count value is written into the memory area that has shown the largest count value in the initialisation step.
  • If an apparatus according to the invention comprises more than one counter, e. g. counters for separately counting sheets of different formats and/or for distinguishing between simplex and duplex copies, the above method may be performed individually for each of these counters which will then have a suitable number of memory areas in the non-volatile memory associated therewith. Then, it will also be possible to count and save also the total number of copies that have been made, irrespective of the format or type (simplex or duplex), and another validity check may be made by comparing the sum of the count values of the individual counters to the total count value.
  • An image forming apparatus implementing the above method is claimed in the independent apparatus claim. Preferably the EEPROM's are distributed over various locations within the apparatus. This will ameliorate the robustness against failures and damages.
  • The control system of the image forming apparatus may further comprise a counting control module that manages a local user interface (LUI) and/or networking with a remote accounting facility, so that the actual count values may at any time be called-up from the remote facility for billing purposes and/or may be viewed by a local user. Preferably, this control module has access to a hard disk device which will serve as a second non-volatile memory for the count values, thereby to provide more redundancy. However, since a hard disk device may be subject to damage and data loss, it is preferable that the "non-volatile memory" in the meaning of this invention is in the first place formed by EEPROM's. On the other hand, if the count values are updated on the hard disk device on a regular basis (per counts or per time), the control unit and the hard disk may act as a server for making the count values available for the local user and the remote facility, even in periods in which the apparatus is in the non-operative mode and the power supply for the embedded software is cut off. If a reset of the control module becomes necessary, updated and correct count values may be downloaded from the EEPROM's.
  • A preferred embodiment of the invention will now be explained in conjunction with the drawings, wherein:
  • Fig. 1
    is a block diagram of an image forming apparatus with a sheet counting system according to the invention;
    Fig. 2
    is a table illustrating several steps in a counting procedure according to the invention;
    Fig. 3
    is a flow diagram illustrating a procedure for initialising a counter in the system shown in Fig. 1; and
    Fig. 4
    is a flow diagram illustrating a counting procedure according to the invention.
  • Fig. 1 shows a block diagram of an image forming apparatus 101 which will briefly be called "printer" hereinafter, although the apparatus may also be a copier, e. g. a digital copier, or a multi-purpose copier/printer combining the functions of scanning, copying and printing. Since the general construction and function of such an image forming apparatus are known in the art, they will not be described herein, and the printer 101 has only been shown as a single block in Fig. 1. Likewise, Fig. 1 shows only those parts that are relevant to explain the present invention.
  • The control system 102 of the printer 101 comprises a Local User interface (LUI) 103, a network interface 104 for connection to a remote accounting facility (not shown), a hard disk device 105, a counting control module 106 connected with a volatile storage location 107 and a non-volatile memory 108. Hardware components making up the control system may be distributed over various locations in the apparatus. Volatile storage location 107 is provided with four counters 109 each of which has a volatile memory (of e. g. four byte) for storing a current count value for the number of sheets that has been printed with the printer 101. To this end, each counter 109 receives a count signal via the counting control module from a fuse unit 110 of the printer 101 each time an image has been fused on a copy sheet. The four counters 109 serve for counting small format simplex sheets, small format duplex sheets, large format simplex sheets and large format duplex sheets, respectively, on which an image has been fused on one side (simplex) or both sides (duplex) in the fuse unit 110. The storage location 107 may further comprise an additional counter (not shown) for counting the total number of sheets, which should always correspond to the sum of the count values of the counters 109.
  • When the printer passes to a sleep mode for reducing power consumption, only some parts of the control system 102 and the related peripheral devices (LUI 103, interface 104 and hard disk device 105) will be kept operative. As a consequence, the count values in the volatile memories of the counter 109 would get lost, if they were not saved to a non-volatile memory. Such a non-volatile memory 108 which is specifically dedicated the purpose of storing the count values of the counters 109 is formed here by a plurality of EEPROM's 111. Each EEPROM provides four 4-byte memory areas, one for each of the counters 109. A 4-byte memory area is capable of storing a count value that may be larger than 750 million counts, which is more than enough for counting all the copies made during the lifetime of the printer 101. When a count value stored in one of the memory areas is to be replaced by a new count value, the corresponding memory area of the EEPROM has to be erased, so that the new contents can be written therein. However, the lifetime of state of the art EEPROM's is limited to about one million erase and write cycles. Thus, if each count signal issued by the fuse unit 110 would be counted on the EEPROM's 111, the lifetime of the EEPROM's would expire long before the printer 101 reaches the end of its life.
  • It will be noted that each of the four counters 109 in the volatile storage area 107 cooperates with a total of four EEPROM's 111. However, even this 4-fold storage capacity would be far to little to store each individual count in the EEPROM'Ss
  • For that reason, the counting control module 23 is so configured that, as a general rule, it stores only every 80-th count value of the counters 109 in one of the storage area's associated with that counter of one of the four EEPROM's and evenly distributes the count values over the four EEPROM's. This will virtually multiply the lifetime of the EEPROM's by 80*5=400, resulting in a counting capacity of 400 million sheets per category (per counter), which will be more than the worst case throughput of the printer 101 in six years of usage.
  • The specific manner in which the count values of an individual counter 109 are stored in the corresponding four memory areas each formed by a distinct EEPROM 111 will be explained in detail as the description proceeds.
  • In order to make the count values of the counters 109 available on the user interface 103 and the network interface 104, updates of the count values of the counters 109 are made available at a frequency of 1/min, as long as the printer is in the operating mode. Further, the current count values will be stored on the hard disk device 105 every 2.5 s. Thus, the current count values can be viewed on the user interface 103 or read from the remote accounting facility via the network interface 104 even when the printer is in the sleep mode. Additionally, day counters can be made available that can be read and reset by the user by entering appropriate commands via the LUI 103.
  • Although the hard disk device 105 storing the count values that are updated once per minute is also a non-volatile memory, it will be understood, that, if these count values were stored only on the hard disk device 105, they would be lost and could no longer be billed for in case of a crash of the hard disk device 105. In this respect, the non-volatile memory formed by the EEPROM's 111 provides a storage facility that will be safer and more robust.
  • Examples of the count and save procedures performed by counting control module will now be described in conjunction with Fig. 2, wherein the first column represents the contents of one of the counters 109, and the second to fifth columns represent the contents of the corresponding memory areas of the EEPROM's 111. These memory areas are numerated as 0,...,3.
  • The first row (a) in Fig. 2 illustrates a condition in which the embedded software is initialised, i.e. when the printer 101 passes from the sleep mode to the operative mode.
  • The last count value that had been reached before the printer went into the sleep mode was 892 and is stored in area 2 in this example. The other memory areas 3, 0 and 1, in that order, show the last four count values that had been stored in the periodic save operations performed every 80 sheets. It can be seen that the increments between the values 720, 800, etc. stored in the areas 3, 0 and 1 is always equal to 80, whereas the last increment from 880 to 892 is smaller. The reason is that the value of 892 was written to the area 2 not in one of the periodic save operations, but in an extra save operation when the printer went into the sleep mode. Thus, the value 892 in area 2 is the largest of the five count values that have been stored, and the counter 109 is initialised with that value.
  • The row (b) shows the situation 13 clicks later, when the counter has counted up to 905. It can be seen that the values in the memory areas are not changed, i. e. no save operation has been performed.
  • In row (c), the counter has reached 972, which is after an increment of 80 from 892, and this triggers the next one of the periodic save operations. As can be seen, the count value 972 is saved in the memory area 2, i. e. the one from which the last (highest) count value 892 had been read.
  • The row (d) shows the situation yet another 80 clicks later, when the count value in the counter has reached 1052 and the next periodic save operation is performed. As can be seen, this count value 1052 is stored in the next memory area 3, replacing the value 720 that had previously been stored in that area.
  • The row (e) illustrates the situation when the printer passes again into the sleep mode while a count value of 1167 has been reached in the counter 109. In the meantime, the count values 1052 and 1132have been saved in the areas 3 and 0 in the periodic save operations. The current count value 1167 is saved in memory area 1. When the printer is switched into the operative mode again, the counter 109 will be initialised with the value of 1167 stored in area 1, i. e. with the maximum of the four count values stored in the memory areas.
  • Row (f) illustrates a situation in which an unexpected power shutdown has occurred when the count value in the counter 109 had reached 1679. This unexpected power shutdown may have occurred because of an error, e. g. because the user has turned down the printer by pressing an emergency button or because of a breakdown of the line power. In the last periodic save operation, the value 1600 had been stored in memory area 0. The next periodic save operation would have taken place at a count value of 1680, and this value would have been saved in area 1. However, this save operation could not be reached because the power shutdown occurred already at 1679. As a result of the power shutdown, the counting control module has attempted to save this value of 1679 in the memory area 1, but the save operation has failed because of power shortage. Due to this failure, a senseless or random value 19631 has been stored in memory area 1.
  • The row (g) illustrates the situation when the printer 101 passes again into the operative mode after the unexpected power shutdown mentioned in conjunction with row (f). In this situation, the largest of the count values stored in the memories areas 0-3 is the value 19631 stored in area 1. However, by comparing this value to the count values stored in the other three memory areas, the counting control module finds that the value of 19631 can not be valid and initialises with the next largest values.
  • If the count and save operations are performed without any errors, as in rows (a)-(e), the difference between the count values stored in any two of the memory areas 0-3 must always be smaller than 400. This condition is not met in row (g), which shows that an error must have occurred.
  • It should be observed here that the erroneous count value stored in area 1 is randomly selected from among the possible count values which range from 0 to 750 million, so that there is only a negligible probability that this count value accidentally meets the above difference criterion, i. e. happens to fall within the interval between 1200 (1600 - 400 ) and 1760 (1360 + 400).
  • It can further be detected that in row (g) the values stored in the memory areas 2, 3 and 0 meet the difference criterion, and the value 19631 in area 1 is the only one that does not fit. It may therefore be concluded that only the value in area 1 is invalid, whereas the values stored in the other memory areas are valid. Thus, when searching for the maximum of the stored count values for initialising the counter 109, the memory area 1 will be excluded, so that the counter will be initialised with 1600. Since the "true" count value that was reached before the power shutdown was 1679 (row (f)), this means that 79 counts are lost and can not be recovered. However, thanks to the procedure described above, such a loss of counts in case of an error will never be larger than 80. Thus, assuming that a fee of 0,01 Euro is charged per copy, the financial damage that may be caused by such an error event will be limited to 80 Cents.
  • The row (h) illustrates the situation that is reached another 160 clicks later. The count value in the counter (which is still 79 counts too small) has reached 1760. In the periodic save operation that has taken place at 1680, this count value has again been stored in the memory area 0 form which the value of 1600 for initialisation had been read, as was described above. In the next periodic save operation occurring at 1760, the erroneous value in area 1 is overwritten with 1760, so that all traces of the error are removed.
  • In order to avoid errors of the type illustrated in row (f), it would be possible to adapt a hardware configuration that maintains a sufficient power voltage level for correctly saving the count value to the EEPROM until the write operation is completed, even in case of an unexpected power shutdown. In most cases, however, such a hardware configuration will not be necessary because the loss of only 80 counts in the worst case will be acceptable.
  • It will be appreciated that the validity check and (approximate) error correction procedure described above does not depend upon the specific type of error that has caused the wrong storage value in one or more of the memory areas. For example, this procedure will also be effective if a wrong result is stored in one of the memory areas because the corresponding EEPROM has reached the end of its lifetime. Since the five memory areas associated with an individual counter 109 are formed by or located on different EEPROM's, the failure of one EEPROM will not affect the results stored in the other EEPROM's.
  • In order to prevent fraud, a normal user will of course not have the possibility to reset the EEPROM's. However, authorised personnel, e. g. a service engineer, may have appropriate tools for resetting the EEPROM's, for example in a case that the printer 101 is refurbished and thus has a "second life". Considering normal usage of the printer 101, the lifetimes of the EEPROM's will be sufficient for a second or even a third life of the printer without exceeding the maximum number of erase/write cycles.
  • The procedures performed by the embedded software in conjunction with initialising the counter, counting the clicks and saving the count results will now be described in detail by reference to Figs. 3 and 4.
  • Fig. 3 is a flow diagram for an initialising routine that will be performed each time the printer 101 passes from the sleep mode to the operative mode. In step S1, the count values Ci are read from the four memory areas 0 -3. Step S2 is the validity check, wherein each of the count values Ci is compared to each of the other three count values Cj, to check whether their difference is smaller than 320. In the example shown, a count value Ci is considered to be valid if there exists at least one other count value Cj for which the difference criterion is met. Thus, if the total number M of memory areas is 4, the system would still be operative if three of the five EEPROM's are defective.
  • A subsequent step S3 searches for the maximum C among the valid count values Ci and stores an index k which points to the memory area in which the highest count value had been stored. Then, in step S4, the counter 109 is initialised with the maximum C found in step S3, and the routine passes on to the count procedure that is illustrated in Fig. 4.
  • In step S5, it is checked whether a shutdown condition is met, i. e. whether a command for starting a regular shutdown procedure has occurred, so that the printer will pass into the sleep mode or will be switched off completely. A command for entering into the sleep mode may for example be generated automatically when the printer has not been used for a predetermined time interval.
  • If no shutdown condition is met, it is checked in step S6 whether a new click has occurred, i. e. whether a count signal has been received from the fuse unit 110. The steps S5 and S6 are repeated cyclically as long as the printer remains in the operative state and no new click occurs. In case of a new click, the loop is left via step S7, where the previous count value C in the volatile memory of the counter 109 is increased by one. Then, it is checked in step S8 whether the count value has been incremented in step S7 with a multiple of 80. If this is not the case, the routine loops back to step S5.
  • On the other hand, if the count value has been incremented with a multiple of 80, the routine branches to step S9 where this count value is written into the EEPROM memory area with the index k (which was initialised in step S3), and the former value of k is replaced by (k + 1) mod3. This assures the cyclic switching of the memory areas 0 - 3 to which the count values are written, as was described in conjunction with Fig. 2.
  • Then, if no shutdown condition was met in step S5, the routine loops back to step S5 via step S10, and the count procedure is continued.
  • If a shutdown condition is detected in step S5, the routine branches directly to step S9 to store the current count value, as in row (e) in Fig. 2. Then, the procedure is ended via step S10, and it will be only then that the shutdown procedure leads to the power supply for the embedded software being cut off. Thus, under normal conditions, it is assured that the save operation will be performed correctly.
  • As an alternative for the embodiment shown in Figure 4 it is proposed to save count values at multiples of 80. In Figure 4 step S8 will then check the condition "has the counter reached a value that is a multiple of 80?". If yes the method proceeds with step S9, if no the method returns to step S5. Row (h) represents a typical configuration in which the differences between all the count values stored in the memory areas 0-3 are multiples of 80. It is an advantage of this embodiment that the differences between all count values are multiples of 80. This condition must always be fulfilled if the number of counts that has occurred since the last power start-up of the embedded software becomes larger than 320. This can be used as a criterion that is easy to check and therefore permits a simple and fast validity check that may replace a more complex checksum or other validity check procedure.
  • In continuation now of the embodiment shown in Fig. 4, the embedded software may not attempt to save a current count value if an unexpected shutdown occurs. Then, unlike the example illustrated in row (f) in Fig. 2, the contents of the pertinent memory area 1 would be left as it is (at1360), but in the next initialisation step (row (g)) the value 1600 would still be highest valid count value, and the further procedure would be the same as in row (h). The only difference would be, that it would not be possible to conclude from the invalidity of at least one count value that a loss of up to 80 counts has occurred. Of course, such a condition which implies a possible loss of counts may be detected by other means, as is well known in the art. A situation comparable to the one shown in rows (f) and (g) in Fig. 2 may however occur when the pertinent EEPROM is defective or when the power supply happens to be cut off in the very moment in which the save operation (step S9) is performed.
  • The validity check performed in step S2 in Fig. 3 may be extended to include a procedure for identifying the memory area that has produced an invalid count value, and this information may be passed on to the control module 106 where the error may be recorded in a log file. Thus, if a specific EEPROM malfunctions and produces invalid results repeatedly, this may be detected in the control module 106, and the control module may disable that EEPROM or memory area and continue with a modified count procedure utilising only the remaining, non-defective memory areas.
  • The control module 106 may further be used for performing additional checks. For example, if the printer has a maximum production rate of 180 copies per minute (summed over all sheet formats), then the difference between the last count value stored in the hard disk device 105 for a specific counter 109 and the next update for that counter cannot be larger than180, since the count values are updated in the control module 106 once per minute. Thus, if an unreasonably large difference is detected or if the count value appears to have decreased, this is an indication that an error has occurred in the counting system. If the printer has been in the sleep mode in the interval between the last and the last but one update, it is likely that the error has occurred in the EEPROM write procedure or the initialisation procedure. Such events may be recorded on the log file and/or may cause the control module 106 to send an error message to the accounting facility via the network interface 104.
  • The behaviour of the system will now be illustrated in conjunction with a number of possible error scenarios.
  • As was explained already, in case of an uncontrolled shutdown of a running system, not more than 80 clicks will be lost in the worst case.
  • If a failure occurs in the intialization of the control system 102 and this control system has to be restarted, the count values stored in the counters 109 will be lost, and the count values that are shown on the LUI 103 immediately after restart will not be correct. However, the values stored in the EEPROM's 111 will serve as a backup, and the control module 106 will be updated with the correct count values after one minute of operation of the printer. In that case, no clicks will be lost.
  • In case of a hardware or software failure the count values in the volatile memories of the counters 109 will be made persistent. Thus, when a service technician has replaced defective parts and/or has reloaded the software for the control system, the correct count values will be written into the counters 109 in the first initialising procedure shown in Fig. 3, and no clicks will be lost.

Claims (8)

  1. An image forming apparatus (10) comprising a control system (12, 14) adapted to switch the apparatus from a non-operative mode to an operative mode and vice versa and including at least one volatile counter (30) and a non-volatile memory (34) with a number N of memory areas (0, 1, 2, 3) for each counter (30), each memory area being implemented as a separate EEPROM,
    characterized in that the control system is adapted to perform the following steps for counting a number of images formed by the apparatus (10):
    a) when the apparatus (10) passes into the operative mode, initialising the counter (30) with the maximum of the count values stored in the N memory areas;
    b) counting events with the volatile counter (30); and
    c) saving the count value to one of the memory areas each time when the count value has been incremented by a predetermined number M > 1 or when the apparatus (10) passes into the non-operative mode.
  2. The apparatus according to claim 1, wherein, in a cycle of N consecutive saving steps, each memory area is written once.
  3. The apparatus according to claim 2, wherein the control system is adapted to perform a step of checking the validity of the count values stored in the non-volatile memory (34) by checking whether the difference between two of the count values in the memory areas (0, 1, 2, 3) is not larger than M * N.
  4. The apparatus according to claim 3, wherein said step of checking the validity includes a step of identifying valid count values on the basis of the criterion that the difference between any two of the valid count values is not larger than N * M, and identifying an invalid count value on the basis of the criterion that the difference between that count value and any of the valid count values is larger than N * M.
  5. The apparatus according to claim 3 or 4, wherein said step of checking the validity is included in step (a), and the initialisation of the counter (30) is based only on the maximum of the valid count values.
  6. The apparatus according to any of the preceding claims, wherein, in step (c), the count value is saved in the memory area that has produced the count value with which the counter (30) has been initialised.
  7. The apparatus according to any of the preceding claims, wherein, each time a count value is saved in step (c) the memory area into which the count value is written is switched cyclically.
  8. The apparatus according to any of the preceding claims, wherein the non-volatile memory is incorporated in an embedded software architecture (12), and the memory areas of the non-volatile memory are distributed over various locations within the apparatus (10).
EP08100628A 2007-01-24 2008-01-18 Image forming apparatus adapted for counting images formed by the apparatus Not-in-force EP1950629B1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
EP08100628A EP1950629B1 (en) 2007-01-24 2008-01-18 Image forming apparatus adapted for counting images formed by the apparatus

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
EP07101082 2007-01-24
EP08100628A EP1950629B1 (en) 2007-01-24 2008-01-18 Image forming apparatus adapted for counting images formed by the apparatus

Publications (2)

Publication Number Publication Date
EP1950629A1 true EP1950629A1 (en) 2008-07-30
EP1950629B1 EP1950629B1 (en) 2011-07-20

Family

ID=39551666

Family Applications (1)

Application Number Title Priority Date Filing Date
EP08100628A Not-in-force EP1950629B1 (en) 2007-01-24 2008-01-18 Image forming apparatus adapted for counting images formed by the apparatus

Country Status (1)

Country Link
EP (1) EP1950629B1 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113302699A (en) * 2018-12-21 2021-08-24 美光科技公司 Monotonic counter in memory

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4665497A (en) 1983-04-22 1987-05-12 Hitachi, Ltd. Electronic odometer
US4774544A (en) 1986-02-28 1988-09-27 Casio Computer Co., Ltd. Counter apparatus for an image forming apparatus for counting and managing the number of image forming operations
EP0412039A2 (en) 1989-08-03 1991-02-06 Lexmark International, Inc. Non-volatile memory usage
US5450460A (en) 1994-03-09 1995-09-12 National Semiconductor Corporation Non-volatile electronic counter with improved reliability and a substantitally increased maximum count
US5568626A (en) 1990-02-27 1996-10-22 Nec Corporation Method and system for rewriting data in a non-volatile memory a predetermined large number of times

Family Cites Families (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2001205867A (en) * 2000-01-28 2001-07-31 Canon Inc Storage device, method for processing stored data, and image-forming apparatus
DE10201553A1 (en) * 2001-09-10 2003-03-27 Philips Corp Intellectual Pty Arrangement storing counter state in non-volatile memory for e.g. battery operated access systems, employs three memory segments and value comparison algorithms

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4665497A (en) 1983-04-22 1987-05-12 Hitachi, Ltd. Electronic odometer
US4774544A (en) 1986-02-28 1988-09-27 Casio Computer Co., Ltd. Counter apparatus for an image forming apparatus for counting and managing the number of image forming operations
EP0412039A2 (en) 1989-08-03 1991-02-06 Lexmark International, Inc. Non-volatile memory usage
US5568626A (en) 1990-02-27 1996-10-22 Nec Corporation Method and system for rewriting data in a non-volatile memory a predetermined large number of times
US5450460A (en) 1994-03-09 1995-09-12 National Semiconductor Corporation Non-volatile electronic counter with improved reliability and a substantitally increased maximum count

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113302699A (en) * 2018-12-21 2021-08-24 美光科技公司 Monotonic counter in memory
CN113302699B (en) * 2018-12-21 2022-08-19 美光科技公司 Monotonic counter in memory
US11657877B2 (en) 2018-12-21 2023-05-23 Micron Technology, Inc. Monotonic counters in memories

Also Published As

Publication number Publication date
EP1950629B1 (en) 2011-07-20

Similar Documents

Publication Publication Date Title
EP0226205B1 (en) Method of relocating data in and extending life of a memory system
KR100383404B1 (en) Semiconductor memory device having error detection and correction
CN100380529C (en) Nonvolatile memory
US6535997B1 (en) Data integrity in smartcard transactions
US7809990B2 (en) Method and apparatus for monitoring failure of memory device, and computer product
US8027609B2 (en) Image forming apparatus for counting images formed by the apparatus
US6625703B2 (en) Verifying primary and backup copies of vital information for a processing system employing a pseudo-fixed reference identifier
US6516440B1 (en) Printer and a control method for saving data from volatile to nonvolatile memory in the printer
EP0821307B1 (en) Error indication for a storage system with removable media
JPH08511368A (en) Method for forming parity in RAID subsystem using non-volatile memory
JPH09274541A (en) Storage device, control method for the same, storage system and control method for the same
JP2008269105A (en) Storage controller and storage control method
US6421137B1 (en) Image forming apparatus
EP1950629B1 (en) Image forming apparatus adapted for counting images formed by the apparatus
JP2004152194A (en) Memory data protection method
EP1195682A2 (en) Status identifying apparatus and method, apparatus to be identified, and printing apparatus
US8308819B2 (en) Method for detecting the removal of a processing unit from a printed circuit board
US6773083B2 (en) Method and apparatus for non-volatile memory usage in an ink jet printer
JP6732234B2 (en) How to reset chips, container of chips and consumables
US20100169572A1 (en) Data storage method, apparatus and system for interrupted write recovery
US6385557B1 (en) Tracking the remaining useful life of a magnetic data storage tape
CN114201320B (en) System block upgrading method and device, readable storage medium and electronic equipment
CN111890805B (en) Memory chip, imaging box and imaging device
JP2001331382A (en) Method and device for managing nonvolatile memory
CN113296682B (en) Data reading and writing method for whole vehicle controller

Legal Events

Date Code Title Description
PUAI Public reference made under article 153(3) epc to a published international application that has entered the european phase

Free format text: ORIGINAL CODE: 0009012

AK Designated contracting states

Kind code of ref document: A1

Designated state(s): AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MT NL NO PL PT RO SE SI SK TR

AX Request for extension of the european patent

Extension state: AL BA MK RS

17P Request for examination filed

Effective date: 20090130

17Q First examination report despatched

Effective date: 20090306

AKX Designation fees paid

Designated state(s): AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MT NL NO PL PT RO SE SI SK TR

GRAP Despatch of communication of intention to grant a patent

Free format text: ORIGINAL CODE: EPIDOSNIGR1

GRAS Grant fee paid

Free format text: ORIGINAL CODE: EPIDOSNIGR3

GRAA (expected) grant

Free format text: ORIGINAL CODE: 0009210

AK Designated contracting states

Kind code of ref document: B1

Designated state(s): AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MT NL NO PL PT RO SE SI SK TR

REG Reference to a national code

Ref country code: GB

Ref legal event code: FG4D

REG Reference to a national code

Ref country code: CH

Ref legal event code: EP

REG Reference to a national code

Ref country code: DE

Ref legal event code: R096

Ref document number: 602008008326

Country of ref document: DE

Effective date: 20110915

REG Reference to a national code

Ref country code: NL

Ref legal event code: T3

REG Reference to a national code

Ref country code: AT

Ref legal event code: MK05

Ref document number: 517372

Country of ref document: AT

Kind code of ref document: T

Effective date: 20110720

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: IS

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20111120

Ref country code: NO

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20111020

Ref country code: LT

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20110720

Ref country code: BE

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20110720

Ref country code: FI

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20110720

Ref country code: HR

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20110720

Ref country code: PT

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20111121

Ref country code: SE

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20110720

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: PL

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20110720

Ref country code: AT

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20110720

Ref country code: SI

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20110720

Ref country code: GR

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20111021

Ref country code: CY

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20110720

Ref country code: LV

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20110720

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: SK

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20110720

Ref country code: CZ

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20110720

PLBE No opposition filed within time limit

Free format text: ORIGINAL CODE: 0009261

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: NO OPPOSITION FILED WITHIN TIME LIMIT

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: IT

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20110720

Ref country code: RO

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20110720

Ref country code: EE

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20110720

26N No opposition filed

Effective date: 20120423

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: DK

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20110720

REG Reference to a national code

Ref country code: DE

Ref legal event code: R097

Ref document number: 602008008326

Country of ref document: DE

Effective date: 20120423

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: MC

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20120131

REG Reference to a national code

Ref country code: CH

Ref legal event code: PL

REG Reference to a national code

Ref country code: IE

Ref legal event code: MM4A

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: LI

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20120131

Ref country code: CH

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20120131

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: IE

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20120118

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: ES

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20111031

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: BG

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20111020

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: MT

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20110720

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: TR

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20110720

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: LU

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20120118

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: HU

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20080118

REG Reference to a national code

Ref country code: FR

Ref legal event code: PLFP

Year of fee payment: 9

REG Reference to a national code

Ref country code: FR

Ref legal event code: PLFP

Year of fee payment: 10

REG Reference to a national code

Ref country code: FR

Ref legal event code: PLFP

Year of fee payment: 11

PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: NL

Payment date: 20180118

Year of fee payment: 11

PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: FR

Payment date: 20190124

Year of fee payment: 12

Ref country code: GB

Payment date: 20190121

Year of fee payment: 12

Ref country code: DE

Payment date: 20190123

Year of fee payment: 12

REG Reference to a national code

Ref country code: NL

Ref legal event code: MM

Effective date: 20190201

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: NL

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20190201

REG Reference to a national code

Ref country code: DE

Ref legal event code: R119

Ref document number: 602008008326

Country of ref document: DE

GBPC Gb: european patent ceased through non-payment of renewal fee

Effective date: 20200118

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: GB

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20200118

Ref country code: DE

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20200801

Ref country code: FR

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20200131