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

« back to all changes in this revision

Viewing changes to src/gallium/drivers/i965/brw_screen.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:
34
34
#include "brw_context.h"
35
35
#include "brw_screen.h"
36
36
#include "brw_winsys.h"
 
37
#include "brw_public.h"
37
38
#include "brw_debug.h"
 
39
#include "brw_resource.h"
38
40
 
39
41
#ifdef DEBUG
40
42
static const struct debug_named_value debug_names[] = {
41
 
   { "tex",   DEBUG_TEXTURE},
42
 
   { "state", DEBUG_STATE},
43
 
   { "ioctl", DEBUG_IOCTL},
44
 
   { "blit",  DEBUG_BLIT},
45
 
   { "curbe", DEBUG_CURBE},
46
 
   { "fall",  DEBUG_FALLBACKS},
47
 
   { "verb",  DEBUG_VERBOSE},
48
 
   { "bat",   DEBUG_BATCH},
49
 
   { "pix",   DEBUG_PIXEL},
50
 
   { "wins",  DEBUG_WINSYS},
51
 
   { "min",   DEBUG_MIN_URB},
52
 
   { "dis",   DEBUG_DISASSEM},
53
 
   { "sync",  DEBUG_SYNC},
54
 
   { "prim",  DEBUG_PRIMS },
55
 
   { "vert",  DEBUG_VERTS },
56
 
   { "dma",   DEBUG_DMA },
57
 
   { "san",   DEBUG_SANITY },
58
 
   { "sleep", DEBUG_SLEEP },
59
 
   { "stats", DEBUG_STATS },
60
 
   { "sing",  DEBUG_SINGLE_THREAD },
61
 
   { "thre",  DEBUG_SINGLE_THREAD },
62
 
   { "wm",    DEBUG_WM },
63
 
   { "urb",   DEBUG_URB },
64
 
   { "vs",    DEBUG_VS },
65
 
   { NULL,    0 }
 
43
   { "tex",   DEBUG_TEXTURE, NULL },
 
44
   { "state", DEBUG_STATE, NULL },
 
45
   { "ioctl", DEBUG_IOCTL, NULL },
 
46
   { "blit",  DEBUG_BLIT, NULL },
 
47
   { "curbe", DEBUG_CURBE, NULL },
 
48
   { "fall",  DEBUG_FALLBACKS, NULL },
 
49
   { "verb",  DEBUG_VERBOSE, NULL },
 
50
   { "bat",   DEBUG_BATCH, NULL },
 
51
   { "pix",   DEBUG_PIXEL, NULL },
 
52
   { "wins",  DEBUG_WINSYS, NULL },
 
53
   { "min",   DEBUG_MIN_URB, NULL },
 
54
   { "dis",   DEBUG_DISASSEM, NULL },
 
55
   { "sync",  DEBUG_SYNC, NULL },
 
56
   { "prim",  DEBUG_PRIMS, NULL },
 
57
   { "vert",  DEBUG_VERTS, NULL },
 
58
   { "dma",   DEBUG_DMA, NULL },
 
59
   { "san",   DEBUG_SANITY, NULL },
 
60
   { "sleep", DEBUG_SLEEP, NULL },
 
61
   { "stats", DEBUG_STATS, NULL },
 
62
   { "sing",  DEBUG_SINGLE_THREAD, NULL },
 
63
   { "thre",  DEBUG_SINGLE_THREAD, NULL },
 
64
   { "wm",    DEBUG_WM, NULL },
 
65
   { "urb",   DEBUG_URB, NULL },
 
66
   { "vs",    DEBUG_VS, NULL },
 
67
   DEBUG_NAMED_VALUE_END
66
68
};
67
69
 
68
70
static const struct debug_named_value dump_names[] = {
69
 
   { "asm",   DUMP_ASM},
70
 
   { "state", DUMP_STATE},
71
 
   { "batch", DUMP_BATCH},
72
 
   { NULL, 0 }
 
71
   { "asm",   DUMP_ASM, NULL },
 
72
   { "state", DUMP_STATE, NULL },
 
73
   { "batch", DUMP_BATCH, NULL },
 
74
   DEBUG_NAMED_VALUE_END
73
75
};
74
76
 
75
77
int BRW_DEBUG = 0;
148
150
}
149
151
 
150
152
static int
151
 
brw_get_param(struct pipe_screen *screen, int param)
 
153
brw_get_param(struct pipe_screen *screen, enum pipe_cap param)
152
154
{
153
155
   switch (param) {
154
156
   case PIPE_CAP_MAX_TEXTURE_IMAGE_UNITS:
171
173
      return 1;
172
174
   case PIPE_CAP_OCCLUSION_QUERY:
173
175
      return 0;
 
176
   case PIPE_CAP_TIMER_QUERY:
 
177
      return 0;
174
178
   case PIPE_CAP_TEXTURE_SHADOW_MAP:
175
179
      return 1;
176
180
   case PIPE_CAP_MAX_TEXTURE_2D_LEVELS:
177
 
      return 11; /* max 1024x1024 */
 
181
      return BRW_MAX_TEXTURE_2D_LEVELS;
178
182
   case PIPE_CAP_MAX_TEXTURE_3D_LEVELS:
179
 
      return 8;  /* max 128x128x128 */
 
183
      return BRW_MAX_TEXTURE_3D_LEVELS;
180
184
   case PIPE_CAP_MAX_TEXTURE_CUBE_LEVELS:
181
 
      return 11; /* max 1024x1024 */
 
185
      return BRW_MAX_TEXTURE_2D_LEVELS;
182
186
   case PIPE_CAP_TGSI_FS_COORD_ORIGIN_UPPER_LEFT:
183
187
   case PIPE_CAP_TGSI_FS_COORD_PIXEL_CENTER_HALF_INTEGER:
184
188
      return 1;
185
189
   case PIPE_CAP_TGSI_FS_COORD_ORIGIN_LOWER_LEFT:
186
190
   case PIPE_CAP_TGSI_FS_COORD_PIXEL_CENTER_INTEGER:
187
191
      return 0;
 
192
   case PIPE_CAP_DEPTHSTENCIL_CLEAR_SEPARATE:
 
193
      /* disable for now */
 
194
      return 0;
188
195
   default:
189
196
      return 0;
190
197
   }
191
198
}
192
199
 
193
200
static float
194
 
brw_get_paramf(struct pipe_screen *screen, int param)
 
201
brw_get_paramf(struct pipe_screen *screen, enum pipe_cap param)
195
202
{
196
203
   switch (param) {
197
204
   case PIPE_CAP_MAX_LINE_WIDTH:
217
224
 
218
225
static boolean
219
226
brw_is_format_supported(struct pipe_screen *screen,
220
 
                         enum pipe_format format, 
 
227
                         enum pipe_format format,
221
228
                         enum pipe_texture_target target,
222
 
                         unsigned tex_usage, 
 
229
                         unsigned sample_count,
 
230
                         unsigned tex_usage,
223
231
                         unsigned geom_flags)
224
232
{
225
233
   static const enum pipe_format tex_supported[] = {
252
260
      /* depth */
253
261
      PIPE_FORMAT_Z32_FLOAT,
254
262
      PIPE_FORMAT_Z24X8_UNORM,
255
 
      PIPE_FORMAT_Z24S8_UNORM,
 
263
      PIPE_FORMAT_Z24_UNORM_S8_USCALED,
256
264
      PIPE_FORMAT_Z16_UNORM,
257
265
      /* signed */
258
266
      PIPE_FORMAT_R8G8_SNORM,
268
276
   static const enum pipe_format depth_supported[] = {
269
277
      PIPE_FORMAT_Z32_FLOAT,
270
278
      PIPE_FORMAT_Z24X8_UNORM,
271
 
      PIPE_FORMAT_Z24S8_UNORM,
 
279
      PIPE_FORMAT_Z24_UNORM_S8_USCALED,
272
280
      PIPE_FORMAT_Z16_UNORM,
273
281
      PIPE_FORMAT_NONE  /* list terminator */
274
282
   };
275
283
   const enum pipe_format *list;
276
284
   uint i;
277
285
 
278
 
   if (tex_usage & PIPE_TEXTURE_USAGE_DEPTH_STENCIL)
 
286
   if (sample_count > 1)
 
287
      return FALSE;
 
288
 
 
289
   if (tex_usage & PIPE_BIND_DEPTH_STENCIL)
279
290
      list = depth_supported;
280
 
   else if (tex_usage & PIPE_TEXTURE_USAGE_RENDER_TARGET)
 
291
   else if (tex_usage & PIPE_BIND_RENDER_TARGET)
281
292
      list = render_supported;
282
293
   else
283
294
      list = tex_supported;
340
351
 * Create a new brw_screen object
341
352
 */
342
353
struct pipe_screen *
343
 
brw_create_screen(struct brw_winsys_screen *sws, uint pci_id)
 
354
brw_screen_create(struct brw_winsys_screen *sws)
344
355
{
345
356
   struct brw_screen *bscreen;
346
357
   struct brw_chipset chipset;
355
366
 
356
367
   memset(&chipset, 0, sizeof chipset);
357
368
 
358
 
   chipset.pci_id = pci_id;
 
369
   chipset.pci_id = sws->pci_id;
359
370
 
360
 
   switch (pci_id) {
 
371
   switch (chipset.pci_id) {
361
372
   case PCI_CHIP_I965_G:
362
373
   case PCI_CHIP_I965_Q:
363
374
   case PCI_CHIP_I965_G_1:
383
394
 
384
395
   default:
385
396
      debug_printf("%s: unknown pci id 0x%x, cannot create screen\n", 
386
 
                   __FUNCTION__, pci_id);
 
397
                   __FUNCTION__, chipset.pci_id);
387
398
      return NULL;
388
399
   }
389
400
 
406
417
   bscreen->base.fence_signalled = brw_fence_signalled;
407
418
   bscreen->base.fence_finish = brw_fence_finish;
408
419
 
409
 
   brw_screen_tex_init(bscreen);
 
420
   brw_init_screen_resource_functions(bscreen);
410
421
   brw_screen_tex_surface_init(bscreen);
411
 
   brw_screen_buffer_init(bscreen);
412
422
 
413
423
   bscreen->no_tiling = debug_get_option("BRW_NO_TILING", FALSE) != NULL;
414
424