1. Field of the Invention
The present invention relates to a printing system which controls timeout processing of a network-connected printing apparatus.
2. Description of the Related Art
Recently, Windows 7® OS (Operating System) available from Microsoft, USA adopts WSD (Web Service on Device) as a method for printing by a network-connected printing apparatus. Detailed information of WSD is laid open to the public in “Windows Hardware Developer Central” by Microsoft Corporation [online] [searched on Oct. 11, 2010] on the Internet (URL: http://www.microsoft.com/whdc/connect/rally/rallywsd.mspx). To avoid occupying a network-connected printing apparatus when printing by a network-connected printing apparatus, there has conventionally been proposed a technique of releasing occupation of the printing apparatus by performing timeout processing unless an information processing apparatus which has transmitted a print job accesses the printing apparatus for a predetermined period.
There is also disclosed processing in which a printing apparatus analyzes a print start request, if no error has occurred, creates a port, and if the port has not been accessed for a predetermined period, closes the port (see Japanese Patent Laid-Open No. 2004-341734).
For example, in manual printing, transmission of print data to a printing apparatus may intentionally stop so that the printer driver can display a manual printing guide dialog. Even in this case, there is a technique of preventing generation of a timeout error by periodically inquiring status information of a printing apparatus.
As a general OS print support function, there is a method of, when a network cable connected to an information processing apparatus is plugged out and plugged in, deleting a print job during printing and newly printing again a job of the same contents. For example, when the network cable is plugged out and plugged in during printing of job 1, the print support function deletes job 1 held in the print queue, and newly generates and prints a job of the same contents as job 2.
At this time, the printing apparatus cannot detect the plug-out and plug-in of the network cable connected to the information processing apparatus, and keeps processing job 1. The port monitor of the information processing apparatus issues a job 2 print start request to the printing apparatus. However, the printing apparatus is processing job 1 and thus sends back an error response. The language monitor of the information processing apparatus issues a status acquisition request to the printing apparatus. Because of access from the information processing apparatus, the printing apparatus resets the timeout processing counter. As a result, no timeout occurs, and the printing apparatus keeps processing job 1 and cannot start processing of job 2 for a predetermined period.
According to one aspect of the present invention, there is provided a printing system comprising a printing apparatus and an information processing apparatus which communicates with the printing apparatus, the information processing apparatus comprising a transmission unit configured to transmit a status acquisition request to the printing apparatus, and the printing apparatus comprising: a timeout processing unit configured to manage a timeout of a job to be processed; a determination unit configured to determine whether the status acquisition request contains an identifier of the job; and a reset unit configured not to reset a lapse of the timeout time of the job by the timeout processing unit when the determination unit determines that the status acquisition request does not contain the identifier of the job, and to reset the lapse of the timeout time of the job by the timeout processing unit when the determination unit determines that the status acquisition request contains the identifier of the job.
According to another aspect of the present invention, there is provided a printing apparatus comprising: a timeout processing unit configured to manage a timeout of a job to be processed; a determination unit configured to determine whether a status acquisition request transmitted from an information processing apparatus contains an identifier of the job; and a reset unit configured not to reset a lapse of the timeout time of the job by the timeout processing unit when the determination unit determines that the status acquisition request does not contain the identifier of the job, and to reset the lapse of the timeout time of the job by the timeout processing unit when the determination unit determines that the status acquisition request contains the identifier of the job.
According to another aspect of the present invention, there is provided a non-transitory computer-readable medium storing a program for causing a computer to function as a timeout processing unit configured to manage a timeout of a job to be processed, a determination unit configured to determine whether a status acquisition request transmitted from an information processing apparatus contains an identifier of the job, and a reset unit configured not to reset a lapse of the timeout time of the job by the timeout processing unit when the determination unit determines that the status acquisition request does not contain the identifier of the job, and to reset the lapse of the timeout time of the job by the timeout processing unit when the determination unit determines that the status acquisition request contains the identifier of the job.
The printing apparatus can discriminate status requests from an information processing apparatus for respective jobs, and avoid erroneous resetting of a timeout processing counter in response to a status request for a job which is not currently processed by the printing apparatus.
Further features of the present invention will become apparent from the following description of exemplary embodiments (with reference to the attached drawings).
Embodiments of the present invention will now be described in detail with reference to the accompanying drawings. It is to be understood that the following embodiments are not intended to limit the claims of the present invention, and that not all combinations of features described in the embodiments are indispensable for the method to solve the problems in the present invention.
[System Arrangement]
The first embodiment according to the present invention will be explained with reference to
Various programs stored in the external storage device 102 use the RAM 101 as a work memory. The external storage device 102 stores application programs, an OS (Operating System), a printer driver, and various other data. The keyboard 103 is used to input data or an operation instruction by the user. The display 106 is used to display data and notify the status. The network board 105 communicates with another device connected via a network 109. The interface 108 controls connection to a printing apparatus 110.
The printing apparatus 110 includes an interface (I/F) 111, RAM 112, ROM 113, CPU 114, and engine 115. The interface 111 is connected to the network 109, and communicates with another device similarly connected to the network. The ROM 113 stores control programs and the like. The CPU 114 controls the printing apparatus 110 in accordance with a control program stored in the ROM 113. The RAM 112 is used as the work memory of the CPU 114, and also used as a reception buffer for temporarily storing received data. The engine 115 prints data stored in the RAM 112. An inkjet engine will be explained as the engine 115 of the printing apparatus 110 in the embodiment. However, the present invention is not limited to this and, for example, an electrophotographic or thermal transfer engine is also applicable.
The language monitor 208 outputs the print job to a port monitor 209. The port monitor 209 transmits the print job transferred from the language monitor 208 to the printing apparatus 110 via the network 109. The embodiment assumes a WSD printing port monitor as the port monitor 209. However, the present invention is not limited to this, and various port monitors are usable as long as the present invention is applicable.
[WSD Print Processing]
In a process 305, the printing apparatus 110 sends back CreatePrintJob Response (print start response) together with JobID 306 to the port monitor 209. The JobID 306 used here is an ID (identifier) which is added to a print job to uniquely identify it in order to manage the print job by the printing apparatus 110. In a process 307, the port monitor 209 transmits SendDocument Request (document transmission request) to the printing apparatus 110, and completes processing of WritePort( ).
In a process 308, the language monitor 208 transmits GetActiveJobs Request to the printing apparatus 110 within a predetermined period after the completion of processing based on WritePort( ) of the port monitor 209. In a process 309, the printing apparatus 110 sends back GetActiveJobs Response to the language monitor 208. GetActiveJobs Response contains information (table 310) having JobID and JobState. Note that the embodiment will exemplify 4 sec as the predetermined period (X sec). Note that the time is not limited to this value and may be another setting value. Alternatively, the administrator may change the value, as needed.
In a process 311, the spooler 205 calls the function WritePort( ) of the language monitor 208 in order to transmit print data to the printing apparatus 110. Subsequently, the language monitor 208 calls the function WritePort( ) of the port monitor 209. The port monitor 209 transmits print data to the printing apparatus 110.
While print data is transmitted, the language monitor 208 transmits GetPrinterElements Request (status acquisition request) to the printing apparatus 110 in a process 312. GetPrinterElements Request contains the JobID 306. In a process 313, the printing apparatus 110 sends back GetPrinterElements Response (status acquisition response) to the language monitor 208. The system in the embodiment repeats the above-described processes until all print data are transmitted (processes 314, 315, and 316).
[JobID and JobState]
JobID and JobState serving as job information used in the above-described processes will be explained with reference to
[Operation Upon Receiving Request]
Operations when the printing apparatus 110 receives CreatePrintJob Request (process 304 in
Upon receiving CreatePrintJob Request from the port monitor 209 (step S501), the printing apparatus 110 determines whether it is processing a job (step S502). If the printing apparatus 110 is not processing a job (NO in step S502), it assigns a new JobID corresponding to the received request (step S503). The printing apparatus 110 sets “Started” in JobState and holds the status for a predetermined time (X sec) (step S503). Assume that the predetermined time is defined in advance. In the embodiment, the status “Started” is maintained as a specific status for the predetermined time. At this time, JobID and JobState are set as represented by the table 310. The printing apparatus 110 sets information indicating “success” in CreatePrintJob Response (step S505). The printing apparatus 110 transmits CreatePrintJob Response to the port monitor 209 (step S507). The process ends.
If the printing apparatus 110 is processing a job (YES in step S502), it sets information indicating “error” in CreatePrintJob Response (step S506). The printing apparatus 110 transmits CreatePrintJob Response to the port monitor 209 (step S507). The process then ends.
The printing apparatus 110 receives GetActiveJobs Request from the language monitor 208 (step S511). After that, the printing apparatus 110 transmits, to the language monitor 208, GetActiveJobs Response containing JobID and JobState in the table 310 shown in
Processing in WritePort( )
When the spooler 205 calls WritePort( ) of the language monitor 208, the language monitor 208 calls the function WritePort( ) of the port monitor 209 (step S601). If processing by WritePort( ) of the port monitor 209 has succeeded (YES in step S602), the language monitor 208 transmits GetActiveJobs Request to the printing apparatus 110 within a predetermined time (X sec) (step S603). Assume that the predetermined time is defined in advance.
If transmission of GetActiveJobs Request has succeeded and the printing apparatus 110 sends back GetActiveJobs Response (YES in step S605), the language monitor 208 determines whether the JobState value contained in GetActiveJobs Response is “Started” (step S606). By this processing, the job status is determined. If the JobState value is “Started” (YES in step S606), the language monitor 208 stores JobID in, for example, the RAM 101 serving as a storage unit (step S607). The language monitor 208 notifies the spooler 205 of the success (step S608). After that, the process ends.
Although not shown in
If WritePort( ) of the port monitor 209 has failed (NO in step S602), the language monitor 208 notifies the spooler 205 of the failure (step S604). Thereafter, the process ends. If GetActiveJobs Request has failed (NO in step S605) or the JobState value is not “Started” (NO in step S606), WritePort( ) of the port monitor 209 has succeeded. In this case, the language monitor 208 notifies the spooler 205 of the success (step S608). The process then ends.
[Structure of GetActiveJobs Response]
GetActiveJobs Response to be sent back from the printing apparatus 110 in step S309 of
As described in step S504 of
[Transmission/Reception of GetPrinterElements]
After the start of processing, the language monitor 208 checks whether JobID has been stored (step S801). If JobID has been stored (YES in step S801), the language monitor 208 sets the stored JobID in XML data of GetPrinterElements Request (step S802). The language monitor 208 transmits GetPrinterElements Request to the printing apparatus 110 (step S804). The process then ends.
If no JobID has been stored (NO in step S801), the language monitor 208 sets a default value as JobID in XML data of GetPrinterElements Request (step S803). The language monitor 208 transmits GetPrinterElements Request (step S804). Thereafter, the process ends.
After the start of processing, the printing apparatus 110 receives GetPrinterElements Request (step S901). The printing apparatus 110 acquires JobID contained in GetPrinterElements Request (step S902). The printing apparatus 110 acquires JobID of the currently processed job (step S903).
The printing apparatus 110 compares the two JobIDs acquired in steps S902 and S903 (step S904). If these JobIDs coincide with each other (YES in step S904), the printing apparatus 110 resets the value of the timeout processing counter (to be referred to as a counter) (step S905). The printing apparatus 110 transmits GetPrinterElements Response to the language monitor 208 (step S906). Then, the process ends.
If these JobIDs do not coincide with each other (NO in step S904), the printing apparatus 110 transmits GetPrinterElements Response to the language monitor 208 without resetting the counter value (step S906). The process then ends.
[Timeout Processing]
In “timeout processing”, in order to avoid occupation of the printing apparatus 110, if the information processing apparatus 100 which has transmitted a print job does not access the printing apparatus 110 for a predetermined period, processing of the print job stops, releasing occupation of the printing apparatus 110. The timeout processing will be explained with reference to
The printing apparatus 110 checks whether the information processing apparatus 100 has accessed it (step S1001). It is determined that access has occurred when the information processing apparatus 100 transmits print data to the printing apparatus 110 or when JobIDs coincide with each other in step S904 of
If the printing apparatus 110 has not been accessed (NO in step S1001), it counts the time by incrementing the counter value by one (step S1003). Subsequently, the printing apparatus 110 checks whether the counter value has exceeded the threshold (step S1004). Assume that the threshold used here is defined in advance, and may be properly changeable by the administrator or the like. If the counter value has exceeded the threshold (YES in step S1004), the printing apparatus 110 stops processing of the print job (step S1005). The process then ends.
If the counter value has not exceeded the threshold (NO in step S1004), the process simply ends. The printing apparatus 110 periodically performs this processing until the print job ends.
In the timeout processing, the counter is used as a timepiece unit which measures the elapsed time when no access has occurred. However, a lapse of a timeout time may be managed using another unit (for example, timer).
[Example of Structure of GetPrinterElements]
GetPrinterElements Request (processes 312 and 315 of
The language monitor 208 transmits GetPrinterElements Request to the printing apparatus 110 to acquire the status of the printing apparatus 110 and prevent timeout processing by the printing apparatus 110 when transmission of print data to the printing apparatus 110 temporarily stops on purpose. For example, when displaying a manual printing guide dialog in manual printing, the language monitor 208 temporarily stops transmission of print data to the printing apparatus 110 on purpose.
The printing apparatus 110 sends back GetPrinterElements Response to the received GetPrinterElements Request.
Note that the structure of each request/response in the XML format is merely an example, and the present invention is not limited to it.
[Operation when LAN Cable is Plugged Out and Plugged In]
The operations of the OS print support function 202, language monitor 208, and printing apparatus 110 when a LAN cable is plugged out from and then plugged in to the information processing apparatus 100 while the printing apparatus 110 prints a job will be explained with reference to
The spooler 205, language monitor 208, port monitor 209, and printing apparatus 110 start processing of job 1′ to be printed again. The spooler 205 sequentially calls functions StartDocPort( ) and WritePort( ) of the language monitor 208 (processes 301 and 302 shown in
The printing apparatus 110 receives CreatePrintJob Request from the port monitor 209 (step S501), but cannot newly start processing of the job because it keeps printing job 1. Hence, the printing apparatus 110 sets an error in CreatePrintJob Response (YES in step S502→step S506), and transmits it to the port monitor 209 (step S507). The process then ends.
The language monitor 208 fails to call WritePort( ) of the port monitor 209 (process 303 of
In another thread, the language monitor 208 transmits GetPrinterElements Request corresponding to the process 312 shown in
The printing apparatus 110 receives GetPrinterElements Request from the language monitor 208 (processes 312 and 315 of
In accordance with this processing, the printing apparatus 110 does not clear the timeout processing counter. Thus, the printing apparatus 110 executes timeout processing upon the lapse of the timeout time. By performing timeout processing, the printing apparatus 110 stops processing for job 1 during printing, releasing the occupation of the printing apparatus 110 by job 1.
After that, a call for WritePort( ) of the language monitor 208 by the spooler 205 succeeds (process 302 of
As described above, the printing apparatus can avoid resetting of the timeout processing counter in response to a status request for a job which is not currently processed by the printing apparatus.
In
The second embodiment according to the present invention will be described with reference to
A case in which the applications 201 and 1500 transmit print jobs to the printing apparatus 110 in the order named will be examined. The application 201 transmits a print job to the printing apparatus 110 via the OS print support function 202 according to the processing described with reference to
The printing apparatus 110 assigns “200” as JobID to CreatePrintJob Request from the application 201, and sends back CreatePrintJob Response. Therefore, GetPrinterElements Request to acquire the status of a job printed by the application 201 has contents as shown in
The application 1500 transmits CreatePrintJob Request and SendDocument Request directly to the printing apparatus 110 without the mediacy of the OS print support function 202, and causes the printing apparatus 110 to print a desired job. In this case, the application 1500 periodically transmits GetPrinterElements Request to acquire the status of the print job and prevent timeout processing by the printing apparatus 110.
Since the printing apparatus 110 is printing the print job from the application 201, it sends back an error in response to CreatePrintJob Request from the application 1500. In this case, the application 1500 cannot acquire JobID. GetPrinterElements Request to acquire the status of a print job by the application 1500 has contents as shown in
Upon receiving GetPrinterElements Request from the application 201 or 1500, the printing apparatus 110 performs the processing described with reference to
As described above, when the printing apparatus 110 receives GetPrinterElements Request from the application 201, JobIDs coincide with each other and the printing apparatus 110 clears the value of the timeout processing counter. To the contrary, when the printing apparatus 110 receives GetPrinterElements Request from the application 1500, JobIDs do not coincide with each other and the printing apparatus 110 does not clear the counter value. In this manner, even when the printing apparatus 110 receives GetPrinterElements Response from a plurality of applications in the information processing apparatus 100, it can execute appropriate timeout processing.
For example, when the application 201 or OS print support function 202 crashes owing to some reason while the printing apparatus 110 prints a job from the application 201, the printing apparatus 110 keeps printing the job from the application 201. At this time, even if the printing apparatus 110 receives GetPrinterElements Request from the application 1500, it does not update the counter value because JobIDs do not coincide with each other.
Upon the lapse of the assumed time, the printing apparatus 110 performs timeout processing to stop the job during printing without erroneously updating the timeout processing counter, and can accept a print job from the application 1500.
Aspects of the present invention can also be realized by a computer of a system or apparatus (or devices such as a CPU or MPU) that reads out and executes a program recorded on a memory device to perform the functions of the above-described embodiment(s), and by a method, the steps of which are performed by a computer of a system or apparatus by, for example, reading out and executing a program recorded on a memory device to perform the functions of the above-described embodiment(s). For this purpose, the program is provided to the computer for example via a network or from a recording medium of various types serving as the memory device (for example, computer-readable medium).
While the present invention has been described with reference to exemplary embodiments, it is to be understood that the invention is not limited to the disclosed exemplary embodiments. The scope of the following claims is to be accorded the broadest interpretation so as to encompass all such modifications and equivalent structures and functions.
This application claims the benefit of Japanese Patent Application No. 2011-035183, filed Feb. 21, 2011, which is hereby incorporated by reference herein in its entirety.
Number | Date | Country | Kind |
---|---|---|---|
2011-035183 | Feb 2011 | JP | national |