1. Field of the Invention
Embodiments of the present invention relate to utilizing multiple graphics subsystems in a computer system.
2. Related Art
Computers often include multiple graphics processing units (GPUs). Often, a computer will supply both an integrated GPU (IGPU) and a discrete GPU (dGPU). Typically, an IGPU is integrated into a portion of a processor chipset, e.g., the north bridge. IGPU's offer a low-cost, low-power video solution. However, many users need a more powerful graphics option, and will use a dGPU to get the functionality they require.
Even for users with high-end graphics requirements, however, it may be advantageous to make use of the IGPU in some scenarios. For example, as the IGPU typically draws much less power than the dGPU, switching to the IGPU for non-graphics intensive work may offer an advantage, in terms of power consumption and/or battery life.
One approach to utilizing both the IGPU and dGPU involves a backend switching mechanism, typically, such as a switching mechanism that allows for selecting whether a display is driven by the IGPU or dGPU. However, this approach involves several issues. Aside from the expense of the actual switching mechanism, the user might experience some disruption in their display, particularly with flat-panel displays, as the low-voltage differential signaling (LVDS) utilized with such displays does not handle such physical switching gracefully.
A second approach involves a making a selection between the frame buffers (and the data contained therein) associated with both the IGPU and dGPU. While this approach eliminates many of the concerns inherent in the previous approach, it introduces several new problems. For example, this approach relies heavily on copying data between frame buffers. This duplication results in performance bottlenecks, e.g., across the PCI-E bus, and also consumes additional bandwidth in the system memory bus.
In the following embodiments, an approach is described for displaying graphics information from a frame buffer associated with one GPU on a display associated with a second GPU. In some embodiments, scan-out data from one graphics subsystem is transmitted to the raster generator of a second graphics subsystem, for display on a monitor coupled to the second graphics subsystem. These embodiments can be used, for example, to output graphics data rendered by a dGPU to a monitor connected to an IGPU. Further, some embodiments allow a computer system to freely utilize multiple displays, without regard to which display is connected to which graphics processor.
The accompanying drawings, which are incorporated in and form a part of this specification, illustrate embodiments of the invention and, together with the description, serve to explain the principles of the invention:
Reference will now be made in detail to several embodiments of the invention. While the invention will be described in conjunction with the alternative embodiment(s), it will be understood that they are not intended to limit the invention to these embodiments. On the contrary, the invention is intended to cover alternative, modifications, and equivalents, which may be included within the spirit and scope of the invention as defined by the appended claims.
Furthermore, in the following detailed description, numerous specific details are set forth in order to provide a thorough understanding of the claimed subject matter. However, it will be recognized by one skilled in the art that embodiments may be practiced without these specific details or with equivalents thereof. In other instances, well-known methods, procedures, components, and circuits have not been described in detail as not to unnecessarily obscure aspects and features of the subject matter.
Portions of the detailed description that follows are presented and discussed in terms of a method. Although steps and sequencing thereof are disclosed in figures herein (e.g.,
Some portions of the detailed description are presented in terms of procedures, steps, logic blocks, processing, and other symbolic representations of operations on data bits that can be performed on computer memory. These descriptions and representations are the means used by those skilled in the data processing arts to most effectively convey the substance of their work to others skilled in the art. A procedure, computer-executed step, logic block, process, etc., is here, and generally, conceived to be a self-consistent sequence of steps or instructions leading to a desired result. The steps are those requiring physical manipulations of physical quantities. Usually, though not necessarily, these quantities take the form of electrical or magnetic signals capable of being stored, transferred, combined, compared, and otherwise manipulated in a computer system. It has proven convenient at times, principally for reasons of common usage, to refer to these signals as bits, values, elements, symbols, characters, terms, numbers, or the like.
It should be borne in mind, however, that all of these and similar terms are to be associated with the appropriate physical quantities and are merely convenient labels applied to these quantities. Unless specifically stated otherwise as apparent from the following discussions, it is appreciated that throughout, discussions utilizing terms such as “accessing,” “writing,” “including,” “storing,” “transmitting,” “traversing,” “associating,” “identifying” or the like, refer to the action and processes of a computer system, or similar electronic computing device, that manipulates and transforms data represented as physical (electronic) quantities within the computer system's registers and memories into other data similarly represented as physical quantities within the computer system memories or registers or other such information storage, transmission or display devices.
Computing devices typically include at least some form of computer readable media. Computer readable media can be any available media that can be accessed by a computing device. By way of example, and not limitation, computer readable medium may comprise computer storage media and communication media. Computer storage media includes volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules, or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile discs (DVD) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by a computing device. Communication media typically embodies computer readable instructions, data structures, program modules, or other data in a modulated data signals such as a carrier wave or other transport mechanism and includes any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared, and other wireless media. Combinations of any of the above should also be included within the scope of computer readable media.
Some embodiments may be described in the general context of computer-executable instructions, such as program modules, executed by one or more computers or other devices. Generally, program modules include routines, programs, objects, components, data structures, etc., that perform particular tasks or implement particular abstract data types. Typically the functionality of the program modules may be combined or distributed as desired in various embodiments.
Although embodiments described herein may make reference to a CPU and a GPU as discrete components of a computer system, those skilled in the art will recognize that a CPU and a GPU can be integrated into a single device, and a CPU and GPU may share various resources such as instruction logic, buffers, functional units and so on; or separate resources may be provided for graphics and general-purpose operations. Accordingly, any or all of the circuits and/or functionality described herein as being associated with GPU could also be implemented in and performed by a suitably configured CPU.
Further, while embodiments described herein may make reference to a GPU, it is to be understood that the circuits and/or functionality described herein could also be implemented in other types of processors, such as general-purpose or other special-purpose coprocessors, or within a CPU.
Basic Computing System
Referring now to
Computer system 112 comprises an address/data bus 100 for communicating information, a central processor 101 coupled with bus 100 for processing information and instructions; a volatile memory unit 102 (e.g., random access memory [RAM], static RAM, dynamic RAM, etc.) coupled with bus 100 for storing information and instructions for central processor 101; and a non-volatile memory unit 103 (e.g., read only memory [ROM], programmable ROM, flash memory, etc.) coupled with bus 100 for storing static information and instructions for processor 101. Moreover, computer system 112 also comprises a data storage device 104 (e.g., hard disk drive) for storing information and instructions.
Computer system 112 also comprises an optional graphics subsystem 105, an optional alphanumeric input device 106, an optional cursor control or directing device 107, and signal communication interface (input/output device) 108. Optional alphanumeric input device 106 can communicate information and command selections to central processor 101. Optional cursor control or directing device 107 is coupled to bus 100 for communicating user input information and command selections to central processor 101. Signal communication interface (input/output device) 108, which is also coupled to bus 100, can be a serial port. Communication interface 108 may also include wireless communication mechanisms. Using communication interface 108, computer system 112 can be communicatively coupled to other computer systems over a communication network such as the Internet or an intranet (e.g., a local area network), or can receive data (e.g., a digital television signal). Computer system 112 may also comprise graphics subsystem 105 for presenting information to the computer user, e.g., by displaying information on an attached display device 110, connected by a video cable 111. In some embodiments, graphics subsystem 105 is incorporated into central processor 101. In other embodiments, graphics subsystem 105 is a separate, discrete component. In other embodiments, graphics subsystem 105 is incorporated into another component. In other embodiments, graphics subsystem 105 is included in system 112 in other ways.
Hybrid Graphics
In the following embodiments, an approach is described for displaying graphics information from a frame buffer associated with one GPU on a display associated with a second GPU. In some embodiments, scan-out data from one graphics subsystem is transmitted to the raster generator of a second graphics subsystem, for display on a monitor coupled to the second graphics subsystem. These embodiments can be used, for example, to output graphics data rendered by a dGPU to a monitor connected to an IGPU. Further, some embodiments allow a computer system to freely utilize multiple displays, without regard to which display is connected to which graphics processor.
In the description that follows, the term “monitor” is understood to represent any type of graphics display unit which might be utilized in a computer system. For example, a cathode rate tube (CRT) a monitor, a thin-film transistor (TFT) monitor, a liquid crystal display (LCD), a plasma flat-panel display, or any sort of projector-based display are included in use of the term monitor. Such monitors may be incorporated any computing system, e.g., as is the case in a laptop computer, a personal digital assistant (PDA), a mobile phone, or a smart phone. Such monitors may also be separate units, as is often the case with a desktop computer. In some embodiments, combinations of monitors of various types may be utilized. The term monitor is utilized exclusively herein to prevent potential confusion through overuse of the term “display.”
Hybrid Display in a Single Monitor System
With reference now to
System 200 is depicted as incorporating both a discrete graphics processing unit (dGPU) 220 and an integrated graphics processing unit (IGPU) 250. A single monitor, monitor 299, is shown as being coupled to IGPU 250. IGPU 250 and dGPU 220 are shown as being coupled to graphics bus 201; in some embodiments, the IGPU may be connected to a different bus than the dGPU.
DGPU 220 incorporates display engine 230 and I/O block 240, and is associated with memory subsystem 225, which is shown here as containing surface 227. IGPU 250 incorporates display engine 260 and I/O block 270, and is associated with memory subsystem 265. In this embodiment, an I/O block is used for transmitting data and instructions to and from a GPU, while the display engine is utilized to generate scan-out data for display on a monitor. A memory subsystem may be dedicated memory, e.g., a frame buffer for a dGPU, or may be allocated portion of system memory, e.g., as is common for many IGPUs.
In order to display graphics information, such as surface 227, from dGPU 220 on monitor 299, data is passed from dGPU 220 to IGPU 250. In some embodiments, as explained in greater detail below, dGPU 220 performs some or all of the necessary rendering operations on surface 227, before the resulting scan-out data is transmitted to IGPU 250 via virtual channel 205. Virtual channels, and several different approaches for implementing them, are also discussed in greater detail below. Once IGPU 250 receives the scan-out data from dGPU 220, display engine 260 is used to display the scan-out data on monitor 299.
Method of Displaying Graphics Data
With reference now to
Flowchart 300 depicts a method of displaying graphics data from one graphics subsystem on a monitor connected to a second graphics subsystem. With reference to step 310, graphics data is prepared for display by the first graphics subsystem. In some embodiments, graphics data, such as a surface, is partially or completely processed by a dGPU associated with the first graphics subsystem. Such embodiments allow, for example, a more capable GPU to perform the necessary operations on the graphics data.
For example, dGPU 220 retrieves surface 227 from memory subsystem 225. DGPU 220, and specifically display engine 230, processes surface 227, and produces scan-out data.
With reference now to step 320, the processed graphics data is transmitted to the second graphics subsystem. In some embodiments, the prepared graphics data, such as scan-out data, is transmitted to the second graphics subsystem. This transmission may be initiated, for example, by an I/O block of the first graphics subsystem. The data may be transmitted via a wide variety of connections. For example, a dedicated physical connection may be utilized; alternatively, an existing connection between the two graphics subsystems may be utilized to transmit the graphics data.
Continuing the preceding example, dGPU 220, and specifically I/O block 240, transmits the scan-out data to IGPU 250 via virtual channel 205.
With reference now to step 330, the processed graphics data is displayed on a monitor coupled to the second graphics subsystem.
Continuing the preceding example, IGPU 250, and specifically I/O block 270, receives the scan-out data. Display engine 260 is used to display the scan-out data on monitor 299.
Embodiments utilizing the above described method offers several advantages. First, either of several GPUs can drive the same monitor, without the need for back-end switching. Second, the contents of the memory subsystem associated with the source GPU are not copied across to the memory subsystem associated with the destination GPU, which removes several potential system bottlenecks. Additionally, the appropriate GPU for a given task may be utilized. For example, the graphics data for a graphics-intensive task, such as a video game, can be handled by the dGPU, while the graphics data for a less-intensive task, such as word processing, can be handled by the IGPU. The ability to allocate graphics processing power is beneficial in terms of power consumption. Other advantages and applications are described herein, or may become apparent to one having skill in the art.
Display Engine
With reference now to
In the depicted embodiment, a logical data path has been added in order to divert scan-out data from display engine 430, as indicated by arrow 439. The scan-out data, rather than passing to raster generator 435, is passed to I/O block 440. The scan-out data can then be transmitted, e.g., via virtual channel 405, to a second GPU, e.g., IGPU 450. This second GPU can then display the scan-out data upon an attached monitor, e.g., monitor 499.
In this way, the depicted embodiment allows graphics data to be processed by one GPU, and displayed upon a monitor connected to a second GPU. This offers several advantages. For example, a more capable GPU, e.g., a dGPU, can be used to process graphics-intensive information, and output the resulting scan-out data to a monitor connected to a less capable GPU, e.g., an IGPU. Further, dissociating the processing of graphics data from the display of the resulting scan-out data allows for a system with multiple independent monitors, such that any given monitor may display any given information, without regard to which GPU in particular monitor is connected to.
In some embodiments, data may be diverted from the display engine at a different point in processing. For example, in one embodiment, the graphics data is diverted from display engine 430 after retrieval by DMA module 431, but before processing by pixel pipeline 433. In such an embodiment, the unprocessed graphics data is diverted to I/O block 440, and passed to IGPU 450 via virtual channel 405. Such an embodiment may, for example, allow raw graphics data to be passed from a less capable GPU to a more capable GPU for processing. In other embodiments, data is diverted from the first graphics subsystem to the second graphics subsystem at other points during processing. While the term “scan-out data” is used throughout this description, it is understood that embodiments are well suited to applications in which graphics data is transmitted between graphics subsystems, irrespective of the current processing and/or format of the graphics data.
I/O Block
With reference now to
In the depicted embodiment, scan-out data is received from display engine 530 via a logical data path 539. This scan-out data is forwarded by I/O block 540 to IGPU 550, via virtual channel 505. IGPU 550 can then display the scan-out data on monitor 599. In different embodiments, virtual channel 505 may be implemented in different ways. In some embodiments, depending upon the implementation of virtual channel 505, one or more of the components of I/O block 540 may be utilized to implement an appropriate forwarding technique. Embodiments involving different implementations of virtual channel 505 are discussed in greater detail, below.
Passing Data Between Graphics Subsystems
As noted previously, in different embodiments different approaches may be utilized for passing data between graphics subsystems. The term “virtual channel” has been used herein as a broad term, meant to encompass the various approaches suitable for such data transactions. Several specific examples of such approaches are described below; these examples are intended to the illustrative, but not exhaustive.
One option for transferring data between two graphics subsystems is to use a dedicated connection. This dedicated connection might use an existing graphics protocol, e.g., Display Port, or a purpose built connection. A dedicated connection offers several advantages, in that the protocol for transmitting the data may not be dictated by the constraints of the connection. Instead, a connection could be implemented specifically to provide for suitable data transmissions. Moreover, a dedicated connection between graphics subsystems would reduce or eliminate bandwidth concerns, such as those which may arise in a shared connection scenario. In some embodiments, implementing a dedicated connection between two graphics subsystems, particularly between a dGPU and an IGPU, may require additional hardware modifications. In some embodiments, this approach may call for modifications to the I/O block of a GPU, to allow for data transmission and reception via a dedicated connection.
Another option for transferring data between two graphics subsystems is to co-opt or otherwise dedicate some portion of an existing connection, to create a direct link. For example, the PCI-E bus commonly used in modern graphics applications offers 16 communications “lanes.” Some portion of these lanes may be utilized solely for passing data between graphics subsystems. This direct link approach makes use of the existing physical connection, but may not rely upon the traditional corresponding protocol. In some embodiments, this approach may call for modifications to the physical layer of the I/O block of a GPU, in order to divert specified traffic to the appropriate portions of the existing connection.
A further option for transferring data between graphics subsystems is to utilize an existing connection between the graphics subsystems. In some embodiments, scan-out data can be packetized and directed to the appropriate graphics subsystem, via an existing connection between the subsystems. For example, packets of scan-out data may be transmitted between a dGPU and an IGPU via the PCI-E bus. In several such embodiments, a modification is made to the arbitration module of the I/O block, in order to allow for deterministic timing of pixel data.
A further option for transferring data between graphics subsystems is to utilize the existing connection between the graphics subsystems to transmit specialized data. For example, the PCI-E protocol that co meets the dGPU to the chip containing the iGPU allows for vendor defined messages (VDM) to be passed via the corresponding connection. The scan-out data can be encapsulated in these VDM packets, and transmitted from one graphics subsystem to another. In some embodiments, a modification is made to the protocol module of the I/O block, in order to allow scan-out data to be appropriately encapsulated. In different embodiments, similar approaches may be utilized, depending upon the architecture and/or protocols involved.
In other embodiments, other approaches are utilized for transmitting data between graphics subsystems.
Scan-Out Data Processing
With reference now to
In some embodiments, graphics data is subjected to some processing before transmission between one graphics subsystem and another. In different embodiments, the exact processing performed may vary.
System 600 is depicted as including GPU 620. GPU 620, in turn, is shown as incorporating display engine 630 and I/O block 640, which are interconnected by processing pipeline 639.
In the depicted embodiment, processing pipeline 639 allows data to flow between display engine 630 and I/O block 640, in either direction. In this embodiment, GPU 620 can transmit graphics data to a second GPU, or receive graphics data from another GPU for display.
When GPU 620 is transmitting graphics data to another graphics subsystem, graphics data, such as scan-out data, passes from display engine 632 compression module 682. Compression module 682 is used to reduce the overall amount of data to be transmitted. In different embodiments, different compression techniques may be utilized; for example, run length coding (RLC) may be used to compress the scan-out data received from display engine 630. Such compression techniques may be lossless or lossy.
In the depicted embodiment, compressed graphics data is passed to packetization module 684. In some embodiments, it is advantageous to use packet-based transmission techniques to transmit graphics data between the two graphics subsystems. One advantage of packetization is that graphics data packets can be interleaved in the connection between the graphics subsystems. As such, graphics packets can be transmitted via an existing connection. Similarly, packets corresponding to multiple surfaces may be transmitted simultaneously, which is especially useful in a multi-monitor scenario.
In the depicted embodiment, the packets of compressed graphics data pass through encryption module 686. In some embodiments, is necessary to encrypt data before it leaves GPU 620. For example, in order to comply with certain digital rights management (DRM) licensing schemes, graphics data is encrypted before it leaves GPU 620. Different embodiments are well-suited to applications involving different types of encryption. For example, an implementation of high-bandwidth digital content protection (HDCP) can be utilized, or a key-exchange encryption technique incorporated into encryption module 686. The encrypted packets of compressed graphics data are then passed to I/O block 640, and forwarded to a second graphics subsystem.
When GPU 620 is receiving graphics data from another graphics subsystem, the received data is passed from I/O block 640 to processing pipeline 639. When receiving graphics data from another graphics subsystem, the processing performed on the graphics data should be reversed. For example, with reference to
Further, in some embodiments, a jitter buffer 690 is included in GPU 620. In these embodiments, jitter buffer 690 is used to temporarily store received graphics data until display engine 620 calls for it. By buffering graphics data in this manner, any timing inconsistencies introduced by the virtual channel between graphics subsystems can be mitigated.
Method of Transmitting Graphics Data
With reference now to
With reference now to step 701, in some embodiments, graphics data is retrieved from a memory subsystem associated with a graphics subsystem. For example, pixel data corresponding to a surface is retrieved from a frame buffer associated with a dGPU. In one embodiment, memory subsystem interactions may be performed by a DMA module of a display engine of the graphics subsystem.
For example, display engine 230 retrieves graphics data corresponding to surface 227 from memory subsystem 225.
With reference now to step 705, the graphics data is rendered by the graphics subsystem, in preparation for display. In some embodiments, graphics data is manipulated by the graphics subsystem before it is transmitted to a destination graphics subsystem. For example, a pixel pipeline in the display engine of the dGPU is used to perform a blending operation on the graphics data, and produces scan-out data. In other embodiments, graphics data is not processed by the graphics subsystem before transmission.
For example, graphics data retrieved by memory DMA module 431 is rendered by pixel pipeline 433.
With reference now to step 710, rendered graphics data is diverted from the display engine of the graphics subsystem. For example, scan-out data is diverted after processing by the pixel pipeline of the display engine. In other embodiments, the processed graphics data may be diverted at a different point in the graphics pipeline.
For example, scan-out data is diverted after processing by pixel pipeline 433, and is passed out of display engine 430 via logical data path 439.
With reference now to step 720, the diverted graphics data is processed before transmission. In different embodiments, different techniques may be utilized in processing the diverted graphics data, in preparation for transmission to a second graphics subsystem. For example, the diverted graphics data may be compressed, encrypted, and/or packetized before it is transmitted.
For example, scan-out data passes through processing pipeline 639. This scan-out data is compressed by compression module 682, packetized by packetization module 60084, and encrypted byte encryption module 686.
With reference now to step 730, the processed graphics data is dispatched to a second graphics subsystem. In some embodiments, a virtual channel is used that the first graphics subsystem with a second graphics subsystem. As discussed previously, this virtual channel may take a variety of forms, in different embodiments. Depending upon the nature of the connection between the two graphics subsystems, different embodiments utilize different techniques within an I/O block of the first graphics subsystem. For example, if vendor defined messages (VDM) are used to pass packets of graphics data between the graphics subsystems, a modification in the protocol layer of the I/O block may be utilized, in order to encapsulate the packets of graphics data accordingly.
For example, packets of graphics data passes through I/O block 540, and are transmitted via virtual channel 505 to IGPU 550.
Method of Receiving Graphics Data
With reference now to
With reference now to step 810, processed graphics data is received. In some embodiments, processed graphics data is transmitted between two graphics subsystems via a virtual channel or connection. The processed graphics data is transmitted by the I/O block of the first graphics subsystem, and received into the I/O block of the second graphics subsystem.
For example, processed graphics data is transmitted by I/O block 240 of dGPU 220 via virtual channel 205, and is received by I/O block 270 of IGPU 250.
With reference now to step 820, the received processed graphics data is unpacked. In some embodiments, the processing performed by the transmitting graphics subsystem is reversed, to restore the original graphics data. For example, graphics data may need to be decrypted, depacketized or similarly reassembled, and decompressed. In some embodiments, e.g., where a lossy compression technique was utilized by the transmitting graphics subsystem, the unpacked graphics data may not exactly match the graphics data provided by the transmitting graphics subsystem.
For example, and encrypted packets of compressed graphics data are received by I/O block 640, where they are decrypted by decryption module 696, reassembled from the packetized state by depacketization module 694, and decompressed by decompression module 692.
With reference now to step 830, the restored graphics data is loaded into a buffer. In some embodiments, graphics data is buffered after it has been unpacked. One such embodiment allows for corrections of timing errors introduced by the virtual channel, for example. A graphics data can be stored in this jitter buffer until the display engine of the receiving graphics subsystem is ready to display information. In some embodiments, a jitter buffer can be implemented as a FIFO, a type of “first in, first out” memory.
For example, the unpacked scan-out data is loaded into jitter buffer 690.
With reference now to step 840, the restored graphics data is output to a monitor by AP receiving graphics subsystem's display engine. In some embodiments, the display engine of the receiving graphics subsystem, and specifically the raster generator of the display engine, draws graphics data from the jitter buffer and outputs it to an attached monitor.
For example, display engine 260 outputs the scan-out data received from dGPU 220 to monitor 299.
Embodiments of the present invention are thus described. While the present invention has been described in particular embodiments, it should be appreciated that the present invention should not be construed as limited by such embodiments, but rather construed according to the following claims.
Number | Name | Date | Kind |
---|---|---|---|
4603400 | Daniels | Jul 1986 | A |
4955066 | Notenboom | Sep 1990 | A |
5016001 | Minagawa et al. | May 1991 | A |
5321510 | Childers et al. | Jun 1994 | A |
5371847 | Hargrove | Dec 1994 | A |
5461679 | Normile et al. | Oct 1995 | A |
5517612 | Dwin et al. | May 1996 | A |
5572649 | Elliott et al. | Nov 1996 | A |
5687334 | Davis et al. | Nov 1997 | A |
5712995 | Cohn | Jan 1998 | A |
5768164 | Hollon, Jr. | Jun 1998 | A |
5781199 | Oniki et al. | Jul 1998 | A |
5841435 | Dauerer et al. | Nov 1998 | A |
5878264 | Ebrahim | Mar 1999 | A |
5900913 | Tults | May 1999 | A |
5917502 | Kirkland et al. | Jun 1999 | A |
5923307 | Hogle, IV | Jul 1999 | A |
5953532 | Lochbaum | Sep 1999 | A |
5978042 | Vaske et al. | Nov 1999 | A |
6008809 | Brooks | Dec 1999 | A |
6018340 | Butler et al. | Jan 2000 | A |
6025841 | Finkelstein et al. | Feb 2000 | A |
6025853 | Baldwin | Feb 2000 | A |
6075531 | DeStefano | Jun 2000 | A |
6078339 | Meinerth et al. | Jun 2000 | A |
6191758 | Lee | Feb 2001 | B1 |
6208273 | Dye et al. | Mar 2001 | B1 |
6226237 | Chan et al. | May 2001 | B1 |
6259460 | Gossett et al. | Jul 2001 | B1 |
6337747 | Rosenthal | Jan 2002 | B1 |
6359624 | Kunimatsu | Mar 2002 | B1 |
6388671 | Yoshizawa et al. | May 2002 | B1 |
6407752 | Harnett | Jun 2002 | B1 |
6473086 | Morein et al. | Oct 2002 | B1 |
6480198 | Kang | Nov 2002 | B2 |
6483502 | Fujiwara | Nov 2002 | B2 |
6483515 | Hanko | Nov 2002 | B1 |
6498721 | Kim | Dec 2002 | B1 |
6557065 | Peleg et al. | Apr 2003 | B1 |
6600500 | Yamamoto | Jul 2003 | B1 |
6628243 | Lyons et al. | Sep 2003 | B1 |
6628309 | Dodson et al. | Sep 2003 | B1 |
6630943 | Nason et al. | Oct 2003 | B1 |
6654826 | Cho et al. | Nov 2003 | B1 |
6657632 | Emmot et al. | Dec 2003 | B2 |
6724403 | Santoro et al. | Apr 2004 | B1 |
6753878 | Heirich et al. | Jun 2004 | B1 |
6774912 | Ahmed et al. | Aug 2004 | B1 |
6784855 | Matthews et al. | Aug 2004 | B2 |
6816977 | Brakmo et al. | Nov 2004 | B2 |
6832269 | Huang et al. | Dec 2004 | B2 |
6832355 | Duperrouzel et al. | Dec 2004 | B1 |
6871348 | Cooper | Mar 2005 | B1 |
6956542 | Okuley et al. | Oct 2005 | B2 |
7007070 | Hickman | Feb 2006 | B1 |
7010755 | Anderson et al. | Mar 2006 | B2 |
7030837 | Vong et al. | Apr 2006 | B1 |
7034776 | Love | Apr 2006 | B1 |
7036089 | Bauer | Apr 2006 | B2 |
7103850 | Engstrom et al. | Sep 2006 | B1 |
7124360 | Drenttel et al. | Oct 2006 | B1 |
7127745 | Herse et al. | Oct 2006 | B1 |
7129909 | Dong et al. | Oct 2006 | B1 |
7149982 | Duperrouzel et al. | Dec 2006 | B1 |
7212174 | Johnston et al. | May 2007 | B2 |
7269797 | Bertocci et al. | Sep 2007 | B1 |
7359998 | Chan et al. | Apr 2008 | B2 |
7486279 | Wong et al. | Feb 2009 | B2 |
7509444 | Chiu et al. | Mar 2009 | B2 |
7546546 | Lewis-Bowen et al. | Jun 2009 | B2 |
7552391 | Evans et al. | Jun 2009 | B2 |
7558884 | Fuller et al. | Jul 2009 | B2 |
7590713 | Brockway et al. | Sep 2009 | B2 |
7612783 | Koduri et al. | Nov 2009 | B2 |
7783985 | Indiran et al. | Aug 2010 | B2 |
8176155 | Yang et al. | May 2012 | B2 |
8190707 | Trivedi et al. | May 2012 | B2 |
20010028366 | Ohki et al. | Oct 2001 | A1 |
20020054141 | Yen et al. | May 2002 | A1 |
20020057295 | Panasyuk et al. | May 2002 | A1 |
20020087225 | Howard | Jul 2002 | A1 |
20020128288 | Kyle et al. | Sep 2002 | A1 |
20020129288 | Loh et al. | Sep 2002 | A1 |
20020140627 | Ohki et al. | Oct 2002 | A1 |
20020163513 | Tsuji | Nov 2002 | A1 |
20020175933 | Ronkainen et al. | Nov 2002 | A1 |
20020182980 | Van Rompay | Dec 2002 | A1 |
20020186257 | Cadiz et al. | Dec 2002 | A1 |
20020196279 | Bloomfield et al. | Dec 2002 | A1 |
20030016205 | Kawabata et al. | Jan 2003 | A1 |
20030025689 | Kim | Feb 2003 | A1 |
20030041206 | Dickie | Feb 2003 | A1 |
20030065934 | Angelo et al. | Apr 2003 | A1 |
20030088800 | Cai | May 2003 | A1 |
20030090508 | Keohane et al. | May 2003 | A1 |
20030105812 | Flowers, Jr. et al. | Jun 2003 | A1 |
20030126335 | Silvester | Jul 2003 | A1 |
20030160816 | Zoller et al. | Aug 2003 | A1 |
20030177172 | Duursma et al. | Sep 2003 | A1 |
20030179240 | Gest | Sep 2003 | A1 |
20030179244 | Erlingsson | Sep 2003 | A1 |
20030188144 | Du et al. | Oct 2003 | A1 |
20030189597 | Anderson et al. | Oct 2003 | A1 |
20030195950 | Huang et al. | Oct 2003 | A1 |
20030197739 | Bauer | Oct 2003 | A1 |
20030200435 | England et al. | Oct 2003 | A1 |
20030208529 | Pendyala et al. | Nov 2003 | A1 |
20030222876 | Giemborek et al. | Dec 2003 | A1 |
20030222915 | Marion et al. | Dec 2003 | A1 |
20030225872 | Bartek et al. | Dec 2003 | A1 |
20030229900 | Reisman | Dec 2003 | A1 |
20040001069 | Snyder et al. | Jan 2004 | A1 |
20040019724 | Singleton, Jr. et al. | Jan 2004 | A1 |
20040027315 | Senda et al. | Feb 2004 | A1 |
20040066414 | Czerwinski et al. | Apr 2004 | A1 |
20040070608 | Saka | Apr 2004 | A1 |
20040080482 | Magendanz et al. | Apr 2004 | A1 |
20040085328 | Maruyama et al. | May 2004 | A1 |
20040095382 | Fisher et al. | May 2004 | A1 |
20040145605 | Basu et al. | Jul 2004 | A1 |
20040153493 | Slavin et al. | Aug 2004 | A1 |
20040184523 | Dawson et al. | Sep 2004 | A1 |
20040222978 | Bear et al. | Nov 2004 | A1 |
20040224638 | Fadell et al. | Nov 2004 | A1 |
20040225901 | Bear et al. | Nov 2004 | A1 |
20040225907 | Jain et al. | Nov 2004 | A1 |
20040235532 | Matthews et al. | Nov 2004 | A1 |
20040260565 | Zimniewicz et al. | Dec 2004 | A1 |
20040268004 | Oakley | Dec 2004 | A1 |
20050025071 | Miyake et al. | Feb 2005 | A1 |
20050059346 | Gupta et al. | Mar 2005 | A1 |
20050064911 | Chen et al. | Mar 2005 | A1 |
20050066209 | Kee et al. | Mar 2005 | A1 |
20050073515 | Kee et al. | Apr 2005 | A1 |
20050076088 | Kee et al. | Apr 2005 | A1 |
20050076256 | Fleck et al. | Apr 2005 | A1 |
20050091610 | Frei et al. | Apr 2005 | A1 |
20050097506 | Heumesser | May 2005 | A1 |
20050125739 | Thompson et al. | Jun 2005 | A1 |
20050132299 | Jones et al. | Jun 2005 | A1 |
20050140566 | Kim et al. | Jun 2005 | A1 |
20050182980 | Sutardja | Aug 2005 | A1 |
20050240538 | Ranganathan | Oct 2005 | A1 |
20050240873 | Czerwinski et al. | Oct 2005 | A1 |
20050262302 | Fuller et al. | Nov 2005 | A1 |
20050268246 | Keohane et al. | Dec 2005 | A1 |
20060001595 | Aoki | Jan 2006 | A1 |
20060007051 | Bear et al. | Jan 2006 | A1 |
20060085760 | Anderson et al. | Apr 2006 | A1 |
20060095617 | Hung | May 2006 | A1 |
20060119537 | Vong et al. | Jun 2006 | A1 |
20060119538 | Vong et al. | Jun 2006 | A1 |
20060119602 | Fisher et al. | Jun 2006 | A1 |
20060125784 | Jang et al. | Jun 2006 | A1 |
20060129855 | Rhoten et al. | Jun 2006 | A1 |
20060130075 | Rhoten et al. | Jun 2006 | A1 |
20060142878 | Banik et al. | Jun 2006 | A1 |
20060150230 | Chung et al. | Jul 2006 | A1 |
20060164324 | Polivy et al. | Jul 2006 | A1 |
20060232494 | Lund et al. | Oct 2006 | A1 |
20060250320 | Fuller et al. | Nov 2006 | A1 |
20060267857 | Zhang et al. | Nov 2006 | A1 |
20060267987 | Litchmanov | Nov 2006 | A1 |
20060267992 | Kelley et al. | Nov 2006 | A1 |
20060282855 | Margulis | Dec 2006 | A1 |
20070046562 | Polivy et al. | Mar 2007 | A1 |
20070050727 | Lewis-Bowen et al. | Mar 2007 | A1 |
20070052615 | Van Dongen et al. | Mar 2007 | A1 |
20070067655 | Shuster | Mar 2007 | A1 |
20070079030 | Okuley et al. | Apr 2007 | A1 |
20070083785 | Sutardja | Apr 2007 | A1 |
20070103383 | Sposato et al. | May 2007 | A1 |
20070195007 | Bear et al. | Aug 2007 | A1 |
20070273699 | Sasaki et al. | Nov 2007 | A1 |
20080034318 | Louch et al. | Feb 2008 | A1 |
20080130543 | Singh et al. | Jun 2008 | A1 |
20080155478 | Stross | Jun 2008 | A1 |
20080172626 | Wu | Jul 2008 | A1 |
20080297433 | Heller et al. | Dec 2008 | A1 |
20080320321 | Sutardja | Dec 2008 | A1 |
20090021450 | Heller et al. | Jan 2009 | A1 |
20090031329 | Kim | Jan 2009 | A1 |
20090059496 | Lee | Mar 2009 | A1 |
20090160865 | Grossman | Jun 2009 | A1 |
20090172450 | Wong et al. | Jul 2009 | A1 |
20090193243 | Ely | Jul 2009 | A1 |
20100010653 | Bear et al. | Jan 2010 | A1 |
20100033433 | Utz et al. | Feb 2010 | A1 |
20100033916 | Douglas et al. | Feb 2010 | A1 |
20110219313 | Mazzaferri | Sep 2011 | A1 |
Number | Date | Country |
---|---|---|
2005026918 | Mar 2005 | WO |
Entry |
---|
“System Management Bus (SMBus) Specification,” Version 2.0, Aug. 3, 2000; pp. 1-59. |
Handtops.com, “FlipStart PC in Detail” pp. 1-4, downloaded from the Internet o Sep. 20, 2005 from http://www.handtops.com/show/news/5. |
Microsoft Corporation, “Microsoft Windows Hardware Showcase”, dated Apr. 28, 2005; pp. 1-5; downloaded from the internet on Sep. 15, 2005, from http://www.microsoft.com/whdc/winhec/hwshowcase05.mspx. |
Paul Thurrot's SuperSite for Windows, “WinHEC 2004 Longhom Prototypes Gallery”, dated May 10, 2004, pp. 1-4, downloaded from the Internet on Sep. 15, 2005 from http://www.sinwupersite.com/showcase.loghom—winhc—proto.asp. |
Vulcan Inc., “Connectivity FAQ”, p. 1, downloaded from the internet on Sep. 20, 2005 from http://www.flipstartpc.com/faq—connectivity.asp. |
Vulcan, Inc., “Product Features: Size and performanc”, p. 1; downloaded from the Internet on Sep. 20, 2005 from http://www.flipstartpc.com/aboutproduct—features—sizeandpower.asp. |
“Usage: NVIDIA GeForce 6800—PCIe x16”, Dell, archived Jan. 15, 2006 by archive.org, Downloaded Jun. 29, 2011, http://web.archive.org/web/20060115050119/http://support.dell.com/support/edocs/video/P82192/en/usage.htm. |
“Graphics: Intel® 82852/82855 Graphics Controller Family”, Intel, Archived Nov. 2, 2006 by archive.org, Downloaded Jun. 30, 2011, http://web.archive.org/web/20061103045644/http://www.intel.com/support/graphics/inte1852gm/sb/CS-009064.htm? |
“Epson: EMP Monitor V4.10 Operation Guide”, by Seiko Epson Corp., 2006, http://support.epson.ru/products/manuals/100396/Manual/EMPMonitor.pdf. |
“The Java Tutorial: How to Use Combo Boxes”, Archived Mar. 5, 2006 by archive.org, Downloaded Jun. 30, 2011, http://web.archive.org/web/20050305000852/http://www-mips.unice.fr/Doc/Java/Tutorial/uiswing/components/combobox.html. |
“Epson; EMP Monitor V4, 10 Operation Guide”, by Seiko Epson Corp., 2006 http://support.epson.ru/products/manuals/100396/Manual/EMPMonitor.pdf. |
“Virtual Network Computing”, http://en.wikipedia.org/wiki/Vnc, Downloaded Circa: Dec. 18, 2008, pp. 1-4. |
Andrew Fuller; “Auxiliary Display Platform in Longhorn”; Microsoft Corporation; The Microsoft Hardware Engineering Conference Apr. 25-27, 2005; slides 1-29. |
McFedries, ebook, titled “Complete Idiot's Guide to Windows XP”, published Oct. 3, 2001, pp. 1-7. |
PCWorld.com, “Microsoft Pitches Display for Laptop Lids” dated Feb. 10, 2005, pp. 1-2, downloaded from the Internet on Mar. 8, 2006 from http://www.pcworld.com/resources/article/aid/119644.asp. |
Vulcan, Inc., “Product Features: Size and performance”, p. 1; downloaded from the internet on Sep. 20, 2005 from http://www.flipstartpc.com/aboutproduct—features—sizeandpower.asp. |
Vulcan, Inc., “Product Features:LID Module”, p. 1, downloaded from the Internet on Sep. 19, 2005 from http://www.flipstartpc.com/aboutproduct—features—lidmodule.asp. |
Vulcan, Inc., “Software FAQ”, p. 1, downloaded from the internet on Sep. 20, 2005 from http://www.flipstartpc.com/faq—software.asp. |
Number | Date | Country | |
---|---|---|---|
20100026692 A1 | Feb 2010 | US |