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

« back to all changes in this revision

Viewing changes to src/glsl/loop_unroll.cpp

  • 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
 * Copyright © 2010 Intel Corporation
 
3
 *
 
4
 * Permission is hereby granted, free of charge, to any person obtaining a
 
5
 * copy of this software and associated documentation files (the "Software"),
 
6
 * to deal in the Software without restriction, including without limitation
 
7
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
 
8
 * and/or sell copies of the Software, and to permit persons to whom the
 
9
 * Software is furnished to do so, subject to the following conditions:
 
10
 *
 
11
 * The above copyright notice and this permission notice (including the next
 
12
 * paragraph) shall be included in all copies or substantial portions of the
 
13
 * Software.
 
14
 *
 
15
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 
16
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 
17
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
 
18
 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 
19
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 
20
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
 
21
 * DEALINGS IN THE SOFTWARE.
 
22
 */
 
23
 
 
24
#include "glsl_types.h"
 
25
#include "loop_analysis.h"
 
26
#include "ir_hierarchical_visitor.h"
 
27
 
 
28
class loop_unroll_visitor : public ir_hierarchical_visitor {
 
29
public:
 
30
   loop_unroll_visitor(loop_state *state, unsigned max_iterations)
 
31
   {
 
32
      this->state = state;
 
33
      this->progress = false;
 
34
      this->max_iterations = max_iterations;
 
35
   }
 
36
 
 
37
   virtual ir_visitor_status visit_leave(ir_loop *ir);
 
38
 
 
39
   loop_state *state;
 
40
 
 
41
   bool progress;
 
42
   unsigned max_iterations;
 
43
};
 
44
 
 
45
 
 
46
ir_visitor_status
 
47
loop_unroll_visitor::visit_leave(ir_loop *ir)
 
48
{
 
49
   loop_variable_state *const ls = this->state->get(ir);
 
50
 
 
51
   /* If we've entered a loop that hasn't been analyzed, something really,
 
52
    * really bad has happened.
 
53
    */
 
54
   if (ls == NULL) {
 
55
      assert(ls != NULL);
 
56
      return visit_continue;
 
57
   }
 
58
 
 
59
   /* Don't try to unroll loops where the number of iterations is not known
 
60
    * at compile-time.
 
61
    */
 
62
   if (ls->max_iterations < 0)
 
63
      return visit_continue;
 
64
 
 
65
   /* Don't try to unroll loops that have zillions of iterations either.
 
66
    */
 
67
   if (ls->max_iterations > max_iterations)
 
68
      return visit_continue;
 
69
 
 
70
   if (ls->num_loop_jumps > 0)
 
71
      return visit_continue;
 
72
 
 
73
   void *const mem_ctx = talloc_parent(ir);
 
74
 
 
75
   for (int i = 0; i < ls->max_iterations; i++) {
 
76
      exec_list copy_list;
 
77
 
 
78
      copy_list.make_empty();
 
79
      clone_ir_list(mem_ctx, &copy_list, &ir->body_instructions);
 
80
 
 
81
      ir->insert_before(&copy_list);
 
82
   }
 
83
 
 
84
   /* The loop has been replaced by the unrolled copies.  Remove the original
 
85
    * loop from the IR sequence.
 
86
    */
 
87
   ir->remove();
 
88
 
 
89
   this->progress = true;
 
90
   return visit_continue;
 
91
}
 
92
 
 
93
 
 
94
bool
 
95
unroll_loops(exec_list *instructions, loop_state *ls, unsigned max_iterations)
 
96
{
 
97
   loop_unroll_visitor v(ls, max_iterations);
 
98
 
 
99
   v.run(instructions);
 
100
 
 
101
   return v.progress;
 
102
}