Devices which are particularly known in the industry for performing sustained communication sequences comprises Mass Storage Devices and Printers. Some examples of Mass Storage Devices include tape drives, and disk drives, Compact Disk/Digital Video Disk (CD/DVD) Drives, and Flash/thumb/key/jump/Universal Serial Bus (USB) drives.
If the operating system is performing a sustained communication sequence with a device, such as saving a file to a mass storage device, or printing a document to a printer, and the device is disconnected, the communication sequence is interrupted. If a file was being read from the device by an application, then removal of the device would cause the read to fail, and possibly result in the application becoming unstable. In the case of a printer, the job being printed would be incomplete, and/or the printer could become confused requiring a reset. In the case of a mass storage device, like a USB drive, interrupting the communications sequence could result in corrupted files and unrecoverable data errors. This can happen often due to an operating system's procedures for buffering Input/Output (I/O) and allowing slower devices to complete transfers in a background process. If a system is very active, then buffered communications may be prolonged past the normally expected completion time.
Some operating systems, such as Linux, give the user a way to ensure I/O buffers have been flushed prior to removal of the device by requiring you to perform an “unmount” or similar command. This command causes any buffers associated with the device to be flushed. Once this is done the device can safely be removed. However this requires knowing exactly where the device in question is mounted. Other operating systems, like Windows, require the user to go through a series of steps involving clicking on an icon in the system tray and choosing to stop the device to be removed to ensure safe removal of the device. This can be a problem if there are multiple devices because the operating system decides how to label a device when it is inserted, so the user may not know the exact designation of the device to be removed. Stopping the wrong device can result in extra steps being required before the device is restarted and returned to operating condition.
A peripheral device is designed to facilitate proper disconnection from a system by a user. By giving the user a method to send a signal to the device driver or operating system prior to disconnecting the device, a user can ensure the software is aware of the pending device removal and is quiescent prior to said removal. Since device driver activity ceases prior to removal, data will not be corrupted or lost due to the interruption of transfer activities by a device removal.
The present invention relates generally to peripheral devices which are removably connected to a computer system and more particularly to devices which preformed prolonged communications as opposed to those which send short burst of information across the bus.
In another embodiment, physical security may be included to prevent premature removal of the peripheral device.
In one embodiment the latch plate is immovably attached to the computing device at one end, and is constructed in manner so as to be flexible between an engaged and disengaged position. In the preferred embodiment the latch plate is movably attached to the computing device such that the latching plate may pivot between an engaged and disengaged position. In an alternative embodiment the latch plate is attached to the computing device by a pivoting connection in the center of the latching plate such that it can pivot between the engaged and disengaged positions.
In the preferred embodiment, an end of the latching plate is formed into two catches (307) which engage the square voids (104) in the electrical interface connection (103). In other embodiments the catch may engage a lip or grove incorporated into the USB device. In other embodiments there may be multiple latching plates which clasp the USB device from multiple directions.
In other embodiment, the latching plate(s) is/are biased such that they remain in a disengaged position until acted upon by a force which causes the latching plates to move into an engaged position. Alternatively, they may be biased to remain in the engaged position until acted upon by a force which causes the latching plates to move into a disengaged position. In the preferred embodiment the latching plate (301) is biased with a spring (305) to hold it in a disengaged position. A solenoid (303) is positioned such that when the plunger (304) exerts a force on the latching plate (301) the springs force is overcome such that the resulting net force causes the latching plate to move into an engaged position. The latching plate is held in the engaged position until the solenoid (303) retracts the plunger (304) allowing the force of the spring (305) to return the latching plate to a disengaged position. In another embodiment the spring is used to bias the latching plate into an engaged position and the solenoid is used to overcome the spring force to move the latching plate into a disengaged position.
In one embodiment the latching plate may be mounted on a servo motor, or other device capable of moving and holding both the engaged and disengaged positions without the aid of a biasing device. In one embodiment the catches (307) are mounted on the plunger (304) of the solenoid (303), and the solenoid is positioned such that it can directly move catches (307) between an engaged and disengaged position.
A peripheral device sends a signal to the operating system requesting driver activity quiescence so the signaling device can be disconnected from the system bus without compromising data integrity. A user will then be able to disconnect a device from a system while allowing the operating system to maintain the integrity of the data involved without having to navigate the operating system control system to identify the correct device and request driver activity quiescence. The result is a quicker and less confusing method for the user to safely disconnect a device on a machine with multiple similar devices.
In one embodiment, the OS may have multiple devices associated with a single driver. In this instance, illustrated in
Signals described above may be sent as a message in a device which uses a packet transmission method to communicate with the driver. The signals may also be a series of unique line levels or sequences which are intercepted and interpreted by the driver.
Quiescence of device activity may include, but is not limited to one or more of the following: Notifying the User of a request to remove the device; updating all queued information to and from the device, identifying and notifying other applications which may be accessing the device; flushing all cached buffers and/or delayed write buffers; ceasing all communication with the device; powering down the device or port; updating system configurations and/or statistics; and possibly unloading the drivers for the device.
(802), to access a plurality of device drivers (902) which communicate with peripheral devices (805) by passing communications through a bus driver (903) which controls a common communication bus (904). A device driver (903), operating in this scenario, can be associated with multiple peripheral devices (805) and can not be unloaded from a system's memory until all peripheral devices (805) utilizing the device driver's (903) services have been disconnected. So each device driver (903) disconnection triggers a test to determine if there are any other peripheral devices (805) using the device driver's services, and when none are found, the device driver may be unloaded from a system's memory.
In some implementations of the current invention, a locking mechanism may be employed on the physical bus connector or device bay which prevents the removal of the device until the operating system has finished device quiescence. Such locks may include a physical override which allows the user to force removal of the device without waiting for the operating system to disengage the lock.
One implementation of the current invention, the EJECT_REQ signal may be sent in response to a user operating a mechanism on the physical device to be removed. The mechanism may be a button conveniently located on the plug housing, where the cable connects to the computer or on the main device housing. The mechanism may be an eject button or lever located on a disk drive or tape cartridge drive.
In one implementation of the current invention the EJECT_REQ signal may be sent in response to activation of an inner-lock preventing the physical removal of the device from a carriage, slot, or other type of holder.
In one implementation of the current invention the EJECT_REQ signal may be sent by the device without intervention by the user. As a security measure, a device may include an internal clock which triggers a EJECT_REQ signal followed by a power down of the device rendering it unusable during certain timeframes. A driver may be configured such that Quiescence does not flush buffers, but instead preserves them in another manner such that upon device reactivation the state can be resumed.
The flow diagrams in accordance with exemplary embodiments of the present invention are provided as examples and should not be construed to limit other embodiments within the scope of the invention. For instance, the blocks should not be construed as steps that must proceed in a particular order. Additional blocks/steps may be added, some blocks/steps removed, or the order of the blocks/steps altered and still be within the scope of the invention. Further, blocks within different figures can be added to or exchanged with other blocks in other figures. Further yet, specific numerical data values (such as specific quantities, numbers, categories, etc.) or other specific information should be interpreted as illustrative for discussing exemplary embodiments. Such specific information is not provided to limit the invention.
In the various embodiments in accordance with the present invention, embodiments are implemented as a method, system, and/or apparatus. As one example, exemplary embodiments are implemented as one or more computer software programs to implement the methods described herein. The software is implemented as one or more modules (also referred to as code subroutines, or “objects” in object-oriented programming). The location of the software will differ for the various alternative embodiments. The software programming code, for example, is accessed by a processor or processors of the computer or server from long-term storage media of some type, such as a CD-ROM drive or hard drive. The software programming code is embodied or stored on any of a variety of known media for use with a data processing system or in any memory device such as semiconductor, magnetic and optical devices, including a disk, hard drive, CD-ROM, ROM, etc. The code is distributed on such media, or is distributed to users from the memory or storage of one computer system over a network of some type to other computer systems for use by users of such other systems. Alternatively, the programming code is embodied in the memory (such as memory of the handheld portable electronic device) and accessed by the processor using the bus. The techniques and methods for embodying software programming code in memory, on physical media, and/or distributing software code via networks are well known and will not be further discussed herein.
The above discussion is meant to be illustrative of the principles and various embodiments of the present invention. Numerous variations and modifications will become apparent to those skilled in the art once the above disclosure is fully appreciated. It is intended that the following claims be interpreted to embrace all such variations and modifications.