US20130278957A1 - Metadata retrieval for multi-function devices - Google Patents

Metadata retrieval for multi-function devices Download PDF

Info

Publication number
US20130278957A1
US20130278957A1 US13/921,005 US201313921005A US2013278957A1 US 20130278957 A1 US20130278957 A1 US 20130278957A1 US 201313921005 A US201313921005 A US 201313921005A US 2013278957 A1 US2013278957 A1 US 2013278957A1
Authority
US
United States
Prior art keywords
metadata
peripheral device
received
function
identifiers
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
US13/921,005
Inventor
Erik Gubitz
Farhan Ahmed
Abed Jawad
Aayaz Bhorania
Palani Perumal
Mitsuru Saito
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.)
Microsoft Technology Licensing LLC
Original Assignee
Microsoft 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 Microsoft Corp filed Critical Microsoft Corp
Priority to US13/921,005 priority Critical patent/US20130278957A1/en
Publication of US20130278957A1 publication Critical patent/US20130278957A1/en
Assigned to MICROSOFT TECHNOLOGY LICENSING, LLC reassignment MICROSOFT TECHNOLOGY LICENSING, LLC ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: MICROSOFT CORPORATION
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/1293Printer information exchange with computer
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F13/00Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • G06F13/10Program control for peripheral devices
    • G06F13/102Program control for peripheral devices where the programme performs an interfacing function, e.g. device driver
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/4401Bootstrapping
    • G06F9/4411Configuring for operating with peripheral devices; Loading of device drivers
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/951Indexing; Web crawling techniques
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q10/00Administration; Management
    • G06Q10/10Office automation; Time management

Definitions

  • This invention relates generally to computer software, and more particularly to software which enables a computer to interoperate with one or more peripheral devices.
  • each hardware identifier is used to identify a function performed by the peripheral device. If the peripheral device is a multi-function device, such as a printer/scanner/fax machine, the client computer may receive one or more hardware identifiers each identifying the print function, the scan function and the fax function. Once received, each hardware identifier is used by the client computer to identify a driver that enables the client computer to interoperate with, and employ the corresponding function provided by, the peripheral device.
  • More than one hardware identifier may be provided for each function, because there may be more than one driver which will allow the client computer to employ a particular function.
  • many device manufacturers typically supply multiple drivers for a given device function, with one driver being very specific to the function, and others being more generic.
  • More generic drivers typically may be used by a client computer to employ functions provided by any of multiple devices (or families of devices), but may not allow the client computer to employ all of the aspects of a given device function.
  • the manufacturer of a monitor may include one driver that enables a client computer to employ all of the display functionality provided by the monitor, and several more generic drivers that do not enable the client computer to employ all of this functionality, but allow the client computer to interoperate with any of several monitors.
  • hardware identifiers for a given function are provided to a client computer in a sequence which ranges from most specific to most generic. That is, for each function performed by the device, the client computer receives a sequence ranging from the most specific hardware identifier to the most generic. If the device is a multi-function device, the hardware identifiers for each individual function conform to this sequence. Thus, if a device has two functions, and two hardware identifiers are provided by the device for each function, the client computer receives two groups of identifiers, each arranged in a sequence from most specific to most generic. Once the hardware identifiers are received by the client computer, it attempts to match hardware identifiers in each group in sequence with a driver (e.g., stored on the client computer).
  • a driver e.g., stored on the client computer.
  • the client computer proceeds with trying to match the next hardware identifier in the sequence in the group. Once a matching driver is found for a group, the client computer may employ the function represented by identifiers in the group.
  • Device 101 includes hardware identifiers 105 , which are provided to client computer 102 when device 101 is connected thereto, and are employed by matching facility 110 (which may be a portion of an operating system executing on client computer 102 ) to retrieve one or more drivers.
  • Hardware identifiers 105 include identifiers for each of three different functions, with the first digit in each identifier following the letter “H” identifying the function. For example, hardware identifiers H 11 and H 12 correspond to a first function, H 21 , H 22 and H 23 correspond to a second function, and H 31 corresponds to a third function.
  • the identifiers for each function are arranged in a sequence from most specific to most generic, with the second digit in each identifier following the letter “H” identifying a level of specificity.
  • hardware identifier H 11 for the first function is more specific than is H 12
  • hardware identifier H 22 for the second function is more specific than is H 23 .
  • matching facility 110 receives the hardware identifiers for each function in sequence, and attempts to match each hardware identifier for a given function in turn to a driver stored in storage facility 115 . For example, for hardware identifiers relating to the first function, matching facility 110 first attempts to match identifier H 11 to a driver stored in storage element 115 , and if no match is found, proceeds to try to match identifier H 12 . Similarly, matching facility 110 attempts to match identifiers for the second function (i.e., H 21 , H 22 and H 23 ) and for the third function (i.e., H 31 ) to a driver in storage facility 115 . When a matching driver is found for any function, client computer 102 employs the corresponding function as defined by the driver.
  • a client computer that receives hardware identifiers corresponding to multiple functions (such as might be supplied by a multi-function device) “perceives” the device as multiple distinct entities (i.e., one entity for each function defined by a set of hardware identifiers). For example, when a multi-function device such as a printer/scanner/fax machine provides hardware identifiers for its functions to a client computer, the client computer perceives the device as three entities, providing print, scan and fax capabilities, respectively.
  • a peripheral device i.e., any device attached to a client computer to provide functionality, such as a printer, disk drive, microphone, camera, cellular telephone, media player, microphone, etc.
  • client computer a term used herein for convenience, and intended to include any computing device, such as a desktop computer, laptop computer, personal digital assistant, cellular telephone, other computing device, or any combination thereof
  • client computer may be used to not only identify specific functions performed by the peripheral device, but also may identify the device itself to the client computer. Enabling the client computer to identify the device itself, rather than just its function(s), may allow the client computer to present an interface that displays information about the device and allows a user to configure the device rather than just its individual functions.
  • the client computer can provide a richer and more meaningful user experience with respect to the device, such as by allowing the user to view information about the device and to manage relationships between individual functions.
  • the user may interact with the device itself, rather than just separately configuring its individual functions.
  • information provided by the device is used to retrieve metadata that includes various information about the device, such as one or more graphical illustrations of the device, the manufacturer's name, information about the device's features, and/or available user configuration tasks.
  • the metadata may, for example, be employed by one or more software routines executing on a client computer to present an interface to the user that enables interaction with and/or configuration of the device and its functions.
  • Metadata may be stored on the client computer and/or one or more server computers. Some embodiments provide for a process whereby the client computer, upon receiving information from the device, first attempts to match the information to metadata stored on the client computer, and if the attempt is unsuccessful or the metadata is deficient (e.g., outdated or stale), the client computer passes the information to one or more server computers, which then attempt(s) to match the information to metadata accessible to the server computer(s). When a match is found, the metadata may be passed back to the client computer, which may use the information to present a user interface, and may update metadata stored locally.
  • the client computer upon receiving information from the device, first attempts to match the information to metadata stored on the client computer, and if the attempt is unsuccessful or the metadata is deficient (e.g., outdated or stale), the client computer passes the information to one or more server computers, which then attempt(s) to match the information to metadata accessible to the server computer(s).
  • the metadata may be passed back to the client computer, which may use the information to present a
  • FIG. 1 is a block diagram depicting an example technique for matching hardware identifiers provided by a peripheral device to drivers on a client computer, according to the prior art
  • FIG. 2 is a block diagram depicting an example technique for matching hardware identifiers provided by a peripheral device with metadata about the device, according to some embodiments of the invention
  • FIG. 3 is a flowchart depicting an example process for identifying metadata relating to a peripheral device using information provided by the device, according to some embodiments of the invention
  • FIG. 4 is a block diagram illustrating a technique for arranging information received from a peripheral device into a sequence, according to some embodiments of the invention
  • FIG. 5 is a flowchart depicting an example process for identifying metadata about a device using information provided by the device, according to some embodiments of the invention.
  • FIG. 6 is a block diagram depicting an example computer system on which some embodiments of the invention may be implemented.
  • FIG. 7 is a block diagram depicting an example memory on which instructions embodying aspects of the present invention may be stored.
  • information received from a peripheral device may be used to retrieve metadata which includes information about the device itself, rather than its individual function(s).
  • the metadata may enable a client computer to provide the user with a richer and more meaningful experience in interacting with the device than is provided by conventional arrangements.
  • a client computer may provide an interface which serves as a “single point of entry” for configuring the device and its various functions, allows the user to view and manage the relationships between individual functions, and/or visually identifies the device in a more precise and aesthetically pleasing manner than the function icons conventionally employed.
  • the client computer may use information provided by metadata to provide a graphical user interface (e.g., via a “control panel” window, and/or any other suitable interface paradigm) which identifies the device, enables the user to configure its individual functions (e.g., synchronizing address book entries stored on the device with counterpart data on the client computer), and allows the user to configure features spanning multiple functions (e.g., by indicating that a particular media file should be played when a telephone call is received from a certain person).
  • a graphical user interface e.g., via a “control panel” window, and/or any other suitable interface paradigm
  • the user may use information provided by metadata to provide a graphical user interface (e.g., via a “control panel” window, and/or any other suitable interface paradigm) which identifies the device, enables the user to configure its individual functions (e.g., synchronizing address book entries stored on the device with counterpart data on the client computer), and allows the user to configure features spanning multiple functions (e.g., by
  • Metadata may be retrieved using information that is provided when the device is connected to a client computer.
  • a hardware identifier and/or other information provided to the client computer by the device may be used to retrieve metadata that includes various information about the device, such as a photograph and/or graphical illustration of the device, one or more available configuration tasks, the manufacturer's name, and/or any other suitable information.
  • some or all of these items of information may be processed by one or more software routines executing on the client computer to cause an interface to be presented enabling the user to configure and otherwise interact with the device and its functions.
  • Metadata may, for example, be provided by a manufacturer or supplier of the device, and may be stored on the client computer, one or more server computers coupled to the client computer via one or more networks, and/or any other suitable component.
  • the client computer may attempt to use information provided by the device to retrieve metadata for the device by constructing and executing a query against a metadata storage facility residing on the client computer. If this attempt at retrieval is successful, items of information included in the metadata may be used to present an interface to a user of the client computer. If the retrieval attempt is unsuccessful, or if retrieved metadata is determined to be deficient in some way (e.g., outdated, incorrect, stale, etc.), the information and/or query may be communicated to one or more server computers for execution on one or more other metadata storage facilities.
  • a metadata storage facility residing on the client computer.
  • Metadata is successfully retrieved by a server computer, it may be provided to the client computer, which may employ it to present an interface to the user, and may employ it to update metadata stored on the client computer so that the metadata can subsequently be retrieved without requiring communication with a server computer.
  • the invention is not limited to such a retrieval technique, and metadata may be retrieved in any suitable fashion.
  • FIG. 2 depicts a system 200 which enables information provided by a device 201 to a client computer 202 to be used to retrieve metadata about the device.
  • device 201 which may be any suitable peripheral device providing one or more functions, stores information 205 .
  • Device 201 is connected to client computer 202 via link 220 , which may comprise any suitable communications media, such as a Universal Serial Bus (USB) link.
  • client computer 202 executes metadata retrieval facility 210 , which may comprise any one or more bodies of programmed instructions, such as stand-alone programs and/or modules, instructions incorporated into one or more other programs and/or modules (e.g., an operating system executing on client computer 202 ), or implemented in any other suitable fashion.
  • Metadata retrieval facility 210 accesses metadata storage facility 215 , which may comprise any one or more data structures.
  • client computer 202 communicates with server computer 203 via network(s) 225 , which may comprise, for example, the Internet, a LAN, a WAN and/or any other wired or wireless network, or combination thereof. It should be appreciated, however, that server computer 203 need not be a separate computer from client computer 201 , and may, as an example, comprise programmed instructions which execute on client computer 201 .
  • Metadata retrieval facility 230 executes on server computer 203 and accesses metadata storage facility 235 .
  • metadata retrieval facility may comprise any one or more bodies of programmed instructions implemented in any other suitable fashion.
  • metadata storage facility 235 may comprise any one or more data structures. Metadata storage facility 215 and metadata storage facility 235 may include the same metadata, different metadata, or metadata which partially overlaps. The invention is not limited to any particular system implementation.
  • information 205 includes the hardware identifiers described above with reference to FIG. 1 (i.e., identifiers H 11 , H 12 , H 21 , H 22 , H 23 and H 31 ), and an additional identifier M 1 referred to herein for convenience as a model identifier.
  • each hardware identifier corresponds to a particular function performed by device 201 , and some hardware identifiers are more specific to device 201 than others.
  • model identifier M 1 identifies the device 201 instead of one or more specific functions performed by the device.
  • a model identifier may be unique to a particular device, although the invention is not limited to such an implementation.
  • a model identifier may be unique to a device and provider, such that multiple providers may each provide a unique model identifier for the device. This may be useful for peripheral devices such as cellular telephones, where a single device may be offered for sale by multiple network service providers.
  • Using a model identifier unique to a device and provider may allow each provider to furnish different metadata, which may be used to present different interfaces (e.g., to perform different configuration tasks, provide different information about the device, etc.).
  • the hardware identifiers included in information 205 are arranged so that the identifiers for each function that are more specific to the device (e.g., H 11 , H 21 ) precede others that are more generic (e.g., H 12 , H 22 , H 23 ).
  • hardware identifiers are further arranged so that a specific identifier and/or function which is deemed most representative of the device overall precedes all other identifiers and/or functions.
  • a device manufacturer may designate a specific hardware identifier (e.g., H 11 ) to be used to retrieve metadata relating to the device.
  • a manufacturer of the device may designate that identifier H 11 , representing the print function, should be used to retrieve metadata for device 201 overall, and may arrange the hardware identifiers so that identifier H 11 precedes all others in information 205 .
  • information 205 is provided to client computer 202 , and more particularly to metadata retrieval facility 210 , which accesses metadata storage facility 215 .
  • the metadata in storage facility 215 may, for example, be provided by one or more device manufacturers or suppliers, such as the manufacturer or supplier of device 201 , client computer 202 , and/or any other device(s).
  • metadata may be installed when client computer 202 is configured for sale.
  • a manufacturer or supplier may also, or alternatively, make metadata available for distribution via one or more networks.
  • a manufacturer/supplier may distribute metadata to client computer 202 via one or more networks (e.g., the Internet, other network(s), or a combination thereof).
  • Metadata may be distributed, for example, at periodic intervals, and/or upon any other occurrence.
  • An example process for distributing metadata via one or more networks is described in further detail below with reference to FIG. 5 .
  • metadata may be provided and/or loaded to storage facility 215 in any suitable fashion, as embodiments of the invention are not limited in this respect.
  • system 200 enables a metadata retrieval process which includes an initial retrieval attempt by client computer 202 (and more particularly, by metadata retrieval facility 210 ), and if no match is found or if retrieved metadata is determined to be deficient in some way, an additional retrieval attempt may be made by server computer 203 (and more particularly, metadata retrieval facility 230 ).
  • metadata retrieval facility 210 may construct a query using information provided by device 210 , and if the retrieval attempt is unsuccessful, may pass the query or parameters used therein via network(s) 225 to metadata retrieval facility 230 , which may construct and/or execute a query to retrieve metadata from storage facility 235 .
  • This two-step retrieval process is also described in further detail below with reference to FIG. 5 .
  • FIG. 3 depicts an example process 300 performed by a client computer (e.g., client computer 202 ) to retrieve metadata for a device using information provided by the device.
  • client computer e.g., client computer 202
  • information is received from the device in act 305 .
  • Information may be provided to the client computer via any one or more direct links (e.g., a USB, FireWire or other link), networks (e.g., a wired or wireless network, such as an ad hoc network between a device and client computer), or other connections.
  • direct links e.g., a USB, FireWire or other link
  • networks e.g., a wired or wireless network, such as an ad hoc network between a device and client computer
  • the invention is not limited to any particular implementation.
  • the client computer determines whether the information received from the device includes a model identifier or one or more hardware identifiers. This determination may be made in any suitable fashion, such as by executing programmed instructions to identify any model identifier or hardware identifier(s) from among information received from the device.
  • act 310 If it is determined in act 310 that the information includes one or more hardware identifiers, the process proceeds to act 315 , wherein the hardware identifier(s) are arranged into a sequence.
  • the hardware identifier(s) are arranged into a sequence.
  • FIG. 4 One exemplary manner of arranging hardware identifiers into a sequence is illustrated conceptually in FIG. 4 .
  • hardware identifiers 405 which include identifiers the H 11 , H 12 , H 21 , H 22 , H 23 and H 31 described above with reference to FIG. 1 , are arranged into a sequence such that identifiers that are most specific to the device for any function precede other identifiers that are more generic.
  • hardware identifiers are arranged into the sequence H 11 , H 21 , H 31 , H 12 , H 22 , H 23 .
  • hardware identifiers, or other information received from a device may be arranged into any suitable sequence, and that embodiments of the invention are not limited to any particular implementation.
  • process 300 proceeds to act 320 , wherein a query employing the information is constructed.
  • the query specifies a query type (e.g., whether a model identifier or one or more hardware identifiers are specified in the query), a locale (e.g., the location of the client computer, which may be used to determine the language in which metadata should be provided), either the model identifier or hardware identifier(s) received from the device, and a stamp date indicating when metadata stored on the client computer was last updated.
  • a query resulting from act 320 may be:
  • process 300 proceeds to act 325 , wherein the query is executed.
  • a metadata retrieval facility e.g., facility 210 , FIG. 2
  • the client computer may execute the query by attempting to match the model identifier or hardware identifier(s) provided in the query with metadata stored on the client computer (e.g., in metadata storage facility 215 ). If more than one hardware identifier is specified in the query, the metadata retrieval facility may attempt to match each hardware identifier in sequence to metadata, so as to attempt to retrieve metadata that is most specific to the device.
  • the process then proceeds to act 330 , where a determination is made whether a match has been found.
  • a match has been found.
  • only one matching item of metadata is retrieved. For example, assume that the metadata stored in metadata storage facility includes the following two items:
  • metadata A is determined to be the matching item.
  • process 300 proceeds to act 335 , wherein the user is informed of this, and process 300 ends (an alternative embodiment wherein the lack of a match does not lead to the end of the process is described below with reference to FIG. 5 ).
  • the metadata that is retrieved may be processed by one of more software routines, such as to present an interface to a user of client computer 202 in act 340 .
  • this interface may present information about the device, and one or more available tasks which the user may undertake to configure the device.
  • process 300 ends.
  • a technique used to retrieve metadata may include one or more acts not described above with reference to FIG. 3 , may not include all of the acts described above, and need not perform the acts described above in the sequence described above. Any of numerous variations on process 300 may be employed, as the invention is not limited to any particular implementation.
  • FIG. 5 depicts an example process whereby a client computer coupled to a server computer may retrieve metadata relating to a device.
  • FIG. 5 depicts a two-step retrieval process wherein a first retrieval attempt is made by a client computer (e.g., client computer 202 , FIG. 2 ), and if no matching metadata is found or if retrieved metadata is deficient (e.g., outdated, stale, etc.), an additional retrieval attempt is made by a server computer (e.g., server computer 203 ). If the additional retrieval attempt is successful, the metadata retrieved by the server computer may be used to update the metadata stored on the client computer, so that subsequent retrieval attempts by the client computer may succeed.
  • a server computer e.g., server computer 203
  • a query is constructed and executed by a client computer (e.g., by a metadata retrieval facility executing thereon) in act 505 .
  • a client computer e.g., by a metadata retrieval facility executing thereon
  • This may, for example, be performed in much the same manner as in acts 320 and 325 , described above with reference to FIG. 3 .
  • the invention is not limited to such an implementation, as a query may be constructed and executed in any suitable fashion.
  • act 510 a determination is made whether a match has been found. This may, for example, be performed in much the same manner as in acts 330 , described above with reference to FIG. 3 , or in any other suitable fashion.
  • process 500 proceeds to act 515 , wherein a determination is made whether the matching metadata is deficient.
  • a metadata retrieval facility executing on the client computer may determine whether matching metadata is outdated. This determination may, for example, be made using an indication of the date and time at which the metadata was last updated, such as the date-time stamp described above. For example, if the metadata is older than a predetermined age (e.g., one month), it may be determined that the metadata is outdated. Of course, being outdated is only one exemplary way in which metadata may be deficient. Any suitable criteria may be used to identify any suitable deficiency or lack thereof, and embodiments of the invention are not limited in this respect.
  • process 500 proceeds to act 525 , wherein the query constructed in act 505 , or one or more parameters defined thereby, is submitted to and executed by a metadata retrieval facility executing on the server computer (e.g., server computer 203 , FIG. 2 ).
  • the query/parameter(s) may be transmitted to, and executed by, the server computer in any suitable fashion, as embodiments of the invention are not limited in this respect.
  • the query/parameter(s) may be transmitted via network(s) 225 ( FIG. 2 ) and executed by the server computer in much the same fashion as was described above with reference to act 325 in FIG. 3 .
  • process 500 proceeds to act 530 , where it is determined whether a match is found among metadata accessible to the server computer. If no match is found, an error message is returned to the client in act 535 , so that, for example, it may be displayed to the user of the client computer. If a match is found, the process proceeds to act 540 , wherein the metadata is returned to the client (e.g., transmitted by server computer 203 via networks 225 to client computer 202 ). The process then proceeds to act 545 , wherein information relating to the device is presented to the user. Upon the completion of either of acts 535 or 545 , process 500 completes.
  • Computer system 600 includes input device(s) 602 , output device(s) 601 , processor 603 , memory system 604 and storage 606 , all of which are coupled, directly or indirectly, via interconnection mechanism 605 , which may comprise one or more buses, switches, networks and/or any other suitable interconnection.
  • the input device(s) 602 receive(s) input from a user or machine (e.g., a human operator), and the output device(s) 601 display(s) or transmit(s) information to a user or machine (e.g., a liquid crystal display).
  • the processor 603 typically executes a computer program called an operating system (e.g., a Microsoft Windows-family operating system, or any other suitable operating system) which controls the execution of other computer programs, and provides scheduling, input/output and other device control, accounting, compilation, storage assignment, data management, memory management, communication and dataflow control.
  • an operating system e.g., a Microsoft Windows-family operating system, or any other suitable operating system
  • Collectively, the processor and operating system define the computer platform for which application programs and other computer program languages are written.
  • the processor 603 may also execute one or more computer programs to implement various functions. These computer programs may be written in any type of computer program language, including a procedural programming language, object-oriented programming language, macro language, or combination thereof. These computer programs may be stored in storage system 606 . Storage system 606 may hold information on a volatile or non-volatile medium, and may be fixed or removable. Storage system 606 is shown in greater detail in FIG. 7 .
  • Storage system 606 typically includes a computer-readable and writable nonvolatile recording medium 701 , on which signals are stored that define a computer program or information to be used by the program.
  • a medium may, for example, be a disk or flash memory.
  • the processor 603 causes data to be read from the nonvolatile recording medium 701 into a volatile memory 702 (e.g., a random access memory, or RAM) that allows for faster access to the information by the processor 603 than does the medium 701 .
  • the memory 702 may be located in the storage system 606 , as shown in FIG. 7 , or in memory system 604 , as shown in FIG. 6 .
  • the processor 603 generally manipulates the data within the integrated circuit memory 604 , 702 and then copies the data to the medium 701 after processing is completed.
  • a variety of mechanisms are known for managing data movement between the medium 701 and the integrated circuit memory element 604 , 702 , and the invention is not limited thereto.
  • the invention is also not limited to a particular memory system 604 or storage system 606 .
  • a (client or server) computer may be embodied in any of a number of forms, such as a rack-mounted computer, a desktop computer, a laptop computer, or a tablet computer. Additionally, a (client or server) computer may be embedded in a device not generally regarded as a computer but with suitable processing capabilities, including a Personal Digital Assistant (PDA), a smart phone or any other suitable portable or fixed electronic device.
  • PDA Personal Digital Assistant
  • a (client or server) computer may have one or more input and output devices. These devices can be used, among other things, to present a user interface. Examples of output devices that can be used to provide a user interface include printers or display screens for visual presentation of output and speakers or other sound generating devices for audible presentation of output. Examples of input devices that can be used for a user interface including keyboards, and pointing devices, such as mice, touch pads, and digitizing tables. As another example, a computer may receive input information through speech recognition or in other audible format.
  • Such computers may be interconnected by one or more networks in any suitable form, including as a local area network or a wide area network, such as an enterprise network or the Internet.
  • networks may be based on any suitable technology and may operate according to any suitable protocol and may include wireless networks, wired networks or fiber optic networks.
  • the various methods or processes outlined herein may be coded as software that is executable on one or more processors that employ any one of a variety of operating systems or platforms.
  • such software may be written using any of a number of suitable programming languages and/or conventional programming or scripting tools, and also may be compiled as executable machine language code or intermediate code that is executed on a framework or virtual machine.
  • the invention may be embodied as a computer-readable medium (or multiple computer readable media) (e.g., a computer memory, one or more floppy disks, compact disks, optical disks, magnetic tapes, flash memories, circuit configurations in Field Programmable Gate Arrays or other semiconductor devices, or other computer storage media) encoded with one or more programs that, when executed on one or more computers or other processors, perform methods that implement the various embodiments of the invention discussed above.
  • the computer-readable medium or media can be transportable, such that the program or programs stored thereon can be loaded onto one or more different computers or other processors to implement various aspects of the present invention as discussed above.
  • program or “software” are used herein in a generic sense to refer to any type of computer code or set of computer-executable instructions that can be employed to program a computer or other processor to implement various aspects of the present invention as discussed above. Additionally, it should be appreciated that according to one aspect of this embodiment, one or more computer programs that when executed perform methods of the present invention need not reside on a single computer or processor, but may be distributed in a modular fashion amongst a number of different computers or processors to implement various aspects of the present invention.
  • Computer-executable instructions may be provided in many forms, such as program modules, executed by one or more computers or other devices.
  • program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types.
  • functionality of the program modules may be combined or distributed as desired in various embodiments.

Abstract

Systems and methods are provided for retrieving metadata relating to a multi-function device. In some embodiments, metadata is retrieved using a plurality of identifiers (e.g., hardware identifiers each identifying at least one function performed by the device) received from the device. The plurality of identifiers are arranged into a sequence, and at least one of the identifiers in the sequence is associated with metadata specifying a characteristic of the device. Using the metadata that is retrieved, a client computer may present an graphical user interface displaying information relating to the device.

Description

    CROSS-REFERENCE TO RELATED APPLICATION(S)
  • This application is a continuation application of U.S. patent application No. 12/002,055, filed on Dec. 14, 2007, and entitled “METADATA RETRIEVAL FOR MULTI-FUNCTION DEVICES” (Attorney Docket No. 321941.01). The afore-referenced application is hereby incorporated by reference.
  • FIELD OF THE INVENTION
  • This invention relates generally to computer software, and more particularly to software which enables a computer to interoperate with one or more peripheral devices.
  • BACKGROUND
  • Conventionally, when a peripheral device is connected to a client computer, the client computer receives information from the peripheral device that includes one or more “hardware identifiers.” In general, each hardware identifier is used to identify a function performed by the peripheral device. If the peripheral device is a multi-function device, such as a printer/scanner/fax machine, the client computer may receive one or more hardware identifiers each identifying the print function, the scan function and the fax function. Once received, each hardware identifier is used by the client computer to identify a driver that enables the client computer to interoperate with, and employ the corresponding function provided by, the peripheral device.
  • More than one hardware identifier may be provided for each function, because there may be more than one driver which will allow the client computer to employ a particular function. For example, many device manufacturers typically supply multiple drivers for a given device function, with one driver being very specific to the function, and others being more generic. More generic drivers typically may be used by a client computer to employ functions provided by any of multiple devices (or families of devices), but may not allow the client computer to employ all of the aspects of a given device function. For example, the manufacturer of a monitor may include one driver that enables a client computer to employ all of the display functionality provided by the monitor, and several more generic drivers that do not enable the client computer to employ all of this functionality, but allow the client computer to interoperate with any of several monitors.
  • Typically, hardware identifiers for a given function are provided to a client computer in a sequence which ranges from most specific to most generic. That is, for each function performed by the device, the client computer receives a sequence ranging from the most specific hardware identifier to the most generic. If the device is a multi-function device, the hardware identifiers for each individual function conform to this sequence. Thus, if a device has two functions, and two hardware identifiers are provided by the device for each function, the client computer receives two groups of identifiers, each arranged in a sequence from most specific to most generic. Once the hardware identifiers are received by the client computer, it attempts to match hardware identifiers in each group in sequence with a driver (e.g., stored on the client computer). When a hardware identifier received from the device does not match a driver, the client computer proceeds with trying to match the next hardware identifier in the sequence in the group. Once a matching driver is found for a group, the client computer may employ the function represented by identifiers in the group.
  • This processing is illustrated conceptually in FIG. 1, in which device 101 is connected to client computer 102 via link 120. Device 101 includes hardware identifiers 105, which are provided to client computer 102 when device 101 is connected thereto, and are employed by matching facility 110 (which may be a portion of an operating system executing on client computer 102) to retrieve one or more drivers. Hardware identifiers 105 include identifiers for each of three different functions, with the first digit in each identifier following the letter “H” identifying the function. For example, hardware identifiers H11 and H12 correspond to a first function, H21, H22 and H23 correspond to a second function, and H31 corresponds to a third function. The identifiers for each function are arranged in a sequence from most specific to most generic, with the second digit in each identifier following the letter “H” identifying a level of specificity. Thus, hardware identifier H11 for the first function is more specific than is H12, and hardware identifier H22 for the second function is more specific than is H23.
  • When device 101 is connected to client computer 102, matching facility 110 receives the hardware identifiers for each function in sequence, and attempts to match each hardware identifier for a given function in turn to a driver stored in storage facility 115. For example, for hardware identifiers relating to the first function, matching facility 110 first attempts to match identifier H11 to a driver stored in storage element 115, and if no match is found, proceeds to try to match identifier H12. Similarly, matching facility 110 attempts to match identifiers for the second function (i.e., H21, H22 and H23) and for the third function (i.e., H31) to a driver in storage facility 115. When a matching driver is found for any function, client computer 102 employs the corresponding function as defined by the driver.
  • Because each hardware identifier provided by a peripheral device relates to a function performed by the device, rather than the device itself, a client computer that receives hardware identifiers corresponding to multiple functions (such as might be supplied by a multi-function device) “perceives” the device as multiple distinct entities (i.e., one entity for each function defined by a set of hardware identifiers). For example, when a multi-function device such as a printer/scanner/fax machine provides hardware identifiers for its functions to a client computer, the client computer perceives the device as three entities, providing print, scan and fax capabilities, respectively.
  • BRIEF SUMMARY OF THE INVENTION
  • Applicant has appreciated that the information provided by a peripheral device (i.e., any device attached to a client computer to provide functionality, such as a printer, disk drive, microphone, camera, cellular telephone, media player, microphone, etc.) to a client computer (a term used herein for convenience, and intended to include any computing device, such as a desktop computer, laptop computer, personal digital assistant, cellular telephone, other computing device, or any combination thereof) may be used to not only identify specific functions performed by the peripheral device, but also may identify the device itself to the client computer. Enabling the client computer to identify the device itself, rather than just its function(s), may allow the client computer to present an interface that displays information about the device and allows a user to configure the device rather than just its individual functions. As a result, the client computer can provide a richer and more meaningful user experience with respect to the device, such as by allowing the user to view information about the device and to manage relationships between individual functions. The user may interact with the device itself, rather than just separately configuring its individual functions.
  • In some embodiments, information provided by the device (e.g., one or more hardware identifiers) is used to retrieve metadata that includes various information about the device, such as one or more graphical illustrations of the device, the manufacturer's name, information about the device's features, and/or available user configuration tasks. The metadata may, for example, be employed by one or more software routines executing on a client computer to present an interface to the user that enables interaction with and/or configuration of the device and its functions.
  • Metadata may be stored on the client computer and/or one or more server computers. Some embodiments provide for a process whereby the client computer, upon receiving information from the device, first attempts to match the information to metadata stored on the client computer, and if the attempt is unsuccessful or the metadata is deficient (e.g., outdated or stale), the client computer passes the information to one or more server computers, which then attempt(s) to match the information to metadata accessible to the server computer(s). When a match is found, the metadata may be passed back to the client computer, which may use the information to present a user interface, and may update metadata stored locally.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 is a block diagram depicting an example technique for matching hardware identifiers provided by a peripheral device to drivers on a client computer, according to the prior art;
  • FIG. 2 is a block diagram depicting an example technique for matching hardware identifiers provided by a peripheral device with metadata about the device, according to some embodiments of the invention;
  • FIG. 3 is a flowchart depicting an example process for identifying metadata relating to a peripheral device using information provided by the device, according to some embodiments of the invention;
  • FIG. 4 is a block diagram illustrating a technique for arranging information received from a peripheral device into a sequence, according to some embodiments of the invention;
  • FIG. 5 is a flowchart depicting an example process for identifying metadata about a device using information provided by the device, according to some embodiments of the invention;
  • FIG. 6 is a block diagram depicting an example computer system on which some embodiments of the invention may be implemented; and
  • FIG. 7 is a block diagram depicting an example memory on which instructions embodying aspects of the present invention may be stored.
  • DETAILED DESCRIPTION
  • In accordance with some embodiments of the invention, information received from a peripheral device, such as one or more hardware identifiers and/or other information, may be used to retrieve metadata which includes information about the device itself, rather than its individual function(s). The metadata may enable a client computer to provide the user with a richer and more meaningful experience in interacting with the device than is provided by conventional arrangements. For example, by identifying a multi-function device as a single entity, rather than as multiple separate entities each performing a separate function, a client computer may provide an interface which serves as a “single point of entry” for configuring the device and its various functions, allows the user to view and manage the relationships between individual functions, and/or visually identifies the device in a more precise and aesthetically pleasing manner than the function icons conventionally employed.
  • As an example, if a multi-function device provides cellular telephone, media player and personal productivity (e.g., address book) functions, the client computer may use information provided by metadata to provide a graphical user interface (e.g., via a “control panel” window, and/or any other suitable interface paradigm) which identifies the device, enables the user to configure its individual functions (e.g., synchronizing address book entries stored on the device with counterpart data on the client computer), and allows the user to configure features spanning multiple functions (e.g., by indicating that a particular media file should be played when a telephone call is received from a certain person). As a result, the user interacts with the device itself, rather than separately configuring its individual functions.
  • In some embodiments, metadata may be retrieved using information that is provided when the device is connected to a client computer. For example, a hardware identifier and/or other information provided to the client computer by the device may be used to retrieve metadata that includes various information about the device, such as a photograph and/or graphical illustration of the device, one or more available configuration tasks, the manufacturer's name, and/or any other suitable information. In some embodiments, some or all of these items of information may be processed by one or more software routines executing on the client computer to cause an interface to be presented enabling the user to configure and otherwise interact with the device and its functions.
  • Metadata may, for example, be provided by a manufacturer or supplier of the device, and may be stored on the client computer, one or more server computers coupled to the client computer via one or more networks, and/or any other suitable component.
  • For example, in some embodiments, the client computer may attempt to use information provided by the device to retrieve metadata for the device by constructing and executing a query against a metadata storage facility residing on the client computer. If this attempt at retrieval is successful, items of information included in the metadata may be used to present an interface to a user of the client computer. If the retrieval attempt is unsuccessful, or if retrieved metadata is determined to be deficient in some way (e.g., outdated, incorrect, stale, etc.), the information and/or query may be communicated to one or more server computers for execution on one or more other metadata storage facilities. If metadata is successfully retrieved by a server computer, it may be provided to the client computer, which may employ it to present an interface to the user, and may employ it to update metadata stored on the client computer so that the metadata can subsequently be retrieved without requiring communication with a server computer. Of course, the invention is not limited to such a retrieval technique, and metadata may be retrieved in any suitable fashion. Some exemplary metadata retrieval techniques are described in the sections that follow.
  • FIG. 2 depicts a system 200 which enables information provided by a device 201 to a client computer 202 to be used to retrieve metadata about the device. In the example of FIG. 2, device 201, which may be any suitable peripheral device providing one or more functions, stores information 205. Device 201 is connected to client computer 202 via link 220, which may comprise any suitable communications media, such as a Universal Serial Bus (USB) link. Client computer 202 executes metadata retrieval facility 210, which may comprise any one or more bodies of programmed instructions, such as stand-alone programs and/or modules, instructions incorporated into one or more other programs and/or modules (e.g., an operating system executing on client computer 202), or implemented in any other suitable fashion. Metadata retrieval facility 210 accesses metadata storage facility 215, which may comprise any one or more data structures.
  • In the example system 200, client computer 202 communicates with server computer 203 via network(s) 225, which may comprise, for example, the Internet, a LAN, a WAN and/or any other wired or wireless network, or combination thereof. It should be appreciated, however, that server computer 203 need not be a separate computer from client computer 201, and may, as an example, comprise programmed instructions which execute on client computer 201.
  • Metadata retrieval facility 230 executes on server computer 203 and accesses metadata storage facility 235. As with metadata retrieval facility 210, metadata retrieval facility may comprise any one or more bodies of programmed instructions implemented in any other suitable fashion. Similarly, like metadata storage facility 215, metadata storage facility 235 may comprise any one or more data structures. Metadata storage facility 215 and metadata storage facility 235 may include the same metadata, different metadata, or metadata which partially overlaps. The invention is not limited to any particular system implementation.
  • In the example system 200, information 205 includes the hardware identifiers described above with reference to FIG. 1 (i.e., identifiers H11, H12, H21, H22, H23 and H31), and an additional identifier M1 referred to herein for convenience as a model identifier. As described above, each hardware identifier corresponds to a particular function performed by device 201, and some hardware identifiers are more specific to device 201 than others. In some embodiments, model identifier M1 identifies the device 201 instead of one or more specific functions performed by the device. In some embodiments, a model identifier may be unique to a particular device, although the invention is not limited to such an implementation. For example, in some embodiments a model identifier may be unique to a device and provider, such that multiple providers may each provide a unique model identifier for the device. This may be useful for peripheral devices such as cellular telephones, where a single device may be offered for sale by multiple network service providers. Using a model identifier unique to a device and provider may allow each provider to furnish different metadata, which may be used to present different interfaces (e.g., to perform different configuration tasks, provide different information about the device, etc.).
  • As described above with reference to FIG. 1, the hardware identifiers included in information 205 are arranged so that the identifiers for each function that are more specific to the device (e.g., H11, H21) precede others that are more generic (e.g., H12, H22, H23). In accordance with some embodiments of the invention, hardware identifiers are further arranged so that a specific identifier and/or function which is deemed most representative of the device overall precedes all other identifiers and/or functions. For example, a device manufacturer may designate a specific hardware identifier (e.g., H11) to be used to retrieve metadata relating to the device. For example, if device 201 provides print, scan and fax functions, a manufacturer of the device may designate that identifier H11, representing the print function, should be used to retrieve metadata for device 201 overall, and may arrange the hardware identifiers so that identifier H11 precedes all others in information 205.
  • When device 201 is connected to client computer 202 via link 220, information 205 is provided to client computer 202, and more particularly to metadata retrieval facility 210, which accesses metadata storage facility 215. As noted above, the metadata in storage facility 215 may, for example, be provided by one or more device manufacturers or suppliers, such as the manufacturer or supplier of device 201, client computer 202, and/or any other device(s). For example, metadata may be installed when client computer 202 is configured for sale.
  • A manufacturer or supplier may also, or alternatively, make metadata available for distribution via one or more networks. Using the example system 200 shown to illustrate, a manufacturer/supplier may distribute metadata to client computer 202 via one or more networks (e.g., the Internet, other network(s), or a combination thereof).
  • Upon receiving newly distributed metadata, client computer 202 may load it to metadata storage facility 215 Metadata may be distributed, for example, at periodic intervals, and/or upon any other occurrence. An example process for distributing metadata via one or more networks is described in further detail below with reference to FIG. 5. Of course, metadata may be provided and/or loaded to storage facility 215 in any suitable fashion, as embodiments of the invention are not limited in this respect.
  • In some embodiments, system 200 enables a metadata retrieval process which includes an initial retrieval attempt by client computer 202 (and more particularly, by metadata retrieval facility 210), and if no match is found or if retrieved metadata is determined to be deficient in some way, an additional retrieval attempt may be made by server computer 203 (and more particularly, metadata retrieval facility 230). For example, metadata retrieval facility 210 may construct a query using information provided by device 210, and if the retrieval attempt is unsuccessful, may pass the query or parameters used therein via network(s) 225 to metadata retrieval facility 230, which may construct and/or execute a query to retrieve metadata from storage facility 235. This two-step retrieval process is also described in further detail below with reference to FIG. 5.
  • FIG. 3 depicts an example process 300 performed by a client computer (e.g., client computer 202) to retrieve metadata for a device using information provided by the device. At the start of process 300, information is received from the device in act 305. Information may be provided to the client computer via any one or more direct links (e.g., a USB, FireWire or other link), networks (e.g., a wired or wireless network, such as an ad hoc network between a device and client computer), or other connections. The invention is not limited to any particular implementation.
  • In act 310, the client computer (e.g., a metadata retrieval facility executing thereon) determines whether the information received from the device includes a model identifier or one or more hardware identifiers. This determination may be made in any suitable fashion, such as by executing programmed instructions to identify any model identifier or hardware identifier(s) from among information received from the device.
  • If it is determined in act 310 that the information includes one or more hardware identifiers, the process proceeds to act 315, wherein the hardware identifier(s) are arranged into a sequence. One exemplary manner of arranging hardware identifiers into a sequence is illustrated conceptually in FIG. 4.
  • In the example of FIG. 4, hardware identifiers 405, which include identifiers the H11, H12, H21, H22, H23 and H31 described above with reference to FIG. 1, are arranged into a sequence such that identifiers that are most specific to the device for any function precede other identifiers that are more generic. Thus, in this example, hardware identifiers are arranged into the sequence H11, H21, H31, H12, H22, H23. However, it should be appreciated that hardware identifiers, or other information received from a device, may be arranged into any suitable sequence, and that embodiments of the invention are not limited to any particular implementation.
  • Upon the completion of act 315, or if it is determined in act 310 that the information received from the multi-function device comprises a model identifier, process 300 proceeds to act 320, wherein a query employing the information is constructed. In some embodiments, the query specifies a query type (e.g., whether a model identifier or one or more hardware identifiers are specified in the query), a locale (e.g., the location of the client computer, which may be used to determine the language in which metadata should be provided), either the model identifier or hardware identifier(s) received from the device, and a stamp date indicating when metadata stored on the client computer was last updated. Thus, in some embodiments, a query resulting from act 320 may be:
  • type=hwid, lang=en-us, hwids=H11, H21, H31, H12, H22, H23, LastStampDate=20070801
  • After the query is constructed in act 320, process 300 proceeds to act 325, wherein the query is executed. For example, in some embodiments, a metadata retrieval facility (e.g., facility 210, FIG. 2) on the client computer may execute the query by attempting to match the model identifier or hardware identifier(s) provided in the query with metadata stored on the client computer (e.g., in metadata storage facility 215). If more than one hardware identifier is specified in the query, the metadata retrieval facility may attempt to match each hardware identifier in sequence to metadata, so as to attempt to retrieve metadata that is most specific to the device.
  • The process then proceeds to act 330, where a determination is made whether a match has been found. In some embodiments, only one matching item of metadata is retrieved. For example, assume that the metadata stored in metadata storage facility includes the following two items:
  • Metadata A:
  • Function=mf
  • Match1=h11
  • Match2=h782
  • Lang=en-us
  • LastStampDate=20070811
  • Metadata B:
  • Function=mf
  • Match1=h31
  • Lang=en-us
  • LastStampDate=20070815
  • In this example, because the metadata retrieval facility attempts to match each hardware identifier in sequence to metadata items, even though both items of metadata include hardware identifiers listed in the query (i.e., identifiers H11 and H31), metadata A is determined to be the matching item.
  • If no match is found, the process proceeds to act 335, wherein the user is informed of this, and process 300 ends (an alternative embodiment wherein the lack of a match does not lead to the end of the process is described below with reference to FIG. 5).
  • If a match is found, the metadata that is retrieved may be processed by one of more software routines, such as to present an interface to a user of client computer 202 in act 340. For example, this interface may present information about the device, and one or more available tasks which the user may undertake to configure the device. At the completion of act 340, process 300 ends.
  • It should be appreciated that any of numerous techniques may be employed to retrieve metadata, and that embodiments of the invention are not limited to using process 300. Further, a technique used to retrieve metadata may include one or more acts not described above with reference to FIG. 3, may not include all of the acts described above, and need not perform the acts described above in the sequence described above. Any of numerous variations on process 300 may be employed, as the invention is not limited to any particular implementation.
  • FIG. 5 depicts an example process whereby a client computer coupled to a server computer may retrieve metadata relating to a device. In particular, FIG. 5 depicts a two-step retrieval process wherein a first retrieval attempt is made by a client computer (e.g., client computer 202, FIG. 2), and if no matching metadata is found or if retrieved metadata is deficient (e.g., outdated, stale, etc.), an additional retrieval attempt is made by a server computer (e.g., server computer 203). If the additional retrieval attempt is successful, the metadata retrieved by the server computer may be used to update the metadata stored on the client computer, so that subsequent retrieval attempts by the client computer may succeed.
  • At the start of process 500, a query is constructed and executed by a client computer (e.g., by a metadata retrieval facility executing thereon) in act 505. This may, for example, be performed in much the same manner as in acts 320 and 325, described above with reference to FIG. 3. Of course, the invention is not limited to such an implementation, as a query may be constructed and executed in any suitable fashion.
  • At the completion of act 505, the process proceeds to act 510, wherein a determination is made whether a match has been found. This may, for example, be performed in much the same manner as in acts 330, described above with reference to FIG. 3, or in any other suitable fashion.
  • If it is determined that a match has been found, process 500 proceeds to act 515, wherein a determination is made whether the matching metadata is deficient. For example, a metadata retrieval facility executing on the client computer may determine whether matching metadata is outdated. This determination may, for example, be made using an indication of the date and time at which the metadata was last updated, such as the date-time stamp described above. For example, if the metadata is older than a predetermined age (e.g., one month), it may be determined that the metadata is outdated. Of course, being outdated is only one exemplary way in which metadata may be deficient. Any suitable criteria may be used to identify any suitable deficiency or lack thereof, and embodiments of the invention are not limited in this respect.
  • If it is determined in act 515 that the metadata is deficient, or if it is determined in act 510 that no match has been found, process 500 proceeds to act 525, wherein the query constructed in act 505, or one or more parameters defined thereby, is submitted to and executed by a metadata retrieval facility executing on the server computer (e.g., server computer 203, FIG. 2). The query/parameter(s) may be transmitted to, and executed by, the server computer in any suitable fashion, as embodiments of the invention are not limited in this respect. For example, the query/parameter(s) may be transmitted via network(s) 225 (FIG. 2) and executed by the server computer in much the same fashion as was described above with reference to act 325 in FIG. 3.
  • The process then proceeds to act 530, where it is determined whether a match is found among metadata accessible to the server computer. If no match is found, an error message is returned to the client in act 535, so that, for example, it may be displayed to the user of the client computer. If a match is found, the process proceeds to act 540, wherein the metadata is returned to the client (e.g., transmitted by server computer 203 via networks 225 to client computer 202). The process then proceeds to act 545, wherein information relating to the device is presented to the user. Upon the completion of either of acts 535 or 545, process 500 completes.
  • Various aspects of the systems and methods for practicing features of the invention may be implemented on one or more computer systems, such as the exemplary computer system 600 shown in FIG. 6. Computer system 600 includes input device(s) 602, output device(s) 601, processor 603, memory system 604 and storage 606, all of which are coupled, directly or indirectly, via interconnection mechanism 605, which may comprise one or more buses, switches, networks and/or any other suitable interconnection. The input device(s) 602 receive(s) input from a user or machine (e.g., a human operator), and the output device(s) 601 display(s) or transmit(s) information to a user or machine (e.g., a liquid crystal display). The processor 603 typically executes a computer program called an operating system (e.g., a Microsoft Windows-family operating system, or any other suitable operating system) which controls the execution of other computer programs, and provides scheduling, input/output and other device control, accounting, compilation, storage assignment, data management, memory management, communication and dataflow control. Collectively, the processor and operating system define the computer platform for which application programs and other computer program languages are written.
  • The processor 603 may also execute one or more computer programs to implement various functions. These computer programs may be written in any type of computer program language, including a procedural programming language, object-oriented programming language, macro language, or combination thereof. These computer programs may be stored in storage system 606. Storage system 606 may hold information on a volatile or non-volatile medium, and may be fixed or removable. Storage system 606 is shown in greater detail in FIG. 7.
  • Storage system 606 typically includes a computer-readable and writable nonvolatile recording medium 701, on which signals are stored that define a computer program or information to be used by the program. A medium may, for example, be a disk or flash memory. Typically, an operation, the processor 603 causes data to be read from the nonvolatile recording medium 701 into a volatile memory 702 (e.g., a random access memory, or RAM) that allows for faster access to the information by the processor 603 than does the medium 701. The memory 702 may be located in the storage system 606, as shown in FIG. 7, or in memory system 604, as shown in FIG. 6. The processor 603 generally manipulates the data within the integrated circuit memory 604, 702 and then copies the data to the medium 701 after processing is completed. A variety of mechanisms are known for managing data movement between the medium 701 and the integrated circuit memory element 604, 702, and the invention is not limited thereto. The invention is also not limited to a particular memory system 604 or storage system 606.
  • Having thus described several aspects of at least one embodiment of this invention, it is to be appreciated that various alterations, modifications, and improvements will readily occur to those skilled in the art. Such alterations, modifications and improvements are intended to be part of this disclosure, and are intended to be within the spirit and scope of the invention. Accordingly, the forgoing description and drawings are by way of example only.
  • Further, it should be appreciated that a (client or server) computer may be embodied in any of a number of forms, such as a rack-mounted computer, a desktop computer, a laptop computer, or a tablet computer. Additionally, a (client or server) computer may be embedded in a device not generally regarded as a computer but with suitable processing capabilities, including a Personal Digital Assistant (PDA), a smart phone or any other suitable portable or fixed electronic device.
  • Also, a (client or server) computer may have one or more input and output devices. These devices can be used, among other things, to present a user interface. Examples of output devices that can be used to provide a user interface include printers or display screens for visual presentation of output and speakers or other sound generating devices for audible presentation of output. Examples of input devices that can be used for a user interface including keyboards, and pointing devices, such as mice, touch pads, and digitizing tables. As another example, a computer may receive input information through speech recognition or in other audible format.
  • Such computers may be interconnected by one or more networks in any suitable form, including as a local area network or a wide area network, such as an enterprise network or the Internet. Such networks may be based on any suitable technology and may operate according to any suitable protocol and may include wireless networks, wired networks or fiber optic networks. Also, the various methods or processes outlined herein may be coded as software that is executable on one or more processors that employ any one of a variety of operating systems or platforms.
  • Additionally, such software may be written using any of a number of suitable programming languages and/or conventional programming or scripting tools, and also may be compiled as executable machine language code or intermediate code that is executed on a framework or virtual machine.
  • In this respect, the invention may be embodied as a computer-readable medium (or multiple computer readable media) (e.g., a computer memory, one or more floppy disks, compact disks, optical disks, magnetic tapes, flash memories, circuit configurations in Field Programmable Gate Arrays or other semiconductor devices, or other computer storage media) encoded with one or more programs that, when executed on one or more computers or other processors, perform methods that implement the various embodiments of the invention discussed above. The computer-readable medium or media can be transportable, such that the program or programs stored thereon can be loaded onto one or more different computers or other processors to implement various aspects of the present invention as discussed above.
  • The terms “program” or “software” are used herein in a generic sense to refer to any type of computer code or set of computer-executable instructions that can be employed to program a computer or other processor to implement various aspects of the present invention as discussed above. Additionally, it should be appreciated that according to one aspect of this embodiment, one or more computer programs that when executed perform methods of the present invention need not reside on a single computer or processor, but may be distributed in a modular fashion amongst a number of different computers or processors to implement various aspects of the present invention.
  • Computer-executable instructions may be provided in many forms, such as program modules, executed by one or more computers or other devices. Generally, program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types. Typically the functionality of the program modules may be combined or distributed as desired in various embodiments.
  • Various aspects of the present invention may be used alone, in combination, or in a variety of arrangements not specifically discussed in the embodiments described in the foregoing and is therefore not limited in its application to the details and arrangement of components set forth in the foregoing description or illustrated in the drawings. For example, aspects described in one embodiment may be combined in any manner with aspects described in other embodiments.
  • Use of ordinal terms such as “first,” “second,” “third,” etc., in the claims to modify a claim element does not by itself connote any priority, precedence, or order of one claim element over another or the temporal order in which acts of a method are performed, but are used merely as labels to distinguish one claim element having a certain name from another element having a same name (but for use of the ordinal term) to distinguish the claim elements.
  • Also, the phraseology and terminology used herein is for the purpose of description and should not be regarded as limiting. The use of “including,” “comprising,” or “having,” “containing,” “involving,” and variations thereof herein, is meant to encompass the items listed thereafter and equivalents thereof as well as additional items.

Claims (20)

What is claimed is:
1. A method of configuring a peripheral device by a host device, the method comprising:
receiving a plurality of functionality identifiers from the peripheral device, each of the plurality of functionality identifiers corresponding to a function of a plurality of functions that the peripheral device is operable to perform;
receiving at least one device identifier from the peripheral device, the device identifier corresponding to at least one of a model or manufacturer of the peripheral device;
retrieving, based on at least one of the received functionality identifiers and the received device identifier, metadata from a local metadata store, the retrieved data being associated with at least one of the received functionality identifiers and with the received device identifier;
determining that the metadata retrieved from the local metadata store has a date stamp indicating that the metadata retrieved from the local metadata store was last updated before a particular date;
in response to the determination, transmitting a request to a server device, over a network, for additional metadata associated with at least one of the received functionality identifiers and with the received device identifier;
receiving the additional metadata from the server device; and
displaying at least a portion of the received additional metadata in a unified configuration interface that facilitates integrated configuration of at least two of the plurality of functions that the peripheral device is operable to perform.
2. The method of claim 1, wherein the peripheral device is a multi-function device adapted to provide at least a printing function and a scanning function via a Universal Serial Bus (USB) link, a FireWire link, or a network link between the peripheral device and the host device.
3. The method of claim 1, wherein the received additional metadata includes information relating to configuring the host device to interoperate with the peripheral device, the peripheral device represented in the unified configuration interface as a single entity instead of as separate entities for each function of the plurality of functions.
4. The method of claim 1, wherein the received additional metadata specifies a manufacturer of the peripheral device, a model number of the peripheral device, at least one task relating to configuring the peripheral device, at least one function that the peripheral device is operable to perform, and a graphical representation of the peripheral device.
5. The method of claim 1, wherein:
retrieving metadata from the local metadata store includes:
constructing a query based on at least some of the received functionality identifiers and the received device identifier; and
executing the constructed query on the local metadata store; and
transmitting the request to the server device includes transmitting the constructed query to the server device.
6. The method of claim 5, wherein constructing the query includes constructing the query based in part on the date stamp.
7. A computer-readable storage medium having stored therein instructions that, in response to execution on a host device, perform a process of configuring a peripheral device for use by the host device, the process comprising:
receiving a plurality of functionality identifiers from the peripheral device, each of the plurality of functionality identifiers associated with a function of a plurality of functions that the peripheral device is adapted to perform;
retrieving metadata associated with at least one of the received functionality identifiers from a local metadata store;
determining a deficiency in the metadata retrieved from the local metadata store;
in response to the determination of the deficiency, retrieving additional metadata associated with at least one of the received functionality identifiers from a server metadata store; and
displaying at least a portion of the retrieving additional metadata in a unified configuration interface, the unified configuration interface facilitating configuration of at least two of the plurality of functions that the peripheral device is adapted to perform.
8. The computer-readable storage medium of claim 7, wherein:
the process further comprises receiving at least one device identifier from the peripheral device, the device identifier corresponding to at least one of a model or manufacturer of the peripheral device; and
retrieving the metadata from the local metadata store includes retrieving the metadata based on the at least one device identifier.
9. The computer-readable storage medium of claim 7, wherein the peripheral device is a multi-function device adapted to provide at least a printing function and a scanning function.
10. The computer-readable storage medium of claim 7, wherein the peripheral device is represented in the unified configuration interface as a single entity capable of performing each of the functions of the plurality of functions.
11. The computer-readable storage medium of claim 7, wherein the received additional metadata specifies a manufacturer of the peripheral device, a model number of the peripheral device, at least one task relating to configuring the peripheral device, at least one function that the peripheral device is adapted to perform, and/or a graphical representation of the peripheral device.
12. The computer-readable storage medium of claim 7, wherein:
retrieving the metadata associated with at least one of the received functionality identifiers from the local metadata store includes:
constructing a query based on the at least some of the received functionality identifiers; and
executing the constructed query on the local metadata store; and
retrieving the additional metadata from the server metadata store includes transmitting the constructed query to the server device.
13. The computer-readable storage medium of claim 7, wherein determining the deficiency in the metadata retrieved from the local metadata store includes determining that the metadata retrieved from the local metadata store is older than a threshold age.
14. A host computing device, comprising:
a memory and at least one processor that are respectively configured to store and execute instructions that:
receive a plurality of functionality identifiers from a peripheral device, the individual functionality identifiers of the plurality of functionality identifiers corresponding to functions of a plurality of functions associated with the peripheral device;
access metadata associated with at least one of the received functionality identifiers from a metadata store of the host computing device;
determining a deficiency in the metadata of the metadata store of the host computing device;
in response to the determination of the deficiency, access additional metadata associated with at least one of the received functionality identifiers from a metadata store of a remote computing device; and
display at least a portion of the additional metadata in a unified configuration interface that facilitates configuration of the peripheral device.
15. The host computing device of claim 14, wherein:
the memory and the at least one processor are also respectively configured to store and execute instructions that receive a device identifier from the peripheral device;
the device identifier corresponds to a model and/or manufacturer of the peripheral device; and
the additional metadata is also associated with the model and/or manufacturer of the peripheral device.
16. The host computing device of claim 14, wherein:
the instructions that access the metadata of the metadata store of the host computing device also:
construct a query from at least some of the received functionality identifiers; and
query the metadata store of the host computing device with the constructed query; and
the instructions that access the additional metadata also transmit the constructed query to the remote computing device.
17. The host computing device of claim 14, wherein:
the instructions that access the metadata of the metadata store of the host computing device also:
construct a query from more than one of the received functionality identifiers; and
query the metadata store of the host computing device with the constructed query; and
the instructions that access the additional metadata also transmit the constructed query to the remote computing device.
18. The host computing device of claim 14, wherein the additional metadata specifies a manufacturer of the peripheral device, a model number of the peripheral device, at least one task relating to configuring the peripheral device, at least one function that the peripheral device is operable to perform, and/or a graphical representation of the peripheral device.
19. The host computing device of claim 14, wherein the deficiency in the metadata of the metadata store of the host computing device includes the metadata of the metadata store of the host computing device being older than a threshold age.
20. The host computing device of claim 14, wherein the peripheral device is represented in the unified configuration interface as a single entity capable of performing each of the functions of the plurality of functions.
US13/921,005 2007-12-14 2013-06-18 Metadata retrieval for multi-function devices Abandoned US20130278957A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US13/921,005 US20130278957A1 (en) 2007-12-14 2013-06-18 Metadata retrieval for multi-function devices

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US12/002,055 US8527554B2 (en) 2007-12-14 2007-12-14 Metadata retrieval for multi-function devices
US13/921,005 US20130278957A1 (en) 2007-12-14 2013-06-18 Metadata retrieval for multi-function devices

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US12/002,055 Continuation US8527554B2 (en) 2007-12-14 2007-12-14 Metadata retrieval for multi-function devices

Publications (1)

Publication Number Publication Date
US20130278957A1 true US20130278957A1 (en) 2013-10-24

Family

ID=40754547

Family Applications (3)

Application Number Title Priority Date Filing Date
US12/002,055 Active 2029-07-10 US8527554B2 (en) 2007-12-14 2007-12-14 Metadata retrieval for multi-function devices
US13/921,005 Abandoned US20130278957A1 (en) 2007-12-14 2013-06-18 Metadata retrieval for multi-function devices
US13/920,962 Abandoned US20130282930A1 (en) 2007-12-14 2013-06-18 Metadata retrieval for multi-function devices

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US12/002,055 Active 2029-07-10 US8527554B2 (en) 2007-12-14 2007-12-14 Metadata retrieval for multi-function devices

Family Applications After (1)

Application Number Title Priority Date Filing Date
US13/920,962 Abandoned US20130282930A1 (en) 2007-12-14 2013-06-18 Metadata retrieval for multi-function devices

Country Status (1)

Country Link
US (3) US8527554B2 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9756549B2 (en) 2014-03-14 2017-09-05 goTenna Inc. System and method for digital communication between computing devices

Families Citing this family (31)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101833346B1 (en) * 2011-11-03 2018-03-02 에스프린팅솔루션 주식회사 Electronic apparatus, cloud server and method for controlling printing thereof
US10091201B2 (en) * 2012-02-16 2018-10-02 Sonicwall Inc. Mobile device identify factor for access control policies
US8826388B2 (en) * 2012-02-16 2014-09-02 Sonicwall, Inc. Mobile device identify factor for access control policies
CN104866332A (en) * 2014-02-26 2015-08-26 华为终端有限公司 Capacity determining method, capacity configuring method, host, terminal equipment and system
US9922050B2 (en) 2014-06-26 2018-03-20 Amazon Technologies, Inc. Identifying data from keyword searches of color palettes and color palette trends
US9514543B2 (en) 2014-06-26 2016-12-06 Amazon Technologies, Inc. Color name generation from images and color palettes
US10073860B2 (en) 2014-06-26 2018-09-11 Amazon Technologies, Inc. Generating visualizations from keyword searches of color palettes
US10120880B2 (en) 2014-06-26 2018-11-06 Amazon Technologies, Inc. Automatic image-based recommendations using a color palette
US9659032B1 (en) 2014-06-26 2017-05-23 Amazon Technologies, Inc. Building a palette of colors from a plurality of colors based on human color preferences
US9996579B2 (en) 2014-06-26 2018-06-12 Amazon Technologies, Inc. Fast color searching
US9898487B2 (en) 2014-06-26 2018-02-20 Amazon Technologies, Inc. Determining color names from keyword searches of color palettes
US9401032B1 (en) 2014-06-26 2016-07-26 Amazon Technologies, Inc. Image-based color palette generation
US9697573B1 (en) 2014-06-26 2017-07-04 Amazon Technologies, Inc. Color-related social networking recommendations using affiliated colors
US9916613B1 (en) 2014-06-26 2018-03-13 Amazon Technologies, Inc. Automatic color palette based recommendations for affiliated colors
US10691744B2 (en) 2014-06-26 2020-06-23 Amazon Technologies, Inc. Determining affiliated colors from keyword searches of color palettes
US9792303B2 (en) 2014-06-26 2017-10-17 Amazon Technologies, Inc. Identifying data from keyword searches of color palettes and keyword trends
US10223427B1 (en) 2014-06-26 2019-03-05 Amazon Technologies, Inc. Building a palette of colors based on human color preferences
US9679532B2 (en) 2014-06-26 2017-06-13 Amazon Technologies, Inc. Automatic image-based recommendations using a color palette
US9652868B2 (en) 2014-06-26 2017-05-16 Amazon Technologies, Inc. Automatic color palette based recommendations
US10235389B2 (en) 2014-06-26 2019-03-19 Amazon Technologies, Inc. Identifying data from keyword searches of color palettes
US10169803B2 (en) 2014-06-26 2019-01-01 Amazon Technologies, Inc. Color based social networking recommendations
US9245350B1 (en) 2014-06-26 2016-01-26 Amazon Technologies, Inc. Image-based color palette generation
US10255295B2 (en) * 2014-06-26 2019-04-09 Amazon Technologies, Inc. Automatic color validation of image metadata
US9524563B2 (en) 2014-06-26 2016-12-20 Amazon Technologies, Inc. Automatic image-based recommendations using a color palette
US9727983B2 (en) 2014-06-26 2017-08-08 Amazon Technologies, Inc. Automatic color palette based recommendations
US10430857B1 (en) 2014-08-01 2019-10-01 Amazon Technologies, Inc. Color name based search
US9785649B1 (en) 2014-09-02 2017-10-10 Amazon Technologies, Inc. Hue-based color naming for an image
US9633448B1 (en) 2014-09-02 2017-04-25 Amazon Technologies, Inc. Hue-based color naming for an image
US20160179803A1 (en) * 2014-12-22 2016-06-23 Rovi Guides, Inc. Augmenting metadata using commonly available visual elements associated with media content
US11093510B2 (en) 2018-09-21 2021-08-17 Microsoft Technology Licensing, Llc Relevance ranking of productivity features for determined context
US11163617B2 (en) * 2018-09-21 2021-11-02 Microsoft Technology Licensing, Llc Proactive notification of relevant feature suggestions based on contextual analysis

Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20050169212A1 (en) * 2003-12-09 2005-08-04 Yusuke Doi Peripheral object communication method, apparatus, and system
US20050256907A1 (en) * 2003-08-21 2005-11-17 Microsoft Corporation Systems and methods for the utilization of metadata for synchronization optimization
US20060265661A1 (en) * 2005-05-20 2006-11-23 Microsoft Corporation Device metadata
US7376666B2 (en) * 2004-03-19 2008-05-20 Sharp Laboratories Of America, Inc. Driver database auto-configuration methods and means
US20080201758A1 (en) * 2002-10-04 2008-08-21 Davies David B Home Communication Systems
US20090138477A1 (en) * 2007-11-26 2009-05-28 Adobe Systems Incorporated Updating Data on a Remote Device
US7730241B2 (en) * 2007-04-20 2010-06-01 Hewlett-Packard Development Company, L.P. Device and configuration method
US8321546B2 (en) * 2007-01-10 2012-11-27 Ricoh Company, Ltd. Integrating discovery functionality within a device and facility manager
US8458731B2 (en) * 2008-07-08 2013-06-04 Dell Products L.P. Methods, systems and media for installing peripheral software drivers

Family Cites Families (21)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5796951A (en) * 1995-12-22 1998-08-18 Intel Corporation System for displaying information relating to a computer network including association devices with tasks performable on those devices
US6094600A (en) * 1996-02-06 2000-07-25 Fisher-Rosemount Systems, Inc. System and method for managing a transaction database of records of changes to field device configurations
US6122639A (en) * 1997-12-23 2000-09-19 Cisco Technology, Inc. Network device information collection and change detection
US6295527B1 (en) * 1998-02-13 2001-09-25 Cisco Technology, Inc. Real-time user-defined creation of network device information collections
JP3782600B2 (en) * 1998-03-12 2006-06-07 キヤノン株式会社 Network device management apparatus, network device management method, and recording medium
US7085763B2 (en) * 1999-04-27 2006-08-01 Canon Kabushiki Kaisha Device search system
US6470332B1 (en) * 1999-05-19 2002-10-22 Sun Microsystems, Inc. System, method and computer program product for searching for, and retrieving, profile attributes based on other target profile attributes and associated profiles
US7266595B1 (en) * 2000-05-20 2007-09-04 Ciena Corporation Accessing network device data through user profiles
US20050015365A1 (en) * 2003-07-16 2005-01-20 Kavacheri Sathyanarayanan N. Hierarchical configuration attribute storage and retrieval
GB0418411D0 (en) * 2004-08-18 2004-09-22 King S College London A method of discovering contact means for network access devices
US7302448B2 (en) * 2004-10-07 2007-11-27 International Business Machines Corporation System and method for maintaining multiple devices with a single device identifier
US8412268B2 (en) * 2004-10-25 2013-04-02 Nokia Corporation Detection, identification and operation of pheripherals connected via an audio/video-plug to an electronic device
US20060130054A1 (en) * 2004-11-12 2006-06-15 Research In Motion Limited System and method for downloading or enabling download of a program from a program store location
US7580936B2 (en) * 2005-03-31 2009-08-25 Xerox Corporation Extendable discovery of network device information
US7292579B2 (en) * 2005-04-29 2007-11-06 Scenera Technologies, Llc Processing operations associated with resources on a local network
US20070055574A1 (en) * 2005-08-31 2007-03-08 Microsoft Corporation Commonly available device statistics for POS devices
US8156208B2 (en) * 2005-11-21 2012-04-10 Sap Ag Hierarchical, multi-tiered mapping and monitoring architecture for service-to-device re-mapping for smart items
JP5037862B2 (en) * 2006-06-14 2012-10-03 キヤノン株式会社 Information processing apparatus and method, and program
US20080153465A1 (en) * 2006-12-26 2008-06-26 Voice Signal Technologies, Inc. Voice search-enabled mobile device
US8103763B2 (en) * 2007-08-24 2012-01-24 Tibbo Technology System for remote configuration, control, and monitoring of devices over computer network using central server
US8418168B2 (en) * 2008-05-29 2013-04-09 Research In Motion Limited Method and system for performing a software upgrade on an electronic device connected to a computer

Patent Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20080201758A1 (en) * 2002-10-04 2008-08-21 Davies David B Home Communication Systems
US20050256907A1 (en) * 2003-08-21 2005-11-17 Microsoft Corporation Systems and methods for the utilization of metadata for synchronization optimization
US20050169212A1 (en) * 2003-12-09 2005-08-04 Yusuke Doi Peripheral object communication method, apparatus, and system
US7376666B2 (en) * 2004-03-19 2008-05-20 Sharp Laboratories Of America, Inc. Driver database auto-configuration methods and means
US20060265661A1 (en) * 2005-05-20 2006-11-23 Microsoft Corporation Device metadata
US8321546B2 (en) * 2007-01-10 2012-11-27 Ricoh Company, Ltd. Integrating discovery functionality within a device and facility manager
US7730241B2 (en) * 2007-04-20 2010-06-01 Hewlett-Packard Development Company, L.P. Device and configuration method
US20090138477A1 (en) * 2007-11-26 2009-05-28 Adobe Systems Incorporated Updating Data on a Remote Device
US8458731B2 (en) * 2008-07-08 2013-06-04 Dell Products L.P. Methods, systems and media for installing peripheral software drivers

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9756549B2 (en) 2014-03-14 2017-09-05 goTenna Inc. System and method for digital communication between computing devices
US10015720B2 (en) 2014-03-14 2018-07-03 GoTenna, Inc. System and method for digital communication between computing devices
US10602424B2 (en) 2014-03-14 2020-03-24 goTenna Inc. System and method for digital communication between computing devices

Also Published As

Publication number Publication date
US20090157595A1 (en) 2009-06-18
US8527554B2 (en) 2013-09-03
US20130282930A1 (en) 2013-10-24

Similar Documents

Publication Publication Date Title
US8527554B2 (en) Metadata retrieval for multi-function devices
US8352492B2 (en) Retrieval of metadata for peripheral devices
JP3617884B2 (en) Portable information equipment
US8458300B2 (en) Method and system to manage services for multiple managed computer systems
JP2023001596A (en) First terminal device, second terminal device, information processing system, display setting switching method and program
US9037685B2 (en) Intelligent migration between devices having different hardware or software configuration
KR101434293B1 (en) System, method, and apparatus for providing telephony and digital media services
US6343360B1 (en) Automated configuration of computing system using zip code data
US20110238498A1 (en) Service stage for subscription management
JPWO2008114491A1 (en) Terminal having application update management function, application update management program, and system
CN102090044A (en) System and method of regulating the download of data files from a server to a client device
US8891111B2 (en) Adaptable printer driver
CN101403974A (en) Method of installing application programs
CN102340616A (en) Image forming apparatus, equipment system, and computer-readable storage medium
KR20150136969A (en) Display apparatus, control mehtod thereof and server
US20080168131A1 (en) Platform for defining single-page web signup facilities
CN105229604B (en) Information processing equipment, information processing method and program
EP2115577A1 (en) Intelligent migration between devices having different hardware or software configuration
CN113806383A (en) Schedule real-time synchronization method and device
CN102150146B (en) Driver controlling device
JP2008177781A (en) Automatic program guide generation system, automatic program guide generation method, and automatic program guide generation program
JP7402290B1 (en) Multi-tenant system, service provision method, and program
TW466450B (en) Method and system for establishing an internet interface
US20230025512A1 (en) Meeting support system, meeting support method, and recording medium recording meeting support program
JP2008269113A (en) Application execution environment construction system, device and method used for it, and program therefor

Legal Events

Date Code Title Description
AS Assignment

Owner name: MICROSOFT TECHNOLOGY LICENSING, LLC, WASHINGTON

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICROSOFT CORPORATION;REEL/FRAME:034544/0541

Effective date: 20141014

STCB Information on status: application discontinuation

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