web-dev-qa-db-fra.com

pas en mesure d'exécuter glxdemo à partir de l'intérieur du conteneur lxc à l'aide de nvidia

J'ai créé le conteneur lxc de notre chaîne d'outils personnalisée qui contient de nombreux packages. En ce qui concerne les graphiques, j'ai installé le pilote nvidia 367.27 à l'aide du programme d'installation nvidia dans ce conteneur (appelé mk7icontainer).

Les bibliothèques/fichiers binaires du pilote nvidia sont installés sur le chemin /usr/share/nvidia chemin dans ce conteneur.

J'ai également installé mesa installé dans le chemin /usr à l'intérieur du conteneur.

J'ai compilé le code source glxdemo en utilisant la commande suivante:

gcc -g glxdemo.c -Wl,--rpath-link,/usr/share/nvidia/lib -Wl,-rpath,/usr/share/nvidia/lib \
-Wl,--rpath-link,/usr/share/nvidia/lib/tls -Wl,-rpath,/usr/share/nvidia/lib/tls \
-Wl,--rpath-link,/usr/share/nvidia/lib/vdpau  -Wl,-rpath,/usr/share/nvidia/lib/vdpau \
-Wl,--rpath-link,/usr/share/nvidia/lib/xorg/modules -Wl,-rpath,/usr/share/nvidia/lib/xorg/modules \
-Wl,--rpath-link,/usr/share/nvidia/lib/xorg/modules/drivers -Wl,-rpath,/usr/share/nvidia/lib/xorg/modules/drivers \
-Wl,--rpath-link,/usr/share/nvidia/lib/xorg/modules/extensions -Wl,-rpath,/usr/share/nvidia/lib/xorg/modules/extensions -lX11 -lGL -lGLU -lglut -lm -o glxdemo

À l'intérieur du conteneur, j'ai

DISPLAY=":0"
XAUTHORITY=/root/.Xauthority

Je lance le bash dans le conteneur en utilisant la commande ci-dessous:

Sudo lxc-attach -n mk7icontainer --clear-env  -- /usr/bin/bash

Mon ordinateur hôte exécute Ubuntu 16.0.4 et j'ai installé le même pilote nvidia 367.27 à l'aide de son programme d'installation. Il fonctionne bien. Je peux même exécuter glxdemo sur la machine hôte sans aucun problème.

Cependant, lorsque j'essaie d'exécuter glxdemo à l'intérieur du conteneur (compilé à l'aide de la commande mentionnée ci-dessus), le message d'erreur suivant s'affiche:

X Error of failed request:  BadValue (integer parameter out of range for operation)
Major opcode of failed request:  154 (GLX)
Minor opcode of failed request:  3 (X_GLXCreateContext)
Value in failed request:  0x0
Serial number of failed request:  24
Current serial number in output stream:  25

quelqu'un a une idée de ce qui ne va pas ici?

Je veux aussi savoir comment lire ces erreurs pour réduire le problème.

Le code source de glxdemo est:

#include <GL/gl.h>
#include <GL/glx.h>
#include <stdio.h>
#include <stdlib.h>
static void redraw( Display *dpy, Window w )
{
   printf("Redraw event\n");
   glClear( GL_COLOR_BUFFER_BIT );

   glColor3f( 1.0, 1.0, 0.0 );
   glRectf( -0.8, -0.8, 0.8, 0.8 );
   glXSwapBuffers( dpy, w );
}

static void resize( unsigned int width, unsigned int height )
{
   printf("Resize event\n");
   glViewport( 0, 0, width, height );
   glMatrixMode( GL_PROJECTION );
   glLoadIdentity();
   glOrtho( -1.0, 1.0, -1.0, 1.0, -1.0, 1.0 );
}

static Window make_rgb_db_window( Display *dpy,
                              unsigned int width, unsigned int height )
{
   int attrib[] = { GLX_RGBA,
                    GLX_RED_SIZE, 1,
                    GLX_GREEN_SIZE, 1,
                    GLX_BLUE_SIZE, 1,
                    GLX_DOUBLEBUFFER,
                    None };
   int scrnum;
   XSetWindowAttributes attr;
   unsigned long mask;
   Window root;
   Window win;
   GLXContext ctx;
   XVisualInfo *visinfo;

   scrnum = DefaultScreen( dpy );
   root = RootWindow( dpy, scrnum );

   visinfo = glXChooseVisual( dpy, scrnum, attrib );
   if (!visinfo) {
      printf("Error: couldn't get an RGB, Double-buffered visual\n");
      exit(1);
   }

   /* window attributes */
   attr.background_pixel = 0;
   attr.border_pixel = 0;
   attr.colormap = XCreateColormap( dpy, root, visinfo->visual, AllocNone);
   attr.event_mask = StructureNotifyMask | ExposureMask;
   mask = CWBackPixel | CWBorderPixel | CWColormap | CWEventMask;

   win = XCreateWindow( dpy, root, 0, 0, width, height,
                    0, visinfo->depth, InputOutput,
                    visinfo->visual, mask, &attr );

   printf("\n XCreateWindow successfull \n");
   ctx = glXCreateContext( dpy, visinfo, NULL, True );
   if (!ctx) {
      printf("Error: glXCreateContext failed\n");
      exit(1);
   }

        printf("\n glXCreateContext successfull \n");

   glXMakeCurrent( dpy, win, ctx );

   return win;
}

static void event_loop( Display *dpy )
{
   XEvent event;

   while (1) {
      XNextEvent( dpy, &event );

      switch (event.type) {
         case Expose:
            redraw( dpy, event.xany.window );
            break;
         case ConfigureNotify:
            resize( event.xconfigure.width, event.xconfigure.height );
            break;
      }
   }
}

int main( int argc, char *argv[] )
{
   Display *dpy;
   Window win;

   dpy = XOpenDisplay(NULL);
        if(!dpy)
        {
                printf("\nError in XOpenDisplay\n");
        }
        printf("\nXOpenDisplay successfull\n");

   win = make_rgb_db_window( dpy, 300, 300 );

   printf("\nmake_rgb_db_window successfull \n");
   glShadeModel( GL_FLAT );
   glClearColor( 0.5, 0.5, 0.5, 1.0 );

   XMapWindow( dpy, win );

   event_loop( dpy );
   return 0;
}
2
Monku

J'ai pu résoudre ce problème.

Je devais ajouter nvidia nœuds de périphérique dans le fichier de configuration lxc container.

lxc.cgroup.devices.allow = c 195:* rwm
lxc.mount.entry = /dev/nvidia0 dev/nvidia0 none bind,optional,create=file
lxc.mount.entry = /dev/nvidiactl dev/nvidiactl none bind,optional,create=file
lxc.mount.entry = /dev/nvidia-modeset dev/nvidia-modeset none bind,optional,create=file
1
Monku