VirtualBox

Changeset 3708 in vbox for trunk/src


Ignore:
Timestamp:
Jul 19, 2007 8:21:00 AM (18 years ago)
Author:
vboxsync
Message:

Merged Linux code from Alexander Eichner.

Location:
trunk/src/VBox/HostServices/SharedOpenGL
Files:
7 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/HostServices/SharedOpenGL/Makefile.kmk

    r3454 r3708  
    3333        $(PATH_TOOL_$(VBOX_VCC_TOOL)_ATLMFC_INC) \
    3434        $(VBOX_PATH_SDK)
     35VBoxSharedOpenGL_CXXFLAGS.linux = -pthread
    3536
    3637VBoxSharedOpenGL_SOURCES = \
     
    5556VBoxSharedOpenGL_LIBS.win = \
    5657        $(PATH_SDK_WINPSDK_LIB)/opengl32.lib
     58VBoxSharedOpenGL_LIBPATH.linux = \
     59        $(VBOX_LIBPATH_X11)
     60VBoxSharedOpenGL_LIBS.linux = \
     61        GL
    5762
    5863include $(PATH_KBUILD)/subfooter.kmk
  • trunk/src/VBox/HostServices/SharedOpenGL/gldrv.h

    r3698 r3708  
    2323
    2424#include <iprt/types.h>
     25#include <iprt/mem.h>
    2526
    2627#ifdef RT_OS_WINDOWS
    2728#define VBOX_OGL_DEBUG_WINDOW_OUTPUT
    28 #endif
    29 
     29#elif defined(RT_OS_LINUX)
     30#include <X11/Xlib.h>
     31#include <GL/glx.h>
     32#include <GL/glxext.h>
     33 
     34typedef GLXContextID (*glXGetContextIDEXTProc) (const GLXContext);
     35typedef GLXContext (*glXImportContextEXTProc) (Display *, GLXContextID);
     36 
     37#define VBOX_OGL_DEBUG_WINDOW_OUTPUT
     38#endif
     39 
    3040#ifdef VBOX_OGL_DEBUG_WINDOW_OUTPUT
     41#if defined(RT_OS_WINDOWS)
    3142#define VBOX_OGL_GUEST_TO_HOST_HDC(a)       pClient->hdc
    32 #else
    33 #define VBOX_OGL_GUEST_TO_HOST_HDC(a)       a
    34 #endif
     43#elif defined(RT_OS_LINUX)
     44#define VBOX_OGL_GUEST_TO_HOST_HDC(a)       pClient->glxContext
     45#endif
     46#endif
     47
    3548
    3649typedef struct
     
    4457    uint32_t    cbLastParam;
    4558
     59    struct
     60    {
     61#ifdef RT_OS_WINDOWS
     62        HWND        hwnd;
     63        HDC         hdc;
     64        HGLRC       hglrc;
     65#elif defined RT_OS_LINUX
     66        Display     *dpy;
     67        Window      win;
     68        GLXContext  ctx;
     69        GLXFBConfig *fbConfig;
     70        XVisualInfo *visinfo;
     71#endif
     72    } enable;
     73
    4674#ifdef VBOX_OGL_DEBUG_WINDOW_OUTPUT
     75#ifdef RT_OS_WINDOWS
    4776    HWND        hwnd;
    4877    HDC         hdc;
     78#elif defined RT_OS_LINUX
     79    Display     *dpy;
     80    Window      xWindow;
     81    GLXFBConfig actFBConfig;
     82    int         winWidth, winHeight;
     83    GLXFBConfig *PixelFormatToFBConfigMapper;
     84    int         numFBConfigs;
     85    GLXContext  glxContext;
     86    PFNGLXCHOOSEFBCONFIGSGIXPROC glxChooseFBConfig;
     87    PFNGLXGETVISUALFROMFBCONFIGSGIXPROC glxGetVisualFromFBConfig;
     88    PFNGLXCREATECONTEXTWITHCONFIGSGIXPROC glxCreateNewContext;
     89    //glXGetContextIDEXTProc getContextIDPtr;
     90    //glXImportContextEXTProc importContextEXTPtr;
     91#endif
    4992#endif
    5093} VBOXOGLCTX, *PVBOXOGLCTX;
     
    72115#define DECLARE_HANDLE(a)  typedef HANDLE a
    73116#define WINAPI
     117
     118#define PFD_DOUBLEBUFFER   0x00000001
     119#define PFD_STEREO         0x00000002
     120#define PFD_DRAW_TO_WINDOW 0x00000004
     121#define PFD_SUPPORT_OPENGL 0x00000020
     122
     123#define PFD_TYPE_RGBA       0
     124#define PFD_TYPE_COLORINDEX 1
     125
     126#define PFD_MAIN_PLANE 0
     127#define PFD_OVERLAY_PLANE 1
     128#define PFD_UNDERLAY_PLANE (-1)
    74129
    75130typedef struct
     
    149204void vboxglDrvSwapBuffers(VBOXOGLCTX *pClient, uint8_t *pCmdBuffer);
    150205
     206int vboxglEnableOpenGL(VBOXOGLCTX *pClient);
     207int vboxglDisableOpenGL(VBOXOGLCTX *pClient);
    151208
    152209RTUINTPTR vboxDrvIsExtensionAvailable(char *pszExtFunctionName);
  • trunk/src/VBox/HostServices/SharedOpenGL/gllindrv.cpp

    r3698 r3708  
    44 *
    55 * Simple buffered OpenGL functions
     6 *
     7 * Contributor: Alexander Eichner
    68 */
    79
     
    2628#define LOG_GROUP LOG_GROUP_SHARED_OPENGL
    2729#include <VBox/log.h>
     30#include <string.h>
     31#include <stdio.h>
     32
     33/*static int (*X_handler)(Display *, XErrorEvent *) = NULL;
     34static int x_errhandler(Display *d, XErrorEvent *e)
     35{
     36    return (X_handler(d, e));
     37}
     38
     39static int (*XIO_handler)(Display *) = NULL;
     40static int xio_errhandler(Display *d)
     41{
     42    return (XIO_handler(d));
     43}*/
     44
     45static Bool WaitForNotify( Display *dpy, XEvent *event, XPointer arg ) {
     46    return (event->type == MapNotify) && (event->xmap.window == (Window) arg);
     47}
     48
     49/* from http://www.mesa3d.org/brianp/sig97/exten.htm */
     50GLboolean vboxglCheckExtension(Display *dpy, int screenNum, char *extName )
     51{
     52   /*
     53    ** Search for extName in the extensions string.  Use of strstr()
     54    ** is not sufficient because extension names can be prefixes of
     55    ** other extension names.  Could use strtok() but the constant
     56    ** string returned by glGetString can be in read-only memory.
     57    */
     58    char *p = (char *) glXQueryExtensionsString(dpy, screenNum);
     59    char *end;
     60    int extNameLen;
     61
     62    extNameLen = strlen(extName);
     63    end = p + strlen(p);
     64
     65    while (p < end) {
     66        int n = strcspn(p, " ");
     67        if ((extNameLen == n) && (strncmp(extName, p, n) == 0)) {
     68            return GL_TRUE;
     69        }
     70        p += (n + 1);
     71    }
     72    return GL_FALSE;
     73}
     74
     75
     76/**
     77 * Print parameters for a GLXFBConfig to stdout.
     78 * Input:  dpy - the X display
     79 *         screen - the X screen number
     80 *         fbConfig - the fbconfig handle
     81 *         horizFormat - if true, print in horizontal format
     82 */
     83void
     84PrintFBConfigInfo(Display *dpy, int screen, GLXFBConfig config)
     85{
     86   int bufferSize, level, doubleBuffer, stereo, auxBuffers;
     87   int redSize, greenSize, blueSize, alphaSize;
     88   int depthSize, stencilSize;
     89   int accumRedSize, accumBlueSize, accumGreenSize, accumAlphaSize;
     90   int sampleBuffers, samples;
     91   int drawableType, renderType, xRenderable, xVisual, id;
     92
     93   /* do queries using the GLX 1.3 tokens (same as the SGIX tokens) */
     94   glXGetFBConfigAttrib(dpy, config, GLX_BUFFER_SIZE, &bufferSize);
     95   glXGetFBConfigAttrib(dpy, config, GLX_LEVEL, &level);
     96   glXGetFBConfigAttrib(dpy, config, GLX_DOUBLEBUFFER, &doubleBuffer);
     97   glXGetFBConfigAttrib(dpy, config, GLX_STEREO, &stereo);
     98   glXGetFBConfigAttrib(dpy, config, GLX_AUX_BUFFERS, &auxBuffers);
     99   glXGetFBConfigAttrib(dpy, config, GLX_RED_SIZE, &redSize);
     100   glXGetFBConfigAttrib(dpy, config, GLX_GREEN_SIZE, &greenSize);
     101   glXGetFBConfigAttrib(dpy, config, GLX_BLUE_SIZE, &blueSize);
     102   glXGetFBConfigAttrib(dpy, config, GLX_ALPHA_SIZE, &alphaSize);
     103   glXGetFBConfigAttrib(dpy, config, GLX_DEPTH_SIZE, &depthSize);
     104   glXGetFBConfigAttrib(dpy, config, GLX_STENCIL_SIZE, &stencilSize);
     105   glXGetFBConfigAttrib(dpy, config, GLX_ACCUM_RED_SIZE, &accumRedSize);
     106   glXGetFBConfigAttrib(dpy, config, GLX_ACCUM_GREEN_SIZE, &accumGreenSize);
     107   glXGetFBConfigAttrib(dpy, config, GLX_ACCUM_BLUE_SIZE, &accumBlueSize);
     108   glXGetFBConfigAttrib(dpy, config, GLX_ACCUM_ALPHA_SIZE, &accumAlphaSize);
     109   glXGetFBConfigAttrib(dpy, config, GLX_SAMPLE_BUFFERS, &sampleBuffers);
     110   glXGetFBConfigAttrib(dpy, config, GLX_SAMPLES, &samples);
     111   glXGetFBConfigAttrib(dpy, config, GLX_DRAWABLE_TYPE, &drawableType);
     112   glXGetFBConfigAttrib(dpy, config, GLX_RENDER_TYPE, &renderType);
     113   glXGetFBConfigAttrib(dpy, config, GLX_X_RENDERABLE, &xRenderable);
     114   glXGetFBConfigAttrib(dpy, config, GLX_X_VISUAL_TYPE, &xVisual);
     115   if (!xRenderable || !(drawableType & GLX_WINDOW_BIT_SGIX))
     116      xVisual = -1;
     117
     118   glXGetFBConfigAttrib(dpy, config, GLX_FBCONFIG_ID, &id);
     119
     120      printf("Id 0x%x\n", id);
     121      printf("  Buffer Size: %d\n", bufferSize);
     122      printf("  Level: %d\n", level);
     123      printf("  Double Buffer: %s\n", doubleBuffer ? "yes" : "no");
     124      printf("  Stereo: %s\n", stereo ? "yes" : "no");
     125      printf("  Aux Buffers: %d\n", auxBuffers);
     126      printf("  Red Size: %d\n", redSize);
     127      printf("  Green Size: %d\n", greenSize);
     128      printf("  Blue Size: %d\n", blueSize);
     129      printf("  Alpha Size: %d\n", alphaSize);
     130      printf("  Depth Size: %d\n", depthSize);
     131      printf("  Stencil Size: %d\n", stencilSize);
     132      printf("  Accum Red Size: %d\n", accumRedSize);
     133      printf("  Accum Green Size: %d\n", accumGreenSize);
     134      printf("  Accum Blue Size: %d\n", accumBlueSize);
     135      printf("  Accum Alpha Size: %d\n", accumAlphaSize);
     136      printf("  Sample Buffers: %d\n", sampleBuffers);
     137      printf("  Samples/Pixel: %d\n", samples);
     138      printf("  Drawable Types: ");
     139      if (drawableType & GLX_WINDOW_BIT)  printf("Window ");
     140      if (drawableType & GLX_PIXMAP_BIT)  printf("Pixmap ");
     141      if (drawableType & GLX_PBUFFER_BIT)  printf("PBuffer");
     142      printf("\n");
     143      printf("  Render Types: ");
     144      if (renderType & GLX_RGBA_BIT_SGIX)  printf("RGBA ");
     145      if (renderType & GLX_COLOR_INDEX_BIT_SGIX)  printf("CI ");
     146      printf("\n");
     147      printf("  X Renderable: %s\n", xRenderable ? "yes" : "no");
     148
     149}
    28150
    29151/**
     
    34156int vboxglGlobalInit()
    35157{
    36     vboxInitOpenGLExtensions();
     158    Log(("vboxglGlobalInit\n"));
     159
     160    /*vboxInitOpenGLExtensions();*/
     161    return VINF_SUCCESS;
     162}
     163
     164
     165/**
     166 * Enable OpenGL
     167 *
     168 * @returns VBox error code
     169 * @param   pClient         Client context
     170 */
     171int vboxglEnableOpenGL(PVBOXOGLCTX pClient)
     172{
     173    Display *dpy;
     174    static int attribs[] = {
     175        GLX_DRAWABLE_TYPE, GLX_WINDOW_BIT,
     176        GLX_RENDER_TYPE,   GLX_RGBA_BIT,
     177        GLX_DOUBLEBUFFER,  True,  /* Request a double-buffered color buffer with */
     178        GLX_RED_SIZE,      1,     /* the maximum number of bits per component    */
     179        GLX_GREEN_SIZE,    1,
     180        GLX_BLUE_SIZE,     1,
     181        None
     182    };
     183    int screen_num;
     184    XSetWindowAttributes attr;
     185    unsigned long mask;
     186    int returnedFBConfigs;
     187
     188    if (!pClient->glxContext)
     189    {
     190        /* we have to set up a rendering context to be able to use glGetString
     191         * a window is created but is not mapped to screen (so it's not visible')
     192         * and a GLXContext is bound to it */
     193        screen_num = DefaultScreen(pClient->dpy);
     194        pClient->enable.fbConfig = pClient->glxChooseFBConfig(pClient->dpy, screen_num, attribs, &returnedFBConfigs);
     195        Log(("vboxglGetString: returned FBConfigs: %d\n", returnedFBConfigs));
     196        pClient->enable.visinfo = pClient->glxGetVisualFromFBConfig(pClient->dpy, fbConfig[0]);
     197        /* Create Window */
     198        attr.background_pixel = 0;
     199        attr.border_pixel = 0;
     200        attr.colormap = XCreateColormap(pClient->dpy, RootWindow(dpy, screen_num), visinfo->visual, AllocNone);
     201        attr.event_mask = StructureNotifyMask | ExposureMask;
     202        mask = CWBackPixel | CWBorderPixel | CWColormap | CWEventMask;
     203        pClient->enable.win = XCreateWindow(pClient->dpy, RootWindow(pClient->dpy, screen_num), 0, 0, 100, 100,
     204                           0, visinfo->depth, InputOutput,
     205                           visinfo->visual, mask, &attr);
     206        /* Create Context */
     207        pClient->enable.ctx = pClient->glxCreateNewContext(pClient->dpy, fbConfig[0], GLX_RGBA_TYPE, NULL, True);
     208
     209        glXMakeCurrent(pClient->dpy, pClient->enable.win, pClient->enable.ctx);
     210    }
     211    else
     212    {
     213        glXMakeCurrent(pClient->dpy, pClient->xWindow, pClient->glxContext);
     214    }
     215
     216    return VINF_SUCCESS;
     217}
     218
     219/**
     220 * Disable OpenGL
     221 *
     222 * @returns VBox error code
     223 * @param   pClient         Client context
     224 */
     225int vboxglDisableOpenGL(PVBOXOGLCTX pClient)
     226{
     227    /* Free all data */
     228    glFlush();
     229    if (!pClient->glxContext)
     230    {
     231        glXMakeCurrent(pClient->dpy, 0, NULL);
     232        XDestroyWindow(pClient->dpy, pClient->enable.win);
     233        glXDestroyContext(pClient->dpy, pClient->enable.ctx);
     234        XFree(pClient->enable.visinfo);
     235        XFree(pClient->enable.fbConfig);
     236    }
    37237    return VINF_SUCCESS;
    38238}
     
    46246int vboxglConnect(PVBOXOGLCTX pClient)
    47247{
    48     return VINF_SUCCESS;
     248    int rc = VERR_NOT_IMPLEMENTED;
     249    Log(("vboxglConnect\n"));
     250    //pClient->getContextIDPtr = NULL;
     251    //pClient->importContextEXTPtr = NULL;
     252    pClient->PixelFormatToFBConfigMapper = NULL;
     253    pClient->xWindow = 0;
     254
     255    pClient->dpy = XOpenDisplay(NULL);
     256
     257    if (pClient->dpy) {
     258        int  screenNum, major, minor;
     259
     260        screenNum = DefaultScreen(pClient->dpy);
     261        glXQueryVersion(pClient->dpy, &major, &minor);
     262
     263        if ((major == 1) && (minor >= 3)) {
     264            Log(("Server GLX 1.3 supported\n"));
     265            pClient->glxChooseFBConfig = (PFNGLXCHOOSEFBCONFIGSGIXPROC) glXGetProcAddress(
     266                                          (GLubyte *) "glXChooseFBConfig");
     267            pClient->glxGetVisualFromFBConfig = (PFNGLXGETVISUALFROMFBCONFIGSGIXPROC) glXGetProcAddress(
     268                                                 (GLubyte *) "glXGetVisualFromFBConfig");
     269            pClient->glxCreateNewContext = (PFNGLXCREATECONTEXTWITHCONFIGSGIXPROC) glXGetProcAddress(
     270                                            (GLubyte *) "glXCreateNewContext");
     271        } else if (vboxglCheckExtension(pClient->dpy, screenNum, "GLX_SGIX_fbconfig")) {
     272            Log(("GLX_SGIX_fbconfig extension supported\n"));
     273            pClient->glxChooseFBConfig = (PFNGLXCHOOSEFBCONFIGSGIXPROC) glXGetProcAddress(
     274                                          (GLubyte *) "glXChooseFBConfigSGIX");
     275            pClient->glxGetVisualFromFBConfig = (PFNGLXGETVISUALFROMFBCONFIGSGIXPROC) glXGetProcAddress(
     276                                                 (GLubyte *) "glXGetVisualFromFBConfigSGIX");
     277            pClient->glxCreateNewContext = (PFNGLXCREATECONTEXTWITHCONFIGSGIXPROC) glXGetProcAddress(
     278                                            (GLubyte *) "glXCreateContextWithConfigSGIX");
     279        } else {
     280                Log(("Error no FBConfig supported\n"));
     281                rc = VERR_NOT_IMPLEMENTED;
     282        }
     283        if (pClient->glxChooseFBConfig && pClient->glxGetVisualFromFBConfig && pClient->glxCreateNewContext)
     284            rc = VINF_SUCCESS;
     285    }
     286
     287    return rc;
    49288}
    50289
     
    57296int vboxglDisconnect(PVBOXOGLCTX pClient)
    58297{
     298    Log(("vboxglDisconnect\n"));
     299
     300#ifdef VBOX_OGL_DEBUG_WINDOW_OUTPUT
     301    if (pClient->dpy) {
     302        if (pClient->xWindow != 0) {
     303            XUnmapWindow(pClient->dpy, pClient->xWindow);
     304            XDestroyWindow(pClient->dpy, pClient->xWindow);
     305        }
     306        if (pClient->PixelFormatToFBConfigMapper) {
     307            XFree(pClient->PixelFormatToFBConfigMapper);
     308        }
     309        XCloseDisplay(pClient->dpy);
     310    }
     311    pClient->dpy = NULL;
     312    pClient->xWindow = 0;
     313    pClient->actFBConfig = NULL;
     314#endif
    59315    return VINF_SUCCESS;
    60316}
     
    63319void vboxglDrvCreateContext(VBOXOGLCTX *pClient, uint8_t *pCmdBuffer)
    64320{
    65     OGL_CMD(DrvCreateContext, 4);
    66     OGL_PARAM(HDC, hdc);
    67     OGL_PARAM(uint32_t, cx);
    68     OGL_PARAM(uint32_t, cy);
    69     OGL_PARAM(BYTE, cColorBits);
    70     OGL_PARAM(BYTE, iPixelType);
    71     OGL_PARAM(BYTE, cDepthBits);
    72 
    73     pClient->lastretval = 0; /** @todo */
     321    XSetWindowAttributes attr;
     322    XVisualInfo *visinfo = NULL;
     323    unsigned long mask;
     324    //GLXContext ctx;
     325    GLXFBConfig fbConfig;
     326    GLXContextID glrc;
     327    int screen_num;
     328    XEvent event;
     329    OGL_CMD(DrvCreateContext, 1);
     330    OGL_PARAM(HDC, hdc);
     331
     332    Log(("DrvCreateContext %x\n", hdc));
     333#ifdef VBOX_OGL_DEBUG_WINDOW_OUTPUT
     334
     335    screen_num = DefaultScreen(pClient->dpy);
     336    fbConfig = pClient->actFBConfig;
     337
     338#if 0
     339    if (!fbConfig) {
     340        /* Create a standard fbconfig */
     341        int returnedNumFBConfigs;
     342        GLXFBConfig *returnedFBConfigs;
     343        static int attribs[] = {
     344            GLX_DRAWABLE_TYPE, GLX_WINDOW_BIT,
     345            GLX_RENDER_TYPE,   GLX_RGBA_BIT,
     346            GLX_DOUBLEBUFFER,  True,  /* Request a double-buffered color buffer with */
     347            GLX_RED_SIZE,      1,     /* the maximum number of bits per component    */
     348            GLX_GREEN_SIZE,    1,
     349            GLX_BLUE_SIZE,     1,
     350            None
     351        };
     352
     353        Log(("Warning: no GLXFBConfig set creating standard one\n"));
     354        returnedFBConfigs = pClient->glxChooseFBConfig(pClient->dpy, screen_num, attribs, &returnedNumFBConfigs);
     355        if (!returnedNumFBConfigs) {
     356            pClient->lastretval = 0;
     357            pClient->fHasLastError = true;
     358            pClient->ulLastError   = glGetError();
     359            return;
     360        }
     361        fbConfig = returnedFBConfigs[0];
     362    }
     363#endif
     364
     365    visinfo = pClient->glxGetVisualFromFBConfig(pClient->dpy, fbConfig);
     366
     367    if (pClient->xWindow == 0) {
     368
     369        /* window attributes */
     370        attr.background_pixel = 0;
     371        attr.border_pixel = 0;
     372        attr.colormap = XCreateColormap(pClient->dpy, RootWindow(pClient->dpy, screen_num ), visinfo->visual, AllocNone);
     373        attr.event_mask = StructureNotifyMask | ExposureMask;
     374        mask = CWBackPixel | CWBorderPixel | CWColormap | CWEventMask;
     375        pClient->xWindow = XCreateWindow(pClient->dpy,
     376                                        RootWindow(pClient->dpy, screen_num),
     377                                        0, 0, pClient->winWidth, pClient->winHeight, 0,
     378                                        visinfo->depth, InputOutput,
     379                                        visinfo->visual, mask, &attr);
     380    }
     381    XResizeWindow(pClient->dpy, pClient->xWindow, pClient->winWidth, pClient->winHeight);
     382    pClient->glxContext = pClient->glxCreateNewContext(pClient->dpy, fbConfig, GLX_RGBA_TYPE, NULL, True);
     383
     384    XMapWindow(pClient->dpy, pClient->xWindow);
     385    XIfEvent(pClient->dpy, &event, WaitForNotify, (XPointer)pClient->xWindow );
     386    //glrc = pClient->getContextIDPtr(ctx);
     387    glrc = 1;
     388    Assert(glrc);
     389#else
     390    AssertFailed();
     391    glrc = 0;
     392#endif
     393
     394    pClient->lastretval = (uint64_t)glrc;
     395    pClient->fHasLastError = true;
     396    pClient->ulLastError   = glGetError();
    74397}
    75398
    76399void vboxglDrvDeleteContext(VBOXOGLCTX *pClient, uint8_t *pCmdBuffer)
    77400{
     401    //GLXContext ctx;
    78402    OGL_CMD(DrvDeleteContext, 1);
    79403    OGL_PARAM(HGLRC, hglrc);
    80     /** @todo */
    81     pClient->lastretval = 0; /** @todo */
     404    Log(("DrvDeleteContext %x\n", hglrc));
     405    //ctx = pClient->importContextEXTPtr(pClient->dpy, hglrc);
     406    glXDestroyContext(pClient->dpy, VBOX_OGL_GUEST_TO_HOST_HDC(hglrc));
     407    pClient->lastretval = 1;
     408    pClient->fHasLastError = true;
     409    pClient->ulLastError   = glGetError();
    82410}
    83411
    84412void vboxglDrvSetContext(VBOXOGLCTX *pClient, uint8_t *pCmdBuffer)
    85413{
     414    //GLXContext ctx;
    86415    OGL_CMD(DrvSetContext, 2);
    87416    OGL_PARAM(HDC, hdc);
    88417    OGL_PARAM(HGLRC, hglrc);
    89 
    90     pClient->lastretval = 0; /** @todo */
     418    Log(("DrvSetContext %x %x\n", hdc, hglrc));
     419#ifdef VBOX_OGL_DEBUG_WINDOW_OUTPUT
     420    //ctx = pClient->importContextEXTPtr(pClient->dpy, hglrc);
     421    pClient->lastretval = glXMakeCurrent(pClient->dpy, pClient->xWindow,
     422                                         VBOX_OGL_GUEST_TO_HOST_HDC(hglrc));
     423    if (!pClient->lastretval)
     424        Log(("glXMakeCurrent failed\n"));
     425    pClient->fHasLastError = true;
     426    pClient->ulLastError   = glGetError();
     427#else
     428    AssertFailed();
     429#endif
    91430}
    92431
    93432void vboxglDrvCopyContext(VBOXOGLCTX *pClient, uint8_t *pCmdBuffer)
    94433{
     434    //GLXContext ctxSrc, ctxDst;
    95435    OGL_CMD(DrvDeleteContext, 3);
    96436    OGL_PARAM(HGLRC, hglrcSrc);
    97437    OGL_PARAM(HGLRC, hglrcDst);
    98438    OGL_PARAM(UINT,  mask);
    99     pClient->lastretval = 0; /** @todo */
     439    Log(("DrvCopyContext %x %x %x\n", hglrcSrc, hglrcDst, mask));
     440    //ctxSrc = pClient->importContextEXTPtr(pClient->dpy, hglrcSrc);
     441    //ctxDst = pClient->importContextEXTPtr(pClient->dpy, hglrcDst);
     442    glXCopyContext(pClient->dpy, VBOX_OGL_GUEST_TO_HOST_HDC(hglrc), VBOX_OGL_GUEST_TO_HOST_HDC(hglrc), mask);
     443    pClient->lastretval = 1;
     444    pClient->fHasLastError = true;
     445    pClient->ulLastError   = glGetError();
    100446}
    101447
     
    104450    OGL_CMD(DrvReleaseContext, 1);
    105451    OGL_PARAM(HGLRC, hglrc);
     452    Log(("DrvReleaseContext %x\n", hglrc));
     453    /* clear current selection */
     454    pClient->lastretval = glXMakeCurrent(pClient->dpy, 0, NULL);
     455
     456    if (!pClient->lastretval)
     457        Log(("glXMakeCurrent failed\n"));
     458    pClient->fHasLastError = true;
     459    pClient->ulLastError   = glGetError();
     460}
     461
     462void vboxglDrvCreateLayerContext(VBOXOGLCTX *pClient, uint8_t *pCmdBuffer)
     463{
     464    OGL_CMD(DrvCreateLayerContext, 2);
     465    OGL_PARAM(HDC, hdc);
     466    OGL_PARAM(int, iLayerPlane);
     467
     468    Log(("DrvCreateLayerContext %x\n", hdc));
     469#ifdef VBOX_OGL_DEBUG_WINDOW_OUTPUT
    106470    pClient->lastretval = 0; /** @todo */
    107 }
    108 
    109 void vboxglDrvCreateLayerContext(VBOXOGLCTX *pClient, uint8_t *pCmdBuffer)
    110 {
    111     OGL_CMD(DrvCreateLayerContext, 5);
    112     OGL_PARAM(HDC, hdc);
    113     OGL_PARAM(int, iLayerPlane);
    114     OGL_PARAM(uint32_t, cx);
    115     OGL_PARAM(uint32_t, cy);
    116     OGL_PARAM(BYTE, cColorBits);
    117     OGL_PARAM(BYTE, iPixelType);
    118     OGL_PARAM(BYTE, cDepthBits);
     471    pClient->fHasLastError = true;
     472    pClient->ulLastError   = glGetError();
     473#else
    119474    AssertFailed();
    120     /** @todo create memory dc with the parameters above */
    121     pClient->lastretval = 0; /** @todo */
     475#endif
    122476}
    123477
     
    128482    OGL_PARAM(HGLRC, hglrc2);
    129483    pClient->lastretval = 0; /** @todo */
     484    pClient->fHasLastError = true;
     485    pClient->ulLastError   = glGetError();
    130486}
    131487
     
    138494    OGL_PARAM(BOOL, bRealize);
    139495    pClient->lastretval = 0; /** @todo */
     496    pClient->fHasLastError = true;
     497    pClient->ulLastError   = glGetError();
    140498}
    141499
     
    146504    OGL_PARAM(UINT, fuPlanes);
    147505    pClient->lastretval = 0; /** @todo */
     506    pClient->fHasLastError = true;
     507    pClient->ulLastError   = glGetError();
    148508}
    149509
    150510void vboxglDrvSetPixelFormat(VBOXOGLCTX *pClient, uint8_t *pCmdBuffer)
    151511{
    152     OGL_CMD(DrvSetPixelFormat, 2);
     512    int screen_num;
     513    OGL_CMD(DrvSetPixelFormat, 4);
    153514    OGL_PARAM(HDC, hdc);
    154515    OGL_PARAM(int, iPixelFormat);
    155 
    156     pClient->lastretval = 0; /** @todo */
     516    OGL_PARAM(uint32_t, cx);
     517    OGL_PARAM(uint32_t, cy);
     518
     519    Log(("vboxDrvSetPixelFormat %d\n", iPixelFormat));
     520
     521    /* Get GLXFBConfig based on the given ID */
     522    pClient->actFBConfig = pClient->PixelFormatToFBConfigMapper[iPixelFormat-1];
     523    screen_num = DefaultScreen(pClient->dpy);
     524    PrintFBConfigInfo(pClient->dpy, screen_num, pClient->actFBConfig);
     525    Log(("Window width: %d Window height: %d\n", cx, cy));
     526    pClient->winWidth = cx;
     527    pClient->winHeight = cy;
     528    pClient->lastretval = true;
     529    pClient->fHasLastError = true;
     530    pClient->ulLastError   = glGetError();
    157531}
    158532
     
    162536    OGL_PARAM(HDC, hdc);
    163537
    164     pClient->lastretval = 0; /** @todo */
     538    glXSwapBuffers(pClient->dpy, pClient->xWindow);
     539    pClient->lastretval = 1;
     540    pClient->fHasLastError = true;
     541    pClient->ulLastError   = glGetError();
    165542}
    166543
     
    178555
    179556    pClient->lastretval = 0; /** @todo */
     557    pClient->fHasLastError = true;
     558    pClient->ulLastError   = glGetError();
    180559}
    181560
     
    189568    OGL_MEMPARAM(COLORREF, pcr);
    190569    pClient->lastretval = 0; /** @todo */
     570    pClient->fHasLastError = true;
     571    pClient->ulLastError   = glGetError();
    191572}
    192573
     
    204585    pcr = (COLORREF *)pClient->pLastParam;
    205586    pClient->lastretval = 0; /** @todo */
     587    pClient->fHasLastError = true;
     588    pClient->ulLastError   = glGetError();
    206589}
    207590
     
    209592{
    210593    LPPIXELFORMATDESCRIPTOR ppfd;
     594    GLXFBConfig *allFBConfigs, matchingFBConfig;
     595    int screenNum, glxReturnValue;
    211596
    212597    OGL_CMD(DrvDescribePixelFormat, 3);
     
    217602    ppfd = (LPPIXELFORMATDESCRIPTOR)pClient->pLastParam;
    218603
    219     pClient->lastretval = 0; /** @todo */
     604    Log(("iPixelFormat: %d\n", iPixelFormat));
     605
     606    if (!pClient->PixelFormatToFBConfigMapper) {
     607        /* First get number of all visuals for the return value */
     608        screenNum = DefaultScreen(pClient->dpy);
     609        allFBConfigs = glXGetFBConfigs(pClient->dpy, screenNum,
     610                                            &pClient->numFBConfigs);
     611        pClient->PixelFormatToFBConfigMapper = allFBConfigs;
     612    }
     613
     614    if (nBytes == sizeof(PIXELFORMATDESCRIPTOR)) {
     615        int redSize, greenSize, blueSize, alphaSize, xVisual, xRenderable;
     616        /* Get GLXFBConfig which matches iPixelFormat */
     617        matchingFBConfig = pClient->PixelFormatToFBConfigMapper[iPixelFormat-1];
     618
     619        Log(("Filling values into PIXELFORMATDESCRIPTOR\n"));
     620        /* translate all values to theire corresponding Windows ones */
     621        ppfd->nSize = sizeof(PIXELFORMATDESCRIPTOR);
     622        ppfd->nVersion = 1;
     623        ppfd->iLayerType = PFD_MAIN_PLANE;
     624        ppfd->dwFlags =  0;
     625
     626        /* Set cColorBits */
     627        glXGetFBConfigAttrib(pClient->dpy, matchingFBConfig, GLX_RED_SIZE, &redSize);
     628        glXGetFBConfigAttrib(pClient->dpy, matchingFBConfig, GLX_GREEN_SIZE, &greenSize);
     629        glXGetFBConfigAttrib(pClient->dpy, matchingFBConfig, GLX_BLUE_SIZE, &blueSize);
     630        glXGetFBConfigAttrib(pClient->dpy, matchingFBConfig, GLX_ALPHA_SIZE, &alphaSize);
     631        ppfd->cColorBits = redSize + greenSize + blueSize;
     632        ppfd->cRedBits = redSize;
     633        ppfd->cBlueBits = blueSize;
     634        ppfd->cGreenBits = greenSize;
     635        ppfd->cAlphaBits = alphaSize;
     636
     637        /* Set dwFlags */
     638        if (!glXGetFBConfigAttrib(pClient->dpy, matchingFBConfig, GLX_DRAWABLE_TYPE, &glxReturnValue)) {
     639            glXGetFBConfigAttrib(pClient->dpy, matchingFBConfig, GLX_VISUAL_ID, &xVisual);
     640            glXGetFBConfigAttrib(pClient->dpy, matchingFBConfig, GLX_X_RENDERABLE, &xRenderable);
     641            if ((glxReturnValue & GLX_WINDOW_BIT) && xVisual)
     642                ppfd->dwFlags |= (PFD_DRAW_TO_WINDOW | PFD_SUPPORT_OPENGL);
     643        }
     644        if (!glXGetFBConfigAttrib(pClient->dpy, matchingFBConfig, GLX_DOUBLEBUFFER, &glxReturnValue)) {
     645            if (glxReturnValue)
     646                ppfd->dwFlags |= PFD_DOUBLEBUFFER;
     647        }
     648        /* Set iPixelType */
     649        if (!glXGetFBConfigAttrib(pClient->dpy, matchingFBConfig, GLX_RENDER_TYPE, &glxReturnValue)) {
     650            if (glxReturnValue & GLX_RGBA_BIT)
     651                ppfd->iPixelType = PFD_TYPE_RGBA;
     652            else if ((glxReturnValue & GLX_COLOR_INDEX_BIT) & !(glxReturnValue & GLX_RGBA_BIT))
     653                ppfd->iPixelType = PFD_TYPE_COLORINDEX;
     654        }
     655        /* Set cDepthBits */
     656        if (!glXGetFBConfigAttrib(pClient->dpy, matchingFBConfig, GLX_DEPTH_SIZE, &glxReturnValue)) {
     657            ppfd->cDepthBits = glxReturnValue;
     658        } else {
     659            ppfd->cDepthBits = 0;
     660        }
     661        /* Set cStencilBits */
     662        if (!glXGetFBConfigAttrib(pClient->dpy, matchingFBConfig, GLX_STENCIL_SIZE, &glxReturnValue)) {
     663            ppfd->cStencilBits = glxReturnValue;
     664        } else {
     665            ppfd->cStencilBits = 0;
     666        }
     667        /** @todo Fill in the rest */
     668    }
     669
     670    pClient->lastretval = pClient->numFBConfigs;
     671    pClient->fHasLastError = true;
     672    pClient->ulLastError   = glGetError();
    220673}
    221674
    222675RTUINTPTR vboxDrvIsExtensionAvailable(char *pszExtFunctionName)
    223676{
    224     return 0;
    225 }
    226 
     677    RTUINTPTR pfnProc = (RTUINTPTR)glXGetProcAddress((const GLubyte *)pszExtFunctionName);
     678    Log(("vboxDrvIsExtensionAvailable %s -> %d\n", pszExtFunctionName, !!pfnProc));
     679    return pfnProc;
     680}
     681
  • trunk/src/VBox/HostServices/SharedOpenGL/glwindrv.cpp

    r3698 r3708  
    105105    PIXELFORMATDESCRIPTOR pfd;
    106106    int iFormat;
     107    /** @todo should NOT use the desktop window -> crashes the Intel OpenGL driver */
    107108    HDC hdc = GetDC(0);
    108109
     
    131132
    132133/**
     134 * Enable OpenGL
     135 *
     136 * @returns VBox error code
     137 * @param   pClient         Client context
     138 */
     139int vboxglEnableOpenGL(PVBOXOGLCTX pClient)
     140{
     141    PIXELFORMATDESCRIPTOR pfd;
     142    int iFormat;
     143
     144    /** @todo should NOT use the desktop window -> crashes the Intel OpenGL driver */
     145    pClient->enable.hdc = GetDC(0);
     146
     147    ZeroMemory(&pfd, sizeof(pfd));
     148    pfd.nSize       = sizeof(pfd);
     149    pfd.nVersion    = 1;
     150    pfd.dwFlags     = PFD_DRAW_TO_WINDOW | PFD_SUPPORT_OPENGL | PFD_DOUBLEBUFFER;
     151    pfd.iPixelType  = PFD_TYPE_RGBA;
     152    pfd.cColorBits  = 24;
     153    pfd.cDepthBits  = 16;
     154    pfd.iLayerType  = PFD_MAIN_PLANE;
     155    iFormat         = ChoosePixelFormat(pClient->enable.hdc, &pfd);
     156    SetPixelFormat(pClient->enable.hdc, iFormat, &pfd);
     157
     158    pClient->enable.hglrc = wglCreateContext(pClient->enable.hdc);
     159    wglMakeCurrent(pClient->enable.hdc, pClient->enable.hglrc);
     160    return VINF_SUCCESS;
     161}
     162
     163
     164/**
     165 * Disable OpenGL
     166 *
     167 * @returns VBox error code
     168 * @param   pClient         Client context
     169 */
     170int vboxglDisableOpenGL(PVBOXOGLCTX pClient)
     171{
     172    wglMakeCurrent(NULL, NULL);
     173    wglDeleteContext(pClient->enable.hglrc);
     174    ReleaseDC(0, pClient->enable.hdc);
     175    return VINF_SUCCESS;
     176}
     177
     178/**
    133179 * Client connect init
    134180 *
  • trunk/src/VBox/HostServices/SharedOpenGL/service.cpp

    r3468 r3708  
    287287                else
    288288                {
     289#ifdef __WIN__
    289290                    /* Execute the function. */
    290291                    if (vboxwglGetProcAddress(pszExtFnName))
     
    292293                    else
    293294                        rc = VERR_FILE_NOT_FOUND;
    294 
     295#else
     296                        rc = VERR_FILE_NOT_FOUND;
     297#endif
    295298                    if (VBOX_SUCCESS(rc))
    296299                    {
  • trunk/src/VBox/HostServices/SharedOpenGL/vboxgl.cpp

    r3698 r3708  
    3131#include <VBox/log.h>
    3232
    33 
    34 
    3533/**
    3634 * glGetString implementation
     
    4846    int      rc = VINF_SUCCESS;
    4947
    50 #ifdef RT_OS_WINDOWS
    51     PIXELFORMATDESCRIPTOR pfd;
    52     int iFormat;
    53     HDC hdc = GetDC(0);
    54 
    55     ZeroMemory(&pfd, sizeof(pfd));
    56     pfd.nSize       = sizeof(pfd);
    57     pfd.nVersion    = 1;
    58     pfd.dwFlags     = PFD_DRAW_TO_WINDOW | PFD_SUPPORT_OPENGL | PFD_DOUBLEBUFFER;
    59     pfd.iPixelType  = PFD_TYPE_RGBA;
    60     pfd.cColorBits  = 24;
    61     pfd.cDepthBits  = 16;
    62     pfd.iLayerType  = PFD_MAIN_PLANE;
    63     iFormat         = ChoosePixelFormat(hdc, &pfd);
    64     SetPixelFormat(hdc, iFormat, &pfd);
    65 
    66     HGLRC hRC = wglCreateContext(hdc);
    67     wglMakeCurrent(hdc, hRC);
    68 #endif
     48    vboxglEnableOpenGL(pClient);
    6949
    7050    pName = glGetString(name);
     
    8767end:
    8868
    89 #ifdef RT_OS_WINDOWS
    90     wglMakeCurrent(NULL, NULL);
    91     wglDeleteContext(hRC);
    92     ReleaseDC(0, hdc);
    93 #endif
     69    vboxglDisableOpenGL(pClient);
    9470    return rc;
    9571}
  • trunk/src/VBox/HostServices/SharedOpenGL/vboxgl.h

    r3698 r3708  
    9393 * @param   pszFunctionName     OpenGL extension function name
    9494 */
     95#ifdef RT_OS_WINDOWS
    9596bool vboxwglGetProcAddress(char *pszFunctionName);
    96 
     97#endif
    9798
    9899/* OpenGL wrappers */
     
    352353void vboxglGetTexImage (VBOXOGLCTX *pClient, uint8_t *pCmdBuffer);
    353354
     355#ifdef RT_OS_WINDOWS
    354356void vboxwglSwapIntervalEXT (VBOXOGLCTX *pClient, uint8_t *pCmdBuffer);
    355357void vboxwglGetSwapIntervalEXT (VBOXOGLCTX *pClient, uint8_t *pCmdBuffer);
     358#endif
    356359
    357360/* after the above */
Note: See TracChangeset for help on using the changeset viewer.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette