Microsoft Reinvents Desktop Graphics in Windows LonghornBy Dave Salvator | Posted 2004-07-30 Email Print
Re-Thinking HR: What Every CIO Needs to Know About Tomorrow's Workforce
From games to the desktop itself, 3D graphics will be everywhere in the new Windows Longhorn OS. Take a sneak peek at Microsoft's forthcoming WGF architecture that will make it happen.Microsoft Corp. is working away on the next-generation of Windows, code-named Longhorn, due in 2006. According to developers, the new operating system will reshape the Windows graphics architecture, from 2D to 3D, with the Windows Graphics Foundation.
The new architecture was given a sneak peek at Microsoft's Meltdown conference, which is all about building games on Windows. Originally started as a compatibility test-fest for hardware makers and software developers, the event has matured into a Windows game developer convention. Highlights from this year's gathering, held July 27th and 28th in Seattle, included presentations about the company's XNA development tools and how to get the most out of Direct3D and DirectSound.
One of the more exciting parts of the conference was a talk entitled "DX Futures," where the Redmond software giant went over some of the architectural details of Longhorn's graphics architecture, which have some big in changes in store for Direct3D.
For starters, it appears that, as some rumors have suggested, the distinction between vertex and pixel shaders will essentially go away. Instead, there will be what Microsoft is calling a Common Shader Core that will contain vertex and pixel shader operations.
Blythe hinted that other kinds of shaders may become available in this framework, though he declined to elaborate as to what those might be. Some possible features that could be added here would be collision detection, and more interestingly, physics calculations. There's been a fair amount of published work coming out of academia about using GPUs' floating-point horsepower to model fluid dynamics, and the movement of gaseous clouds (like smoke).
The line between vertex and pixel shader ops and instructions has been blurring for some time already. There was even some speculation that ATI pushed the R400 out to be the R500 because this architecture was going to try to unify its vertex and pixel shader units. It would appear WGF will lay the groundwork for that unification.
Other major changes call for the GPU to be available to multiple applications simultaneously. Blythe articulated what he termed a "crawl/walk/run" strategy, where an initial feature set would be introduced in WGF 1.0, when Longhorn ships. Other features would be folded in as they became stable and ready for release.
For instance, WGF's scheduler will be tasked with keeping multiple 3D applications fed and happy. This scheduler will likely have a three-step rollout:
- Schedule batches
- Schedule contexts
- Preemptive context scheduling
Given Avalon's 3D-centric architecture, this feature will be crucial to keeping Longhorn running smoothly in multitasking environments, where each application requires ready access to its displayed data.
We have some concern that the word "preemptive" doesn't appear until the third stage of this rollout. Windows has had a preemptive multitasking model since Windows 95, and that model has worked fairly well.
However, if an application's display processing chores can't preemptively be given higher priority when that app comes into the foreground focus, we wonder if there might be some perceptible latency as other instructions are retired and the in-focus app's processing gets the driver's full attention. The answer to that question will likely have to wait until the Longhorn beta sometime next year.
One of the first orders of business in is to "fix busted stuff," as Blythe put it. These items include no more blue-screens (hard crashes) caused by the graphics driver, and moving more processing into what's known as user mode. This initiative dovetails with the Longhorn Display Driver Model (LDDM), outlined at this year's WinHEC conference.