pingou / rpms / mesa

Forked from rpms/mesa 6 years ago
Clone
2741728
diff -up Mesa-7.0/src/mesa/tnl/t_vertex_sse.c.jx Mesa-7.0/src/mesa/tnl/t_vertex_sse.c
2741728
--- Mesa-7.0/src/mesa/tnl/t_vertex_sse.c.jx	2007-06-21 18:10:54.000000000 -0400
2741728
+++ Mesa-7.0/src/mesa/tnl/t_vertex_sse.c	2007-07-23 15:59:26.000000000 -0400
2741728
@@ -348,7 +348,8 @@ static GLboolean build_vertex_emit( stru
2741728
    struct x86_reg vp1 = x86_make_reg(file_XMM, 2);
2741728
    GLubyte *fixup, *label;
2741728
 
2741728
-   x86_init_func(&p->func);
2741728
+   if (!x86_init_func(&p->func))
2741728
+       return GL_FALSE;
2741728
    
2741728
    /* Push a few regs?
2741728
     */
2741728
@@ -646,7 +647,10 @@ void _tnl_generate_sse_emit( GLcontext *
2741728
    p.identity = x86_make_reg(file_XMM, 6);
2741728
    p.chan0 = x86_make_reg(file_XMM, 7);
2741728
 
2741728
-   x86_init_func(&p.func);
2741728
+   if (!x86_init_func(&p.func)) {
2741728
+      vtx->codegen_emit = NULL;
2741728
+      return;
2741728
+   }
2741728
 
2741728
    if (build_vertex_emit(&p)) {
2741728
       _tnl_register_fastpath( vtx, GL_TRUE );
2741728
diff -up Mesa-7.0/src/mesa/x86/rtasm/x86sse.h.jx Mesa-7.0/src/mesa/x86/rtasm/x86sse.h
2741728
--- Mesa-7.0/src/mesa/x86/rtasm/x86sse.h.jx	2007-06-21 18:10:55.000000000 -0400
2741728
+++ Mesa-7.0/src/mesa/x86/rtasm/x86sse.h	2007-07-23 15:59:23.000000000 -0400
2741728
@@ -80,8 +80,8 @@ enum sse_cc {
Kristian Høgsberg 1b24297
  */
182f8fe
 
182f8fe
 
Kristian Høgsberg 1b24297
-void x86_init_func( struct x86_function *p );
Kristian Høgsberg 1b24297
-void x86_init_func_size( struct x86_function *p, GLuint code_size );
Kristian Høgsberg 1b24297
+int x86_init_func( struct x86_function *p );
Kristian Høgsberg 1b24297
+int x86_init_func_size( struct x86_function *p, GLuint code_size );
Kristian Høgsberg 1b24297
 void x86_release_func( struct x86_function *p );
Kristian Høgsberg 1b24297
 void (*x86_get_func( struct x86_function *p ))( void );
Kristian Høgsberg 1b24297
 
2741728
diff -up Mesa-7.0/src/mesa/x86/rtasm/x86sse.c.jx Mesa-7.0/src/mesa/x86/rtasm/x86sse.c
2741728
--- Mesa-7.0/src/mesa/x86/rtasm/x86sse.c.jx	2007-06-21 18:10:55.000000000 -0400
2741728
+++ Mesa-7.0/src/mesa/x86/rtasm/x86sse.c	2007-07-23 15:59:23.000000000 -0400
2741728
@@ -1063,15 +1063,17 @@ struct x86_reg x86_fn_arg( struct x86_fu
Kristian Høgsberg 1b24297
 }
Kristian Høgsberg 1b24297
 
Kristian Høgsberg 1b24297
 
Kristian Høgsberg 1b24297
-void x86_init_func( struct x86_function *p )
Kristian Høgsberg 1b24297
+int x86_init_func( struct x86_function *p )
Kristian Høgsberg 1b24297
 {
Kristian Høgsberg 1b24297
-   x86_init_func_size(p, 1024);
Kristian Høgsberg 1b24297
+   return x86_init_func_size(p, 1024);
Kristian Høgsberg 1b24297
 }
Kristian Høgsberg 1b24297
 
Kristian Høgsberg 1b24297
-void x86_init_func_size( struct x86_function *p, GLuint code_size )
Kristian Høgsberg 1b24297
+int x86_init_func_size( struct x86_function *p, GLuint code_size )
Kristian Høgsberg 1b24297
 {
Kristian Høgsberg 1b24297
    p->store = _mesa_exec_malloc(code_size);
Kristian Høgsberg 1b24297
    p->csr = p->store;
Kristian Høgsberg 1b24297
+
Kristian Høgsberg 1b24297
+   return (p->store != NULL);
Kristian Høgsberg 1b24297
 }
Kristian Høgsberg 1b24297
 
Kristian Høgsberg 1b24297
 void x86_release_func( struct x86_function *p )
2741728
diff -up Mesa-7.0/src/mesa/main/execmem.c.jx Mesa-7.0/src/mesa/main/execmem.c
2741728
--- Mesa-7.0/src/mesa/main/execmem.c.jx	2007-06-21 18:10:54.000000000 -0400
2741728
+++ Mesa-7.0/src/mesa/main/execmem.c	2007-07-23 16:02:30.000000000 -0400
182f8fe
@@ -46,6 +46,7 @@
182f8fe
 #include <unistd.h>
182f8fe
 #include <sys/mman.h>
182f8fe
 #include "mm.h"
182f8fe
+#include <selinux/selinux.h>
182f8fe
 
182f8fe
 #define EXEC_HEAP_SIZE (10*1024*1024)
182f8fe
 
2741728
@@ -55,9 +56,16 @@ static struct mem_block *exec_heap = NUL
182f8fe
 static unsigned char *exec_mem = NULL;
182f8fe
 
182f8fe
 
182f8fe
-static void
182f8fe
+static int
182f8fe
 init_heap(void)
182f8fe
 {
182f8fe
+
182f8fe
+   if (is_selinux_enabled()) {
182f8fe
+      if (!security_get_boolean_active("allow_execmem") ||
182f8fe
+	  !security_get_boolean_pending("allow_execmem"))
2741728
+      return 0;
182f8fe
+   }
182f8fe
+
182f8fe
    if (!exec_heap)
182f8fe
       exec_heap = mmInit( 0, EXEC_HEAP_SIZE );
182f8fe
    
2741728
@@ -65,6 +73,8 @@ init_heap(void)
182f8fe
       exec_mem = (unsigned char *) mmap(0, EXEC_HEAP_SIZE, 
182f8fe
 					PROT_EXEC | PROT_READ | PROT_WRITE, 
182f8fe
 					MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);
182f8fe
+
182f8fe
+   return (exec_mem != NULL);
182f8fe
 }
182f8fe
 
182f8fe
 
2741728
@@ -76,7 +86,8 @@ _mesa_exec_malloc(GLuint size)
182f8fe
 
182f8fe
    _glthread_LOCK_MUTEX(exec_mutex);
182f8fe
 
182f8fe
-   init_heap();
182f8fe
+   if (!init_heap())
Kristian Høgsberg 1b24297
+      goto bail;
182f8fe
 
182f8fe
    if (exec_heap) {
182f8fe
       size = (size + 31) & ~31;
2741728
@@ -87,7 +98,8 @@ _mesa_exec_malloc(GLuint size)
Kristian Høgsberg 1b24297
       addr = exec_mem + block->ofs;
Kristian Høgsberg 1b24297
    else 
Kristian Høgsberg 1b24297
       _mesa_printf("_mesa_exec_malloc failed\n");
Kristian Høgsberg 1b24297
-   
182f8fe
+
2741728
+bail: 
Kristian Høgsberg 1b24297
    _glthread_UNLOCK_MUTEX(exec_mutex);
Kristian Høgsberg 1b24297
    
Kristian Høgsberg 1b24297
    return addr;
2741728
diff -up Mesa-7.0/configs/linux-dri.jx Mesa-7.0/configs/linux-dri
2741728
--- Mesa-7.0/configs/linux-dri.jx	2007-07-23 15:59:07.000000000 -0400
2741728
+++ Mesa-7.0/configs/linux-dri	2007-07-23 17:37:36.000000000 -0400
2741728
@@ -39,7 +39,8 @@ EXTRA_LIB_PATH =
Kristian Høgsberg 1b24297
 
Kristian Høgsberg 1b24297
 LIBDRM_CFLAGS = `pkg-config --cflags libdrm`
Kristian Høgsberg 1b24297
 LIBDRM_LIB = `pkg-config --libs libdrm`
Kristian Høgsberg 1b24297
-DRI_LIB_DEPS  = $(EXTRA_LIB_PATH) -lm -lpthread -lexpat -ldl $(LIBDRM_LIB)
Kristian Høgsberg 1b24297
+DRI_LIB_DEPS  = $(EXTRA_LIB_PATH) -lm -lpthread -lexpat -ldl $(LIBDRM_LIB) \
Kristian Høgsberg 1b24297
+		-lselinux
2741728
 GL_LIB_DEPS   = $(EXTRA_LIB_PATH) -lX11 -lXext -lXxf86vm -lXdamage -lXfixes \
2741728
 		-lm -lpthread -ldl \
Kristian Høgsberg 1b24297
                 $(LIBDRM_LIB)
a427a13
diff -up Mesa-7.1pre/configs/linux-osmesa16.BAD Mesa-7.1pre/configs/linux-osmesa16
a427a13
--- Mesa-7.1pre/configs/linux-osmesa16.BAD	2007-11-15 14:56:18.000000000 -0500
a427a13
+++ Mesa-7.1pre/configs/linux-osmesa16	2007-11-15 14:56:35.000000000 -0500
a427a13
@@ -26,6 +26,6 @@ PROGRAM_DIRS = 
a427a13
 
a427a13
 
a427a13
 # Dependencies
a427a13
-OSMESA_LIB_DEPS = -lm -lpthread
a427a13
+OSMESA_LIB_DEPS = -lm -lpthread -lselinux
a427a13
 GLU_LIB_DEPS = -L$(TOP)/$(LIB_DIR) -l$(OSMESA_LIB)
a427a13
 APP_LIB_DEPS = -lOSMesa16
a427a13
diff -up Mesa-7.1pre/configs/linux-osmesa32.BAD Mesa-7.1pre/configs/linux-osmesa32
a427a13
--- Mesa-7.1pre/configs/linux-osmesa32.BAD	2007-11-15 14:55:35.000000000 -0500
a427a13
+++ Mesa-7.1pre/configs/linux-osmesa32	2007-11-15 14:55:44.000000000 -0500
a427a13
@@ -26,6 +26,6 @@ PROGRAM_DIRS = 
a427a13
 
a427a13
 
a427a13
 # Dependencies
a427a13
-OSMESA_LIB_DEPS = -lm -lpthread
a427a13
+OSMESA_LIB_DEPS = -lm -lpthread -lselinux
a427a13
 GLU_LIB_DEPS = -L$(TOP)/$(LIB_DIR) -l$(OSMESA_LIB)
a427a13
 APP_LIB_DEPS = -lOSMesa32
a427a13
diff -up Mesa-7.1pre/configs/linux-osmesa.BAD Mesa-7.1pre/configs/linux-osmesa
a427a13
--- Mesa-7.1pre/configs/linux-osmesa.BAD	2007-11-15 15:00:23.000000000 -0500
a427a13
+++ Mesa-7.1pre/configs/linux-osmesa	2007-11-15 15:00:28.000000000 -0500
a427a13
@@ -23,6 +23,6 @@ PROGRAM_DIRS = osdemos
a427a13
 
a427a13
 
a427a13
 # Dependencies
a427a13
-OSMESA_LIB_DEPS = -lm -lpthread
a427a13
+OSMESA_LIB_DEPS = -lm -lpthread -lselinux
a427a13
 GLU_LIB_DEPS = -L$(TOP)/$(LIB_DIR) -l$(OSMESA_LIB)
a427a13
 APP_LIB_DEPS = -lOSMesa -lGLU