Computer system and processing method for driving program of smart peripheral device6915368Abstract A processing method and a computer system for the driving program of a smart peripheral device. The processing method requests that the computer's operating system return any information regarding any smart peripheral device connected to a peripheral bus through a driving program written according to this invention. If the particular smart peripheral device is supported by the operating system, a plug-and-play notification is used to open a function device object established through a factory-provided driving program. The function device object is used to retrieve a physical device object established through a bus-driving program. Using the physical device object, descriptors and calling data of the smart peripheral device are retrieved and employed to set up necessary information for executing the driving program of this invention. Claims 1. A method of processing the driving program of a smart peripheral device in a computer system using an operating system, wherein the smart peripheral device is connected to the computer system through a peripheral bus and the operating system includes a bus-driving program for controlling the peripheral bus and the processing method comprising: Description CROSS-REFERENCE TO RELATED APPLICATION
SUMMARY OF THE INVENTION Accordingly, one object of the present invention is to provide a computer system and a processing method for dealing with the driving programs of a smart peripheral device. The driving program according to this invention does not depend on the application programming interface (API) within the factory-provide driving programs. Hence, problems resulting from a reliance on the API of factory-supplied driving programs and problems resulting from incompatible API due to the presence of a variety of driving programs each developed by a different manufacturer are avoided. Furthermore, the driving programs according to this invention can coexist with factory-supplied driving program in the same operating system. Therefore, there is no need to switch API when a different application program is used, download driving programs or re-plug the smart peripheral device. To achieve these and other advantages and in accordance with the purpose of the invention, as embodied and broadly described herein, the invention provides a method of processing the driving program of a smart peripheral device. The method is suitable for processing the operating system of a computer system. The smart peripheral device may connect with the computer system via a peripheral bus and the operating system includes a bus-driving program for controlling the peripheral bus. The processing method includes the following steps. First, the driving programs of the smart peripheral device according to this invention request the operating system to report on any peripheral device having linkage with the peripheral bus. According to the plug-and-play notifications received from the operating system, the driving program of the smart peripheral device are inspected to see if they support any peripheral bus linked peripheral device. If the driving program of the smart peripheral device supports the linked peripheral device, the plug-and-play notifications are used to trigger the function device object established through the factory-provided driving programs. According to the function device object, the physical device object established through the bus driving programs is retrieved. Thereafter, descriptor and calling information of the connected peripheral device are retrieved according to the physical device object. Through the descriptor and calling information, various types of information required for executing the driving programs of a smart peripheral device is established. This invention also provides a computer system capable of connecting with a smart peripheral device. The computer system includes a peripheral bus, an operating system, a factory-provided driving program and a general-purpose driving program. The smart peripheral device is coupled to the computer system via the peripheral bus. The operating system includes a bus-driving program for controlling the peripheral bus. The bus-driving program is utilized to establish a physical device object corresponding to the smart peripheral device. The factory-provided driving program is utilized to establish a function device object. The function device object communicates with the smart peripheral device through the physical device object. The general-purpose driving program communicates with the smart peripheral device also through the physical device object. As soon as the smart peripheral device is connected to the computer system, the general-purpose driving program triggers the function device object established through the factor-provided driving program. The physical device object established through the bus-driving program is retrieved according to the function device object. Thereafter, descriptor and calling information of the smart peripheral device are retrieved according to the physical device object. Using the descriptor and calling information, various types of information necessary for executing the general-purpose driving program are established. In brief, the driving program according to this invention does not depend on the API of factory-provided driving programs. Hence, the need to receive APIs from factory-provided driving programs is eliminated and the problem of having incompatible APIs due to each smart peripheral device manufacturer manufacturing its own driving program is solved. Furthermore, the driving program according to this invention may coexist with the factory-provided driving program in the same operating system. Hence, there is no need to switch APIs, download driving programs or re-plug when a different application program is used. It is to be understood that both the foregoing general description and the following detailed description are exemplary, and are intended to provide further explanation of the invention as claimed. BRIEF DESCRIPTION OF THE DRAWINGS The accompanying drawings are included to provide a further understanding of the invention, and are incorporated in and constitute a part of this specification. The drawings illustrate embodiments of the invention and, together with the description, serve to explain the principles of the invention. In the drawings, FIG. 1 is a block diagram showing a computer system according to one preferred embodiment of this invention; FIG. 2 is a flow-chart showing a series of steps for processing the driving program of a smart peripheral device according to one preferred embodiment of this invention; and FIG. 3 is a flow-chart showing a series of steps for processing the driving program of a smart peripheral device when the application program uses a processing request to call up the driving program according to this invention. DESCRIPTION OF THE PREFERRED EMBODIMENTS Reference will now be made in detail to the present preferred embodiments of the invention, examples of which are illustrated in the accompanying drawings. Wherever possible, the same reference numbers are used in the drawings and the description to refer to the same or like parts. FIG. 1 is a block diagram showing a computer system according to one preferred embodiment of this invention. As shown in FIG. 1, the computer system 100 includes a peripheral bus 104, an operating system 106, a factory-provided driving program 108 and a general-purpose driving program 110 designed according to this invention. A smart peripheral device 102 is coupled to the computer system 100 via the peripheral bus 104. The peripheral bus 104 can be a USB bus or an IEEE-1394 bus, for example. The operating system 106 further includes a bus-driving program 114 that controls the peripheral bus 104. The bus-driving program 114 establishes a physical device object (PDO) that corresponds to the smart peripheral device 102. The factory-provided driving program 108 establishes a function device object (FDO). The function device object communicates with the smart peripheral device 102 through the physical device object. Similarly, the general-purpose driving program 110 communicates with the smart peripheral device 102 through the physical device object. As soon as the smart peripheral device 102 is hooked onto the computer system 100, the general-purpose driving program 110 switches on the function device object established by the factory-provided driving program 110. The physical device object established by the bus-driving program 114 is retrieved according to the function device object. Descriptor and calling information related to the smart peripheral device 102 are retrieved according to the physical device object. The descriptor and calling information are utilized to establish various data necessary for executing the general-purpose driving program 110. In addition, the computer system 100 further includes an application program 112. When the application program 112 issues a processing request call to the general-purpose driving program 110, the general-purpose driving program 110 produces a request block and an input/output request packet (IRP). The input/output request packet is transmitted to the physical device object for further processing. The request block, for example, is a USB request block (URB) or an IEEE-1394 request block (IRB). Similarly, the input/output request packet can also be a URB or an IRB. After the input/output request packet is processed, the physical device object returns correct data to the application program 112. On the other hand, if there is a delay in the processing of the input/output request package, the physical device object responds by returning a delay signal to the application program 112. FIG. 2 is a flow-chart showing a series of steps for processing the driving program of a smart peripheral device according to one preferred embodiment of this invention. In the following, the processing steps are explained with reference to FIG. 1. First, the general-purpose driving program 110 registers itself with the plug-and-play administrator of the operating system 106 and requests the smart peripheral device having a class identification (CLSID) that meets the peripheral bus 104. In general, each peripheral bus has a different CLSID. In this embodiment, the CLSID can either be a USB CLSID or an IEEE-1394 CLSID. When the peripheral bus 104 already has a smart peripheral device 102 plugged into the peripheral bus 104 or a new smart peripheral device 102 is plugged into the peripheral bus 104, the operating system 106 utilizes the plug-and-play notification to inform the general-purpose driving program (in step 202). According to the special identification code provided by the plug-and-play notification, the smart peripheral device 102 is checked to see if the smart peripheral device 102 meets the operating characteristics of the types of peripheral devices processed by the general-purpose driving program 110 (in step 204). If the peripheral bus 104 is a USB bus, the special code is the vender identification (VID) and the product identification (PID). On the other hand, if the peripheral bus is the IEEE-1394 bus, the special code is the plug-and-play identification (PnPID). If the general-purpose driving program 110 supports the smart peripheral device 102, device name and other data from plug-and-play notification corresponding to the smart peripheral device 102 are used to retrieve the device object. The device object has a stacked structure. Thereafter, the factory-provided driving program established function device object is opened (in step 206). According to the function device object, a special input/output request packet (IRP) is prepared and the function device object is called. When the lower layer of the device object processes the special input/output request packet, it will report its pointer in the special input/output request packet. A block of memory is set aside for holding data indicated by the pointer. On returning from the function device object, physical device object is retrieved according to the pointer within the special input/output request packet and then the memory block is release (in step 208). Note that since the device object has a stacked structure, the function device object is formed over and above the physical device object of the bus-driving program 114. The special input/output request packet is processed such that the input/output request packet is downwardly delivered, layer by layer, so that the driving program of each layer may be reported. The special input/output request packet is sent to the function device object in this manner. Because the special input/output request packet not processed by the function device object is delivered to the next lower layer, pointers of the physical device object in the next lower layer can be retrieved. Descriptor and calling data of the smart peripheral device 102 are retrieved according to the physical device object (in step 210). According to the descriptor and the calling data, various data necessary for executing the general-purpose driving program 110 of the smart peripheral device 102 are established (in step 212). In this embodiment, if the peripheral bus is the USB bus, the descriptor and calling data include device descriptor, configuration descriptor, interface descriptor, end-point descriptor and USB pipe. On the other hand, if the peripheral bus is the IEEE-1394 bus, the descriptor and calling data include configuration ROM. For example, from the descriptor and calling data, transmission characteristics such as control, interrupt, bulk or isochronous of the end point, size of the largest transmission packet at the end point or USB pipe handle of the end point may all be obtained. If the received plug-and-play notification indicates the absence of the particular smart peripheral device 102, the application program 112 for calling the general-purpose driving program 110 is informed of the non-existence of the smart peripheral device 102. Afterwards, all requests for processing the non-existent smart peripheral device are canceled. Finally, the operating system 106 is returned to its initial state. In addition, when the smart peripheral device 102 is automatically shut to preserve energy or the smart peripheral device 102 is removed from the peripheral bus 104, the operating system 106 informs the general-purpose driving program 110 through the plug-and-play notification. After the general-purpose driving program 110 has confirmed the removal of the smart peripheral device 102, the application program 112 is informed and the in-process requests for transmission or reception are canceled. Again, the operating system 106 is returned to its initial state. FIG. 3 is a flow-chart showing a series of steps for processing the driving program of a smart peripheral device when the application program uses a processing request to call up the driving program according to this invention. The following is explained with reference to FIG. 1. When the application program 112 calls up the general-purpose driving program 110 to process requests, an inspection is carried out to determine if the smart peripheral device 102 is really absent (in step 300). If the smart peripheral device 102 is really absent, an error signal is sent back to the application program 112. If the smart peripheral device 102 is present, a search for end point that corresponds to the processing request of the smart peripheral device 102 is sought (in step 302). When no such end point for the smart peripheral device 102 is found, an error signal is returned to the application program 112. On the other hand, if the smart peripheral device 102 has an end point, a request block is set up (in step 304). The request block is selected from either the URB or the IRB and then the input/output request packet is set up (in step 306). The input/output request packet is either a URB or an IRB. The input/output request packet is transmitted to the physical device object for further processing (in step 308). After the physical device object has completely processed the input/output request packet, a correct signal is sent to the application program 112 (in step 310). When the physical device object encounters some delay, a delay signal is returned to the application program 112 (in step 312). In conclusion, major advantages of this invention include:
It will be apparent to those skilled in the art that various modifications and variations can be made to the structure of the present invention without departing from the scope or spirit of the invention. In view of the foregoing, it is intended that the present invention cover modifications and variations of this invention provided they fall within the scope of the following claims and their equivalents.
|
Same subclass Same class Consider this |
||||||||||
