US20060206575A1 - Method and Apparatus for Controlling an Input or Output Device over the Internet - Google Patents

Method and Apparatus for Controlling an Input or Output Device over the Internet Download PDF

Info

Publication number
US20060206575A1
US20060206575A1 US11/420,696 US42069606A US2006206575A1 US 20060206575 A1 US20060206575 A1 US 20060206575A1 US 42069606 A US42069606 A US 42069606A US 2006206575 A1 US2006206575 A1 US 2006206575A1
Authority
US
United States
Prior art keywords
printing
print job
network
internet
printing device
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.)
Abandoned
Application number
US11/420,696
Inventor
Gregory LeClair
Babulal Thummar
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.)
Seiko Epson Corp
Original Assignee
Seiko Epson Corp
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 Seiko Epson Corp filed Critical Seiko Epson Corp
Priority to US11/420,696 priority Critical patent/US20060206575A1/en
Publication of US20060206575A1 publication Critical patent/US20060206575A1/en
Abandoned legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1202Dedicated interfaces to print systems specifically adapted to achieve a particular effect
    • G06F3/1203Improving or facilitating administration, e.g. print management
    • G06F3/1204Improving or facilitating administration, e.g. print management resulting in reduced user or operator actions, e.g. presetting, automatic actions, using hardware token storing data
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1202Dedicated interfaces to print systems specifically adapted to achieve a particular effect
    • G06F3/1203Improving or facilitating administration, e.g. print management
    • G06F3/1207Improving or facilitating administration, e.g. print management resulting in the user being informed about print result after a job submission
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1202Dedicated interfaces to print systems specifically adapted to achieve a particular effect
    • G06F3/1203Improving or facilitating administration, e.g. print management
    • G06F3/1208Improving or facilitating administration, e.g. print management resulting in improved quality of the output result, e.g. print layout, colours, workflows, print preview
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1223Dedicated interfaces to print systems specifically adapted to use a particular technique
    • G06F3/1237Print job management
    • G06F3/1259Print job monitoring, e.g. job status
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1223Dedicated interfaces to print systems specifically adapted to use a particular technique
    • G06F3/1237Print job management
    • G06F3/126Job scheduling, e.g. queuing, determine appropriate device
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1223Dedicated interfaces to print systems specifically adapted to use a particular technique
    • G06F3/1237Print job management
    • G06F3/1265Printing by reference, e.g. retrieving document/image data for a job from a source mentioned in the job
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1278Dedicated interfaces to print systems specifically adapted to adopt a particular infrastructure
    • G06F3/1285Remote printer device, e.g. being remote from client or server
    • G06F3/1286Remote printer device, e.g. being remote from client or server via local network
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1278Dedicated interfaces to print systems specifically adapted to adopt a particular infrastructure
    • G06F3/1285Remote printer device, e.g. being remote from client or server
    • G06F3/1288Remote printer device, e.g. being remote from client or server in client-server-printer device configuration
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L41/00Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
    • H04L41/22Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks comprising specially adapted graphical user interfaces [GUI]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/133Protocols for remote procedure calls [RPC]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/34Network arrangements or protocols for supporting network services or applications involving the movement of software or configuration parameters 
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/60Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources
    • H04L67/62Establishing a time schedule for servicing the requests
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/40Network security protocols
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/00127Connection or combination of a still picture apparatus with another apparatus, e.g. for storage, processing or transmission of still picture signals or of information associated with a still picture
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L41/00Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
    • H04L41/02Standardisation; Integration
    • H04L41/0246Exchanging or transporting network management information using the Internet; Embedding network management web servers in network elements; Web-services-based protocols
    • H04L41/0253Exchanging or transporting network management information using the Internet; Embedding network management web servers in network elements; Web-services-based protocols using browsers or web-pages for accessing management information
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/00127Connection or combination of a still picture apparatus with another apparatus, e.g. for storage, processing or transmission of still picture signals or of information associated with a still picture
    • H04N1/00204Connection or combination of a still picture apparatus with another apparatus, e.g. for storage, processing or transmission of still picture signals or of information associated with a still picture with a digital computer or a digital computer system, e.g. an internet server
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/00127Connection or combination of a still picture apparatus with another apparatus, e.g. for storage, processing or transmission of still picture signals or of information associated with a still picture
    • H04N1/00347Connection or combination of a still picture apparatus with another apparatus, e.g. for storage, processing or transmission of still picture signals or of information associated with a still picture with another still picture apparatus, e.g. hybrid still picture apparatus
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/32Circuits or arrangements for control or supervision between transmitter and receiver or between image input and image output device, e.g. between a still-image camera and its memory or between a still-image camera and a printer device
    • H04N1/32101Display, printing, storage or transmission of additional information, e.g. ID code, date and time or title
    • H04N1/32106Display, printing, storage or transmission of additional information, e.g. ID code, date and time or title separate from the image data, e.g. in a different computer file
    • H04N1/32122Display, printing, storage or transmission of additional information, e.g. ID code, date and time or title separate from the image data, e.g. in a different computer file in a separate device, e.g. in a memory or on a display separate from image data
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N2201/00Indexing scheme relating to scanning, transmission or reproduction of documents or the like, and to details thereof
    • H04N2201/0008Connection or combination of a still picture apparatus with another apparatus
    • H04N2201/0015Control of image communication with the connected apparatus, e.g. signalling capability
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N2201/00Indexing scheme relating to scanning, transmission or reproduction of documents or the like, and to details thereof
    • H04N2201/0008Connection or combination of a still picture apparatus with another apparatus
    • H04N2201/0034Details of the connection, e.g. connector, interface
    • H04N2201/0037Topological details of the connection
    • H04N2201/0039Connection via a network
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N2201/00Indexing scheme relating to scanning, transmission or reproduction of documents or the like, and to details thereof
    • H04N2201/0008Connection or combination of a still picture apparatus with another apparatus
    • H04N2201/0065Converting image data to a format usable by the connected apparatus or vice versa
    • H04N2201/0068Converting from still picture data
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N2201/00Indexing scheme relating to scanning, transmission or reproduction of documents or the like, and to details thereof
    • H04N2201/0008Connection or combination of a still picture apparatus with another apparatus
    • H04N2201/0074Arrangements for the control of a still picture apparatus by the connected apparatus
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N2201/00Indexing scheme relating to scanning, transmission or reproduction of documents or the like, and to details thereof
    • H04N2201/0077Types of the still picture apparatus
    • H04N2201/0081Image reader
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N2201/00Indexing scheme relating to scanning, transmission or reproduction of documents or the like, and to details thereof
    • H04N2201/0077Types of the still picture apparatus
    • H04N2201/0082Image hardcopy reproducer
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N2201/00Indexing scheme relating to scanning, transmission or reproduction of documents or the like, and to details thereof
    • H04N2201/0077Types of the still picture apparatus
    • H04N2201/0084Digital still camera
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N2201/00Indexing scheme relating to scanning, transmission or reproduction of documents or the like, and to details thereof
    • H04N2201/0077Types of the still picture apparatus
    • H04N2201/0093Facsimile machine
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N2201/00Indexing scheme relating to scanning, transmission or reproduction of documents or the like, and to details thereof
    • H04N2201/32Circuits or arrangements for control or supervision between transmitter and receiver or between image input and image output device, e.g. between a still-image camera and its memory or between a still-image camera and a printer device
    • H04N2201/3201Display, printing, storage or transmission of additional information, e.g. ID code, date and time or title
    • H04N2201/3212Display, printing, storage or transmission of additional information, e.g. ID code, date and time or title of data relating to a job, e.g. communication, capture or filing of an image
    • H04N2201/3219Display, printing, storage or transmission of additional information, e.g. ID code, date and time or title of data relating to a job, e.g. communication, capture or filing of an image of a job status, e.g. successful execution
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N2201/00Indexing scheme relating to scanning, transmission or reproduction of documents or the like, and to details thereof
    • H04N2201/32Circuits or arrangements for control or supervision between transmitter and receiver or between image input and image output device, e.g. between a still-image camera and its memory or between a still-image camera and a printer device
    • H04N2201/3201Display, printing, storage or transmission of additional information, e.g. ID code, date and time or title
    • H04N2201/3278Transmission

Definitions

  • This invention relates generally to methods and apparatus for transmitting data to, and receiving data from, an output or input device over a computer network.
  • networks such as LANs, WANs, and the Internet
  • networks have revolutionized the field of computing and, in particularly, the field of data transfer (i.e. inputting and outputting data) between devices.
  • Early computer workstations included a personal computer electrically connected to input and output devices, such as printers, scanners, fax machines, and video cameras.
  • clients multiple computer workstations or personal computers (collectively called “clients”) to share input or output devices.
  • TCP/IP Transmission Control Protocol/Internet Protocol
  • IP Internet protocol
  • SMB Server Message Block
  • FIG. 1 shows a conventional printing system including multiple clients and a shared printing device.
  • Clients 105 , 110 , and 115 are connected via network 118 to a shared server 120 and printer 135 . Any of clients 105 , 110 , and 115 may use printer 135 via server 120 .
  • client 105 wants to print, for example, it sends, or “pushes,” a print job consisting of print commands and print data over network 118 to server 120 .
  • Server 120 stores the print job to a disk, queue, or “spool,” 125 in server 120 .
  • print controller 130 reads the stored file from spool 125 and transmits the file to printer 135 .
  • Print controller 130 also sends commands to printer 135 . In response, printer 135 processes the received file.
  • This conventional “push” technology has some limitations.
  • clients transmit command information as well as a digital copy of the output file across the network to the server.
  • the server 120 must therefore have sufficient disk space in the spool 124 to store the print jobs waiting to be printed.
  • the server requires large amounts of costly disk space, and may delay accepting new jobs if the disk's spool has reached its maximum storage capacity.
  • the client may waste time querying the server and waiting for it to have sufficient space to receive the job.
  • the client may be inoperable for other tasks until the server can process the job, which can be a significant period of time if the output file is very large.
  • FIG. 2 illustrates a conventional print server 210 that receives print requests from clients 220 , 240 , and 250 , each operating on a different platform.
  • Client 230 may be an Apple Macintosh using the MacOS® operating system
  • client 240 may be a PC using the UNIX operating system
  • client 250 may be a PC operating the Windows 95® operating system.
  • a server that accepts print jobs from clients on different platforms requires multiple protocol stacks to interpret and output the print request. For example, as shown in FIG.
  • print server 210 must contain TCP/IP 214 , SMB 216 , and PAP (Printer Access Protocol) 212 protocol stacks to communicate with the various clients 230 , 240 , and 250 on the network.
  • PAP Printer Access Protocol
  • a server that must be configured to use a multitude of protocols is very complex, requiring additional time and resources to develop, troubleshoot, and maintain.
  • IPDS Intelligent Printer Data Stream
  • a server receives from an initiator a request comprising a network storage location of data to be output using the output device.
  • the server places the request in a queue and schedules an output action based on the request.
  • the server retrieves the output data from the network storage location which is different from the queue.
  • a computer-readable medium consistent with the present invention contains instructions for outputting data in a network corresponding to tasks executable by a computer and performed by the server.
  • Another method for receiving data from an input device in a network consistent with this invention comprises the following operations, performed by the server.
  • the server receives from input job information from an input device.
  • the server stores the input job information to an input queue.
  • the server receives a request from an initiator to process data from the input device based on the input job information.
  • the server retrieves data from the input device based on the request and transmits the data to a location based on the data destination information.
  • a computer-readable medium consistent with the present invention contains instructions for retrieving data from an input device in a network corresponding to tasks executable by a computer and performed by the server.
  • a network printer consistent with the present invention comprises a print mechanism for outputting data provided by the initiator.
  • the network printer also comprises a controller for receiving from the initiator a request comprising the network storage location of data to be printed, placing the request in a queue, and scheduling the data to be printed based on the request.
  • the server retrieves the data from a location different from the queue, and transmits the data to the print mechanism.
  • An apparatus for controlling data in a network consistent with the present invention comprises a memory having program instructions; and a processor configured to receive a request from an initiator to output data provided by the initiator using the output device, the request comprising a network storage location of data to be output; place the request in a queue; schedule an output action based on the request in the queue, and retrieve the output data from the network storage location based on the request when the scheduled action is ready to be implemented, wherein the network storage location of the output data is different from the queue.
  • a further apparatus for controlling data in a network comprises a memory having program instructions; and a processor configured to receive input job information from an input device; store the input job information to an input queue; receive a request from an initiator to process data from the input device based on the input job information; and retrieve data from the input device based on the input job information when the input device is available.
  • a data control system comprises an initiator that transmits a request comprising a network storage location of data provided by the initiator to be output using the output device.
  • a server receives the request, places the request in a queue, and schedules an action based on the request. When the scheduled action is ready to be implemented, the server retrieves the data from the network storage location which is different from the queue.
  • the server may also retrieve input job information from an input device and retrieve data from an input device based on the input job information when the input device is available.
  • a network output device in a network comprises an output mechanism; a memory having program instructions; and a processor configured to receive a request from an initiator to output data provided by the initiator using the output device, the request comprising a network storage location of data to be output; place the request in a queue; schedule an output action based on the request in the queue, and retrieve the output data from the network storage location based on the request when the scheduled action is ready to be implemented, wherein the network storage location of the output data is different from the queue.
  • a network input device comprises a data input mechanism; a memory having program instructions; and a processor configured to receive input job information from an input device; store the input job information to an input queue; receive a request from an initiator to process data from the input device based on the input job information; and retrieve data from the input device based on the input job information when the input device is available.
  • FIG. 1 is an illustration of a conventional network comprising clients, a printer, and a print server;
  • FIG. 2 illustrates a conventional print server
  • FIG. 3 shows a system consistent with the present invention
  • FIG. 4 shows a controller consistent with the present invention
  • FIG. 5 is a flow diagram of operations performed to output to an output device consistent with the present invention.
  • FIG. 6 is a data flow diagram consistent with the present invention.
  • FIG. 7 is a data flow diagram of network printing consistent with the present invention.
  • FIG. 8 is a flow diagram of operations performed to retrieve data from an input device consistent with the present invention.
  • FIG. 9 is a data flow diagram consistent with the present invention.
  • FIG. 10 is a flow diagram of operations performed to obtain status information consistent with the present invention.
  • Systems and methods consistent with the present invention operate in a network environment that has a client acting as an initiator of a transaction, a server, and an I/O device.
  • an initiator requests a server to perform an input/output transaction and negotiates the specifics of the transaction with the server.
  • the server retrieves, or “pulls,” the data from one location and sends it to another.
  • HTTP Web transfer protocol
  • the HTTP protocol operates well over many different physical links and is a popular protocol for transferring various types of information between devices on a network.
  • Implementation of the HTTP protocol reduces the need for the server to contain multiple protocol stacks for translating requests from initiators on different platforms. Reducing the number of protocol stacks in the server reduces complexity of the device thereby reducing development, testing, and troubleshooting time.
  • the systems will comprise an initiator, a server, and an I/O mechanism connected via a network.
  • the I/O mechanism may be a “thin” device attached to the network, server, or client.
  • a “thin” device is one that performs most I/O operations and stores most data on a server.
  • the I/O mechanism may also be collocated in the same device as an additional server such as, for example, a conventional printer with embedded server.
  • FIG. 3 is a block diagram that illustrates an I/O system consistent with the present invention.
  • the I/O system comprises a client 305 acting as an initiator, a server 310 , and an I/O device 350 capable of communicating with one another through network 300 .
  • Network 300 may be a LAN, WAN, or Internet comprising multiple LANs and WANs.
  • Network 300 uses electric, electromagnetic, radio frequency, and/or optical signals to carry digital data streams.
  • the signals that carry digital data through network 300 to and from client 305 , server 310 , and I/O device 350 are exemplary forms of carrier waves.
  • Client 305 and server 310 can send messages and receive data, including program code, through the network 300 .
  • client 305 might transmit a request to download code for an application program to server 310 , or server 310 may download the code to client 305 through network 300 .
  • One such downloaded application may be an input/output driver program, as described herein.
  • client 305 may obtain application code in the form of a carrier wave.
  • the application code may be encoded and transmitted as packets on a carrier wave.
  • both client 305 and server 310 contain controllers 308 and 318 , respectively, similar to controller 405 as shown in FIG. 4 .
  • Controller 405 contains a processor 406 , RAM 404 , ROM 408 , storage device 409 , and communication interface 410 capable of communicating via bus 402 .
  • Processor 406 is a conventional microprocessor unit.
  • RAM 404 can be a static or dynamic storage device, and stores information, temporary variables, and instructions to be executed by processor 406 .
  • ROM 408 which can be any type of nonvolatile static storage device appropriate to the task, stores static information and instructions for processor 406 .
  • a storage device 410 such as a magnetic disk or optical disk, is provided and coupled to bus 402 for storing information and instructions.
  • Controller 405 also includes a communication interface 410 coupled to bus 402 .
  • Communication interface 410 provides a two-way data communication coupling to a network.
  • communication interface 410 may be an ISDN card, cable modem, or a modem to provide a data communication connection to a corresponding type of telephone line.
  • communication interface 410 may be a LAN card that provides a data communication connection to a compatible LAN.
  • Wireless links may also be implemented.
  • communication interface 410 sends and receives electrical, electromagnetic or optical signals that carry digital data streams representing various types of information.
  • processor 406 executes one or more sequences of instructions in ROM 408 . Executing the sequences of instructions in memory ROM 408 causes processor 406 to perform the method for controlling access to a I/O device described below.
  • processor 406 executes one or more sequences of instructions in memory ROM 408 . Executing the sequences of instructions in memory ROM 408 causes processor 406 to perform the method for controlling access to a I/O device described below.
  • hard-wired circuitry may be used in place of or in combination with software instructions. Systems and methods consistent with the present invention are not limited to any specific combination of hardware circuitry and software.
  • Non-volatile media includes, for example, optical or magnetic disks, such as ROM 408 .
  • Volatile media includes dynamic memory, such as RAM 404 .
  • Transmission media includes coaxial cables, copper wire, and fiber optics, including bus 402 . Transmission media can also take the form of acoustic or light waves, such as those generated during radio-wave and infra-red data communications.
  • Computer-readable media include a floppy disk, a flexible disk, hard disk, magnetic tape, or any other magnetic medium, a CD-ROM, any other optical medium, punch cards, papertape, any other physical medium with patterns of holes, a RAM, PROM, and EPROM, a FLASH-EPROM, any other memory chip or cartridge, a carrier wave as described above, or any other medium from which a computer can read data.
  • the instructions may initially be carried on magnetic disk of a remote computer.
  • the remote computer can load the instructions into its dynamic memory and send the instructions over a telephone line using a modem.
  • a modem local to controller 405 can receive the data on the telephone line and use an infrared transmitter to convert the data to an infrared signal.
  • An infrared detector coupled to bus 402 can receive the data carried in that signal and place the data on bus 402 .
  • Bus 402 carries the data to ROM 408 , from which processor 406 retrieves and executes the instructions.
  • the instructions received by processor 406 may also be stored on storage device 409 either before or after execution by processor 406 .
  • client 305 and server 310 may be conventional PCs containing controllers 308 and 318 , respectively.
  • client 305 and server 310 may contain attached peripherals, such as displays, input devices, and devices for cursor control.
  • client 305 is shown coupled via standard bus to display 312 , input device 314 , and cursor control 316 .
  • Server 310 is shown coupled via standard bus to display 322 , input device 324 , and cursor control 326 .
  • Displays 312 and 322 may be any conventional display device used for displaying information to a computer user, such as a CRT, LCD, LED, or custom display device.
  • input devices 314 and 324 are devices, such as keyboards, that include alphanumeric and other keys for communicating information and command selections to client 305 and server 310 .
  • cursor control 316 and 326 is Another type of user input device, such as a mouse, a trackball or cursor direction keys for communicating direction information and command selections to client 305 and server 310 and for controlling cursor movement on displays 312 and 322 .
  • I/O device 350 may be an output device, such as a printer, or an input device, such as a scanner or digital camera. As shown in FIG. 3 , I/O device 350 can include a controller 360 and an I/O mechanism 370 . Controller 360 may be similar to controller 405 in FIG. 4 , or may contain a smaller RAM, ROM, or storage device, or a processor with different capabilities. I/O mechanism 370 inputs or outputs data. If I/O device 350 is a laser printer, for example, I/O mechanism 370 may be a printer engine unit that converts data to printed pages. Pages can contain various types of content (such as text or graphics) and can be marked with a variety of compounds (such as ink, toner, heat, light, finisher, or pressure).
  • I/O device 350 is an input device such a scanner, for example, I/O mechanism 370 may be a scan converter that converts printed information to digital data such as, for example, an Epson Scanner model ES-8000C.
  • I/O device 350 comprises an embedded controller 360 that is similar to controller 405 illustrated in FIG. 4 . Controller 360 then would perform both its own functions and those performed by controller 318 of server 310 in the embodiment described above.
  • I/O device 350 may be an output device, such as a printer, or an input device, such as a scanner or digital camera with an enhanced controller.
  • I/O device 350 may also be a conventional I/O device with an additional peripheral device, such as a PC Card.
  • I/O device 350 can also contain only an I/O mechanism 370 .
  • I/O device 350 will be physically connected to a device with a controller, such as client 305 or server 310 .
  • FIG. 5 illustrates steps of a method of outputting data consistent with the present invention.
  • FIG. 6 shows a data flow diagram illustrating the flow of data consistent with the method of FIG. 5 .
  • the steps of the method of FIG. 5 are described in more detail below with reference to the system depicted in FIG. 3 and the data flow diagram of FIG. 6 .
  • FIG. 7 illustrates one embodiment of the method of FIG. 5 in which the I/O device is a printer.
  • FIG. 8 illustrates steps of a method of receiving data from an input device consistent with the present invention.
  • FIG. 9 shows a data flow diagram illustrating the flow of data consistent with the method of FIG. 8 .
  • the steps of the method of FIG. 8 are described in more detail below with reference to the system depicted in FIG. 3 and the data flow diagram of FIG. 9 .
  • the method of FIG. 8 can be implemented for receiving data from an input device, such as a scanner, fax, or digital camera.
  • the method begins with an initiator remote from the server providing data to be output (step 505 ).
  • data may be generated by data source 605 of initiator 600 , which is remote from server 610 , or initiator 600 may provide the data by, for example, reading previously generated data from a disk or other computer-readable medium.
  • Initiator 600 may be, for example, client 305 of FIG. 3 .
  • the data is conditioned into the proper format by, for example, adding formatting commands or other information.
  • the conditioned data may then be stored locally in, for example, spool 620 of initiator 600 or in another physical location, such as storage 622 , which may be a file server operatively connected to a network and capable of communicating with initiator 600 .
  • data source 605 notifies initiator agent 625 that the data is ready for use and gives initiator agent 625 the location where the data is stored.
  • Initiator agent 625 may be, for example, an HTTP client.
  • Initiator 600 then submits a request to server 610 , which may be, for example, server 310 of FIG. 3 (step 510 ). If the output device has an embedded server, initiator 600 may submit the request directly to I/O device 350 . Initiator agent 625 of initiator 600 formulates the request as an HTTP “POST” command.
  • the POST command contains a URL of the location of the data to be outputted.
  • the body of the request contains the page/request.
  • the page/request may be encoded using MIME, in which case the lines following the command might include ContentType and authentication headers, to prove the initiator has permission to perform the requested operation.
  • the POST request may also include information about the requirements such as the destination output device, output format type, and other special requirements. Alternatively, a user may invoke a browser or custom HTTP client to submit the same information as the POST command to the server.
  • the server receives the request and determines whether it is capable of satisfying the request (step 515 ).
  • Server 310 of FIG. 3 may determine whether it is capable of outputting to the device requested and whether it has available storage space in the queue.
  • a server like server 310 , may not be capable of handling the request.
  • the server may not be connected via the network to the device requested.
  • the server may also recognize that the request specifies a particular output format, such as PostScript, and that none of the devices with which it has connectivity is capable of outputting in the requested output type.
  • the server If the server can handle the request, it responds and acknowledges the request, such as by transmitting a status line telling the initiator that it has received the request, placing the request in a queue, or by scheduling the request (step 525 ). If the server cannot handle the request in its current form, the server determines whether it can convert the request into a request that it can satisfy (step 520 ). For example, if the initiator requested that the data be output in a format that is not supported, the server may recognize that it can convert the data into the requested format or can obtain via the network the necessary tools for converting the request (such as conversion software). If the server can convert the data into a proper form, the server acknowledges the request (step 525 ).
  • step 522 the server sends back an acknowledgment that it received the request but cannot accommodate it at this time.
  • the process may be terminated or the process may be configured so that the client continues to post requests until the job is accepted by the server. If so, the process would continue from step 510 .
  • the initiator posts the job to a memory structure or “queue” (step 525 ).
  • the job posting consists of the URL of the data output file which is stored in a location other than the queue.
  • the server periodically monitors the output queue.
  • Server agent 640 accesses the queue and adds, controls, and removes jobs from the queue. If the queue has jobs for output devices, and the output device is ready (step 530 ), the server retrieves the data from the storage location designated by the URL (step 535 ).
  • the server fetches the data using the URL (step 535 ), for example, by executing an HTTP GET object request.
  • server agent 640 of server 610 may transmit the request to initiator agent 625 of initiator 600 , which may access data stored in spool 620 .
  • server agent 640 of server 610 transmits a GET request directly to storage 622 , which may be, for example, a file server remote to initiator 600 and server 610 .
  • the amount of data that the server gets at any one time may depend on the capabilities of the output device for which the data is destined. If, for example, the output device is a serial device, a GET request may obtain only a small block of data.
  • the GET request may bring back data one page at a time. There are instances where the GET request may copy and bring back the entire output file. If the output device needs to output multiple copies of a large file, for example, the output process may be quicker if the destination client retrieves a copy of the entire output file rather than make multiple requests one page at a time.
  • the server may convert the data (step 537 ) before sending it to output device 680 (step 540 ). If the data does not need conversion, the server simply transmits it to output device 680 (step 540 ).
  • the transfer may be by parallel interface or other suitable interface such as USB, RS 232, or 1394 interfaces, or by a network or internet. Transfer may also be via internal proprietary CPU bus or a standard bus.
  • Methods consistent with the present invention allow data storage to be distributed over the network thereby reducing the need for any one device, such as a server, to possess large amounts of disk space.
  • a server By storing data across more locations on the network and retrieving data to be outputted or inputted when needed from its storage location, network operation is more efficient.
  • the initiator will know whether the output device is capable of handling the output request prior to commencing the job.
  • the outputting method of the present invention may also be described with reference to network printing.
  • the method begins with an initiator remote from the print server providing data to be printed (step 505 ).
  • data source 705 of initiator 700 provides the data to be printed by, for example, generating the data or reading previously generated data from a disk or other computer-readable medium.
  • the data is conditioned into the proper format by, for example, adding formatting commands or other information.
  • the conditioned data is stored and data source 705 gives initiator agent 725 the location where the data is stored.
  • Initiator agent 725 may be, for example, an HTTP client.
  • Initiator 700 then submits a request to print server 710 , which may be, for example, server 310 of FIG. 3 (step 510 ). If the output device is a printer with embedded server or controller, similar to I/O device 350 of FIG. 3 , initiator 700 may submit the request directly to the enhanced printer. Initiator agent 725 of initiator 700 formulates the request as an HTTP “POST” command containing a URL of the location of the data to be printed. The POST request may also include information about the printer, printer format types, and other special requirements. Alternatively, a user may invoke a browser or custom HTTP client to submit the same information as the POST command to print server 710 .
  • the server receives the request and determines whether it is capable of satisfying the request (step 515 ).
  • Print server 710 may determine whether it is capable of printing to the device requested and whether it has available storage space in the queue. If print server 710 can handle the request, printer server agent 740 responds and acknowledges the request, such as by transmitting a status line telling the initiator that it has received the request, placing the request in a queue, or by scheduling the request (step 525 ). If print server 710 cannot handle the request in its current form, print server 710 determines whether it can convert the request into a request that it can satisfy (step 520 ).
  • print server 710 may recognize that it can convert the data into the requested format or can obtain via the network the necessary tools for converting the request (such as conversion software). If print server 710 can convert the data into a proper form, print server 710 acknowledges the request (step 525 ).
  • print server 710 determines that it cannot handle the request, print server 710 sends back an acknowledgment that it received the request but cannot accommodate it at this time (step 522 ). At this point, the process may be terminated or the process may be configured so that the client continues to post requests until the job is accepted by print server 710 . If so, the process would continue from step 510 .
  • the initiator posts the job to a memory structure or “queue” (step 525 ).
  • the job posting consists of the URL of the data output file which is stored in a location other than the queue.
  • Print server 710 periodically monitors the output queue.
  • Server agent 740 accesses the queue and adds, controls, and removes jobs from the queue. If the queue has jobs for a printer, and the printer is ready (step 530 ), the server retrieves the data from the storage location designated by the URL (step 535 ).
  • the server fetches the data using the URL (step 535 ), for example, by executing an HTTP GET object request.
  • server agent 740 of print server 710 may transmit the request to initiator agent 725 of initiator 700 , which may access data stored in spool 720 .
  • server agent 740 of print server 710 transmits a GET request directly to storage 722 , which may be, for example, a file server remote to initiator 700 and print server 710 .
  • the amount of data that the server gets with at any one time may depend on the capabilities of the printer for which the data is destined. If, for example, the printer is a serial device, a GET request may obtain only a small block of data.
  • the GET request may bring back data one page at a time. There are instances where the GET request may copy and bring back the entire output file. If the printer needs to output multiple copies of a large file, for example, the output process may be quicker if the destination client retrieves a copy of the entire output file rather than make multiple requests one page at a time.
  • Print mechanism 780 may be, for example, a printer engine unit that converts data to printed pages.
  • the transfer may be by parallel interface or other suitable interface such as USB, RS 232, or 1394 interfaces, or by a network or internet. Transfer may also be via internal proprietary CPU bus or a standard bus.
  • Methods consistent with the present invention allow data storage to be distributed over the network thereby reducing the need for any one device, such as a server, to possess large amounts of disk space.
  • a server By storing data across more locations on the network and retrieving data to be outputted or inputted when needed from its storage location, network operation is more efficient.
  • the initiator will know whether the printer is capable of handling the output request prior to commencing the job and less paper will be wasted by printing improperly formatted print jobs.
  • FIG. 8 also illustrates an example of a method of receiving data from an input device, such as a scanner, digital video camera, or fax. The steps of the method are illustrated with reference to the systems depicted in FIG. 3 and the data flow diagram of FIG. 9 .
  • the method begins with the generation of data at the input device (step 805 ), such as by putting a document on a scanner, turning on a video camera, or receiving a signal indicating an incoming fax. Receipt of input data therefore generally begins with the input device 980 of FIG. 9 .
  • Input device 980 will convert the received images to digital data and may also store the data to a location in input device 980 , server 910 , or another accessible storage location.
  • Input device 980 may also accept a list of addresses to which the device would like to transfer the input data.
  • input device 980 may be a digital fax machine that accepts a document, converts it to digital data, and allows the user to input various network addresses that would like to receive the faxed information.
  • Input device 980 notifies the server that input device 980 has data to transmit by, for example, transmitting input job information to the server.
  • the input job information may contain such information as format type or destination, such as a list of storage addresses or a list of recipients.
  • Server 910 stores the input job information to an input queue (step 807 ). Initiator 910 may learn that information is available at input device 980 by, for example, receiving notice from server 910 or periodically checking the input queue (step 808 ).
  • initiator 900 sends a request to server 910 based on the input job information (step 810 ).
  • Initiator agent 925 of initiator 900 formulates the request as an HTTP “GET” command containing a URL of the location of the data to be retrieved.
  • the body of the request contains the page/request.
  • the page/request may be encoded using MIME, in which case the lines following the command might include ContentType and authentication headers to prove the initiator has permission to perform the requested operation.
  • the GET request may also include information about the requirements such as the input device, input format type, and other special requirements. Alternatively, a user may invoke a browser or custom HTTP client to submit the same information as the GET command to the server.
  • Server 910 receives the request. If the GET request contains a job identifier (step 815 ), server agent 940 either returns the status of the job to initiator 900 (step 822 ) or executes the GET request.
  • server 910 recognizes the request as a new request. Server 910 then queries input device 980 for data by invoking server agent 940 , which may be, for example, a process or CGI script. If input device 980 is active (step 825 ), input device 980 is currently satisfying a different job and is unavailable. Server agent 940 returns a “busy” status to initiator 900 (step 827 ).
  • server agent 740 responds to initiator 900 with a job identifier (step 830 ).
  • Server agent 940 then retrieves data from input device 980 , for example, by executing an HTTP GET object request (step 835 ).
  • the amount of data that server 910 receives with any one request may depend on the capabilities of the input device for which the job is destined. If, for example, the input device is a serial device, a GET request may obtain only a small block of data. If the input device is a page-oriented device, such as a laser printer, the GET request may bring back data one page at a time. Additionally, there are instances where the GET request may copy and bring back the entire input file. If the input device needs to input multiple copies of a large file, for example, the input process may be quicker if the destination client retrieves a copy of the entire input file rather than make multiple requests one page at a time.
  • Server 910 receives the data and determines whether the data needs conversion to the format requested by initiator 900 (step 836 ). If the data needs to be converted, server 910 converts the data ( 837 ). Server 910 transmits the data to a destination based either on the input job information or the request from the initiator (step 840 ). The transfer may be by parallel interface or other suitable interface such as USB, RS 232, or 1394 interfaces.
  • an initiator may also query the server (or an I/O device with embedded server) for status of the I/O request or the I/O device.
  • FIG. 10 illustrates the steps of requesting and receiving status reports.
  • initiator 600 or 900 makes a status request (step 1005 ) including, for example, job identifier, information containing in the I/O request, or information identifying the I/O device (output device 680 or input device 980 ).
  • the status request may be made in the form of a GET request to a server, such as server 610 in FIG. 7 or server 910 in FIG. 9 .
  • the GET request may also be followed by header information that asks the server to send only that data that has been modified since the last status request.
  • status information is stored in a status information cache on the I/O server. Frequently contacting an I/O device for status may interrupt or slow data transfer, particularly if status is checked very frequently.
  • Use of a status cache can control interruptions to I/O devices and improve performance.
  • the cache is updated during idle states or when there is an error at the I/O device that prevents data transfer.
  • Another advantage of caching status information on the server is that the server administrator can define the rules for updating the status cache and the frequency of status queries to the I/O device.
  • the I/O server may check to see if the status cache contains current status information (step 1010 ).
  • the server may, for example, compare the time on the request to see if the cache has been updated since the last status request. If the cache is current, the server may send the status information from the cache (step 1025 ).
  • the server determines whether it is an appropriate time to update the status cache. If not, the server may wait for an update (step 1015 ) or send the information that is in the cache. If, however, the server has not queried the I/O device in a long time, or if the server detects that the I/O device is inactive, the server may update the cache by querying the I/O device for status (step 1020 ).
  • the I/O server then formats a reply containing the status of the I/O device and transmits the information to the initiator (step 1025 ).
  • methods and apparatus consistent with the present invention operate in a network environment having an initiator, a server, and an I/O device.
  • the initiator requests a server to perform an input/output transactions and negotiates the specifics of the transaction with the server.
  • the server When the request is ready to be initiated, the server “pulls” the data from one location and sends it to another.

Abstract

In a network having an initiator, a server, and an input/output (I/O) device remote from the initiator, the initiator transmits to the server a request containing the network location of data to be retrieved from an input device, such as a video camera, fax, or scanner, or output by an output device, such as a printer. Output requests are placed in a queue and scheduled for completion. When an output device is ready, the server retrieves the data from a network storage location different from the queue and transmits the data to the printer or output device for action. When an input device is ready, the server retrieves the data from the input device and transmits it to a network location based on the request. The server can also provide the initiator with status information about the request and the input or output device.

Description

    RELATED APPLICATIONS
  • Japanese patent application No.(s) 09/187,193, and 10/117,874, is hereby incorporated by reference in its/their entirety.
  • BACKGROUND OF THE INVENTION FIELD OF THE INVENTION
  • This invention relates generally to methods and apparatus for transmitting data to, and receiving data from, an output or input device over a computer network.
  • The introduction of networks, such as LANs, WANs, and the Internet, has revolutionized the field of computing and, in particularly, the field of data transfer (i.e. inputting and outputting data) between devices. Early computer workstations included a personal computer electrically connected to input and output devices, such as printers, scanners, fax machines, and video cameras. Today, networks allow multiple computer workstations or personal computers (collectively called “clients”) to share input or output devices.
  • To share resources across a network, the resources must be able to communicate using the same or compatible protocols. Conventional networks are organized as a series of layers, the numbers, names, contents, and function of which differ from network to network. In most conventional networks, however, each layer offers services to the higher layers while shielding those layers from the details of how the offered services are actually implemented. When machines communicate, the layers on each machine can communicate with an equivalent layer on other machines using the appropriate protocol for that layer. The protocols used by the layers of a system is referred to as a “protocol stack” and define the network environment. In an UNIX environment, for example, the Transmission Control Protocol/Internet Protocol (TCP/IP) protocol stack includes the transmission control protocol (TCP) and Internet protocol (IP). Server Message Block (SMB) is a protocol stack for passing information between network computers for processing by a device. The TCP/IP protocol stack is one of the most common protocols used on the Internet.
  • FIG. 1 shows a conventional printing system including multiple clients and a shared printing device. Clients 105, 110, and 115 are connected via network 118 to a shared server 120 and printer 135. Any of clients 105, 110, and 115 may use printer 135 via server 120. If client 105 wants to print, for example, it sends, or “pushes,” a print job consisting of print commands and print data over network 118 to server 120. Server 120 stores the print job to a disk, queue, or “spool,” 125 in server 120. As a print job percolates to the top of the print queue, print controller 130 reads the stored file from spool 125 and transmits the file to printer 135. Print controller 130 also sends commands to printer 135. In response, printer 135 processes the received file.
  • This conventional “push” technology has some limitations. In a conventional printing system, for example, clients transmit command information as well as a digital copy of the output file across the network to the server. The server 120 must therefore have sufficient disk space in the spool 124 to store the print jobs waiting to be printed. In networks with many clients, the server requires large amounts of costly disk space, and may delay accepting new jobs if the disk's spool has reached its maximum storage capacity. When the spool is full, the client may waste time querying the server and waiting for it to have sufficient space to receive the job. Furthermore, the client may be inoperable for other tasks until the server can process the job, which can be a significant period of time if the output file is very large.
  • Additionally, in a conventional configuration, access to printers by clients will frequently be determined by chance and can be unfair. When a server rejects print jobs because the spool is full, clients wishing to output to a device controlled by that server may not be accepted in a predetermined order, but may have to keep querying the server hoping that its request arrives before the those of other clients when the server becomes available.
  • Furthermore, network print servers that receive requests to print from clients on a variety of platforms require multiple protocols and are more difficult to implement and troubleshoot. A platform is any piece of hardware plus its software operating system. FIG. 2 illustrates a conventional print server 210 that receives print requests from clients 220, 240, and 250, each operating on a different platform. Client 230 may be an Apple Macintosh using the MacOS® operating system, client 240 may be a PC using the UNIX operating system, and client 250 may be a PC operating the Windows 95® operating system. A server that accepts print jobs from clients on different platforms requires multiple protocol stacks to interpret and output the print request. For example, as shown in FIG. 2, print server 210 must contain TCP/IP 214, SMB 216, and PAP (Printer Access Protocol) 212 protocol stacks to communicate with the various clients 230, 240, and 250 on the network. A server that must be configured to use a multitude of protocols is very complex, requiring additional time and resources to develop, troubleshoot, and maintain.
  • In addition, many conventional methods of printing using a network server do not allow a client to receive information about some status conditions. For example, in a conventional setting, once the client sends a print job to the print server, the client can only query the printer server for the status of the print job (such as whether it is currently printing or place in the print queue), but not for the status of the output device (such as amount of paper left in tray, etc.). Those systems that do allow full bidirectional querying of printer status require specific hardware or licensed software. For example, IBM Corporation offers its Intelligent Printer Data Stream (IPDS) product that purportedly contains a command set for querying a printer for status information. The printer, however, must support the IPDS printer interface that recognizes a set of specially designed command sets in the IPDS architecture.
  • SUMMARY OF THE INVENTION
  • Consistent with this invention, in a network comprising an initiator, a server, and an output device, a server receives from an initiator a request comprising a network storage location of data to be output using the output device. The server places the request in a queue and schedules an output action based on the request. When the scheduled action is ready to be implemented, the server retrieves the output data from the network storage location which is different from the queue. A computer-readable medium consistent with the present invention contains instructions for outputting data in a network corresponding to tasks executable by a computer and performed by the server.
  • Another method for receiving data from an input device in a network consistent with this invention comprises the following operations, performed by the server. The server receives from input job information from an input device. The server stores the input job information to an input queue. The server receives a request from an initiator to process data from the input device based on the input job information. The server retrieves data from the input device based on the request and transmits the data to a location based on the data destination information. A computer-readable medium consistent with the present invention contains instructions for retrieving data from an input device in a network corresponding to tasks executable by a computer and performed by the server.
  • A network printer consistent with the present invention comprises a print mechanism for outputting data provided by the initiator. The network printer also comprises a controller for receiving from the initiator a request comprising the network storage location of data to be printed, placing the request in a queue, and scheduling the data to be printed based on the request. When the data is scheduled to be printed, the server retrieves the data from a location different from the queue, and transmits the data to the print mechanism.
  • An apparatus for controlling data in a network consistent with the present invention comprises a memory having program instructions; and a processor configured to receive a request from an initiator to output data provided by the initiator using the output device, the request comprising a network storage location of data to be output; place the request in a queue; schedule an output action based on the request in the queue, and retrieve the output data from the network storage location based on the request when the scheduled action is ready to be implemented, wherein the network storage location of the output data is different from the queue.
  • A further apparatus for controlling data in a network comprises a memory having program instructions; and a processor configured to receive input job information from an input device; store the input job information to an input queue; receive a request from an initiator to process data from the input device based on the input job information; and retrieve data from the input device based on the input job information when the input device is available.
  • Consistent with the present invention, a data control system comprises an initiator that transmits a request comprising a network storage location of data provided by the initiator to be output using the output device. A server receives the request, places the request in a queue, and schedules an action based on the request. When the scheduled action is ready to be implemented, the server retrieves the data from the network storage location which is different from the queue. The server may also retrieve input job information from an input device and retrieve data from an input device based on the input job information when the input device is available.
  • A network output device in a network comprises an output mechanism; a memory having program instructions; and a processor configured to receive a request from an initiator to output data provided by the initiator using the output device, the request comprising a network storage location of data to be output; place the request in a queue; schedule an output action based on the request in the queue, and retrieve the output data from the network storage location based on the request when the scheduled action is ready to be implemented, wherein the network storage location of the output data is different from the queue.
  • A network input device comprises a data input mechanism; a memory having program instructions; and a processor configured to receive input job information from an input device; store the input job information to an input queue; receive a request from an initiator to process data from the input device based on the input job information; and retrieve data from the input device based on the input job information when the input device is available.
  • Other objects and attainments together with a fuller understanding of the invention will become apparent and appreciated by referring to the following description and claims taken in conjunction with the accompanying drawings.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • In the drawings wherein like reference symbols refer to like parts.
  • The accompanying drawings, which are incorporated in and constitute a part of this specification, illustrate an embodiment of the invention and, together with the description, serve to explain the advantages and principles of the invention. In the drawings,
  • FIG. 1 is an illustration of a conventional network comprising clients, a printer, and a print server;
  • FIG. 2 illustrates a conventional print server;
  • FIG. 3 shows a system consistent with the present invention;
  • FIG. 4 shows a controller consistent with the present invention;
  • FIG. 5 is a flow diagram of operations performed to output to an output device consistent with the present invention;
  • FIG. 6 is a data flow diagram consistent with the present invention;
  • FIG. 7 is a data flow diagram of network printing consistent with the present invention;
  • FIG. 8 is a flow diagram of operations performed to retrieve data from an input device consistent with the present invention;
  • FIG. 9 is a data flow diagram consistent with the present invention; and
  • FIG. 10 is a flow diagram of operations performed to obtain status information consistent with the present invention.
  • DESCRIPTION OF THE PREFERRED EMBODIMENTS
  • Systems and methods consistent with the present invention operate in a network environment that has a client acting as an initiator of a transaction, a server, and an I/O device. In general, an initiator requests a server to perform an input/output transaction and negotiates the specifics of the transaction with the server. When the request from the initiator is ready to be executed, the server retrieves, or “pulls,” the data from one location and sends it to another.
  • One system and method consistent with the present invention uses the standard Web transfer protocol, HTTP. The HTTP protocol operates well over many different physical links and is a popular protocol for transferring various types of information between devices on a network. Implementation of the HTTP protocol reduces the need for the server to contain multiple protocol stacks for translating requests from initiators on different platforms. Reducing the number of protocol stacks in the server reduces complexity of the device thereby reducing development, testing, and troubleshooting time.
  • Reference will now be made in detail to implementations consistent with the principles of the present invention as illustrated in the accompanying drawings. Wherever possible, the same reference numbers will be used throughout the drawings and the following description to refer to the same or like parts.
  • A. Architecture
  • Systems and methods consistent with the present invention may be implemented using a variety of architectures that will be described in more detail below. In general, the systems will comprise an initiator, a server, and an I/O mechanism connected via a network. As will be described below, the I/O mechanism may be a “thin” device attached to the network, server, or client. A “thin” device is one that performs most I/O operations and stores most data on a server. The I/O mechanism may also be collocated in the same device as an additional server such as, for example, a conventional printer with embedded server.
  • FIG. 3 is a block diagram that illustrates an I/O system consistent with the present invention. As shown in FIG. 3, the I/O system comprises a client 305 acting as an initiator, a server 310, and an I/O device 350 capable of communicating with one another through network 300. Network 300 may be a LAN, WAN, or Internet comprising multiple LANs and WANs. Network 300 uses electric, electromagnetic, radio frequency, and/or optical signals to carry digital data streams. The signals that carry digital data through network 300 to and from client 305, server 310, and I/O device 350 are exemplary forms of carrier waves.
  • Client 305 and server 310 can send messages and receive data, including program code, through the network 300. For example, client 305 might transmit a request to download code for an application program to server 310, or server 310 may download the code to client 305 through network 300. One such downloaded application may be an input/output driver program, as described herein. In this manner, client 305 may obtain application code in the form of a carrier wave. For example, the application code may be encoded and transmitted as packets on a carrier wave.
  • In FIG. 3, both client 305 and server 310 contain controllers 308 and 318, respectively, similar to controller 405 as shown in FIG. 4. Controller 405 contains a processor 406, RAM 404, ROM 408, storage device 409, and communication interface 410 capable of communicating via bus 402. Processor 406 is a conventional microprocessor unit. RAM 404 can be a static or dynamic storage device, and stores information, temporary variables, and instructions to be executed by processor 406. ROM 408, which can be any type of nonvolatile static storage device appropriate to the task, stores static information and instructions for processor 406. A storage device 410, such as a magnetic disk or optical disk, is provided and coupled to bus 402 for storing information and instructions.
  • Controller 405 also includes a communication interface 410 coupled to bus 402. Communication interface 410 provides a two-way data communication coupling to a network. For example, communication interface 410 may be an ISDN card, cable modem, or a modem to provide a data communication connection to a corresponding type of telephone line. As another example, communication interface 410 may be a LAN card that provides a data communication connection to a compatible LAN. Wireless links may also be implemented. In any such implementation, communication interface 410 sends and receives electrical, electromagnetic or optical signals that carry digital data streams representing various types of information.
  • Consistent with one implementation of the invention, processor 406 executes one or more sequences of instructions in ROM 408. Executing the sequences of instructions in memory ROM 408 causes processor 406 to perform the method for controlling access to a I/O device described below. Alternatively, hard-wired circuitry may be used in place of or in combination with software instructions. Systems and methods consistent with the present invention are not limited to any specific combination of hardware circuitry and software.
  • The term “computer-readable medium” as used herein refers to any media that participates in providing instructions to processor 406 for execution. Such a medium may take many forms, including but not limited to, non-volatile media, volatile media, and transmission media. Non-volatile media includes, for example, optical or magnetic disks, such as ROM 408. Volatile media includes dynamic memory, such as RAM 404. Transmission media includes coaxial cables, copper wire, and fiber optics, including bus 402. Transmission media can also take the form of acoustic or light waves, such as those generated during radio-wave and infra-red data communications. Common forms of computer-readable media include a floppy disk, a flexible disk, hard disk, magnetic tape, or any other magnetic medium, a CD-ROM, any other optical medium, punch cards, papertape, any other physical medium with patterns of holes, a RAM, PROM, and EPROM, a FLASH-EPROM, any other memory chip or cartridge, a carrier wave as described above, or any other medium from which a computer can read data.
  • Various forms of computer readable media may be involved in carrying the instructions to processor 406 for execution. For example, the instructions may initially be carried on magnetic disk of a remote computer. The remote computer can load the instructions into its dynamic memory and send the instructions over a telephone line using a modem. A modem local to controller 405 can receive the data on the telephone line and use an infrared transmitter to convert the data to an infrared signal. An infrared detector coupled to bus 402 can receive the data carried in that signal and place the data on bus 402. Bus 402 carries the data to ROM 408, from which processor 406 retrieves and executes the instructions. The instructions received by processor 406 may also be stored on storage device 409 either before or after execution by processor 406.
  • Referring again to FIG. 3, client 305 and server 310 may be conventional PCs containing controllers 308 and 318, respectively. In addition, client 305 and server 310 may contain attached peripherals, such as displays, input devices, and devices for cursor control. In FIG. 3, client 305 is shown coupled via standard bus to display 312, input device 314, and cursor control 316. Server 310 is shown coupled via standard bus to display 322, input device 324, and cursor control 326. Displays 312 and 322 may be any conventional display device used for displaying information to a computer user, such as a CRT, LCD, LED, or custom display device. In addition, input devices 314 and 324 are devices, such as keyboards, that include alphanumeric and other keys for communicating information and command selections to client 305 and server 310. Another type of user input device is cursor control 316 and 326, such as a mouse, a trackball or cursor direction keys for communicating direction information and command selections to client 305 and server 310 and for controlling cursor movement on displays 312 and 322.
  • I/O device 350 may be an output device, such as a printer, or an input device, such as a scanner or digital camera. As shown in FIG. 3, I/O device 350 can include a controller 360 and an I/O mechanism 370. Controller 360 may be similar to controller 405 in FIG. 4, or may contain a smaller RAM, ROM, or storage device, or a processor with different capabilities. I/O mechanism 370 inputs or outputs data. If I/O device 350 is a laser printer, for example, I/O mechanism 370 may be a printer engine unit that converts data to printed pages. Pages can contain various types of content (such as text or graphics) and can be marked with a variety of compounds (such as ink, toner, heat, light, finisher, or pressure). Examples of output devices include printers, such as the Epson Stylus Color 5000. If I/O device 350 is an input device such a scanner, for example, I/O mechanism 370 may be a scan converter that converts printed information to digital data such as, for example, an Epson Scanner model ES-8000C.
  • Another example of an I/O system consistent with the present invention comprises a client 305 and I/O device 350. In this example, I/O device 350 comprises an embedded controller 360 that is similar to controller 405 illustrated in FIG. 4. Controller 360 then would perform both its own functions and those performed by controller 318 of server 310 in the embodiment described above. In this example, I/O device 350 may be an output device, such as a printer, or an input device, such as a scanner or digital camera with an enhanced controller. I/O device 350 may also be a conventional I/O device with an additional peripheral device, such as a PC Card. I/O device 350 can also contain only an I/O mechanism 370. In this embodiment, I/O device 350 will be physically connected to a device with a controller, such as client 305 or server 310.
  • The I/O systems described above may be used to implement methods of controlling access to I/O devices consistent with the present invention. FIG. 5 illustrates steps of a method of outputting data consistent with the present invention. FIG. 6 shows a data flow diagram illustrating the flow of data consistent with the method of FIG. 5. The steps of the method of FIG. 5 are described in more detail below with reference to the system depicted in FIG. 3 and the data flow diagram of FIG. 6. FIG. 7 illustrates one embodiment of the method of FIG. 5 in which the I/O device is a printer.
  • FIG. 8 illustrates steps of a method of receiving data from an input device consistent with the present invention. FIG. 9 shows a data flow diagram illustrating the flow of data consistent with the method of FIG. 8. The steps of the method of FIG. 8 are described in more detail below with reference to the system depicted in FIG. 3 and the data flow diagram of FIG. 9. The method of FIG. 8 can be implemented for receiving data from an input device, such as a scanner, fax, or digital camera.
  • B. Outputting to an Output Device
  • With reference to FIGS. 5 and 6, the method begins with an initiator remote from the server providing data to be output (step 505). As shown in FIG. 6, data may be generated by data source 605 of initiator 600, which is remote from server 610, or initiator 600 may provide the data by, for example, reading previously generated data from a disk or other computer-readable medium. Initiator 600 may be, for example, client 305 of FIG. 3. Referring again to FIG. 6, the data is conditioned into the proper format by, for example, adding formatting commands or other information. The conditioned data may then be stored locally in, for example, spool 620 of initiator 600 or in another physical location, such as storage 622, which may be a file server operatively connected to a network and capable of communicating with initiator 600. Concurrently, data source 605 notifies initiator agent 625 that the data is ready for use and gives initiator agent 625 the location where the data is stored. Initiator agent 625 may be, for example, an HTTP client.
  • Initiator 600 then submits a request to server 610, which may be, for example, server 310 of FIG. 3 (step 510). If the output device has an embedded server, initiator 600 may submit the request directly to I/O device 350. Initiator agent 625 of initiator 600 formulates the request as an HTTP “POST” command. The POST command contains a URL of the location of the data to be outputted. The body of the request contains the page/request. The page/request may be encoded using MIME, in which case the lines following the command might include ContentType and authentication headers, to prove the initiator has permission to perform the requested operation. The POST request may also include information about the requirements such as the destination output device, output format type, and other special requirements. Alternatively, a user may invoke a browser or custom HTTP client to submit the same information as the POST command to the server.
  • Referring again to FIG. 5, the server receives the request and determines whether it is capable of satisfying the request (step 515). Server 310 of FIG. 3 may determine whether it is capable of outputting to the device requested and whether it has available storage space in the queue. There are many circumstances in which a server, like server 310, may not be capable of handling the request. The server, for example, may not be connected via the network to the device requested. The server may also recognize that the request specifies a particular output format, such as PostScript, and that none of the devices with which it has connectivity is capable of outputting in the requested output type.
  • If the server can handle the request, it responds and acknowledges the request, such as by transmitting a status line telling the initiator that it has received the request, placing the request in a queue, or by scheduling the request (step 525). If the server cannot handle the request in its current form, the server determines whether it can convert the request into a request that it can satisfy (step 520). For example, if the initiator requested that the data be output in a format that is not supported, the server may recognize that it can convert the data into the requested format or can obtain via the network the necessary tools for converting the request (such as conversion software). If the server can convert the data into a proper form, the server acknowledges the request (step 525).
  • If the server determines that it cannot handle the request, the server sends back an acknowledgment that it received the request but cannot accommodate it at this time (step 522). At this point, the process may be terminated or the process may be configured so that the client continues to post requests until the job is accepted by the server. If so, the process would continue from step 510.
  • If the request is scheduled, the initiator posts the job to a memory structure or “queue” (step 525). The job posting consists of the URL of the data output file which is stored in a location other than the queue. The server periodically monitors the output queue. Server agent 640 accesses the queue and adds, controls, and removes jobs from the queue. If the queue has jobs for output devices, and the output device is ready (step 530), the server retrieves the data from the storage location designated by the URL (step 535).
  • The server fetches the data using the URL (step 535), for example, by executing an HTTP GET object request. As shown in FIG. 6, server agent 640 of server 610 may transmit the request to initiator agent 625 of initiator 600, which may access data stored in spool 620. In another example, server agent 640 of server 610 transmits a GET request directly to storage 622, which may be, for example, a file server remote to initiator 600 and server 610. The amount of data that the server gets at any one time may depend on the capabilities of the output device for which the data is destined. If, for example, the output device is a serial device, a GET request may obtain only a small block of data. If the output device is a page-oriented device, such as a laser printer, the GET request may bring back data one page at a time. There are instances where the GET request may copy and bring back the entire output file. If the output device needs to output multiple copies of a large file, for example, the output process may be quicker if the destination client retrieves a copy of the entire output file rather than make multiple requests one page at a time.
  • If the data needs conversion (step 536), the server may convert the data (step 537) before sending it to output device 680 (step 540). If the data does not need conversion, the server simply transmits it to output device 680 (step 540). The transfer may be by parallel interface or other suitable interface such as USB, RS 232, or 1394 interfaces, or by a network or internet. Transfer may also be via internal proprietary CPU bus or a standard bus.
  • Methods consistent with the present invention allow data storage to be distributed over the network thereby reducing the need for any one device, such as a server, to possess large amounts of disk space. By storing data across more locations on the network and retrieving data to be outputted or inputted when needed from its storage location, network operation is more efficient. The initiator will know whether the output device is capable of handling the output request prior to commencing the job.
  • C. Network Printing
  • The outputting method of the present invention may also be described with reference to network printing. As shown in FIG. 5, the method begins with an initiator remote from the print server providing data to be printed (step 505). In FIG. 7, like FIG. 6, data source 705 of initiator 700 provides the data to be printed by, for example, generating the data or reading previously generated data from a disk or other computer-readable medium. Referring again to FIG. 7, the data is conditioned into the proper format by, for example, adding formatting commands or other information. The conditioned data is stored and data source 705 gives initiator agent 725 the location where the data is stored. Initiator agent 725 may be, for example, an HTTP client.
  • Initiator 700 then submits a request to print server 710, which may be, for example, server 310 of FIG. 3 (step 510). If the output device is a printer with embedded server or controller, similar to I/O device 350 of FIG. 3, initiator 700 may submit the request directly to the enhanced printer. Initiator agent 725 of initiator 700 formulates the request as an HTTP “POST” command containing a URL of the location of the data to be printed. The POST request may also include information about the printer, printer format types, and other special requirements. Alternatively, a user may invoke a browser or custom HTTP client to submit the same information as the POST command to print server 710.
  • Referring again to FIG. 5, the server receives the request and determines whether it is capable of satisfying the request (step 515). Print server 710 may determine whether it is capable of printing to the device requested and whether it has available storage space in the queue. If print server 710 can handle the request, printer server agent 740 responds and acknowledges the request, such as by transmitting a status line telling the initiator that it has received the request, placing the request in a queue, or by scheduling the request (step 525). If print server 710 cannot handle the request in its current form, print server 710 determines whether it can convert the request into a request that it can satisfy (step 520). For example, if the initiator requested that the data be printed in a format that is not supported, print server 710 may recognize that it can convert the data into the requested format or can obtain via the network the necessary tools for converting the request (such as conversion software). If print server 710 can convert the data into a proper form, print server 710 acknowledges the request (step 525).
  • If print server 710 determines that it cannot handle the request, print server 710 sends back an acknowledgment that it received the request but cannot accommodate it at this time (step 522). At this point, the process may be terminated or the process may be configured so that the client continues to post requests until the job is accepted by print server 710. If so, the process would continue from step 510.
  • If the request is scheduled, the initiator posts the job to a memory structure or “queue” (step 525). The job posting consists of the URL of the data output file which is stored in a location other than the queue. Print server 710 periodically monitors the output queue. Server agent 740 accesses the queue and adds, controls, and removes jobs from the queue. If the queue has jobs for a printer, and the printer is ready (step 530), the server retrieves the data from the storage location designated by the URL (step 535).
  • The server fetches the data using the URL (step 535), for example, by executing an HTTP GET object request. As shown in FIG. 7, server agent 740 of print server 710 may transmit the request to initiator agent 725 of initiator 700, which may access data stored in spool 720. In another example, server agent 740 of print server 710 transmits a GET request directly to storage 722, which may be, for example, a file server remote to initiator 700 and print server 710. The amount of data that the server gets with at any one time may depend on the capabilities of the printer for which the data is destined. If, for example, the printer is a serial device, a GET request may obtain only a small block of data. If the printer is a page-oriented device, such as a laser printer, the GET request may bring back data one page at a time. There are instances where the GET request may copy and bring back the entire output file. If the printer needs to output multiple copies of a large file, for example, the output process may be quicker if the destination client retrieves a copy of the entire output file rather than make multiple requests one page at a time.
  • If the data needs conversion (step 536), the server may convert the data (step 537) before sending it to print mechanism 780 (step 540). If the data does not need conversion, the server simply transmits it to print mechanism 780 (step 540). Print mechanism 780 may be, for example, a printer engine unit that converts data to printed pages. The transfer may be by parallel interface or other suitable interface such as USB, RS 232, or 1394 interfaces, or by a network or internet. Transfer may also be via internal proprietary CPU bus or a standard bus.
  • Methods consistent with the present invention allow data storage to be distributed over the network thereby reducing the need for any one device, such as a server, to possess large amounts of disk space. By storing data across more locations on the network and retrieving data to be outputted or inputted when needed from its storage location, network operation is more efficient. The initiator will know whether the printer is capable of handling the output request prior to commencing the job and less paper will be wasted by printing improperly formatted print jobs.
  • D. Inputting From an Input Device
  • The I/O systems described above may also be used to control an input device that receives or generates data. FIG. 8 also illustrates an example of a method of receiving data from an input device, such as a scanner, digital video camera, or fax. The steps of the method are illustrated with reference to the systems depicted in FIG. 3 and the data flow diagram of FIG. 9.
  • Consistent with the present invention, the method begins with the generation of data at the input device (step 805), such as by putting a document on a scanner, turning on a video camera, or receiving a signal indicating an incoming fax. Receipt of input data therefore generally begins with the input device 980 of FIG. 9. Input device 980 will convert the received images to digital data and may also store the data to a location in input device 980, server 910, or another accessible storage location. Input device 980 may also accept a list of addresses to which the device would like to transfer the input data. For example, input device 980 may be a digital fax machine that accepts a document, converts it to digital data, and allows the user to input various network addresses that would like to receive the faxed information.
  • Input device 980 notifies the server that input device 980 has data to transmit by, for example, transmitting input job information to the server. The input job information may contain such information as format type or destination, such as a list of storage addresses or a list of recipients. Server 910 stores the input job information to an input queue (step 807). Initiator 910 may learn that information is available at input device 980 by, for example, receiving notice from server 910 or periodically checking the input queue (step 808).
  • To get the data from input device 980, initiator 900 sends a request to server 910 based on the input job information (step 810). Initiator agent 925 of initiator 900 formulates the request as an HTTP “GET” command containing a URL of the location of the data to be retrieved. The body of the request contains the page/request. The page/request may be encoded using MIME, in which case the lines following the command might include ContentType and authentication headers to prove the initiator has permission to perform the requested operation. The GET request may also include information about the requirements such as the input device, input format type, and other special requirements. Alternatively, a user may invoke a browser or custom HTTP client to submit the same information as the GET command to the server.
  • Server 910 receives the request. If the GET request contains a job identifier (step 815), server agent 940 either returns the status of the job to initiator 900 (step 822) or executes the GET request.
  • If the request does not specify a job identifier (step 815), server 910 recognizes the request as a new request. Server 910 then queries input device 980 for data by invoking server agent 940, which may be, for example, a process or CGI script. If input device 980 is active (step 825), input device 980 is currently satisfying a different job and is unavailable. Server agent 940 returns a “busy” status to initiator 900 (step 827).
  • If input device 980 is inactive (step 825), server agent 740 responds to initiator 900 with a job identifier (step 830). Server agent 940 then retrieves data from input device 980, for example, by executing an HTTP GET object request (step 835). The amount of data that server 910 receives with any one request may depend on the capabilities of the input device for which the job is destined. If, for example, the input device is a serial device, a GET request may obtain only a small block of data. If the input device is a page-oriented device, such as a laser printer, the GET request may bring back data one page at a time. Additionally, there are instances where the GET request may copy and bring back the entire input file. If the input device needs to input multiple copies of a large file, for example, the input process may be quicker if the destination client retrieves a copy of the entire input file rather than make multiple requests one page at a time.
  • Server 910 receives the data and determines whether the data needs conversion to the format requested by initiator 900 (step 836). If the data needs to be converted, server 910 converts the data (837). Server 910 transmits the data to a destination based either on the input job information or the request from the initiator (step 840). The transfer may be by parallel interface or other suitable interface such as USB, RS 232, or 1394 interfaces. The
  • E. Querying for Status
  • Using an HTTP protocol for communications between an initiator and a server, an initiator may also query the server (or an I/O device with embedded server) for status of the I/O request or the I/O device. FIG. 10 illustrates the steps of requesting and receiving status reports.
  • To obtain status, initiator 600 or 900 makes a status request (step 1005) including, for example, job identifier, information containing in the I/O request, or information identifying the I/O device (output device 680 or input device 980). In an HTTP environment, the status request may be made in the form of a GET request to a server, such as server 610 in FIG. 7 or server 910 in FIG. 9. The GET request may also be followed by header information that asks the server to send only that data that has been modified since the last status request.
  • Consistent with the present invention, status information is stored in a status information cache on the I/O server. Frequently contacting an I/O device for status may interrupt or slow data transfer, particularly if status is checked very frequently. Use of a status cache can control interruptions to I/O devices and improve performance. The cache is updated during idle states or when there is an error at the I/O device that prevents data transfer. Another advantage of caching status information on the server is that the server administrator can define the rules for updating the status cache and the frequency of status queries to the I/O device.
  • Before providing the initiator with status, the I/O server may check to see if the status cache contains current status information (step 1010). The server may, for example, compare the time on the request to see if the cache has been updated since the last status request. If the cache is current, the server may send the status information from the cache (step 1025).
  • If the status information is not current, the server determines whether it is an appropriate time to update the status cache. If not, the server may wait for an update (step 1015) or send the information that is in the cache. If, however, the server has not queried the I/O device in a long time, or if the server detects that the I/O device is inactive, the server may update the cache by querying the I/O device for status (step 1020).
  • The I/O server then formats a reply containing the status of the I/O device and transmits the information to the initiator (step 1025).
  • F. Conclusion
  • As described in detail above, methods and apparatus consistent with the present invention operate in a network environment having an initiator, a server, and an I/O device. The initiator requests a server to perform an input/output transactions and negotiates the specifics of the transaction with the server. When the request is ready to be initiated, the server “pulls” the data from one location and sends it to another. The foregoing description of an implementation of the invention has been presented for purposes of illustration and description. Modifications and variations are possible in light of the above teachings or may be acquired from practicing the invention.
  • Although systems and methods consistent with the present invention are described as operating in the exemplary distributed system, one skilled in the art will appreciate that the present invention can be practiced in other systems and programming environments. The scope of the invention is therefore defined by the claims and their equivalents.
  • While the invention has been described in conjunction with several specific embodiments, it is evident to those skilled in the art that many further alternatives, modifications and variations will be apparent in light of the foregoing description. Thus, the invention described herein is intended to embrace all such alternatives, modifications, applications and variations as may fall within the spirit and scope of the appended claims.

Claims (30)

1. A network printing system comprising:
a printing device having access to a network, and effective for receiving print requests over said network;
a client device having access to said network, and effective for submitting a first print request for a print job to said printing device over said network;
wherein said printing device accepts said first print request and stores it in a queue;
wherein said printing device initiates the downloading of said print job for printing and
wherein if said print job is not currently in a printing format supported by said printing device, then said printing device converts said print job into a supported printing format prior to printing.
2. The network printing system of claim 1, wherein said printing device waits until it is ready to execute said first print request before downloading said print job for printing.
3. The network printing system of claim 1, wherein:
said network is the Internet; and
said client device is remote from said printing device.
4. The network printing system of claim 1, wherein said printing device downloads said print job using HTTP communication protocols.
5. The network printing system of claim 1 further comprising:
a memory store remote from said client device and said printing device, said memory store being accessible over said network; wherein
said client device stores said print job in said memory store, and includes storage location information of said print job within said first print request; and
said printing device uses said storage location information to download said print job from said memory store over said network.
6. The network printing system of claim 1, wherein if said printing device does not have a conversion capability suitable for converting said print job into said supported printing format, then said printing device locates and downloads over said network the required conversion means for converting said print job into said supported printing format.
7. The network printing system of claim 1, wherein said printing device has direct access to said network.
8. The network printing system of claim 1, wherein said printing device has indirect access to said network through a network-access computing device.
9. The network printing system of claim 1, wherein if said printing device does not have a conversion capability suitable for converting said print job into said supported printing format, then said printing device informs said client device that its submitted print request will not be completed and does not down load said print job.
10. An internet printing system comprising:
a printing device having communication access to the internet, and effective for receiving print requests over the internet;
a first computing device remote from said printing device and having access to the internet, said first computing device being effective for submitting a first print request for a print job to said printing device over the internet;
wherein said printing device accepts said first print request and stores it in a queue;
wherein said printing device uses HTTP communication protocols to initiate the downloading of said print job for printing, and
wherein if said print job is not currently in a printing format supported by said printing device, then said printing device converts said print job into a supported printing format prior to printing.
11. The internet printing system of claim 10, wherein said printing device waits until it is ready to execute said first print request before downloading said print job for printing.
12. The internet printing system of claim 10, wherein said printing device uses an HTTP GET object request to download said print job.
13. The internet printing system of claim 10, wherein first computing device uses an HTTP POST command to submit said print request to said printing device.
14. The internet printing system of claim 10, wherein said printing device downloads said print job from said first computing device.
15. The internet printing system of claim 10 further comprising:
a memory store remote from said first computing device and from said printing device, said memory store being accessible over the internet; wherein
said first computing device stores said print job in said memory store, and includes storage location information of said print job within said first print request; and
said printing device uses said storage location information to locate and download said print job from said memory store over the internet.
16. The internet printing system of claim 10, wherein if said printing device does not have a conversion capability suitable for converting said print job into said supported printing format, then said printing device locates and downloads over the internet the required conversion means for converting said print job into said supported printing format.
17. The internet printing system of claim 10, wherein said printing device has direct access to the internet.
18. The network printing system of claim 10, wherein said printing device has indirect access to the internet through a second computing device.
19. The network printing system of claim 10, wherein if said printing device does not have a conversion capability suitable for converting said print job into said supported printing format, then said printing device informs said first computing device that its submitted print request will not be completed and does not down load said print job.
20. An internet printing system comprising:
a printing device having communication access to the internet;
a network server having communication access to the internet, and effective for receiving print requests over the internet;
a client computing device having communication access to the internet, said first computing device being effective for submitting a first print request for a print job to said network server over the internet;
wherein said network server accepts said first print request and stores it in a queue;
wherein said network server uses HTTP communication protocols to initiate the downloading of said print job for printing and to convey the print job over the internet to said printing device; and
wherein if said print job is not currently in a printing format supported by said printing device, then said network server converts said print job into said a supported printing format prior conveying it to said printing device.
21. The internet printing system of claim 19, wherein said client computing device is remote from said network server and said printing device, and wherein said network server is remote from said printing device.
22. The internet printing system of claim 19, wherein said network server waits until said printing device is ready to execute said first print request before downloading said print job for printing.
23. The internet printing system of claim 19, wherein said networks server uses an HTTP GET object request to download said print job.
24. The internet printing system of claim 19, wherein client computing device uses an HTTP POST command submit said print request to said network server.
25. The internet printing system of claim 19, wherein said network server downloads said print job from said client computing device.
26. The internet printing system of claim 19 further comprising:
a memory store accessible over the internet and remote from said client computing device, network server, and printing device; wherein
said first computing device stores said print job in said memory store, and includes storage location information of said print job within said first print request; and
said network server uses said storage location information to locate and download said print job from said memory store over the internet.
27. The internet printing system of claim 19, wherein if said network server does not have a conversion capability suitable for converting said print job into said supported printing format, then said network server locates and downloads over the internet the required conversion means for converting said print job into said supported printing format.
28. A network printing system comprising:
a printing device having access to a network, and effective for receiving print requests over said network;
a client device having access to said network, and effective for submitting a first print request for a print job to said printing device over said network;
wherein if said print job is not currently in a printing format supported by said printing device, and if said printing device does not have a conversion capability suitable for converting said print job into said supported printing format, then said printing device does not down load said print job.
29. The network printing system of claim 27, wherein if said printing device does not down load said print job, then said printing device further informs said client device that its submitted print request will not be completed.
30. The network printing system of claim 27, wherein if said print job is not currently in a printing format supported by said printing device and said printing device does have a conversion capability suitable for converting said print job into a supported printing format, then said printing device down loads said print job, converts the downloaded print job into said supported format prior to printing.
US11/420,696 1998-11-06 2006-05-26 Method and Apparatus for Controlling an Input or Output Device over the Internet Abandoned US20060206575A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US11/420,696 US20060206575A1 (en) 1998-11-06 2006-05-26 Method and Apparatus for Controlling an Input or Output Device over the Internet

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US09/187,193 US6636891B1 (en) 1998-11-06 1998-11-06 Methods and apparatus for controlling an input or output device over the internet
US10/117,874 US7069341B2 (en) 1998-11-06 2002-04-08 Method and apparatus for controlling an input or output device over the internet
US11/420,696 US20060206575A1 (en) 1998-11-06 2006-05-26 Method and Apparatus for Controlling an Input or Output Device over the Internet

Related Parent Applications (2)

Application Number Title Priority Date Filing Date
US09/187,193 Division US6636891B1 (en) 1998-11-06 1998-11-06 Methods and apparatus for controlling an input or output device over the internet
US10/117,874 Division US7069341B2 (en) 1998-11-06 2002-04-08 Method and apparatus for controlling an input or output device over the internet

Publications (1)

Publication Number Publication Date
US20060206575A1 true US20060206575A1 (en) 2006-09-14

Family

ID=22687965

Family Applications (3)

Application Number Title Priority Date Filing Date
US09/187,193 Expired - Lifetime US6636891B1 (en) 1998-11-06 1998-11-06 Methods and apparatus for controlling an input or output device over the internet
US10/117,874 Expired - Lifetime US7069341B2 (en) 1998-11-06 2002-04-08 Method and apparatus for controlling an input or output device over the internet
US11/420,696 Abandoned US20060206575A1 (en) 1998-11-06 2006-05-26 Method and Apparatus for Controlling an Input or Output Device over the Internet

Family Applications Before (2)

Application Number Title Priority Date Filing Date
US09/187,193 Expired - Lifetime US6636891B1 (en) 1998-11-06 1998-11-06 Methods and apparatus for controlling an input or output device over the internet
US10/117,874 Expired - Lifetime US7069341B2 (en) 1998-11-06 2002-04-08 Method and apparatus for controlling an input or output device over the internet

Country Status (3)

Country Link
US (3) US6636891B1 (en)
EP (2) EP1571552A3 (en)
JP (2) JP2000227890A (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20080276177A1 (en) * 2007-05-03 2008-11-06 Microsoft Corporation Tag-sharing and tag-sharing application program interface

Families Citing this family (51)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6988123B2 (en) * 1998-11-06 2006-01-17 Seiko Epson Corporation Methods and apparatus for remote execution of an application over the internet
US8266266B2 (en) 1998-12-08 2012-09-11 Nomadix, Inc. Systems and methods for providing dynamic network authorization, authentication and accounting
JP2000235464A (en) * 1999-02-15 2000-08-29 Canon Inc Printing system and its control method
TW571599B (en) * 1999-09-27 2004-01-11 Qualcomm Inc Method and system for querying attributes in a cellular communications system
WO2001031861A1 (en) 1999-10-22 2001-05-03 Nomadix, Inc. Systems and methods for dynamic bandwidth management on a per subscriber basis in a communications network
US7265854B1 (en) * 2000-01-24 2007-09-04 International Business Machines Corporation Method and apparatus for managing complex presentation objects using globally-unique identifiers
US7092983B1 (en) 2000-04-19 2006-08-15 Silicon Graphics, Inc. Method and system for secure remote distributed rendering
US7783695B1 (en) * 2000-04-19 2010-08-24 Graphics Properties Holdings, Inc. Method and system for distributed rendering
US7623253B1 (en) * 2000-05-15 2009-11-24 Hewlett-Packard Development Company, L.P. Indirect processing of print jobs
US7249369B2 (en) * 2000-07-10 2007-07-24 Oracle International Corporation Post data processing
US7194764B2 (en) 2000-07-10 2007-03-20 Oracle International Corporation User authentication
US6914694B1 (en) * 2000-10-12 2005-07-05 Seiko Epson Corporation Web print system with image enhancement
US7139819B1 (en) * 2000-10-31 2006-11-21 Verizon Laboratories Inc. Systems and methods for managing faults in a network
US20030014476A1 (en) * 2001-01-03 2003-01-16 Peterson David Allen Thin client computer operating system
US7185364B2 (en) 2001-03-21 2007-02-27 Oracle International Corporation Access system interface
US7088461B2 (en) * 2001-07-02 2006-08-08 Alps Electric Co., Ltd. Printer for printing in conjunction with a server
US6959437B2 (en) * 2001-09-07 2005-10-25 Sharp Laboratories Of America, Inc. System and method for installing printer driver software
US20030088476A1 (en) * 2001-11-02 2003-05-08 Shell Sterling Simpson Pay-for-printing system and method
US7181485B1 (en) * 2001-11-26 2007-02-20 Integrated Device Technology, Inc. Variably delayable transmission of packets between independently clocked source, intermediate, and destination circuits while maintaining orderly and timely processing in one or both of the intermediate and destination circuits
US7225256B2 (en) 2001-11-30 2007-05-29 Oracle International Corporation Impersonation in an access system
US20030112306A1 (en) * 2001-12-13 2003-06-19 Simpson Shell S. System and method for form processing
US7400425B2 (en) * 2002-04-16 2008-07-15 Hewlett-Packard Development Company, L.P. System and method for facilitating network printing
US7317550B2 (en) * 2002-05-03 2008-01-08 Hewlett-Packard Development Company, L.P. Printing utilizing external storage
WO2003107171A1 (en) * 2002-06-01 2003-12-24 セイコーエプソン株式会社 Printer, server and print system, and data receiving device and data sending/receiving system
US7443523B2 (en) 2002-11-22 2008-10-28 Xerox Corporation Printing to a client site from an application running on a remote server
US8081323B2 (en) * 2003-01-31 2011-12-20 Canon Kabushiki Kaisha Apparatus and method for transferring data to remote printer
JP4266870B2 (en) * 2003-04-07 2009-05-20 キヤノン株式会社 Image output system, printing apparatus, imaging apparatus, communication apparatus, information processing apparatus, storage apparatus, and method thereof
US20040239978A1 (en) * 2003-05-29 2004-12-02 Hewlett-Packard Co. Method and apparatus for tracking a plurality of image devices in a network
US8203731B2 (en) * 2003-06-10 2012-06-19 Hewlett-Packard Development Company, L.P. Hard imaging devices, and hard imaging device file system accessing and sharing method
US7773248B2 (en) * 2003-09-30 2010-08-10 Brother Kogyo Kabushiki Kaisha Device information management system
US7904487B2 (en) 2003-10-09 2011-03-08 Oracle International Corporation Translating data access requests
US7882132B2 (en) 2003-10-09 2011-02-01 Oracle International Corporation Support for RDBMS in LDAP system
US7440809B2 (en) * 2004-07-14 2008-10-21 York International Corporation HTML driven embedded controller
JP4367929B2 (en) * 2004-08-27 2009-11-18 キヤノン株式会社 Mobile phone, printing system and control method thereof
US8781848B1 (en) 2004-09-10 2014-07-15 Ldm Group, Llc Systems and methods for providing an inducement of a purchase in conjunction with a prescription
US8533004B1 (en) 2004-09-10 2013-09-10 Ldm Group, Llc Systems and methods for patient communications in conjunction with prescription medications
US8688813B2 (en) 2006-01-11 2014-04-01 Oracle International Corporation Using identity/resource profile and directory enablers to support identity management
US7777905B2 (en) * 2006-01-24 2010-08-17 Ricoh Company, Ltd. MIME type-based printer driver selection
US7999951B2 (en) * 2006-12-29 2011-08-16 Sharp Laboratories Of America Direct print handling of native and non-native data formats
US20080263071A1 (en) * 2007-04-19 2008-10-23 Sharp Laboratories Of America, Inc. Systems and methods for driverless imaging of documents
US20080313334A1 (en) * 2007-06-18 2008-12-18 Nokia Corporation Data exchange protocol enhancement to query object permissions
US8838760B2 (en) * 2007-09-14 2014-09-16 Ricoh Co., Ltd. Workflow-enabled provider
US8860981B2 (en) * 2010-03-29 2014-10-14 Konica Minolta Laboratory U.S.A., Inc. Systems and methods for print job scheduling
JP5263211B2 (en) 2010-03-30 2013-08-14 ブラザー工業株式会社 Server, printer, and computer program for server
US9223890B2 (en) 2011-03-15 2015-12-29 Hewlett-Packard Development Company, L.P. System and method of processing content using a uniform resource identifier
US9092167B2 (en) 2011-04-04 2015-07-28 Hewlett-Packard Development Company, L.P. Systems and methods for managing a print job
DE102011109748B4 (en) 2011-08-09 2014-08-14 Eht Vermögensverwaltung Ug METHOD FOR OPERATING A NETWORK SYSTEM
US9036188B2 (en) * 2012-01-19 2015-05-19 Seiko Epson Corporation Data transmission device, data transfer server, and data transmission method
JP6048134B2 (en) * 2012-12-28 2016-12-21 ブラザー工業株式会社 Relay device, relay device program, and communication method
US9792108B2 (en) 2015-08-12 2017-10-17 Comcast Cable Communications, Llc Scheme for managing last-modified information
US10015230B1 (en) * 2016-02-09 2018-07-03 Robert Buergi Copying and pasting among networked devices

Citations (28)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5220674A (en) * 1987-07-17 1993-06-15 Digital Equipment Corporation Local area print server for requesting and storing required resource data and forwarding printer status message to selected destination
US5276879A (en) * 1989-10-31 1994-01-04 Hewlett-Packard Company Portable, resource sharing file server using co-routines
US5287194A (en) * 1992-11-25 1994-02-15 Xerox Corporation Distributed printing
US5307490A (en) * 1992-08-28 1994-04-26 Tandem Computers, Inc. Method and system for implementing remote procedure calls in a distributed computer system
US5450571A (en) * 1991-08-29 1995-09-12 Xerox Corporation Dialog filtering process for a printing system to filter out non-selectable print programming selections
US5535222A (en) * 1993-12-23 1996-07-09 At&T Corp. Method and apparatus for controlling a plurality of systems via a boundary-scan port during testing
US5566278A (en) * 1993-08-24 1996-10-15 Taligent, Inc. Object oriented printing system
US5602974A (en) * 1994-10-05 1997-02-11 Microsoft Corporation Device independent spooling in a print architecture
US5666532A (en) * 1994-07-26 1997-09-09 Novell, Inc. Computer method and apparatus for asynchronous ordered operations
US5666486A (en) * 1995-06-23 1997-09-09 Data General Corporation Multiprocessor cluster membership manager framework
US5687320A (en) * 1995-04-27 1997-11-11 Hewlett-Packard Company Indirect method for network peripheral automated detection
US5689642A (en) * 1993-10-04 1997-11-18 Xerox Corporation Recipient prioritized communication channel profiles
US5699495A (en) * 1994-07-27 1997-12-16 Microsoft Corporation Point-and-print in a distributed environment
US5701451A (en) * 1995-06-07 1997-12-23 International Business Machines Corporation Method for fulfilling requests of a web browser
US5822507A (en) * 1991-09-04 1998-10-13 Canon Kabushiki Kaisha Scanner printer server for selectively controlling a scanner and a printer in accordance with a copy operation
US5898821A (en) * 1997-01-21 1999-04-27 Xerox Corporation Printing system with halftone substitution capability
US5995723A (en) * 1997-11-18 1999-11-30 Xerox Corporation Client subsystem for changing document/job attributes in a network printing system
US6003065A (en) * 1997-04-24 1999-12-14 Sun Microsystems, Inc. Method and system for distributed processing of applications on host and peripheral devices
US6020973A (en) * 1997-04-15 2000-02-01 Xerox Corporation Centralized print server for interfacing one or more network clients with a plurality of printing devices
US6085227A (en) * 1998-03-20 2000-07-04 International Business Machines Corporation System and method for operating scientific instruments over wide area networks
US6092078A (en) * 1998-04-24 2000-07-18 Axis Communications Ab Method and apparatus for interfacing network peripheral devices with a browser
US6119137A (en) * 1997-01-30 2000-09-12 Tumbleweed Communications Corp. Distributed dynamic document conversion server
US6184996B1 (en) * 1997-06-18 2001-02-06 Hewlett-Packard Company Network printer with remote print queue control procedure
US6201611B1 (en) * 1997-11-19 2001-03-13 International Business Machines Corporation Providing local printing on a thin client
US6266160B1 (en) * 1997-06-02 2001-07-24 Matsushita Graphic Communication Systems, Inc. Internet facsimile apparatus
US6327045B1 (en) * 1997-09-18 2001-12-04 Microsoft Corporation Computer network
US6453127B2 (en) * 1997-09-26 2002-09-17 Nexpress Solutions Llc Establishment at a remote location of an internet/intranet user interface to a copier/printer
US6476927B1 (en) * 1998-01-21 2002-11-05 Electronics For Imaging, Inc. Job token printer assignment system

Family Cites Families (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH05292240A (en) 1991-09-04 1993-11-05 Canon Inc Scanner printer server and its system
KR100259417B1 (en) 1996-04-04 2000-06-15 오케노 다카시 Facsimile communication method and facsimile
KR980006297U (en) * 1996-07-04 1998-04-30 이경호 Sandals with mini-legs and ankle straps
JPH10240552A (en) * 1996-12-26 1998-09-11 Canon Inc Information processor and its method
EP0854415B1 (en) 1996-12-27 2004-05-19 Canon Kabushiki Kaisha Printing system
JP3745070B2 (en) 1997-02-19 2006-02-15 キヤノン株式会社 Data communication apparatus and method
US5982996A (en) * 1997-03-13 1999-11-09 Hewlett-Packard Company Mechanism for printer driver switching in windows operating systems to allow distribution of print jobs to an output device from a single print request within an application
JPH10275063A (en) 1997-03-28 1998-10-13 Nec Corp Low-load communication printer
EP0872792A3 (en) 1997-04-17 2000-04-26 Adobe Systems, Inc. Network communication with printing systems
US6240456B1 (en) * 1997-09-18 2001-05-29 Microsoft Corporation System and method for collecting printer administration information
US6128279A (en) 1997-10-06 2000-10-03 Web Balance, Inc. System for balancing loads among network servers
US6219151B1 (en) * 1998-08-24 2001-04-17 Hitachi Koki Imaging Solutions, Inc. Network printing system
US6373585B1 (en) * 1998-08-26 2002-04-16 International Business Machines Corporation Load balancing for processing a queue of print jobs
US6412022B1 (en) * 1998-09-30 2002-06-25 Hewlett-Packard Company Simultaneous print and scan logical channel network multifunction peripheral
US6289371B1 (en) * 1998-09-30 2001-09-11 Hewlett-Packard Company Network scan server support method using a web browser

Patent Citations (29)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5220674A (en) * 1987-07-17 1993-06-15 Digital Equipment Corporation Local area print server for requesting and storing required resource data and forwarding printer status message to selected destination
US5276879A (en) * 1989-10-31 1994-01-04 Hewlett-Packard Company Portable, resource sharing file server using co-routines
US5450571A (en) * 1991-08-29 1995-09-12 Xerox Corporation Dialog filtering process for a printing system to filter out non-selectable print programming selections
US5933580A (en) * 1991-09-04 1999-08-03 Canon Kabushiki Kaisha Scanner printer server
US5822507A (en) * 1991-09-04 1998-10-13 Canon Kabushiki Kaisha Scanner printer server for selectively controlling a scanner and a printer in accordance with a copy operation
US5307490A (en) * 1992-08-28 1994-04-26 Tandem Computers, Inc. Method and system for implementing remote procedure calls in a distributed computer system
US5287194A (en) * 1992-11-25 1994-02-15 Xerox Corporation Distributed printing
US5566278A (en) * 1993-08-24 1996-10-15 Taligent, Inc. Object oriented printing system
US5689642A (en) * 1993-10-04 1997-11-18 Xerox Corporation Recipient prioritized communication channel profiles
US5535222A (en) * 1993-12-23 1996-07-09 At&T Corp. Method and apparatus for controlling a plurality of systems via a boundary-scan port during testing
US5666532A (en) * 1994-07-26 1997-09-09 Novell, Inc. Computer method and apparatus for asynchronous ordered operations
US5699495A (en) * 1994-07-27 1997-12-16 Microsoft Corporation Point-and-print in a distributed environment
US5602974A (en) * 1994-10-05 1997-02-11 Microsoft Corporation Device independent spooling in a print architecture
US5687320A (en) * 1995-04-27 1997-11-11 Hewlett-Packard Company Indirect method for network peripheral automated detection
US5701451A (en) * 1995-06-07 1997-12-23 International Business Machines Corporation Method for fulfilling requests of a web browser
US5666486A (en) * 1995-06-23 1997-09-09 Data General Corporation Multiprocessor cluster membership manager framework
US5898821A (en) * 1997-01-21 1999-04-27 Xerox Corporation Printing system with halftone substitution capability
US6119137A (en) * 1997-01-30 2000-09-12 Tumbleweed Communications Corp. Distributed dynamic document conversion server
US6020973A (en) * 1997-04-15 2000-02-01 Xerox Corporation Centralized print server for interfacing one or more network clients with a plurality of printing devices
US6003065A (en) * 1997-04-24 1999-12-14 Sun Microsystems, Inc. Method and system for distributed processing of applications on host and peripheral devices
US6266160B1 (en) * 1997-06-02 2001-07-24 Matsushita Graphic Communication Systems, Inc. Internet facsimile apparatus
US6184996B1 (en) * 1997-06-18 2001-02-06 Hewlett-Packard Company Network printer with remote print queue control procedure
US6327045B1 (en) * 1997-09-18 2001-12-04 Microsoft Corporation Computer network
US6453127B2 (en) * 1997-09-26 2002-09-17 Nexpress Solutions Llc Establishment at a remote location of an internet/intranet user interface to a copier/printer
US5995723A (en) * 1997-11-18 1999-11-30 Xerox Corporation Client subsystem for changing document/job attributes in a network printing system
US6201611B1 (en) * 1997-11-19 2001-03-13 International Business Machines Corporation Providing local printing on a thin client
US6476927B1 (en) * 1998-01-21 2002-11-05 Electronics For Imaging, Inc. Job token printer assignment system
US6085227A (en) * 1998-03-20 2000-07-04 International Business Machines Corporation System and method for operating scientific instruments over wide area networks
US6092078A (en) * 1998-04-24 2000-07-18 Axis Communications Ab Method and apparatus for interfacing network peripheral devices with a browser

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20080276177A1 (en) * 2007-05-03 2008-11-06 Microsoft Corporation Tag-sharing and tag-sharing application program interface

Also Published As

Publication number Publication date
EP1571552A2 (en) 2005-09-07
US7069341B2 (en) 2006-06-27
JP2000227890A (en) 2000-08-15
US6636891B1 (en) 2003-10-21
EP0999494A2 (en) 2000-05-10
US20020109861A1 (en) 2002-08-15
EP1571552A3 (en) 2006-05-10
EP0999494A3 (en) 2002-02-13
JP2003131823A (en) 2003-05-09

Similar Documents

Publication Publication Date Title
US7069341B2 (en) Method and apparatus for controlling an input or output device over the internet
RU2349953C2 (en) Translation of documents for network printing on client
US6184996B1 (en) Network printer with remote print queue control procedure
US6959437B2 (en) System and method for installing printer driver software
CN100430881C (en) Distributed peripheral device control system and method
US20100073707A1 (en) Systems and methods for facilitating virtual cloud printing
JPH10301732A (en) Network printing system
KR19990045431A (en) It provides local printing on thin clients,
US6988123B2 (en) Methods and apparatus for remote execution of an application over the internet
US20060287962A1 (en) Information processor, method for controlling the same, and image forming system
US7502134B2 (en) Network system and network interface card
TW200415864A (en) A system for processing print jobs
US7457839B2 (en) Selective rejection of access to parameters of an option application detachable from an embedded apparatus including web server function
JP2005004751A (en) System and method for transmitting native structure document printing instruction
US20030195952A1 (en) Digital transmitter device configuration
JP2001043055A (en) Printer, printer control method, print system, and recording medium
JPH11154061A (en) Method and device for printer control
JP2000284926A (en) Print processing system and its method
JPH08249141A (en) Network processor
JPH09179833A (en) Job processing system
US20040246518A1 (en) Systems and methods for spooling a print job
JP2004086354A (en) Image processor
JP4159869B2 (en) Information providing apparatus, information providing method, information providing system, and information providing program
JP3356572B2 (en) Digital MFP
JP2004206456A (en) Information providing device, information providing method, information providing system, and information providing program

Legal Events

Date Code Title Description
STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION