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

« back to all changes in this revision

Viewing changes to src/gallium/drivers/cell/ppu/cell_state_vertex.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:
32
32
#include "cell_context.h"
33
33
#include "cell_state.h"
34
34
 
 
35
#include "util/u_memory.h"
35
36
#include "draw/draw_context.h"
36
37
 
37
38
 
 
39
static void *
 
40
cell_create_vertex_elements_state(struct pipe_context *pipe,
 
41
                                  unsigned count,
 
42
                                  const struct pipe_vertex_element *attribs)
 
43
{
 
44
   struct cell_velems_state *velems;
 
45
   assert(count <= PIPE_MAX_ATTRIBS);
 
46
   velems = (struct cell_velems_state *) MALLOC(sizeof(struct cell_velems_state));
 
47
   if (velems) {
 
48
      velems->count = count;
 
49
      memcpy(velems->velem, attribs, sizeof(*attribs) * count);
 
50
   }
 
51
   return velems;
 
52
}
 
53
 
38
54
static void
39
 
cell_set_vertex_elements(struct pipe_context *pipe,
40
 
                         unsigned count,
41
 
                         const struct pipe_vertex_element *elements)
 
55
cell_bind_vertex_elements_state(struct pipe_context *pipe,
 
56
                                void *velems)
42
57
{
43
58
   struct cell_context *cell = cell_context(pipe);
44
 
 
45
 
   assert(count <= PIPE_MAX_ATTRIBS);
46
 
 
47
 
   memcpy(cell->vertex_element, elements, count * sizeof(elements[0]));
48
 
   cell->num_vertex_elements = count;
 
59
   struct cell_velems_state *cell_velems = (struct cell_velems_state *) velems;
 
60
 
 
61
   cell->velems = cell_velems;
49
62
 
50
63
   cell->dirty |= CELL_NEW_VERTEX;
51
64
 
52
 
   draw_set_vertex_elements(cell->draw, count, elements);
 
65
   if (cell_velems)
 
66
      draw_set_vertex_elements(cell->draw, cell_velems->count, cell_velems->velem);
 
67
}
 
68
 
 
69
static void
 
70
cell_delete_vertex_elements_state(struct pipe_context *pipe, void *velems)
 
71
{
 
72
   FREE( velems );
53
73
}
54
74
 
55
75
 
71
91
}
72
92
 
73
93
 
 
94
static void
 
95
cell_set_index_buffer(struct pipe_context *pipe,
 
96
                      const struct pipe_index_buffer *ib)
 
97
{
 
98
   struct cell_context *cell = cell_context(pipe);
 
99
 
 
100
   if (ib)
 
101
      memcpy(&cell->index_buffer, ib, sizeof(cell->index_buffer));
 
102
   else
 
103
      memset(&cell->index_buffer, 0, sizeof(cell->index_buffer));
 
104
 
 
105
   draw_set_index_buffer(cell->draw, ib);
 
106
}
 
107
 
 
108
 
74
109
void
75
110
cell_init_vertex_functions(struct cell_context *cell)
76
111
{
77
112
   cell->pipe.set_vertex_buffers = cell_set_vertex_buffers;
78
 
   cell->pipe.set_vertex_elements = cell_set_vertex_elements;
 
113
   cell->pipe.set_index_buffer = cell_set_index_buffer;
 
114
   cell->pipe.create_vertex_elements_state = cell_create_vertex_elements_state;
 
115
   cell->pipe.bind_vertex_elements_state = cell_bind_vertex_elements_state;
 
116
   cell->pipe.delete_vertex_elements_state = cell_delete_vertex_elements_state;
79
117
}