WO2005098637A1 - Operating a remote usb host controller - Google Patents

Operating a remote usb host controller Download PDF

Info

Publication number
WO2005098637A1
WO2005098637A1 PCT/US2005/010369 US2005010369W WO2005098637A1 WO 2005098637 A1 WO2005098637 A1 WO 2005098637A1 US 2005010369 W US2005010369 W US 2005010369W WO 2005098637 A1 WO2005098637 A1 WO 2005098637A1
Authority
WO
WIPO (PCT)
Prior art keywords
host controller
usb
remote host
remote
media
Prior art date
Application number
PCT/US2005/010369
Other languages
French (fr)
Inventor
John Keys
John Howard
Abdul Ismail
Original Assignee
Intel Corporation
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 Intel Corporation filed Critical Intel Corporation
Priority to EP05726164A priority Critical patent/EP1730645B1/en
Priority to AT05726164T priority patent/ATE556527T1/en
Publication of WO2005098637A1 publication Critical patent/WO2005098637A1/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/30Definitions, standards or architectural aspects of layered protocol stacks
    • H04L69/32Architecture of open systems interconnection [OSI] 7-layer type protocol stacks, e.g. the interfaces between the data link level and the physical level
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/56Provisioning of proxy services
    • H04L67/59Providing operational support to end devices by off-loading in the network or by emulation, e.g. when they are unavailable
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/30Definitions, standards or architectural aspects of layered protocol stacks
    • H04L69/32Architecture of open systems interconnection [OSI] 7-layer type protocol stacks, e.g. the interfaces between the data link level and the physical level
    • H04L69/322Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions
    • H04L69/323Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions in the physical layer [OSI layer 1]

Definitions

  • the present invention relates generally to the field of device connectivity.
  • USB Universal Serial Bus
  • host controller the Master in the system is called a USB host controller
  • Conventional host controllers are tightly integrated in a "host” platform, e.g., integrated into a processor, processor chipset, as a bus master controller on a Peripheral Control Interface (“PCI”) or other "inside the box” bus or the like.
  • PCI Peripheral Control Interface
  • a USB host includes applications, device drivers (which manage attached USB devices), a USB bus driver (which provides a standard USB bus services abstraction to USB device drivers), a host controller driver, and a physical USB host controller (of which there are several types), all of which manages data communications for a bus.
  • the host controller provides status and control mechanism to allow a USB host to manage USB ports for connecting USB devices and/or USB hubs.
  • USB hubs are devices for allowing one or more USB devices (through additional one or more additional ports) to connect back through the hub to a USB port.
  • USB hubs Under Universal Serial Bus Specification v2.0, up to 127 devices may be connected to a single host controller.
  • a conventional USB system software implementation provides a buffer- oriented streaming service for USB device drivers.
  • a USB device driver submits buffer input/output ("I/O") requests to the USB bus driver, which in turn sends the buffer to the appropriate USB host controller driver.
  • the USB host controller driver then gives the buffer to the host controller hardware utilizing its specific interface. In effect, the entire stack is buffer oriented.
  • USB devices must be within a prescribed distance of the USB host.
  • the distance is governed by the length of the cables and the length of the cables are a function of the protocol parameters, which limit the maximum flight time. Therefore conventional USB controllers are limited in the distance they may connect to USB devices.
  • Figure 1 illustrates a block diagram view of a computing environment, in accordance with an embodiment of the present invention
  • Figure 2 illustrates the couplings of software components of Figure 1 to communicate with the remote host controller, in accordance with one embodiment of the present invention
  • Figure 3 illustrates a block diagram view of a computing system environment with a host computer and a remote host controller, in accordance with an embodiment of the present invention
  • Figures 4a-d illustrate exemplary configurations of host systems connected to remote host controllers, in accordance with embodiments of the present invention.
  • Illustrative embodiments of the present invention include, but are not limited to, a buffer-oriented abstraction that allows a host controller to be physically located somewhere other than inside a USB host computer.
  • Various aspects of the illustrative embodiments will be described using terms commonly employed by those skilled in the art to convey the substance of their work to others skilled in the art. However, it will be apparent to those skilled in the art that the present invention may be practiced with only some of the described aspects. For purposes of explanation, specific numbers, materials and configurations are set forth in order to provide a thorough understanding of the illustrative embodiments.
  • Embodiments of the present invention define an architecture that allows a USB host controller to be physically located somewhere other than “inside” the USB host (e.g., host computer). In other words, a USB host controller may be "remoted” from a traditional host platform.
  • the remote USB host controller enhances the architecture of the traditional USB host system software by extending the flexible, buffer-oriented USB interface to allow USB connections to be mapped over multiple link technologies including, but not limited to: local area networks ("LANs”), wide area networks ("WANs”), personal area networks (“PANs”), telephone networks (e.g., POTs, PBXs, etc.), wireless links (e.g., wireless telephone networks, 802.11 networks, BlueTooth, etc.), USB, Institute of Electrical and Electronic Engineers (“IEEE”) 1394, powerlines and the like.
  • LANs local area networks
  • WANs wide area networks
  • PANs personal area networks
  • wireless links e.g., wireless telephone networks, 802.11 networks, BlueTooth, etc.
  • IEEE Institute of Electrical and Electronic Engineers 1394
  • the abstraction in various exemplary embodiments are USB-centric (to allow easy integration with existing software stacks) other embodiments may not be USB-centric.
  • the devices downstream of the remote host controller may or may not be USB devices. Accordingly,
  • the remote host controller may also provide a standardized means of bridging the USB host system software to non-USB applications (such as powerline-based home automation), which allows non-USB technologies to make use of the rich set of application support present in the USB device class specifications and drivers.
  • non-USB applications such as powerline-based home automation
  • a remote host controller extends in at least two ways the model of how devices may connect to a host computer. First, it allows USB devices that are physically separate from the host computer to connect to the host computer. For example, USB printers and scanners in one room of a home can be connected to a computer in another room, using some other connection (for example wired or wireless LAN) between the two rooms. Second, a remote host controller allows devices to use a different physical link as the connection between the remote host controller and the device. In other words, the remote host controller provides a single point standardized interface for bridging USB support software to other types of physical hardware. This model, for example, may be the basis for how Wireless USB may be introduced. It could also allow devices that are connected to powerlines (e.g. home appliances, light switches, receptacles, etc.) to be connected to computers and show up as USB devices, giving the computer a standardized way to interface with and control these devices.
  • powerlines e.g. home appliances, light switches, receptacles, etc.
  • Another benefit of using one or more remote host controllers in a computing environment is that with a plurality of host controllers (either remote controllers or a local host controller with one or more remote host controllers) there is a corresponding increase in the number of USB ports accessible to a USB enable computer as each host controller manages its own set of USB ports.
  • FIG. 1 illustrates an exemplary host computer 100 suitable for use in embodiments of the present invention.
  • the host computer 100 may include many more components than those shown in Figure 1. However, it is not necessary that all of these generally conventional components be shown in order to disclose an enabling embodiment for practicing the present invention.
  • the host computer.100 includes a transport interface 130 for connecting to remote devices (not shown) through a remote USB host controller (not shown).
  • transport interface 130 may be a transport interface designed to support a LAN, WAN, PAN, telephone network, powerline connection, serial bus (USB) or wireless connection.
  • Transport interface 130 includes the necessary circuitry, driver and/or transceiver for such a connection and is constructed for use with the appropriate protocols for such a connection.
  • the word "remote” as used in "remote USB host controller” and other terms of the like in the specification and in the claims refers to the ability of remote host controller, by itself or in combination with a local USB host controller, to allow USB or non-USB devices to be capable of being located at a greater distance than specified by the Universal Serial Bus Specification v2.0.
  • the host computer 100 also includes a processing unit 110, an optional display 140 and a memory 150, all interconnected along with the transport interface 130 via a bus 120.
  • the memory 150 generally comprises random access memory (“RAM”), a read only memory (“ROM”) and a permanent mass storage device, such as a disk drive, flash RAM, or the like.
  • the memory 150 stores an operating system 155 and at least one USB driver 160 (e.g., a specific USB device driver, miniport driver, or some combination of drivers) formed in accordance with embodiments of the present invention.
  • USB driver 160 e.g., a specific USB device driver, miniport driver, or some combination of drivers
  • memory 150 also stores at least one remote host controller function 165 (e.g. miniport), at least one remote USB host controller driver 170 and applications 175.
  • USB driver 160 remote host controller function 165, remote host controller driver 170 and applications 175 are described as separate individual software components, they may actually be comprised of multiple software components; or may in fact be sub-parts of one or more integrated software components.
  • the software components may be loaded from a computer readable medium into memory 150 of the host computer 100 using a drive mechanism (not shown) or network mechanism (not shown) associated with the computer readable medium, such as a floppy, tape, DVD/CD-ROM drive, flash RAM, or network interface card.
  • remote host controller transport interface 130 may optionally be included in the host computer 100.
  • remote host controller function 165, remote host controller driver 170 and remote host controller transport interface 130 facilitate a remote host controller 300 in connecting host computer 100 with external devices, for example, devices for reading and/or writing a machine readable medium, digital cameras, printers, digital music players/recorders such as MP3 players, etc.
  • Various input devices may also be coupled to personal computer 100 via elements 165, 170 and 130, such as, for example, keyboards or mice.
  • Figure 2 illustrates the couplings of software components of Figure 1 to communicate with the remote host controller 300, in accordance with one embodiment of the present invention.
  • an implementation of the remote host controller system in accordance with an embodiment of the present invention includes a remote host controller function 165, a remote host controller driver 170 and remote host controller transport interface 130 through which an operating system 155 may communicate with and control the remote host controller 300 via USB driver 160.
  • applications 175 provide the necessary logical connections with remote USB devices (not shown) that are connected via the remote host controller 300.
  • remote host controller transport interface 130 may also be referred to as remote host controller media transport.
  • USB driver 160 performs its conventional functions, i.e. making buffer I/O requests to remote host controller function 165 and servicing returns from remote host controller function 165, as if remote host controller function 165 in combination with remote host controller driver 170 and transport interface 130 constitute a "local USB host controller". Accordingly USB driver 160 may be implemented in any one of a number of device class dependent manners. Remote host controller function 165 cooperates with a counterpart on the remote host controller 300 to effectuate the buffer I/O requests made by USB driver 160 for the function(s) supported by remote host controller function 165. In various embodiments, multiple remote host controller functions 165 may be employed to support multiple functions. The implementation of each remote host controller function 165 is function dependent.
  • Remote host controller driver 170 is equipped to package the buffer I/O request (independent of the nature of the function supported by remote host controller function 165) into a suitable transmission format (e.g., Ethernet) for transmission by remote host controller transport interface 130, in accordance with the remote host controller protocol (e.g. a Transmission Control Protocol/Internet Protocol ["TCP/IP"] based message protocol).
  • Remote host controller driver 170 is also equipped to extract the USB contents from reply messages received from remote host controller 300 through remote host controller transport interface 130.
  • Figure 3 illustrates one exemplary embodiment of the present invention where a host computer 100 is connected through a remote host controller 300 to a remotely located USB device, USB keyboard 380.
  • a host computer 100 is connected through a remote host controller 300 to a remotely located USB device, USB keyboard 380.
  • the host computer 100 includes a number of software and hardware components used to communicate through a remote host controller 300 with a remotely located USB device, USB keyboard 380.
  • USB human interface device driver 320 which is the device driver used to logically control the USB keyboard 380.
  • the USB keyboard 380 also includes USB HID keyboard functions 385 that are logically controlled by the host computer's USB HID driver 320.
  • the host computer 100 also includes a USB driver 160 that provides USB functionality to the host computer 100.
  • the host computer 100 also includes an abstraction layer 360 used to "abstract" the connection between the host computer 100 and the remote host controller 300.
  • the abstraction layer 360 includes a remote host controller function 165, a remote host controller driver 170 and remote host control media transport 130.
  • the remote host controller function 165 logically communicates with a remote host controller function driver 315 of the remote host controller 300 through remote host controller driver 170, remote host controller media transport 130, and corresponding remote host controller media transport 305 of remote host controller 300. More specifically, the physical communication path between the remote host controller driver 170 and the remote host controller 300 goes through the remote host controller media transport 130, via a remote host controller protocol, to remote host controller media transport 305 on the remote host controller 300.
  • the remote host controller media transport 305 further communicates with the remote host controller function driver 315, also via a remote host controller protocol (either the same or another remote host controller protocol).
  • the remote host controller 300 also includes its own USB host controller 310 that physically connects with remote USB devices, e.g., USB keyboard 380.
  • the USB host controller 310 physically connects with a USB bus interface 395 of the USB keyboard 380.
  • the logical connection between the remote host controller 300 and the USB keyboard 380 is between the remote host controller function driver 315 and a USB logical device 390 of the USB keyboard 380.
  • USB HID keyboard function 385 of the USB keyboard 380 which communicates with a USB HID driver 320 on the host computer 100 (through the earlier described logical and physical connections between host computer 100 and remote host controller 300, and remote host controller 300 and USB keyboard 380).
  • USB driver 160 USB driver 160
  • host controller function 165 remote host controller driver 170
  • remote host controller driver 170 the drivers of the host computer are shown as separate individual drivers.
  • more or fewer drivers may be used to facilitate communications between USB devices, local and remote host controllers.
  • alternate communication paths both logical and physical, may be used to pass signals between components.
  • Non-USB devices may be coupled to a host computer with USB driver, allowing the host computer to operate with the non-USB devices using its USB stack.
  • Non-USB devices may include, but are not limited to, other serial bus devices (such as IEEE 1394), local area network devices or parallel interface devices.
  • FIG. 4a illustrates a configuration of an embodiment of the present invention wherein a host computer 100 A has a non-USB wireline connection to remote host controller 300 A, but has a USB connection to a USB device 405 A.
  • a host computer 100 A has a non-USB wireline connection to remote host controller 300 A, but has a USB connection to a USB device 405 A.
  • the logical communications with the USB device 405 A from the host computer 100A may continue using USB drivers as the remote host controller 300 A and the abstraction layer 360 on the host computer abstracts out the non- USB connection so that logical communications with the USB device 405 A can continue without having to introduce separate non-USB connection drivers.
  • FIG. 4b illustrates one exemplary embodiment where a host computer 100B has a non-USB wireline connection to a remote host controller 300B which in turn has a non- USB wireline connection to a non-USB device 410B.
  • USB host controller 310 is replaced with a non-USB host controller suitable for the non-USB connection.
  • Remote host controller function driver 315 may be further equipped to handle the translation between the USB commands and the non-USB commands.
  • Such an embodiment of the present invention while not making use of any USB connections, can still utilize the abstraction layer 360 of the host computer 100B to treat the non-USB device for 100B as a USB device and, therefore, utilize USB device drivers to communicate with and/or control the non-USB device 410B.
  • Figure 4c is similar to Figure 4a, however, the transport media between the host computer 100C and the remote host controller 300C is a wireless connection. That is, remote host controller media transports 130 and 305 are equipped to support a wireless connection between host computer 100 and remote host controller 300. The remote host controller 300C in turn has a USB connection to the USB device 405C. [0035] Similarly, in Figure 4d the host computer 100D has a wireless connection to the remote host controller 300D. Accordingly, remote host controller media transports 130 and 305 are similarly equipped as earlier described for Figure 4c. However, the remote host controller 300D has a non-USB comiection to non-USB device 410D like Figure 4b. That is, USB host controller 310 is replaced with a non-USB host controller, and remote host controller function driver 315 is equipped to handle translations between USB and non-USB commands as earlier described.

Abstract

An apparatus and method for remote USB host controlling are described herein.

Description

Operating a Remote USB Host Controller
CROSS-REFRENCE TO RELATED APPLICATION [0001] This application claims the benefit of U.S. Provisional Application No. 60/521,070, entitled "Remote USB Host Controlling" and filed February 16, 2004.
FIELD OF THE INVENTION
[0002] The present invention relates generally to the field of device connectivity.
BACKGROUND OF THE INVENTION
[0003] A conventional Universal Serial Bus ("USB") architecture is based on Master/Slave communications, where the Master in the system is called a USB host controller ("host controller"). Conventional host controllers are tightly integrated in a "host" platform, e.g., integrated into a processor, processor chipset, as a bus master controller on a Peripheral Control Interface ("PCI") or other "inside the box" bus or the like. A USB host includes applications, device drivers (which manage attached USB devices), a USB bus driver (which provides a standard USB bus services abstraction to USB device drivers), a host controller driver, and a physical USB host controller (of which there are several types), all of which manages data communications for a bus. The host controller provides status and control mechanism to allow a USB host to manage USB ports for connecting USB devices and/or USB hubs. USB hubs are devices for allowing one or more USB devices (through additional one or more additional ports) to connect back through the hub to a USB port. Under Universal Serial Bus Specification v2.0, up to 127 devices may be connected to a single host controller.
[0004] Conventional host controllers provide a register and memory-based interface that the host controller driver utilizes to accomplish data transfers between the system and connected USB devices. Registers provide status control information for "root ports" of a host controller as well as management and general status/control information about data transfers. Memory-based interfaces provide control/status information Registers are for status & control of root ports, host controller management and general status/control information about data transfers. Memory-based interface is for control/status specific to data transfers. A conventional USB system software implementation provides a buffer- oriented streaming service for USB device drivers. A USB device driver submits buffer input/output ("I/O") requests to the USB bus driver, which in turn sends the buffer to the appropriate USB host controller driver. The USB host controller driver then gives the buffer to the host controller hardware utilizing its specific interface. In effect, the entire stack is buffer oriented.
[0005] An artifact of conventional USB hosts is that they have tightly integrated host controllers. Accordingly, USB devices must be within a prescribed distance of the USB host. The distance is governed by the length of the cables and the length of the cables are a function of the protocol parameters, which limit the maximum flight time. Therefore conventional USB controllers are limited in the distance they may connect to USB devices.
BRIEF DESCRIPTION OF THE DRAWINGS
[0006] The present invention will be described by way of exemplary embodiments, but not limitations, illustrated in the accompanying drawings in which like references denote similar elements, and in which:
[0007] Figure 1 illustrates a block diagram view of a computing environment, in accordance with an embodiment of the present invention;
[0008] Figure 2 illustrates the couplings of software components of Figure 1 to communicate with the remote host controller, in accordance with one embodiment of the present invention;
[0009] Figure 3 illustrates a block diagram view of a computing system environment with a host computer and a remote host controller, in accordance with an embodiment of the present invention; and [0010] Figures 4a-d illustrate exemplary configurations of host systems connected to remote host controllers, in accordance with embodiments of the present invention.
DETAILED DESCRIPTION OF ILLUSTRATIVE EMBODIMENTS [0011] Illustrative embodiments of the present invention include, but are not limited to, a buffer-oriented abstraction that allows a host controller to be physically located somewhere other than inside a USB host computer. [0012] Various aspects of the illustrative embodiments will be described using terms commonly employed by those skilled in the art to convey the substance of their work to others skilled in the art. However, it will be apparent to those skilled in the art that the present invention may be practiced with only some of the described aspects. For purposes of explanation, specific numbers, materials and configurations are set forth in order to provide a thorough understanding of the illustrative embodiments. However, it will be apparent to one skilled in the art that the present invention may be practiced without the specific details. In other instances, well-known features are omitted or simplified in order not to obscure the illustrative embodiments. [0013] Further, various operations and/or communications will be described as multiple discrete operations and/or communications, in turn, in a manner that is most helpful in understanding the present invention; however, the order of description should not be construed as to imply that these operations and/or communications are necessarily order dependent. In particular, these operations and/or communications need not be performed in the order of presentation.
[0014] The phrase "in one embodiment" is used repeatedly. The phrase generally does not refer to the same embodiment; however, it may. The terms "comprising," "having" and "including" are synonymous, unless the context dictates otherwise. [0015] Embodiments of the present invention define an architecture that allows a USB host controller to be physically located somewhere other than "inside" the USB host (e.g., host computer). In other words, a USB host controller may be "remoted" from a traditional host platform. In various embodiments, the remote USB host controller ("remote host controller") enhances the architecture of the traditional USB host system software by extending the flexible, buffer-oriented USB interface to allow USB connections to be mapped over multiple link technologies including, but not limited to: local area networks ("LANs"), wide area networks ("WANs"), personal area networks ("PANs"), telephone networks (e.g., POTs, PBXs, etc.), wireless links (e.g., wireless telephone networks, 802.11 networks, BlueTooth, etc.), USB, Institute of Electrical and Electronic Engineers ("IEEE") 1394, powerlines and the like. Although the abstraction in various exemplary embodiments are USB-centric (to allow easy integration with existing software stacks) other embodiments may not be USB-centric. In any case, the devices downstream of the remote host controller may or may not be USB devices. Accordingly, the abstraction allows the exemplary implementation of the remote host controller to expose devices connected downstream as USB devices to a USB host, regardless of whether they are native USB devices or not.
[0016] By providing a well-defined abstraction at the lowest driver layer, the remote host controller may also provide a standardized means of bridging the USB host system software to non-USB applications (such as powerline-based home automation), which allows non-USB technologies to make use of the rich set of application support present in the USB device class specifications and drivers.
[0017] A remote host controller extends in at least two ways the model of how devices may connect to a host computer. First, it allows USB devices that are physically separate from the host computer to connect to the host computer. For example, USB printers and scanners in one room of a home can be connected to a computer in another room, using some other connection (for example wired or wireless LAN) between the two rooms. Second, a remote host controller allows devices to use a different physical link as the connection between the remote host controller and the device. In other words, the remote host controller provides a single point standardized interface for bridging USB support software to other types of physical hardware. This model, for example, may be the basis for how Wireless USB may be introduced. It could also allow devices that are connected to powerlines (e.g. home appliances, light switches, receptacles, etc.) to be connected to computers and show up as USB devices, giving the computer a standardized way to interface with and control these devices.
[0018] Another benefit of using one or more remote host controllers in a computing environment is that with a plurality of host controllers (either remote controllers or a local host controller with one or more remote host controllers) there is a corresponding increase in the number of USB ports accessible to a USB enable computer as each host controller manages its own set of USB ports.
[0019] Figure 1 illustrates an exemplary host computer 100 suitable for use in embodiments of the present invention. Those of ordinary skill in the art and others will appreciate that the host computer 100 may include many more components than those shown in Figure 1. However, it is not necessary that all of these generally conventional components be shown in order to disclose an enabling embodiment for practicing the present invention. As shown in Figure 1, the host computer.100 includes a transport interface 130 for connecting to remote devices (not shown) through a remote USB host controller (not shown). As described earlier, transport interface 130 may be a transport interface designed to support a LAN, WAN, PAN, telephone network, powerline connection, serial bus (USB) or wireless connection. Transport interface 130 includes the necessary circuitry, driver and/or transceiver for such a connection and is constructed for use with the appropriate protocols for such a connection. The word "remote" as used in "remote USB host controller" and other terms of the like in the specification and in the claims refers to the ability of remote host controller, by itself or in combination with a local USB host controller, to allow USB or non-USB devices to be capable of being located at a greater distance than specified by the Universal Serial Bus Specification v2.0. [0020] The host computer 100 also includes a processing unit 110, an optional display 140 and a memory 150, all interconnected along with the transport interface 130 via a bus 120. Those of ordinary skill in the art and others will appreciate that the display 140 may not be necessary in all forms of computing devices and, accordingly, is an optional component. The memory 150 generally comprises random access memory ("RAM"), a read only memory ("ROM") and a permanent mass storage device, such as a disk drive, flash RAM, or the like. The memory 150 stores an operating system 155 and at least one USB driver 160 (e.g., a specific USB device driver, miniport driver, or some combination of drivers) formed in accordance with embodiments of the present invention. In various embodiments, memory 150 also stores at least one remote host controller function 165 (e.g. miniport), at least one remote USB host controller driver 170 and applications 175. It will be appreciated by those of ordinary skill in the art and others, that while the USB driver 160, remote host controller function 165, remote host controller driver 170 and applications 175 are described as separate individual software components, they may actually be comprised of multiple software components; or may in fact be sub-parts of one or more integrated software components. [0021] It will be appreciated that the software components may be loaded from a computer readable medium into memory 150 of the host computer 100 using a drive mechanism (not shown) or network mechanism (not shown) associated with the computer readable medium, such as a floppy, tape, DVD/CD-ROM drive, flash RAM, or network interface card. [0022] Although only one remote host controller transport interface 130 is shown, one or more local USB host controllers (not shown) may optionally be included in the host computer 100. In various embodiments, remote host controller function 165, remote host controller driver 170 and remote host controller transport interface 130 facilitate a remote host controller 300 in connecting host computer 100 with external devices, for example, devices for reading and/or writing a machine readable medium, digital cameras, printers, digital music players/recorders such as MP3 players, etc. Various input devices may also be coupled to personal computer 100 via elements 165, 170 and 130, such as, for example, keyboards or mice.
[0023] Figure 2 illustrates the couplings of software components of Figure 1 to communicate with the remote host controller 300, in accordance with one embodiment of the present invention. Generally, an implementation of the remote host controller system in accordance with an embodiment of the present invention includes a remote host controller function 165, a remote host controller driver 170 and remote host controller transport interface 130 through which an operating system 155 may communicate with and control the remote host controller 300 via USB driver 160. In one embodiment, applications 175 provide the necessary logical connections with remote USB devices (not shown) that are connected via the remote host controller 300. Hereinafter, remote host controller transport interface 130 may also be referred to as remote host controller media transport.
[0024] USB driver 160 performs its conventional functions, i.e. making buffer I/O requests to remote host controller function 165 and servicing returns from remote host controller function 165, as if remote host controller function 165 in combination with remote host controller driver 170 and transport interface 130 constitute a "local USB host controller". Accordingly USB driver 160 may be implemented in any one of a number of device class dependent manners. Remote host controller function 165 cooperates with a counterpart on the remote host controller 300 to effectuate the buffer I/O requests made by USB driver 160 for the function(s) supported by remote host controller function 165. In various embodiments, multiple remote host controller functions 165 may be employed to support multiple functions. The implementation of each remote host controller function 165 is function dependent. Remote host controller driver 170 is equipped to package the buffer I/O request (independent of the nature of the function supported by remote host controller function 165) into a suitable transmission format (e.g., Ethernet) for transmission by remote host controller transport interface 130, in accordance with the remote host controller protocol (e.g. a Transmission Control Protocol/Internet Protocol ["TCP/IP"] based message protocol). Remote host controller driver 170 is also equipped to extract the USB contents from reply messages received from remote host controller 300 through remote host controller transport interface 130.
[0025] Figure 3 illustrates one exemplary embodiment of the present invention where a host computer 100 is connected through a remote host controller 300 to a remotely located USB device, USB keyboard 380. Those of ordinary skill in the art and others will appreciate that the device arrangement shown in Figure 3 is merely one arrangement of devices in accordance with one exemplary embodiment of the present invention, and that other configurations of devices, including non-USB devices and or non-USB communication links, may be used with other embodiments of the present invention. [0026] The host computer 100 includes a number of software and hardware components used to communicate through a remote host controller 300 with a remotely located USB device, USB keyboard 380. One such component is a USB human interface device ("HID") driver 320 which is the device driver used to logically control the USB keyboard 380. The USB keyboard 380 also includes USB HID keyboard functions 385 that are logically controlled by the host computer's USB HID driver 320.
The host computer 100 also includes a USB driver 160 that provides USB functionality to the host computer 100.
[0027] Additionally, the host computer 100 also includes an abstraction layer 360 used to "abstract" the connection between the host computer 100 and the remote host controller 300. The abstraction layer 360 includes a remote host controller function 165, a remote host controller driver 170 and remote host control media transport 130. The remote host controller function 165 logically communicates with a remote host controller function driver 315 of the remote host controller 300 through remote host controller driver 170, remote host controller media transport 130, and corresponding remote host controller media transport 305 of remote host controller 300. More specifically, the physical communication path between the remote host controller driver 170 and the remote host controller 300 goes through the remote host controller media transport 130, via a remote host controller protocol, to remote host controller media transport 305 on the remote host controller 300. The remote host controller media transport 305 further communicates with the remote host controller function driver 315, also via a remote host controller protocol (either the same or another remote host controller protocol). [0028] The remote host controller 300 also includes its own USB host controller 310 that physically connects with remote USB devices, e.g., USB keyboard 380. The USB host controller 310 physically connects with a USB bus interface 395 of the USB keyboard 380. However, the logical connection between the remote host controller 300 and the USB keyboard 380 is between the remote host controller function driver 315 and a USB logical device 390 of the USB keyboard 380. As already noted above, the high level communication and control of the USB keyboard is handled via a USB HID keyboard function 385 of the USB keyboard 380, which communicates with a USB HID driver 320 on the host computer 100 (through the earlier described logical and physical connections between host computer 100 and remote host controller 300, and remote host controller 300 and USB keyboard 380). [0029] As can be seen from the above description of a remotely located USB keyboard 380 connected to a host computer 100 via a remote host controller 300, embodiments of the present invention allow devices to be "remoted" from the host computers to which they are to be connected. [0030] It will be appreciated by those of ordinary skill in the art and others that the devices shown in Figure 3 are merely one exemplary configuration of one embodiment of the present invention and that more or fewer components may be included. For example, the drivers (USB driver 160, host controller function 165 and remote host controller driver 170) of the host computer are shown as separate individual drivers. In other embodiments of the present invention more or fewer drivers may be used to facilitate communications between USB devices, local and remote host controllers. In still other embodiments, alternate communication paths, both logical and physical, may be used to pass signals between components.
[0031] Figures 4a-d illustrate other exemplary embodiments of the present invention, including exemplary embodiments where non-USB devices may be coupled to a host computer with USB driver, allowing the host computer to operate with the non-USB devices using its USB stack. Non-USB devices may include, but are not limited to, other serial bus devices (such as IEEE 1394), local area network devices or parallel interface devices.
[0032] Figure 4a illustrates a configuration of an embodiment of the present invention wherein a host computer 100 A has a non-USB wireline connection to remote host controller 300 A, but has a USB connection to a USB device 405 A. Those of ordinary skill in the art and others will appreciate that the logical communications with the USB device 405 A from the host computer 100A may continue using USB drivers as the remote host controller 300 A and the abstraction layer 360 on the host computer abstracts out the non- USB connection so that logical communications with the USB device 405 A can continue without having to introduce separate non-USB connection drivers. [0033] Figure 4b illustrates one exemplary embodiment where a host computer 100B has a non-USB wireline connection to a remote host controller 300B which in turn has a non- USB wireline connection to a non-USB device 410B. For the embodiment, USB host controller 310 is replaced with a non-USB host controller suitable for the non-USB connection. Remote host controller function driver 315 may be further equipped to handle the translation between the USB commands and the non-USB commands. Such an embodiment of the present invention, while not making use of any USB connections, can still utilize the abstraction layer 360 of the host computer 100B to treat the non-USB device for 100B as a USB device and, therefore, utilize USB device drivers to communicate with and/or control the non-USB device 410B. [0034] Figure 4c is similar to Figure 4a, however, the transport media between the host computer 100C and the remote host controller 300C is a wireless connection. That is, remote host controller media transports 130 and 305 are equipped to support a wireless connection between host computer 100 and remote host controller 300. The remote host controller 300C in turn has a USB connection to the USB device 405C. [0035] Similarly, in Figure 4d the host computer 100D has a wireless connection to the remote host controller 300D. Accordingly, remote host controller media transports 130 and 305 are similarly equipped as earlier described for Figure 4c. However, the remote host controller 300D has a non-USB comiection to non-USB device 410D like Figure 4b. That is, USB host controller 310 is replaced with a non-USB host controller, and remote host controller function driver 315 is equipped to handle translations between USB and non-USB commands as earlier described.
[0036] Although specific embodiments have been illustrated and described herein, it will be appreciated by those of ordinary skill in the art that a wide variety of alternate and/or equivalent implementations may be substituted for the specific embodiments shown and described without departing from the scope of the present invention. This application is intended to cover any adaptations or variations of the embodiments discussed herein. Therefore, it is manifestly intended that this invention be limited only by the claims and the equivalents thereof.

Claims

What is claimed is:
1. A system comprising: a computer including: a processor, and a memory coupled to said processor, having a USB driver and an abstraction of a remote host controller; and a remote host controller, coupled with and remotely disposed from said computer, operating in combination with said abstraction of a remote host controller as a USB host controller of the computer.
2. The system of Claim 1, further comprising a remote device coupled to said remote host controller.
3. The system of Claim 2, wherein said remote device is a selected one of a digital camera, a printer, a digital music player/recorder, a keyboard and a cursor control device.
4. The system of Claim 1, wherein said abstraction of a remote host controller comprises a remote host controller function equipped to provide function specific processing for a USB buffer I/O request of a function of the remote host controller.
5. The system of Claim 1, wherein said abstraction of a remote host controller comprises a remote host controller driver equipped to provide function independent processing to format a USB buffer I/O request for transmission to the remote host controller.
6. The system of Claim 1, wherein said abstraction of a remote host controller comprises a media transport equipped to transmit a USB buffer I/O request formatted for a media type over a media of the media type to the remote host controller.
7. The system of Claim 6, wherein said remote host controller comprises a media transport of like type, a remote host function driver coupled to the media transport of the remote host controller and a USB host controller.
8. The system of Claim 6, wherein said media includes a communications link selected from the group consisting of: local area networks, wide area networks, personal area networks, telephone networks, parallel interfaces, wireless links, USB, IEEE 1394 and powerlines.
9. A remote USB host controller comprising: a media transport to communicate with a counterpart media transport of an abstraction of the remote USB host controller disposed in a remotely located host computer; a remote host controller function driver coupled to the media transport to process a
USB buffer I/O request from a remote host controller function of the abstraction of the remote USB host controller; and a USB host controller coupled to the remote host controller function driver to facilitate coupling of a USB device to the remotely located host computer.
10. The remote USB host controller of Claim 9, wherein the media transports are equipped to support a media selected from the group consisting of: local area networks, wide area networks, personal area networks, telephone networks, wireless links, USB, IEEE 1394 and powerlines.
11. The remote USB host controller of Claim 9, where the remote host controller function driver comprises support for a miniport function.
12. A remote host controller comprising: a media transport to communicate with a counterpart media transport of an abstraction of the remote host controller disposed in a remotely located host computer, the host computer including a USB driver coupled to the abstraction of the remote host controller; a remote host confroller function driver coupled to the media transport to process a USB buffer I/O request from a remote host controller function of the abstraction of the remote host controller, the remote host controller function driver being also equipped to translate USB commands to non-USB commands and vice versa; and a non-USB host controller coupled to the remote host controller function driver to facilitate coupling of a non-USB device to the remotely located host computer.
13. The remote host controller of Claim 12, wherein the media transports are equipped to support a media selected from the group consisting of: local area networks, wide area networks, personal area networks, telephone networks, parallel interfaces, wireless links, USB, IEEE 1394 and powerlines.
14. The remote host controller of Claim 12, wherein the non-USB host controller comprises hardware to support the control of devices utilizing communication media link selected from the group consisting of: local area networks, wide area networks, personal area networks, telephone networks, parallel interfaces, wireless links, USB, IEEE 1394 and powerlines.
15. A method of connecting a USB device to a host computer, the method comprising: coupling a remotely disposed host controller to a host computer having a USB driver and an abstraction of the remote host controller; and coupling a USB device to a USB host controller of the remote host controller.
16. The method of Claim 15, wherein the absfraction of the remote host controller and the remote host controller comprise complementary media transport equipped to support transmission over a media of a media type, and the method further comprises formatting a USB buffer I/O request for transmission from the host computer to the remote host controller over the media.
17. The method of Claim 15, wherein the method further comprises recovering the USB buffer I/O request on receipt at the remote host controller.
18. A method of connecting non-USB devices to a host computer as USB devices, the method comprising: coupling a remotely disposed host controller to a host computer having USB capabilities and an abstraction of the remote host controller, wherein the remote host controller is equipped to receive a non-USB device and operative to convert between USB signals and at least one type of non-USB signals; and coupling a non-USB device to said host computer through said remote host controller.
19. The method of Claim 18, wherein the abstraction of the remote host controller and the remote host controller comprise complementary media fransport equipped to support transmission over a media of a media type, and the method further comprises: formatting a USB buffer I/O request for transmission from the host computer to the remote host controller over the media; and recovering the USB buffer I/O request on receipt at the remote host controller.
20. The method of Claim 19, wherein the method further comprises translating the USB buffer I/O request to a non-USB buffer I/O request.
PCT/US2005/010369 2004-03-31 2005-03-25 Operating a remote usb host controller WO2005098637A1 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
EP05726164A EP1730645B1 (en) 2004-03-31 2005-03-25 Operating a remote usb host controller
AT05726164T ATE556527T1 (en) 2004-03-31 2005-03-25 OPERATION OF A REMOTE USB HOST CONTROLLER

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US10/814,505 US7213096B2 (en) 2004-03-31 2004-03-31 Operating a remote USB host controller
US10/814,505 2004-03-31

Publications (1)

Publication Number Publication Date
WO2005098637A1 true WO2005098637A1 (en) 2005-10-20

Family

ID=34963564

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2005/010369 WO2005098637A1 (en) 2004-03-31 2005-03-25 Operating a remote usb host controller

Country Status (6)

Country Link
US (1) US7213096B2 (en)
EP (1) EP1730645B1 (en)
CN (1) CN100583070C (en)
AT (1) ATE556527T1 (en)
TW (1) TWI302258B (en)
WO (1) WO2005098637A1 (en)

Families Citing this family (25)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7581041B1 (en) * 2003-12-29 2009-08-25 Apple Inc. Methods and apparatus for high-speed serialized data transfer over network infrastructure using a different protocol
US7624392B2 (en) * 2004-05-18 2009-11-24 Oki Semiconductor Co., Ltd. USB device set
US7886353B2 (en) * 2005-03-25 2011-02-08 Microsoft Corporation Accessing a USB host controller security extension using a HCD proxy
US7761618B2 (en) * 2005-03-25 2010-07-20 Microsoft Corporation Using a USB host controller security extension for controlling changes in and auditing USB topology
US7702825B2 (en) * 2005-06-29 2010-04-20 Intel Corporation Enhancements to universal serial bus (USB) suspend and resume operations
US8284768B2 (en) * 2005-10-06 2012-10-09 Sierra Wireless, Inc. Dynamic bus-based virtual channel multiplexing device driver architecture
JP4709966B2 (en) * 2006-06-28 2011-06-29 サイレックス・テクノロジー株式会社 Remote control system and remote control device
US7490255B2 (en) * 2006-06-30 2009-02-10 Intel Corporation Power efficient flow control model for USB asynchronous transfers
KR101088376B1 (en) * 2006-12-27 2011-12-01 삼성전자주식회사 Method and apparatus for communication between USB host and USB device
US8315269B1 (en) 2007-04-18 2012-11-20 Cypress Semiconductor Corporation Device, method, and protocol for data transfer between host device and device having storage interface
TWI448902B (en) 2007-08-24 2014-08-11 Cypress Semiconductor Corp Bridge device with page-access based processor interface
US8090894B1 (en) 2007-09-21 2012-01-03 Cypress Semiconductor Corporation Architectures for supporting communication and access between multiple host devices and one or more common functions
US7895387B1 (en) * 2007-09-27 2011-02-22 Cypress Semiconductor Corporation Devices and methods for sharing common target device with two different hosts according to common communication protocol
US8260985B2 (en) 2007-10-05 2012-09-04 Pano Logic, Inc. Universal serial bus assistance engine
TWI414945B (en) * 2010-01-12 2013-11-11 Process system and method for automatically connecting with remote USB device
US20110182155A1 (en) * 2010-01-28 2011-07-28 S1Digital, Llc System and method for remote access of optical disc media
US8566934B2 (en) 2011-01-21 2013-10-22 Gigavation, Inc. Apparatus and method for enhancing security of data on a host computing device and a peripheral device
US8335875B1 (en) 2011-06-24 2012-12-18 Intel Corporation System and method for performing isochronous data buffering
WO2013023105A1 (en) 2011-08-10 2013-02-14 Srivastava Gita Apparatus and method for enhancing security of data on a host computing device and a peripheral device
US9129064B2 (en) * 2012-04-26 2015-09-08 Icron Technologies Corporation USB 3.0 link layer timer adjustment to extend distance
CN103457806A (en) * 2012-05-29 2013-12-18 中兴通讯股份有限公司 Converter, control system and control method
US9292108B2 (en) 2012-06-28 2016-03-22 Dell Products Lp Systems and methods for remote mouse pointer management
WO2014209386A1 (en) 2013-06-28 2014-12-31 Hewlett-Packard Development Company, L.P. Attached computing device
US9742632B2 (en) * 2013-12-27 2017-08-22 Intel Corporation Hybrid SDN controller
US9858224B2 (en) 2014-08-30 2018-01-02 Microsoft Technology Licensing, Llc Universal serial bus emulation layer

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5890015A (en) 1996-12-20 1999-03-30 Intel Corporation Method and apparatus for implementing a wireless universal serial bus host controller by interfacing a universal serial bus hub as a universal serial bus device
US6567875B1 (en) 1999-04-05 2003-05-20 Opti, Inc. USB data serializer
US20030208643A1 (en) 2002-03-28 2003-11-06 Ferguson Patrick Lee Extension of USB functionality through shadowing of a remote USB host controller

Family Cites Families (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6356968B1 (en) * 1997-09-03 2002-03-12 Cirrus Logic, Inc Apparatus and method for transparent USB-to-1394 bridging and video delivery between a host computer system and a remote peripheral device
US6389029B1 (en) * 1998-11-10 2002-05-14 Nortel Networks Limited Local area network incorporating universal serial bus protocol
US6708247B1 (en) * 1999-07-21 2004-03-16 Clearcube Technology, Inc. Extending universal serial bus to allow communication with USB devices at a remote location
US6742076B2 (en) * 2000-01-03 2004-05-25 Transdimension, Inc. USB host controller for systems employing batched data transfer
NO20011465L (en) * 2001-03-22 2002-09-23 Ericsson Telefon Ab L M Additional call grab service for mobile networks
US6904489B2 (en) * 2001-10-23 2005-06-07 Digi International Inc. Methods and systems for remotely accessing universal serial bus devices
US7778750B2 (en) * 2002-02-25 2010-08-17 Cummins Inc. Vehicle communications network adapter
US20040090984A1 (en) * 2002-11-12 2004-05-13 Intel Corporation Network adapter for remote devices
US20050138229A1 (en) * 2003-12-23 2005-06-23 Sartore Ronald H. Method and apparatus for remote operation of a USB peripheral
US20050209842A1 (en) * 2004-03-16 2005-09-22 Digi International Inc. Remote USB port system and method

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5890015A (en) 1996-12-20 1999-03-30 Intel Corporation Method and apparatus for implementing a wireless universal serial bus host controller by interfacing a universal serial bus hub as a universal serial bus device
US6567875B1 (en) 1999-04-05 2003-05-20 Opti, Inc. USB data serializer
US20030208643A1 (en) 2002-03-28 2003-11-06 Ferguson Patrick Lee Extension of USB functionality through shadowing of a remote USB host controller

Also Published As

Publication number Publication date
CN100583070C (en) 2010-01-20
US7213096B2 (en) 2007-05-01
TWI302258B (en) 2008-10-21
ATE556527T1 (en) 2012-05-15
CN1934553A (en) 2007-03-21
US20050223119A1 (en) 2005-10-06
EP1730645A1 (en) 2006-12-13
EP1730645B1 (en) 2012-05-02
TW200602954A (en) 2006-01-16

Similar Documents

Publication Publication Date Title
EP1730645B1 (en) Operating a remote usb host controller
US7458075B2 (en) Virtual USB port system and method
US7743178B2 (en) Method and apparatus for SATA tunneling over fibre channel
AU2009281668B2 (en) Method and apparatus for connecting USB devices to a remote computer
US9152597B2 (en) Unified system area network and switch
EP1750401B1 (en) USB 1.1 over a high speed link
US7155546B2 (en) Multiple physical interfaces in a slot of a storage enclosure to support different storage interconnect architectures
EP2047370B1 (en) Method and apparatus for distributing usb hub functions across a network
US20050138154A1 (en) Enclosure management device
US20100217878A1 (en) Method, system, and program for enabling communication between nodes
US8046481B2 (en) Peer-to-peer network communications using SATA/SAS technology
US20080189392A1 (en) Computer system with lan-based i/o
EP1115052A2 (en) Storage device in an expansion slot of a computer input device
CN117873924A (en) Computing device, management controller and data processing method
TW200905489A (en) Diskless computer system using single identification code to provide access service for Internet and disks, and its data transmitting and receiving method thereof

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BW BY BZ CA CH CN CO CR CU CZ DE DK DM DZ EC EE EG ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX MZ NA NI NO NZ OM PG PH PL PT RO RU SC SD SE SG SK SL SM SY TJ TM TN TR TT TZ UA UG US UZ VC VN YU ZA ZM ZW

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): GM KE LS MW MZ NA SD SL SZ TZ UG ZM ZW AM AZ BY KG KZ MD RU TJ TM AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HU IE IS IT LT LU MC NL PL PT RO SE SI SK TR BF BJ CF CG CI CM GA GN GQ GW ML MR NE SN TD TG

121 Ep: the epo has been informed by wipo that ep was designated in this application
WWE Wipo information: entry into national phase

Ref document number: 2005726164

Country of ref document: EP

WWE Wipo information: entry into national phase

Ref document number: 200580009419.2

Country of ref document: CN

NENP Non-entry into the national phase

Ref country code: DE

WWW Wipo information: withdrawn in national office

Country of ref document: DE

WWP Wipo information: published in national office

Ref document number: 2005726164

Country of ref document: EP