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

« back to all changes in this revision

Viewing changes to src/gallium/auxiliary/draw/draw_pt_vsplit.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:
 
1
/*
 
2
 * Mesa 3-D graphics library
 
3
 * Version:  7.9
 
4
 *
 
5
 * Copyright 2007-2008 Tungsten Graphics, Inc., Cedar Park, Texas.
 
6
 * Copyright (C) 2010 LunarG Inc.
 
7
 *
 
8
 * Permission is hereby granted, free of charge, to any person obtaining a
 
9
 * copy of this software and associated documentation files (the "Software"),
 
10
 * to deal in the Software without restriction, including without limitation
 
11
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
 
12
 * and/or sell copies of the Software, and to permit persons to whom the
 
13
 * Software is furnished to do so, subject to the following conditions:
 
14
 *
 
15
 * The above copyright notice and this permission notice shall be included
 
16
 * in all copies or substantial portions of the Software.
 
17
 *
 
18
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 
19
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 
20
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
 
21
 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 
22
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 
23
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
 
24
 * DEALINGS IN THE SOFTWARE.
 
25
 */
 
26
 
 
27
#include "util/u_math.h"
 
28
#include "util/u_memory.h"
 
29
 
 
30
#include "draw/draw_context.h"
 
31
#include "draw/draw_private.h"
 
32
#include "draw/draw_pt.h"
 
33
 
 
34
#define SEGMENT_SIZE 1024
 
35
#define MAP_SIZE     256
 
36
 
 
37
struct vsplit_frontend {
 
38
   struct draw_pt_front_end base;
 
39
   struct draw_context *draw;
 
40
 
 
41
   unsigned prim;
 
42
 
 
43
   struct draw_pt_middle_end *middle;
 
44
 
 
45
   unsigned max_vertices;
 
46
   ushort segment_size;
 
47
 
 
48
   /* buffers for splitting */
 
49
   unsigned fetch_elts[SEGMENT_SIZE];
 
50
   ushort draw_elts[SEGMENT_SIZE];
 
51
   ushort identity_draw_elts[SEGMENT_SIZE];
 
52
 
 
53
   struct {
 
54
      /* map a fetch element to a draw element */
 
55
      unsigned fetches[MAP_SIZE];
 
56
      ushort draws[MAP_SIZE];
 
57
      boolean has_max_fetch;
 
58
 
 
59
      ushort num_fetch_elts;
 
60
      ushort num_draw_elts;
 
61
   } cache;
 
62
};
 
63
 
 
64
 
 
65
static void
 
66
vsplit_clear_cache(struct vsplit_frontend *vsplit)
 
67
{
 
68
   memset(vsplit->cache.fetches, 0xff, sizeof(vsplit->cache.fetches));
 
69
   vsplit->cache.has_max_fetch = FALSE;
 
70
   vsplit->cache.num_fetch_elts = 0;
 
71
   vsplit->cache.num_draw_elts = 0;
 
72
}
 
73
 
 
74
static void
 
75
vsplit_flush_cache(struct vsplit_frontend *vsplit, unsigned flags)
 
76
{
 
77
   vsplit->middle->run(vsplit->middle,
 
78
         vsplit->fetch_elts, vsplit->cache.num_fetch_elts,
 
79
         vsplit->draw_elts, vsplit->cache.num_draw_elts, flags);
 
80
}
 
81
 
 
82
/**
 
83
 * Add a fetch element and add it to the draw elements.
 
84
 */
 
85
static INLINE void
 
86
vsplit_add_cache(struct vsplit_frontend *vsplit, unsigned fetch)
 
87
{
 
88
   unsigned hash = fetch % MAP_SIZE;
 
89
 
 
90
   if (vsplit->cache.fetches[hash] != fetch) {
 
91
      /* update cache */
 
92
      vsplit->cache.fetches[hash] = fetch;
 
93
      vsplit->cache.draws[hash] = vsplit->cache.num_fetch_elts;
 
94
 
 
95
      /* add fetch */
 
96
      assert(vsplit->cache.num_fetch_elts < vsplit->segment_size);
 
97
      vsplit->fetch_elts[vsplit->cache.num_fetch_elts++] = fetch;
 
98
   }
 
99
 
 
100
   vsplit->draw_elts[vsplit->cache.num_draw_elts++] = vsplit->cache.draws[hash];
 
101
}
 
102
 
 
103
 
 
104
/**
 
105
 * Add a fetch element and add it to the draw elements.  The fetch element is
 
106
 * in full range (uint).
 
107
 */
 
108
static INLINE void
 
109
vsplit_add_cache_uint(struct vsplit_frontend *vsplit, unsigned fetch)
 
110
{
 
111
   /* special care for 0xffffffff */
 
112
   if (fetch == 0xffffffff && !vsplit->cache.has_max_fetch) {
 
113
      unsigned hash = fetch % MAP_SIZE;
 
114
      vsplit->cache.fetches[hash] = fetch - 1; /* force update */
 
115
      vsplit->cache.has_max_fetch = TRUE;
 
116
   }
 
117
 
 
118
   vsplit_add_cache(vsplit, fetch);
 
119
}
 
120
 
 
121
 
 
122
#define FUNC vsplit_run_linear
 
123
#include "draw_pt_vsplit_tmp.h"
 
124
 
 
125
#define FUNC vsplit_run_ubyte
 
126
#define ELT_TYPE ubyte
 
127
#define ADD_CACHE(vsplit, fetch) vsplit_add_cache(vsplit, fetch)
 
128
#include "draw_pt_vsplit_tmp.h"
 
129
 
 
130
#define FUNC vsplit_run_ushort
 
131
#define ELT_TYPE ushort
 
132
#define ADD_CACHE(vsplit, fetch) vsplit_add_cache(vsplit, fetch)
 
133
#include "draw_pt_vsplit_tmp.h"
 
134
 
 
135
#define FUNC vsplit_run_uint
 
136
#define ELT_TYPE uint
 
137
#define ADD_CACHE(vsplit, fetch) vsplit_add_cache_uint(vsplit, fetch)
 
138
#include "draw_pt_vsplit_tmp.h"
 
139
 
 
140
 
 
141
static void vsplit_prepare(struct draw_pt_front_end *frontend,
 
142
                           unsigned in_prim,
 
143
                           struct draw_pt_middle_end *middle,
 
144
                           unsigned opt)
 
145
{
 
146
   struct vsplit_frontend *vsplit = (struct vsplit_frontend *) frontend;
 
147
 
 
148
   switch (vsplit->draw->pt.user.eltSize) {
 
149
   case 0:
 
150
      vsplit->base.run = vsplit_run_linear;
 
151
      break;
 
152
   case 1:
 
153
      vsplit->base.run = vsplit_run_ubyte;
 
154
      break;
 
155
   case 2:
 
156
      vsplit->base.run = vsplit_run_ushort;
 
157
      break;
 
158
   case 4:
 
159
      vsplit->base.run = vsplit_run_uint;
 
160
      break;
 
161
   default:
 
162
      assert(0);
 
163
      break;
 
164
   }
 
165
 
 
166
   /* split only */
 
167
   vsplit->prim = in_prim;
 
168
 
 
169
   vsplit->middle = middle;
 
170
   middle->prepare(middle, vsplit->prim, opt, &vsplit->max_vertices);
 
171
 
 
172
   vsplit->segment_size = MIN2(SEGMENT_SIZE, vsplit->max_vertices);
 
173
}
 
174
 
 
175
 
 
176
static void vsplit_finish(struct draw_pt_front_end *frontend)
 
177
{
 
178
   struct vsplit_frontend *vsplit = (struct vsplit_frontend *) frontend;
 
179
   vsplit->middle->finish(vsplit->middle);
 
180
   vsplit->middle = NULL;
 
181
}
 
182
 
 
183
 
 
184
static void vsplit_destroy(struct draw_pt_front_end *frontend)
 
185
{
 
186
   FREE(frontend);
 
187
}
 
188
 
 
189
 
 
190
struct draw_pt_front_end *draw_pt_vsplit(struct draw_context *draw)
 
191
{
 
192
   struct vsplit_frontend *vsplit = CALLOC_STRUCT(vsplit_frontend);
 
193
   ushort i;
 
194
 
 
195
   if (!vsplit)
 
196
      return NULL;
 
197
 
 
198
   vsplit->base.prepare = vsplit_prepare;
 
199
   vsplit->base.run     = NULL;
 
200
   vsplit->base.finish  = vsplit_finish;
 
201
   vsplit->base.destroy = vsplit_destroy;
 
202
   vsplit->draw = draw;
 
203
 
 
204
   for (i = 0; i < SEGMENT_SIZE; i++)
 
205
      vsplit->identity_draw_elts[i] = i;
 
206
 
 
207
   return &vsplit->base;
 
208
}