This application is related to pending U.S. patent application Ser. No. 11/222,256 entitled “RFID ARCHITECTURE IN AN INDUSTRIAL CONTROLLER ENVIRONMENT” filed on Sep. 8, 2005, and pending U.S. patent application Ser. No. 11/200,915 entitled “ENHANCED CONTROLLER UTILIZING RFID TECHNOLOGY” filed on Aug. 10, 2005.
The subject invention relates to industrial control systems and, more particularly, to systems and methods that employ radio frequency identification (RFID) technology in connection with manufactured goods.
Industrial controllers are special purpose processing devices used for controlling (e.g., automated and semi-automated) industrial processes, machines, manufacturing equipment, plants, and the like. A controller executes a control program or routine in order to measure one or more process variables or inputs representative of the status of a controlled process and/or effectuate outputs associated with control of the process. Such inputs and outputs can be digital and/or analog, assuming a continuous range of values. A control routine can be created in a controller configuration environment that has various tools and interfaces whereby a developer can construct and implement a control strategy using industrial and conventional programming languages or graphical representations of control functionality. Such control routine can be downloaded from the configuration system into one or more controllers for implementation of the control strategy in controlling a process or machine.
Measured inputs received from a controlled process and outputs transmitted to the process can pass through one or more input/output (I/O) modules in a control system. Such modules can serve in the capacity of an electrical interface between the controller and the controlled process, and can be located local or remote from the controller. Inputs and outputs can be recorded in an I/O memory. The input values can be asynchronously or synchronously read from the controlled process by one or more input modules and output values can be written directly to memory by a processor for subsequent communication to the process by specialized communications circuitry. An output module can interface directly with a controlled process by providing an output from memory to an actuator such as a motor, drive, valve, solenoid, and the like.
During execution of the control routine, values of the inputs and outputs exchanged with the controlled process can pass through memory. The values of inputs in memory can be asynchronously or synchronously updated from the controlled process by dedicated and/or common scanning circuitry. Such scanning circuitry can communicate with input and/or output modules over a bus on a backplane or network. The scanning circuitry can also asynchronously or synchronously write values of the outputs in memory to the controlled process. The output values from the memory can be communicated to one or more output modules for interfacing with the process. Thus, a controller processor can simply access the memory rather than needing to communicate directly with the controlled process.
In distributed control systems, controller hardware configuration can be facilitated by separating the industrial controller into a number of control elements, each of which performs a different function. Particular control modules needed for the control task can then be connected together on a common backplane within a rack and/or through a network or other communications medium. The control modules can include processors, power supplies, network communication modules, and I/O modules exchanging input and output signals directly with the controlled process. Data can be exchanged between modules using a backplane communications bus, which can be serial or parallel, or via a network. In addition to performing I/O operations based solely on network communications, smart modules exist which can execute autonomous logical or other control programs or routines. Various control modules of a distributed industrial control system can be spatially distributed along a common communication link in several locations. Certain I/O modules can thus be located proximate to a portion of the controlled equipment, and away from the controller. Data can be communicated with these remote modules over a common communication link, or network, wherein all modules on the network communicate via standard communication protocols.
In a conventional distributed control system, one or more I/O modules are provided for interfacing with a process. The outputs derive control or output values in the form of a message from a master or peer device over a network or a backplane. For example, an output module can receive an output value from a processor via a communications network or a backplane communications bus. The desired output value is generally sent to the output module in a message. The output module receiving such a message will provide a corresponding output (analog or digital) to the controlled process. Input modules measure a value of a process variable and report the input values to another device over a network or backplane. The input values can be used by a processor for performing control computations.
As noted above, industrial controllers can be utilized to control systems, machines, processes, etc., in the industrial automation and manufacturing environment. An evolving technology that is gaining more and more interest in this environment is Radio Frequency Identification (RFID), which leverages electronic data to mitigate data from reading (e.g., scanning bar codes) and/or opening containers to obtain product information. Suitable electronic product data can include electronic product code (EPC) data as well as other product-related data. A typical EPC is a unique number bit-encoded and embedded in an RFID tag (a small silicon chip with one or more antennas) affixed to an associated product. An RFID reader is a device that can be utilized to read and/or write RFID tag data, depending on read/write privileges. For example, an RFID reader can be utilized to read EPC and/or electronic data from an RFID tag via wireless (e.g., radio frequency (RF)) communication and/or write EPC and/or electronic data to an RFID tag.
Electronic product data read from an RFID tag can be utilized to provide a greater degree of certainty over what goes into a supply chain and/or how to manage raw materials, warehouse inventory, shipments, logistics, and/or various other aspects of manufacturing. However, conventional systems that employ RFID technology generally convey electronic product data obtained by RFID readers from RFID tags to a PC-based server that performs data filtering and management, and provides interfaces to other industrial applications. Thus, there is an unmet need to provide improved RFID technology mechanisms with industrial controllers.
The following presents a simplified summary of the invention in order to provide a basic understanding of some aspects of the invention. This summary is not an extensive overview of the invention. It is intended neither to identify key or critical elements of the invention nor to delineate the scope of the invention. Its sole purpose is to present some concepts of the invention in a simplified form as a prelude to the more detailed description that is presented later.
The systems and methods of the subject invention relate to novel techniques that integrate Radio Frequency Identification (RFID) technology with industrial controllers. The systems and methods herein provide for printing RFID tags based on RFID tag information that has been generated or received by an industrial controller. The industrial controller can operate within in an industrial environment, and can be part of an industrial and/or manufacturing network. Middleware software, as part of the industrial controller, can be managed by the industrial controller to organize and schedule the RFID tag information in a manner compatible with an RFID tag printer. Such organization can include creating and/or publishing reliable messages in XML (eXtensible Markup Language) and based on the RFID tag information, and/or arranging the RFID tag information in printing queues based on one or more topics, for example. RFID tag printing occurs in conjunction with one or more industrial processes, as the industrial controller allows for a seamless integration of RFID tag printing in the industrial environment.
In another aspect thereof, the industrial controller can further manage one or more RFID tag related processes such as RFID tag affixation, RFID tag programming, and/or a RFID tag quality verification procedure, for example.
In yet another aspect of the subject invention, the industrial controller can update a global registry with RFID tag information (e.g., RFID tag ID) associated with printed RFID tags. The registry update procedure can be facilitated by creating email messages related to the RFID tags that have been created, for example.
In still another embodiment, the subject invention facilitates distribution of electronic product data such as EPC data to a PLC (Programmable Logic Controller), controllers, modules, and/or control applications, for example. The systems and methods integrate RFID technology with such industrial components and/or processes. Electronic data residing in RFID tags can be received through RFID reader interfaces employing various vendor specific plug-ins, and electronic data residing in a server can be received through server interfaces. Received electronic product data can be filtered, processed, and stored, for example, as records in a table. Stored data can be provided to one or more controllers, modules, control applications, for example, upon receiving a subscription and/or request for such data.
To the accomplishment of the foregoing and related ends, the invention, then, comprises the features hereinafter fully described. The following description and the annexed drawings set forth in detail certain illustrative aspects of the invention. However, these aspects are indicative of but a few of the various ways in which the principles of the invention can be employed. Other aspects, advantages and novel features of the invention will become apparent from the following detailed description of the invention when considered in conjunction with the drawings.
As utilized in this application, terms “component,” “object,” “module,” “system,” “controller,” “device,” “interface,” “middleware” and variants thereof are intended to refer to a computer-related entities, either hardware, a combination of hardware and software, software, or software in execution. For example, a component may be, but is not limited to being, a process running on a processor, a processor, an object, an executable, a thread of execution, a program, and/or a computer. By way of illustration, both an application running on a server and the server can be a component. One or more components can reside within a process and/or thread of execution and a component can be localized on one computer and/or distributed between two or more computers. Additionally, it is noted that printing of a Radio Frequency Identification (RFID) tag and programming of an RFID tag can be understood as identical processes or separate processes directed to the creation, assembly, encoding, and/or production of one or more RFID tags.
The subject invention is described with reference to the drawings, wherein like reference numerals are used to refer to like elements throughout. In the following description, for purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the subject invention. It may be evident, however, that the subject invention may be practiced without these specific details. In other instances, well-known structures and devices are shown in block diagram form in order to facilitate describing the subject invention.
The industrial controller 110 and/or Ethernet module 115 comprise middleware 120 that at least manages the exchange of the RFID tag information with the RFID tag printers 125 in conjunction with one or more manufacturing processes. For instance, the middleware 120 can capture RFID tag information and publish a message to one or more of the RFID tag printers 125 regarding one or more unique RFID tags to be printed. Such message publication provides for the creation of reliable messages in XML (eXtensible Markup Language), and/or creating messages queues. Furthermore, the middleware 120 publishes the messages via a protocol that is compatible with the design and/or configuration of the RFID tag printers 125. As an example, one or more of the RFID tag printers 125 can comprise a subscription module that accesses the published messages as part of a broader RFID tag printing program. The middleware 120 of the industrial controller 110 can sense the subscription requirements and adapt publication procedures as the RFID tag printers 125 configuration and/or subscription module is modified. Additional aspects of the subject invention are further described below.
The system 100 can facilitate electronic data exchange within an industrial environment. The industrial controller 110 and/or Ethernet module 115 can exchange electronic data with entities within the industrial environment in order to store and/or convey electronic data. For example, the industrial controller 110 and/or Ethernet module 115 can include and/or be coupled to a processing module in order to exchange electronic data (e.g., RFID tag information) with various readers, writers, servers, storage components, etc. Such data can include unprocessed (e.g., raw data) and/or processed (e.g., filtered and formatted) electronic data. In addition, suitable electronic data can be compressed, encrypted, encoded, modulated within a carrier envelope, protected (e.g., password), etc., and conveyed as a data stream, one or more data bursts and/or one or more data packets, for example.
In one instance, the electronic data can be electronic product data (e.g., EPC-Electronic Product Code data) and other data associated with the product and/or manufactured good). Such data can be obtained from a RFID tag affixed to the product and read by devices such as RFID readers and/or stored in related servers. The communications channel between the processing module and these devices can be through essentially any wire and/or wireless channel, including Ethernet (e.g., 10BASE-T, 100BASE-T and 1000BASE-T), serial port (e.g., RS-232 and RS-485), parallel port, coaxial cable, Infrared (IR), BlueTooth, Universal Serial Bus (USB), Firewire, powerline communications such as HomePlug, ZigBee IEEE 802.15, WiFi IEEE 802.11, WiMax IEEE 802.16, and the like. In addition, the processing module can employ various interfaces to receive data from different sources (e.g., different device models, manufacturers, vendors, and software revisions).
The processing module can receive pushed and/or pulled data. In one example, a reader can periodically transmit or emit electronic data to the processing module, which can accept or reject the electronic data, for example, based on whether the electronic data is data of interest to the industrial environment. Such data discrimination can be facilitated by filters or other software and/or hardware that pass and/or reject data. Alternatively and/or additionally, intelligence can be utilized to facilitate selection of suitable electronic data. In this instance, the intelligence can employ machine learning techniques that utilize statistics, probabilities, inferences, classifiers, etc., to render a decision as to whether electronic data should be accepted. In another example, the processing module can transmit a message that indicates it is ready to receive electronic data. In yet another example, the processing module can query electronic data, for example, from one or more other components, servers and/or databases. It is to be understood that the RFID middleware and/or the industrial controller 102 can execute similar procedures as the processing module in regards to handling the electronic product data in order to expedite RFID tag printing.
A further example leverages reliable messaging to show the information exchange between one or more of the RFID printers 125 and the industrial controller component 110. In this example, the printers 125 can subscribe to a reliable messaging queue, such as a MQTT (message queue telemetry transport) broker topic, depicted as a message broker component 130. In one implementation, the message broker component 130, for example purposes, can be employed in the middleware component 120. In another embodiment, the broker component 130 can be employed as a separate node on the network 105, and/or can also be contained in one or more of the printers 125, for example, a first tag printer, denoted RFID TAG PRINTER1. The industrial controller 110 can publish a message to the topic to which the printer is subscribed. Each time the PLC publishes a message, the RFID printer prints the tag with information contained in the MQTT message. This example can be extended where the printer or another RFID reader may read back in the newly minted or applied tag and send a confirmation message to the broker, to which the PLC subscribes, and provide the PLC with an acknowledgement that the tag was programmed, applied and successfully read before leaving the work area. This message broker may also operate coupled with an upper layer system performing tag filtering such as the IBM Premises Server through the MQTT queues, for example.
The processing module can operate on received electronic data. For example, the processing module can filter, parse, and/or format electronic data. In addition, the processing module can selectively extract and/or discard portions of the electronic data. Where the data is compressed, encrypted, encoded, modulated, protected, etc., the industrial controller 110 and/or Ethernet module 115 can act on the electronic product data in this state and/or decompress, decrypt, decode, demodulate, unprotect, etc., the data prior to acting on it. In addition, the industrial controller 110 and/or Ethernet module 115 can store the electronic data, for example, within local and/or remote storage components. For example, the processing module can include various volatile and/or non-volatile memory that can be utilized to store the electronic data. Alternatively and/or additionally such memory can reside remote from the processing module, such as within the industrial controller 110 and/or Ethernet module 115. Additionally, such memory can reside in other modules controlled and/or managed by the industrial controller 110 and/or Ethernet module 115.
It is to be appreciated that the electronic data can be stored. For example, the data can be stored in records of a database, one or more binary files, and one or more ASCII (American Standard Code for Information Interchange) files. Stored electronic data can be conveyed to an industrial control 110 and/or Ethernet module 115 interface, which can provide communication interfaces to convey at least a portion of the electronic data to one or more entities within the industrial environment (e.g., RFID tag printers). Such interfaces can include essentially any interface, including publish/subscribe and query based interfaces that enable an entity to subscribe to receive electronic product data and/or a signal quality indicator when such data becomes available and/or query saved electronic data.
It is to be appreciated that the system 100 can be integrated within one or more control systems. In one instance, the system 100 can reside and execute within an entity of a control system. In another instance, the system 100 can be an additional component that facilitates electronic data exchange as described herein. It is noted that any interface employed by the industrial controller 110 and/or Ethernet module 115 can be software and/or hardware based. For example, these components can be implemented in essentially any programming language, such as, for example, LISP, C, C++, C# or Java based languages. In addition, a markup language such as XML and/or Physical Markup Language (PML) can be utilized to define a system configuration, and/or create reliable messages based on RFID tag information, which can include information on mapping between logical-physical readers, available filters, etc. Additional aspects of the subject invention are further described below. It is understood that such further discussion can include and/or incorporate fully and/or partially, aspects described as to
The industrial module 315 can be an industrial controller, a PLC, or the like. As such, the industrial module 315 can comprise one or more modules such as a processing module, a memory module, and an I/O module, and a power component to energize components therein. The processing module can be utilized to execute control applications, end-user programs and associated instructions, which can be stored within the memory module or memory external to the industrial module 315. The I/O module provides communication with the environment. For example, an input channel can be employed to receive analog and digital signals through sensors, switches and the like to provide information indicative of state and/or relating to a process, whereas an output channel can be utilized to convey a next state to an entity under the control of the controller.
The RFID tag printer 340 can utilize the subscription configuration 345 to access the RFID tag information, however formatted, organized and/or scheduled 335, to print and program one or more unique RFID tags 350. The RFID tag printer 340 can also create and/or store time stamps as to when one or more unique RFID tags 350 were actually printed, and can also print duplicate RFID tags, as necessary.
The RFID tag information 310 can include a variety of information to enable accurate and manageable RFID tag printing and/or RFID tag programming. For example, the RFID tag information received and/or generated can include, RFID tag serial numbers, tag identification numbers, priority codes, formatting instructions, message publication instructions, tag programming instructions, product specific information, logistics information, product cost information, supply chain data, global registry information, and codes that can interact and/or adapt to the subscription configuration of the RFID tag printer 340. RFID tag information can also include visual information and graphics to print on the tag carrier label, in addition to the programming of the tag itself. This can include bar codes, colors, graphics, and duplicates of the information programmed into the tag. The information on the label can be both plain text, as well as encoded data, using encryption schemes that can include cipher text which is alphanumeric as well as graphical and non-alphanumeric encoding.
The RFID tag affixation module 330, managed by the industrial module 315, can oversee affixing the RFID tag upon one or more manufactured goods. It is noted that such tag adhesion can also occur upon a package in which one or more manufactured goods are enclosed. Further, the RFID tag affixation module 330 is not limited to affixing only one RFID tag per package and/or manufactured good, but can apply multiple tags, where desired.
The manufacture control module 420 can run and/or regulate one or more manufacturing and/or production processes to produce at least one manufactured item. The package control module 435 can place one or more manufactured items in a distinct package, and can also arrange a plurality of distinct packages into package sets intended to facilitate product sale and/or transportation. The tag publish control module 425 can format and schedule RFID tag information that has been received by the industrial controller 410 via the bus 405 and/or a network related to the industrial environment. The industrial controller 410 can also generate the RFID tag information. RFID tag information scheduling and formatting can be facilitated and processed through RFID middleware 430 residing in the tag publish control module 425 of the industrial controller 410. The tag publish control module 425 publishes messages, based on the RFID tag information, to the RFID tag printer cluster 445.
The RFID tag printer(s) 445 includes subscription configuration data 450 to access the published messages. The printer(s) 445 can then print and program one or more unique RFID tags 455, 460, 465. Such programming can include encoding the printed unique RFID tags with information that is specific to the tag itself and related to the item and/or distinct package upon which the unique RFID tag will be placed. RFID tag application can occur via the robot arm control module 415 operating a robotic arm to place at least one printed and programmed RFID tag on the proper manufactured item, distinct package, and/or package set.
The read back verification control module 440 can scan one or more affixed RFID tags to determine whether the RFID tags are operative, and/or whether the encoded information is correct. If an inoperative RFID tag(s), and/or an improperly encoded RFID tag(s) are detected, the industrial controller 410 can initiate the entire RFID tag information generation and/or retrieval process in order to reprint the RFID tag(s) found to be problematic.
Information related to operative RFID tags can be sent to the supply chain global registry 470. Such information can include tag ID numbers, the information encoded in each unique RFID tag, and data related to the transport of the one or more manufactured items and/or one or more distinct packages containing one or more RFID tags.
At 505, the Ethernet module can publish electronic product data by one or more topics. Such publication can include creating one or more reliable XML messages based on the electronic product data under one or more topics compatible with the design, configuration, and/or the subscription process of the RFID printer. Each reliable XML message can include electronic product data that is relevant to one or more unique RFID tags that need to be printed and eventually affixed to a particular manufactured good(s). For instance, the electronic product data can comprise indications describing characteristics of the manufactured good(s), characteristics of the product type(s), as well as data that is intended to facilitate the management and execution of actual RFID tag printing that can occur at 510.
It is understood that after printing one or more unique RFID tags, the electronic product data from the one or more reliable XML messages can be erased, stored, or sent to other various components of the production line and/or industrial environment. Such electronic product data handling includes formatting the electronic data for subsequent storage, recognizing electronic product data of interest, etc. In one instance, the electronic data can be stored as records in a table, wherein individual rows are utilized to delineate related electronic data across fields, or columns. In one particular example, individual fields can store an EPC code, a logical reader identifier, a timestamp, a flag that indicates a logistical path of a RFID tag, etc. Such information can be later compiled for a supply chain registry update procedure. Additionally, the electronic data can filtered before and/or after RFID tag printing. Such filtering includes recognizing and filtering duplicate readings. The filtering can recognize differing electronic data formatted in a reliable XML message and consider the printing of different unique RFID tags.
At 610, the PLC can publish one or more reliable messages and/or send printing instructions to a queue and/or a message topic list. It is understood that the PLC can organize and/or schedule the RFID tag information via various protocols and/or algorithms. At 615, the RFID tag printer can access the RFID tag information from the queue and/or message topic list. The printer can access the tag information while the PLC is generating and/or publishing more tag information. Further, the PLC and the tag printer can modify organization and/or scheduling protocols dynamically. At 620, the RFID tag printer prints one or more unique RFID tags based on accessed RFID tag information.
It is to be appreciated that each printed unique RFID tag can comprise, for example, one or more silicon chips containing data about the object to which the tag is attached, data of an antenna that transmits and/or reflects to an RFID reader radio waves containing data about the object the to which the tag can be attached, and an enclosure that embodies the complete package of silicon chip, antenna (with printed circuit board), and protective casing (such as a label), which is applied later to an object.
At 705, an industrial controller, coupled to one or more RFID tag printers, can generate RFID tag data (e.g., tag IDs). The industrial controller can also be operative to pull a RFID tag data list from a network and/or another module such as a server, data storage unit, or a memory associated with the industrial environment, for example. The RFID tag data is further processed by the industrial controller in order to organize the RFID tag data for interaction with one or more RFID tag printers. For example, the industrial controller can execute middleware that filters and/or formats the RFID tag data into messages that one or more RFID tag printers can access and process to facilitate tag printing.
At 710, the industrial controller can publish and/or send the messages through an information channel to the one or more RFID tag printers. The communication protocol of the information channel can be compatible with the configuration and/or design of the RFID tag printer(s), and/or the RFID tag printer(s) can employ a subscription component to enable interaction with the information channel. For instance, the industrial controller can publish messages through the information channel by topic and/or in or more queues. The subscription component of one or more RFID tag printers can sense the organization and/or formatting of the published messages and can access the messages accordingly.
At 715, the one or more RFID tag printers can print and program one or more unique RFID tags based on the RFID tag data provided in the published messages sent through the information channel. The tag printing can occur in conjunction with one or more industrial processes related to the industrial environment. At 720, the industrial controller can directly and/or indirectly manage a procedure that utilizes a robotic arm to affix the printed RFID tags onto one or more manufactured goods. The manufactured goods can be in packaging as well, for example. The robotic arm can affix one or more RFID tags upon one or more manufactured goods and/or one or more distinct packages. It is to be appreciated that multiple robotic arms can also be controlled by the industrial controller to affix the RFID tags.
At 725, the industrial controller, and/or another module related to the industrial environment, can directly and/or indirectly manage a read-back verification procedure in order to verify proper RFID tag printing and/or programming. The read-back verification procedure can be executed before, during, and/or after affixation. RFID tags, and the one or more respective manufactured goods upon which the tags are affixed, can be routed through a procedure where the inoperative tags and the one or more goods can be separated and the tags can be destroyed, modified, and/or reprinted.
At 730, data related to printed RFID tags and/or affixed RFID tags that have been verified as valid, and/or RFID tags that have been destroyed and/or reprinted can be sent over a network to a global supply chain registry. The data can include RFID tag identification numbers, the data encoded in each tag, and data associated with the printing of the RFID tags. Data relating to destroyed tags can be utilized to determine tag printing efficiency and/or affixation efficiency.
At 810, the module can also direct the publication of messages based on the parsed RFID tag data that can assist one or more tag printers to each print at least one unique RFID tag. The messages can be in XML, Hypertext Markup Language (HTML), and/or conform to a predetermined code representing the information, for example. In addition, the parsed RFID tag data can simply be bits and/or a code meant to act as a key that can enable the tag printer to access RFID tag data located in the memory of another computer-related module that is included in the industrial environment, for example.
At 815, once the RFID tag data has been accessed by the tag printer, the tag printer can print and/or program one or more distinct RFID tags based on the RFID tag data. The printed tags can further be affixed to a manufactured good, a product, a set of items, or a package containing a product(s). The RFID tags can also be encoded with data related to other affixed tags. As an example, an RFID tag can store the serial number of a tag that was printed before and/or after the given RFID tag. Storing such data can be helpful for tracing quality issues concerning a production line as a whole, even as RFID tags get dispersed during a distribution process.
At 820, the one or more affixed tags can be sent through a verification procedure in which one or more RFID readers read at least one affixed RFID tag in order to verify proper operation of the RFID tag and proper data programming. The RFID reader can be associated with one or more antennas, which can be respectively directed at an area in which to read data from affixed RFID tags. The RFID readers can compare the data in the tag with a copy of the data produced and stored in the RFID printer and/or the module. The verification procedure can further separate the operative and affixed RFID tags from the inoperative and affixed RFID tags.
At 825, the one or more inoperative RFID tags, and the product(s) upon which the inoperative RFID tags are affixed can be directed to one or more procedures to correct any detected defects. For example, the entire tag printing process, starting at 800, can be initiated to reprint the defective RFID tag(s). Further, a procedure can separate the one or more affixed and inoperative RFID tags from their respective product(s) in order to properly discard the tags without wasting viable materials and product. Data associated with operative RFID tags can be transmitted to a global registry. The global registry can be accessible, for example, over the Internet, an Intranet, and/or via Personal Digital Assistants. Such data transmission can update the global registry with the data to enable inventory procedures, supply chain procedures, logistics and/or distribution procedures. Additionally, data associated with a payload of a recent set of tags can be emailed to a distribution center and/or the global registry.
With reference to
The system bus 908 can be any of several types of bus structure(s) including the memory bus or memory controller, a peripheral bus or external bus, and/or a local bus using any variety of available bus architectures including, but not limited to, an 11-bit bus, Industrial Standard Architecture (ISA), Micro-Channel Architecture (MSA), Extended ISA (EISA), Intelligent Drive Electronics (IDE), VESA Local Bus (VLB), Peripheral Component Interconnect (PCI), Universal Serial Bus (USB), Advanced Graphics Port (AGP), Personal Computer Memory Card International Association bus (PCMCIA), and Small Computer Systems Interface (SCSI) technologies.
The system memory 906 includes volatile memory 910 and non-volatile memory 912. The basic input/output system (BIOS), containing the basic routines to transfer information between elements within the computer 902, such as during start-up, is stored in non-volatile memory 912. By way of illustration, and not limitation, non-volatile memory 912 can include read only memory (ROM), programmable ROM (PROM), electrically programmable ROM (EPROM), electrically erasable ROM (EEPROM), or flash memory. Volatile memory 910 includes random access memory (RAM), which acts as external cache memory. By way of illustration and not limitation, RAM is available in many forms such as synchronous RAM (SRAM), dynamic RAM (DRAM), synchronous DRAM (SDRAM), double data rate SDRAM (DDR SDRAM), enhanced SDRAM (ESDRAM), Synchlink DRAM (SLDRAM), and direct Rambus RAM (DRRAM).
Computer 902 also includes removable/non-removable, volatile/non-volatile computer storage media.
It is to be appreciated that
A user enters commands or information into the computer 902 through input device(s) 926. Input devices 926 include, but are not limited to, a pointing device such as a mouse, trackball, stylus, touch pad, keyboard, microphone, joystick, game pad, satellite dish, scanner, TV tuner card, digital camera, digital video camera, web camera, and the like. These and other input devices connect to the processing unit 904 through the system bus 908 via interface port(s) 928. Interface port(s) 928 include, for example, a serial port, a parallel port, a game port, and a universal serial bus (USB). Output device(s) 930 use some of the same type of ports as input device(s) 926. Thus, for example, a USB port may be used to provide input to computer 902 and to output information from computer 902 to an output device 930. Output adapter 942 is provided to illustrate that there are some output devices 930 like monitors, speakers, and printers, among other output devices 930, which require special adapters. The output adapters 942 include, by way of illustration and not limitation, video and sound cards that provide a means of connection between the output device 930 and the system bus 908. It should be noted that other devices and/or systems of devices provide both input and output capabilities such as remote computer(s) 934.
Computer 902 can operate in a networked environment using logical connections to one or more remote computers, such as remote computer(s) 934. The remote computer(s) 934 can be a personal computer, a server, a router, a network PC, a workstation, a microprocessor based appliance, a peer device or other common network node and the like, and typically includes many or all of the elements described relative to computer 902. For purposes of brevity, only a memory storage device 936 is illustrated with remote computer(s) 934. Remote computer(s) 934 is logically connected to computer 902 through a network interface 938 and then physically connected via communication connection 940. Network interface 938 encompasses communication networks such as local-area networks (LAN) and wide-area networks (WAN). LAN technologies include Fiber Distributed Data Interface (FDDI), Copper Distributed Data Interface (CDDI), and the like. WAN technologies include, but are not limited to, point-to-point links, circuit switching networks like Integrated Services Digital Networks (ISDN) and variations thereon, packet switching networks, and Digital Subscriber Lines (DSL).
Communication connection(s) 940 refers to the hardware/software employed to connect the network interface 938 to the bus 908. While communication connection 940 is shown for illustrative clarity inside computer 902, it can also be external to computer 902. The hardware/software necessary for connection to the network interface 938 includes, for exemplary purposes only, internal and external technologies such as, modems including regular telephone grade modems, cable modems and DSL modems, ISDN adapters, and Ethernet cards.
What has been described above includes examples of the subject invention. It is, of course, not possible to describe every conceivable combination of components or methodologies for purposes of describing the subject invention, but one of ordinary skill in the art may recognize that many further combinations and permutations of the subject invention are possible. Accordingly, the subject invention is intended to embrace all such alterations, modifications, and variations that fall within the spirit and scope of the appended claims.
In particular and in regard to the various functions performed by the above described components, devices, circuits, systems and the like, the terms (including a reference to a “means”) used to describe such components are intended to correspond, unless otherwise indicated, to any component which performs the specified function of the described component (e.g., a functional equivalent), even though not structurally equivalent to the disclosed structure, which performs the function in the herein illustrated exemplary aspects of the invention. In this regard, it will also be recognized that the invention includes a system as well as a computer-readable medium having computer-executable instructions for performing the acts and/or events of the various methods of the invention.
In addition, while a particular feature of the invention may have been disclosed with respect to only one of several implementations, such feature may be combined with one or more other features of the other implementations as may be desired and advantageous for any given or particular application. Furthermore, to the extent that the terms “includes,” and “including” and variants thereof are used in either the detailed description or the claims, these terms are intended to be inclusive in a manner similar to the term “comprising.”
Number | Name | Date | Kind |
---|---|---|---|
3858212 | Tompkins et al. | Dec 1974 | A |
4949299 | Pickett et al. | Aug 1990 | A |
5300875 | Tuttle | Apr 1994 | A |
5461666 | McMahan et al. | Oct 1995 | A |
5613228 | Tuttle et al. | Mar 1997 | A |
5621199 | Calari et al. | Apr 1997 | A |
5629981 | Nerlikar | May 1997 | A |
5689415 | Calotychos et al. | Nov 1997 | A |
5701127 | Sharpe | Dec 1997 | A |
5703347 | Reddersen et al. | Dec 1997 | A |
5785181 | Quartararo, Jr. | Jul 1998 | A |
5798693 | Engellenner | Aug 1998 | A |
5822714 | Cato | Oct 1998 | A |
5874724 | Cato | Feb 1999 | A |
5874896 | Lowe et al. | Feb 1999 | A |
5905249 | Reddersen et al. | May 1999 | A |
5910776 | Black | Jun 1999 | A |
5949335 | Maynard | Sep 1999 | A |
5963134 | Bowers et al. | Oct 1999 | A |
5964656 | Lawler, Jr. et al. | Oct 1999 | A |
5971587 | Kato et al. | Oct 1999 | A |
5973600 | Mosher, Jr. | Oct 1999 | A |
6049745 | Douglas et al. | Apr 2000 | A |
6091998 | Vasko et al. | Jul 2000 | A |
6115616 | Halperin et al. | Sep 2000 | A |
6116505 | Withrow | Sep 2000 | A |
6121878 | Brady et al. | Sep 2000 | A |
6144301 | Frieden | Nov 2000 | A |
6150948 | Watkins | Nov 2000 | A |
6154790 | Pruett et al. | Nov 2000 | A |
6169483 | Ghaffari et al. | Jan 2001 | B1 |
6170059 | Pruett et al. | Jan 2001 | B1 |
6172609 | Lu et al. | Jan 2001 | B1 |
6205362 | Eidson | Mar 2001 | B1 |
6211789 | Oldham et al. | Apr 2001 | B1 |
6263440 | Pruett et al. | Jul 2001 | B1 |
6264106 | Bridgelall | Jul 2001 | B1 |
6265976 | Roesner et al. | Jul 2001 | B1 |
6272321 | Bruhnke et al. | Aug 2001 | B1 |
6275681 | Vega et al. | Aug 2001 | B1 |
6282407 | Vega et al. | Aug 2001 | B1 |
6285295 | Casden | Sep 2001 | B1 |
6286762 | Reynolds et al. | Sep 2001 | B1 |
6286763 | Reynolds et al. | Sep 2001 | B1 |
6293467 | Reddersen et al. | Sep 2001 | B1 |
6305548 | Sato et al. | Oct 2001 | B1 |
6307517 | Lee | Oct 2001 | B1 |
6317027 | Watkins | Nov 2001 | B1 |
6318636 | Reynolds et al. | Nov 2001 | B1 |
6330971 | Mabry et al. | Dec 2001 | B1 |
6342839 | Curkendall et al. | Jan 2002 | B1 |
6354493 | Mon | Mar 2002 | B1 |
6362738 | Vega | Mar 2002 | B1 |
6366206 | Ishikawa et al. | Apr 2002 | B1 |
6377176 | Lee | Apr 2002 | B1 |
6377203 | Doany | Apr 2002 | B1 |
6377764 | Morris-Jones | Apr 2002 | B1 |
6392544 | Collins et al. | May 2002 | B1 |
6400272 | Holtzman et al. | Jun 2002 | B1 |
6401936 | Isaacs | Jun 2002 | B1 |
6409401 | Petteruti et al. | Jun 2002 | B1 |
6415978 | McAllister | Jul 2002 | B1 |
6429776 | Alicot et al. | Aug 2002 | B1 |
6445297 | Nicholson | Sep 2002 | B1 |
6445969 | Kenney | Sep 2002 | B1 |
6448886 | Garber et al. | Sep 2002 | B2 |
6451154 | Grabau | Sep 2002 | B1 |
6476708 | Johnson | Nov 2002 | B1 |
6480100 | Frieden et al. | Nov 2002 | B1 |
6484886 | Isaacs | Nov 2002 | B1 |
6486780 | Garber | Nov 2002 | B1 |
6501382 | Rehfus | Dec 2002 | B1 |
6505780 | Yassin et al. | Jan 2003 | B1 |
6517000 | McAllister et al. | Feb 2003 | B1 |
6523752 | Nishitani et al. | Feb 2003 | B2 |
6529880 | McKeen et al. | Mar 2003 | B1 |
6547040 | Goodwin, III | Apr 2003 | B2 |
6549064 | Bandy et al. | Apr 2003 | B2 |
6554187 | Otto | Apr 2003 | B2 |
6563425 | Nicholson et al. | May 2003 | B2 |
6566997 | Bradin | May 2003 | B1 |
6585165 | Kuroda | Jul 2003 | B1 |
6593853 | Barrett et al. | Jul 2003 | B1 |
6600418 | Francis et al. | Jul 2003 | B2 |
6607123 | Jollifee et al. | Aug 2003 | B1 |
6608551 | Anderson et al. | Aug 2003 | B1 |
6608561 | Lawler, Jr. et al. | Aug 2003 | B2 |
6612495 | Reddersen et al. | Sep 2003 | B2 |
6617962 | Horwitz et al. | Sep 2003 | B1 |
6621417 | Duncan et al. | Sep 2003 | B2 |
6622567 | Hamel et al. | Sep 2003 | B1 |
6641042 | Pierenkemper et al. | Nov 2003 | B1 |
6650227 | Bradin | Nov 2003 | B1 |
6664897 | Pape et al. | Dec 2003 | B2 |
6669089 | Cybulski et al. | Dec 2003 | B2 |
6672512 | Bridgelall | Jan 2004 | B2 |
6677852 | Landt | Jan 2004 | B1 |
6687293 | Loyer et al. | Feb 2004 | B1 |
6693539 | Bowers et al. | Feb 2004 | B2 |
6700931 | Lee et al. | Mar 2004 | B1 |
6707376 | Patterson et al. | Mar 2004 | B1 |
6712276 | Abali et al. | Mar 2004 | B1 |
6714121 | Moore | Mar 2004 | B1 |
6724308 | Nicholson | Apr 2004 | B2 |
6726099 | Becker et al. | Apr 2004 | B2 |
6745008 | Carrender et al. | Jun 2004 | B1 |
6747560 | Stevens, III | Jun 2004 | B2 |
6750769 | Smith | Jun 2004 | B1 |
6752277 | Sempliner | Jun 2004 | B1 |
6784789 | Eroglu et al. | Aug 2004 | B2 |
6784813 | Shanks et al. | Aug 2004 | B2 |
6791603 | Lazo et al. | Sep 2004 | B2 |
6793127 | Alsafadi et al. | Sep 2004 | B2 |
6802659 | Cremon et al. | Oct 2004 | B2 |
6808116 | Eslambolchi | Oct 2004 | B1 |
6809646 | Lee | Oct 2004 | B1 |
6812838 | Maloney | Nov 2004 | B1 |
6816817 | Retlich | Nov 2004 | B1 |
6828902 | Casden | Dec 2004 | B2 |
6842106 | Hughes et al. | Jan 2005 | B2 |
6847856 | Bohannon | Jan 2005 | B1 |
6853294 | Ramamurthy et al. | Feb 2005 | B1 |
6853303 | Chen et al. | Feb 2005 | B2 |
6859757 | Muehl et al. | Feb 2005 | B2 |
6870797 | Reasoner et al. | Mar 2005 | B2 |
6873260 | Lancos et al. | Mar 2005 | B2 |
6879809 | Vega et al. | Apr 2005 | B1 |
6888459 | Stilp | May 2005 | B2 |
6897763 | Schulmerich et al. | May 2005 | B2 |
6899476 | Barrus et al. | May 2005 | B1 |
6901304 | Swan et al. | May 2005 | B2 |
6903656 | Lee | Jun 2005 | B1 |
6917291 | Allen | Jul 2005 | B2 |
6918541 | Knowles et al. | Jul 2005 | B2 |
6929412 | Barrus et al. | Aug 2005 | B1 |
6935560 | Andreasson et al. | Aug 2005 | B2 |
6940408 | Ferguson et al. | Sep 2005 | B2 |
6943678 | Muirhead | Sep 2005 | B2 |
6943688 | Chung et al. | Sep 2005 | B2 |
6967579 | Elizondo | Nov 2005 | B1 |
6975229 | Carrender et al. | Dec 2005 | B2 |
6992574 | Aupperle et al. | Jan 2006 | B2 |
6999955 | Horvitz | Feb 2006 | B1 |
7023342 | Corbett et al. | Apr 2006 | B2 |
7036729 | Chung | May 2006 | B2 |
7057509 | Gualdi et al. | Jun 2006 | B2 |
7061379 | Chen et al. | Jun 2006 | B2 |
7066388 | He | Jun 2006 | B2 |
7066667 | Chapman et al. | Jun 2006 | B2 |
7069100 | Monette et al. | Jun 2006 | B2 |
7073712 | Jusas et al. | Jul 2006 | B2 |
7075412 | Reynolds et al. | Jul 2006 | B1 |
7079023 | Haller | Jul 2006 | B2 |
7084769 | Bauer et al. | Aug 2006 | B2 |
7114655 | Chapman et al. | Oct 2006 | B2 |
7127507 | Clark et al. | Oct 2006 | B1 |
7135976 | Neff et al. | Nov 2006 | B2 |
7151456 | Godfrey | Dec 2006 | B2 |
7165722 | Shafer et al. | Jan 2007 | B2 |
7183922 | Mendolia et al. | Feb 2007 | B2 |
7187288 | Mendolia et al. | Mar 2007 | B2 |
7194072 | Gamble | Mar 2007 | B2 |
7195159 | Sloan et al. | Mar 2007 | B2 |
7212637 | Salisbury | May 2007 | B2 |
7221258 | Lane et al. | May 2007 | B2 |
7230730 | Owen et al. | Jun 2007 | B2 |
7240027 | McConnell et al. | Jul 2007 | B2 |
7272502 | Lee et al. | Sep 2007 | B2 |
7336167 | Olsen et al. | Feb 2008 | B2 |
7336243 | Jo et al. | Feb 2008 | B2 |
7373087 | Shi et al. | May 2008 | B2 |
7388491 | Chand et al. | Jun 2008 | B2 |
7389921 | Lin et al. | Jun 2008 | B2 |
7486181 | Olsen et al. | Feb 2009 | B2 |
7510110 | Pietrzyk et al. | Mar 2009 | B2 |
20010000019 | Bowers et al. | Mar 2001 | A1 |
20010008390 | Berquist | Jul 2001 | A1 |
20010015760 | Fellegara et al. | Aug 2001 | A1 |
20020005774 | Rudolph | Jan 2002 | A1 |
20020067265 | Rudolph | Jun 2002 | A1 |
20020070862 | Francis et al. | Jun 2002 | A1 |
20020130778 | Nicholson | Sep 2002 | A1 |
20020143320 | Levin | Oct 2002 | A1 |
20020165758 | Hind et al. | Nov 2002 | A1 |
20020167397 | Eroglu et al. | Nov 2002 | A1 |
20020185532 | Berquist et al. | Dec 2002 | A1 |
20030007473 | Strong et al. | Jan 2003 | A1 |
20030023337 | Godfrey et al. | Jan 2003 | A1 |
20030102367 | Monette et al. | Jun 2003 | A1 |
20030109951 | Hsiung et al. | Jun 2003 | A1 |
20030150908 | Pokorny et al. | Aug 2003 | A1 |
20030169149 | Ohki et al. | Sep 2003 | A1 |
20030203730 | Wan et al. | Oct 2003 | A1 |
20030216969 | Bauer et al. | Nov 2003 | A1 |
20040024644 | Gui et al. | Feb 2004 | A1 |
20040032443 | Moylan | Feb 2004 | A1 |
20040061324 | Howard | Apr 2004 | A1 |
20040062294 | Clemens et al. | Apr 2004 | A1 |
20040066281 | Hughes et al. | Apr 2004 | A1 |
20040069851 | Grunes | Apr 2004 | A1 |
20040084526 | Knowles et al. | May 2004 | A1 |
20040095910 | Metts et al. | May 2004 | A1 |
20040108378 | Gatz | Jun 2004 | A1 |
20040124988 | Leonard et al. | Jul 2004 | A1 |
20040160324 | Stilp | Aug 2004 | A1 |
20040181467 | Raiyani et al. | Sep 2004 | A1 |
20040189443 | Eastburn | Sep 2004 | A1 |
20040220860 | Persky et al. | Nov 2004 | A1 |
20050012613 | Eckstein et al. | Jan 2005 | A1 |
20050021369 | Cohen et al. | Jan 2005 | A1 |
20050035849 | Yizhack | Feb 2005 | A1 |
20050040934 | Shanton | Feb 2005 | A1 |
20050052283 | Collins et al. | Mar 2005 | A1 |
20050058483 | Chapman et al. | Mar 2005 | A1 |
20050062603 | Fuerst et al. | Mar 2005 | A1 |
20050083180 | Horwitz | Apr 2005 | A1 |
20050088299 | Bandy et al. | Apr 2005 | A1 |
20050092825 | Cox et al. | May 2005 | A1 |
20050093678 | Forster et al. | May 2005 | A1 |
20050093703 | Twitchell | May 2005 | A1 |
20050099268 | Juels et al. | May 2005 | A1 |
20050110641 | Mendolia et al. | May 2005 | A1 |
20050219039 | Edwards | May 2005 | A1 |
20050135181 | Shionoiri et al. | Jun 2005 | A1 |
20050140511 | Bonnell et al. | Jun 2005 | A1 |
20050143026 | Bellantoni | Jun 2005 | A1 |
20050143916 | Kim et al. | Jun 2005 | A1 |
20050145688 | Milenkovic et al. | Jul 2005 | A1 |
20050149414 | Schrodt et al. | Jul 2005 | A1 |
20050154572 | Sweeney | Jul 2005 | A1 |
20050155213 | Eastin | Jul 2005 | A1 |
20050159913 | Ariyoshi et al. | Jul 2005 | A1 |
20050162256 | Kinoshita | Jul 2005 | A1 |
20050170784 | Ariyoshi et al. | Aug 2005 | A1 |
20050177423 | Swanson | Aug 2005 | A1 |
20050177466 | Willins | Aug 2005 | A1 |
20050179521 | Pillai et al. | Aug 2005 | A1 |
20050180566 | Ryal | Aug 2005 | A1 |
20050188095 | Gardiner et al. | Aug 2005 | A1 |
20050190098 | Bridgelall et al. | Sep 2005 | A1 |
20050192727 | Shostak et al. | Sep 2005 | A1 |
20050197775 | Smith | Sep 2005 | A1 |
20050200457 | Bridgelall et al. | Sep 2005 | A1 |
20050206552 | Friedrich | Sep 2005 | A1 |
20050206555 | Bridgelall et al. | Sep 2005 | A1 |
20050212660 | Hansen et al. | Sep 2005 | A1 |
20050212673 | Forster | Sep 2005 | A1 |
20050212676 | Steinberg | Sep 2005 | A1 |
20050228528 | Farchmin et al. | Oct 2005 | A1 |
20050237162 | Hyde et al. | Oct 2005 | A1 |
20050240305 | Bogash et al. | Oct 2005 | A1 |
20050253717 | Howarth et al. | Nov 2005 | A1 |
20050253718 | Droms et al. | Nov 2005 | A1 |
20050258955 | Gloekler et al. | Nov 2005 | A1 |
20050269407 | Harmon | Dec 2005 | A1 |
20060006231 | Anson et al. | Jan 2006 | A1 |
20060027658 | Genc et al. | Feb 2006 | A1 |
20060038077 | Olin et al. | Feb 2006 | A1 |
20060049250 | Sullivan | Mar 2006 | A1 |
20060053234 | Kumar et al. | Mar 2006 | A1 |
20060055508 | Kumar et al. | Mar 2006 | A1 |
20060060657 | Choong et al. | Mar 2006 | A1 |
20060071774 | Brown et al. | Apr 2006 | A1 |
20060125653 | McQuade | Jun 2006 | A1 |
20060145850 | Krstulich | Jul 2006 | A1 |
20060170565 | Husak et al. | Aug 2006 | A1 |
20060200256 | Mason et al. | Sep 2006 | A1 |
20060208859 | Hougen et al. | Sep 2006 | A1 |
20060232382 | Bauer et al. | Oct 2006 | A1 |
20060279412 | Holland et al. | Dec 2006 | A1 |
20070008073 | Poasevara | Jan 2007 | A1 |
20070013517 | Posamentier | Jan 2007 | A1 |
20070013519 | Chung et al. | Jan 2007 | A1 |
20070035396 | Chand et al. | Feb 2007 | A1 |
20070040681 | Jessup | Feb 2007 | A1 |
20070063029 | Brandt et al. | Mar 2007 | A1 |
20070137531 | Muirhead | Jun 2007 | A1 |
20070159311 | Schober | Jul 2007 | A1 |
20070205860 | Jones et al. | Sep 2007 | A1 |
20070205861 | Nair et al. | Sep 2007 | A1 |
Number | Date | Country |
---|---|---|
10314260 | Oct 2004 | DE |
1542105 | Jun 2005 | EP |
0016289 | Mar 2000 | WO |
0058752 | Oct 2000 | WO |
0169516 | Sep 2001 | WO |
02073523 | Sep 2002 | WO |
02101670 | Dec 2002 | WO |
03056403 | Jul 2003 | WO |
03056469 | Jul 2003 | WO |
2005045743 | May 2005 | WO |
2007030544 | Mar 2007 | WO |