~ubuntu-branches/ubuntu/natty/mesa/natty-proposed

« back to all changes in this revision

Viewing changes to src/egl/main/eglscreen.c

  • Committer: Bazaar Package Importer
  • Author(s): Robert Hooker, Robert Hooker, Christopher James Halse Rogers
  • Date: 2010-09-14 08:55:40 UTC
  • mfrom: (1.2.28 upstream)
  • Revision ID: james.westby@ubuntu.com-20100914085540-m4fpl0hdjlfd4jgz
Tags: 7.9~git20100909-0ubuntu1
[ Robert Hooker ]
* New upstream git snapshot up to commit 94118fe2d4b1e5 (LP: #631413)
* New features include ATI HD5xxx series support in r600, and a vastly
  improved glsl compiler.
* Remove pre-generated .pc's, use the ones generated at build time
  instead.
* Remove all references to mesa-utils now that its no longer shipped
  with the mesa source.
* Disable the experimental ARB_fragment_shader option by default on
  i915, it exposes incomplete functionality that breaks KDE compositing
  among other things. It can be enabled via driconf still. (LP: #628930).

[ Christopher James Halse Rogers ]
* debian/patches/04_osmesa_version.diff:
  - Refresh for new upstream
* Bugs fixed in this release:
  - Fixes severe rendering corruption in Unity on radeon (LP: #628727,
    LP: #596292, LP: #599741, LP: #630315, LP: #613694, LP: #599741).
  - Also fixes rendering in gnome-shell (LP: #578619).
  - Flickering in OpenGL apps on radeon (LP: #626943, LP: #610541).
  - Provides preliminary support for new intel chips (LP: #601052).
* debian/rules:
  - Update configure flags to match upstream reshuffling.
  - Explicitly remove gallium DRI drivers that we don't want to ship.
* Update debian/gbp.conf for this Maverick-specific packaging
* libegl1-mesa-dri-x11,kms: There are no longer separate kms or x11 drivers
  for EGL, libegl1-mesa-drivers now contains a single driver that provides
  both backends.

Show diffs side-by-side

added added

removed removed

Lines of Context:
16
16
#include <string.h>
17
17
 
18
18
#include "egldisplay.h"
19
 
#include "eglglobals.h"
20
19
#include "eglcurrent.h"
21
20
#include "eglmode.h"
22
21
#include "eglconfig.h"
25
24
#include "eglmutex.h"
26
25
 
27
26
 
 
27
#ifdef EGL_MESA_screen_surface
 
28
 
 
29
 
 
30
/* ugh, no atomic op? */
 
31
static _EGL_DECLARE_MUTEX(_eglNextScreenHandleMutex);
 
32
static EGLScreenMESA _eglNextScreenHandle = 1;
 
33
 
 
34
 
28
35
/**
29
36
 * Return a new screen handle/ID.
30
37
 * NOTE: we never reuse these!
33
40
_eglAllocScreenHandle(void)
34
41
{
35
42
   EGLScreenMESA s;
36
 
   
37
 
   _eglLockMutex(_eglGlobal.Mutex);
38
 
   s = _eglGlobal.FreeScreenHandle++;
39
 
   _eglUnlockMutex(_eglGlobal.Mutex);
 
43
 
 
44
   _eglLockMutex(&_eglNextScreenHandleMutex);
 
45
   s = _eglNextScreenHandle++;
 
46
   _eglUnlockMutex(&_eglNextScreenHandleMutex);
40
47
 
41
48
   return s;
42
49
}
62
69
{
63
70
   EGLint i;
64
71
 
65
 
   for (i = 0; i < display->NumScreens; i++) {
66
 
      if (display->Screens[i]->Handle == screen)
67
 
         return display->Screens[i];
 
72
   if (!display || !display->Screens)
 
73
      return NULL;
 
74
 
 
75
   for (i = 0; i < display->Screens->Size; i++) {
 
76
      _EGLScreen *scr = (_EGLScreen *) display->Screens->Elements[i];
 
77
      if (scr->Handle == screen)
 
78
         return scr;
68
79
   }
69
80
   return NULL;
70
81
}
76
87
void
77
88
_eglAddScreen(_EGLDisplay *display, _EGLScreen *screen)
78
89
{
79
 
   EGLint n;
80
 
 
81
90
   assert(display);
82
91
   assert(screen);
83
92
 
 
93
   if (!display->Screens) {
 
94
      display->Screens = _eglCreateArray("Screen", 4);
 
95
      if (!display->Screens)
 
96
         return;
 
97
   }
84
98
   screen->Handle = _eglAllocScreenHandle();
85
 
   n = display->NumScreens;
86
 
   display->Screens = realloc(display->Screens, (n+1) * sizeof(_EGLScreen *));
87
 
   display->Screens[n] = screen;
88
 
   display->NumScreens++;
89
 
}
90
 
 
 
99
   _eglAppendArray(display->Screens, (void *) screen);
 
100
}
 
101
 
 
102
 
 
103
 
 
104
static EGLBoolean
 
105
_eglFlattenScreen(void *elem, void *buffer)
 
106
{
 
107
   _EGLScreen *scr = (_EGLScreen *) elem;
 
108
   EGLScreenMESA *handle = (EGLScreenMESA *) buffer;
 
109
   *handle = scr->Handle;
 
110
   return EGL_TRUE;
 
111
}
91
112
 
92
113
 
93
114
EGLBoolean
94
115
_eglGetScreensMESA(_EGLDriver *drv, _EGLDisplay *display, EGLScreenMESA *screens,
95
116
                   EGLint max_screens, EGLint *num_screens)
96
117
{
97
 
   EGLint n;
98
 
 
99
 
   if (display->NumScreens > max_screens) {
100
 
      n = max_screens;
101
 
   }
102
 
   else {
103
 
      n = display->NumScreens;
104
 
   }
105
 
 
106
 
   if (screens) {
107
 
      EGLint i;
108
 
      for (i = 0; i < n; i++)
109
 
         screens[i] = display->Screens[i]->Handle;
110
 
   }
111
 
   if (num_screens)
112
 
      *num_screens = n;
 
118
   *num_screens = _eglFlattenArray(display->Screens, (void *) screens,
 
119
         sizeof(screens[0]), max_screens, _eglFlattenScreen);
113
120
 
114
121
   return EGL_TRUE;
115
122
}
263
270
   free(scrn);
264
271
}
265
272
 
 
273
 
 
274
#endif /* EGL_MESA_screen_surface */