Specifications
Data Transfer 
Quadro SDI Output  PG-03776-001_v06 | 15 
Creation of an FBO is identical on both Windows and Linux, and requires only a current 
OpenGL context. In the previous code listing example, when a texture object is specified, 
it is attached as 
COLOR_ATTACHMENT0, otherwise, a renderbuffer is used. For more 
information on FBO creation and usage, refer to the 
GL_EXT_framebuffer_object 
specification. 
In order for an application to render into an FBO render target, the target must first be 
bound using the command in Code Listing 9. 
Code Listing 9: Configuring a Frame Buffer Object 
glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, fboId); 
Either before or after buffer object creation, the SDI video device must be bound in 
OpenGL. The procedure for enumerating the available video devices and binding one of 
them is outlined in Code Listing 10. 
Code Listing 10: Binding a Video Device 
// Enumerate the available video devices and 
// bind to the first one found 
HVIDEOOUTPUTDEVICENV *videoDevices; 
// Get list of available video devices. 
int numDevices = wglEnumerateVideoDevicesNV(ghWinDC, NULL); 
if (numDevices <= 0) { 
 MessageBox(NULL, "wglEnumerateVideoDevicesNV() did not return 
any devices.", "Error", MB_OK); 
 exit(1); 
} 
videoDevices = (HVIDEOOUTPUTDEVICENV *)malloc(numDevices * 
 sizeof(HVIDEOOUTPUTDEVICENV)); 
if (!videoDevices) { 
 fprintf(stderr, "malloc failed. OOM?"); 
 exit(1); 
} 
if (numDevices != wglEnumerateVideoDevicesNV(ghWinDC, 
 videoDevices)) { 
 free(videoDevices); 
 MessageBox(NULL, "Invonsistent results from 
 wglEnumerateVideoDevicesNV()", "Error", MB_OK); 
 exit(1); 
} 
//Bind the first device found. 
if (!wglBindVideoDeviceNV(ghWinDC, 1, videoDevices[0], NULL)) { 
 free(videoDevices); 










