summaryrefslogtreecommitdiffstats
path: root/src/mesa
Commit message (Collapse)AuthorAgeFilesLines
* i965: Add support for LRP in VPs.Eric Anholt2009-01-071-0/+42
| | | | Bug #19226.
* mesa: Add _mesa_snprintf.José Fonseca2009-01-075-7/+22
| | | | | | On Windows snprintf is renamed as _snprintf. (cherry picked from commit f8f9a1b620d31d1a59855fd502caed325d4a324f)
* glsl: disable some unused functions (but don't remove just yet)Brian Paul2009-01-071-1/+8
|
* glsl: also unroll loops with variable declarations such as "for (int i = 0; ..."Brian Paul2009-01-071-24/+58
|
* glsl: remove dead codeBrian Paul2009-01-071-13/+2
|
* mesa: OSMesa Makefile fixes (use LIB_DIR)Brian Paul2009-01-071-4/+3
|
* glsl: loop unroll adjustmentsBrian Paul2009-01-061-1/+20
| | | | | | | Add a "max complexity" heuristic to allow unrolling long loops with small bodies and short loops with large bodies. The loop unroll limits may need further tweaking...
* glsl: implement loop unrolling for simple 'for' loopsBrian Paul2009-01-061-24/+205
| | | | | | | | | | | | | | | | | Loops such as this will be unrolled: for (i = 0; i < 4; ++i) { body; } where 'body' isn't too large. This also helps to fix the issue reported in bug #19190. The problem there is indexing vector types with a variable index. For example: vec4 v; v[2] = 1.0; // equivalent to v.z = 1.0 v[i] = 2.0; // variable index into vector!! Since the for-i loop can be unrolled, we can avoid the problems associated with variable indexing into a vector (at least in this case).
* mesa: Move var declaration to top of scope.Brian Paul2009-01-061-0/+8
| | | | (cherry picked from commit 3740a06e28f4cd09e2a3dce2da60320aa9304df1)
* mesa: fix GL_DEPTH_CLEAR_VALUE castingBrian Paul2009-01-062-4/+4
| | | | (cherry picked from commit d14d494dcda3d80ec2cf452551c680ffb432e306)
* mesa: Fix the size per pixel for packed pixel format data type.Xiang, Haihao2009-01-063-2/+9
|
* mesa: Fix the number of components for GL_UNSIGNED_SHORT_1_5_5_5_REV. (bug ↵Xiang, Haihao2009-01-061-1/+1
| | | | #19390)
* dri: correct the damage.Xiang, Haihao2009-01-061-2/+17
| | | | Fixes bug #17234
* mesa: add GLushort cases for render to texture (Z-buffers)Brian Paul2009-01-051-2/+50
|
* mesa: fix a GLSL swizzled writemask bugBrian Paul2009-01-051-2/+18
| | | | | | | | | This fixes cases such as: vec4 v4; vec2 v2; v4.xz.yx = v2; The last line now correctly compiles into MOV TEMP[1].xz, TEMP[0].yyxw; Helps to fix the Humus Domino demo. See bug 19189.
* i965: implement OPCODE_TRUNC (round toward zero) on vertex path.Brian Paul2009-01-054-1/+7
| | | | Also, fix some RNDD vs. RNDZ confusion elsewhere.
* mesa: fix warning about possibly undefined var in GLSL compilerBrian Paul2009-01-021-6/+4
|
* mesa: fix another "out of samplers" problemBrian Paul2009-01-023-18/+50
| | | | | | Now only the samplers that are actually used by texture() functions are saved in the uniform variable list. Before, we could run out of samplers if too many were declared while only some of them were actually used.
* i965: increase number of texture samplers to 16Brian Paul2009-01-012-3/+5
| | | | | | This lets GLSL shaders use up to 16 samplers. Fixed function is still limited to 8 textures. Tested with progs/glsl/samplers.c
* i965: comments, clean-ups, re-order some functionsBrian Paul2009-01-011-34/+54
|
* i965: added OPCODE_NRM3/4Brian Paul2009-01-011-0/+3
|
* i965: fix commentBrian Paul2009-01-011-1/+1
|
* i965: indentation and formatting fixesBrian Paul2009-01-011-45/+36
|
* i965: implement OPCODE_NRM3/NRM4Brian Paul2009-01-011-3/+33
|
* i965: whitespace, comment changesBrian Paul2009-01-011-26/+11
|
* mesa: comments, whitespace changesBrian Paul2009-01-011-13/+31
|
* mesa: updated comments about GLSL constantsBrian Paul2009-01-011-2/+3
|
* mesa: increase max texture image units and GLSL samplers to 16Brian Paul2008-12-3114-137/+189
| | | | | | | | | | | | | | | | The max texture coord units is still 8. All the fixed-function paths are still limited to 8 too. But GLSL shaders can use more samplers now. Note that some texcoord-related data structures are declared to be 16 elements in size rather than 8. This just simplifies the code in a few places; the extra elements aren't accessible to the user. These changes haven't been extensively tested yet, but sanity checking has been done. It should be possible to increase the max image units/samplers to 32 without doing anything special. Beyond that we'll need longer bitfields in a few places.
* intel: Share passthrough transform setup between glBitmap and glDrawPixels.Eric Anholt2008-12-315-45/+52
| | | | | | | The DrawPixels path was missing glViewport care, so blender's toolbar icons would go to the wrong places. Bug #19118.
* intel: Add support for glBitmap as metaops using GL calls.Eric Anholt2008-12-314-0/+350
| | | | | | | | | | This lets us avoid software fallbacks when clients forget to turn some state off (engine demo) or just do crazy things to test conformance (OGLC). This should probably be brought into mesa generic code so other drivers can make use of it. Bug #19016.
* mesa: fix bug in evaluation of structure fieldsBrian Paul2008-12-301-3/+1
| | | | Fixes incorrect size information. See bug 19273.
* mesa: allow variable indexing into the predefined uniform variable arraysBrian Paul2008-12-305-91/+376
| | | | | | | | | | | | | | | | | | | This allows code such as "vec4 a = gl_LightSource[i].ambient;" to work. When a built-in uniform array is indexed with a variable index we need to "unroll" the whole array into the parameter list (aka constant buffer) because we don't know which elements may be accessed at compile-time. In the case of the gl_LightSource array of size [8], we emit 64 state references into the parameter array (8 elements times 8 vec4s per gl_LightSourceParameters struct). Previously, we only allowed constant-indexed references to uniform arrays (such as gl_LightSource[2].position) which resulted in a single state reference being added to the parameter array, not 64. We still optimize this case. Users should be aware that using "gl_LightSource[i].ambient" in their shaders is a bit expensive since state validation will involve updating all 64 light source entries in the parameter list.
* mesa: better error message when running out of GLSL samplersBrian Paul2008-12-301-1/+4
|
* mesa: comments for some state varsBrian Paul2008-12-301-4/+4
|
* mesa: increase max constants/uniforms to 256 (vec4 vectors)Brian Paul2008-12-301-2/+2
|
* intel: disable ATI_texture_env_combine3 for i830( and related device).Xiang, Haihao2008-12-302-1/+2
| | | | Thanks to Eric for pointing it out.
* dri: Fix driWaitForMSC32 when divisor >= 2 and msc < 0.Eric Anholt2008-12-291-9/+9
| | | | | | | | | | We'd come up with a negative remainder, while we were looking for the positive version of it in the loop conditional. And, since the "did we hit our target" break was disabled for the target_msc == 0 ("Just make the divisor/remainder work") path, we'd never exit. Simplify the code by just using int64_t all over instead of trying to do it in a u32 space.
* R300: missing semicolonAlex Deucher2008-12-291-1/+1
|
* intel: enable ATI_texture_env_combine3. Fixes #17707Xiang, Haihao2008-12-291-0/+1
|
* r300: remove the unknowns from the indx_buffer codeDave Airlie2008-12-282-5/+6
|
* i915: separate the fog term from the specular color term.Xiang, Haihao2008-12-241-19/+3
| | | | | | | | Previously fog parameter and specular color are packed into the same dword. Note specular color should be packed in BGRA for device, so if fog parameter and specular color all are present, fog parameter will dirty the alpha term of specular color. This fixes rendering issue when playing 'Yo Frankie' on 915/945.
* intel: Fix glBitmap clipping for DRI1.Eric Anholt2008-12-231-2/+2
|
* Remove third buffer support from Mesa.Dave Airlie2008-12-236-35/+3
| | | | This is part of the deprecated pageflipping infrastructure.
* Add do_row_3d for mipmapping 3D texturesIan Romanick2008-12-191-21/+444
| | | | | | | | | | | | Previously 3D textures were mipmapped using multiple passed through the 2D mipmap generation code. This had 3 disadvantages. First, the extra passes were slow. Second, this required the allocation of a temporary buffer to hold intermediate data. Third, and most important, the extra passes caused loss of additional bits due to integer division / bit-shifting. With this change, our mipmapgen conformance test passes for non-compressed texture formats.
* Fix typeo in mipmap filter for GL_UNSIGNED_SHORT_1_5_5_5_REVIan Romanick2008-12-191-1/+1
|
* 965 / GLSL: Use full precision for EXP instructionIan Romanick2008-12-191-1/+1
| | | | | The partial precision mode doesn't have quite enough bits of precision to pass conformance tests.
* GLSL: The LOG2 macro doesn't have enough precisionIan Romanick2008-12-191-2/+9
| | | | | It looks like the LOG2 macro only has 8 or 9 bits of precission, but the ARB_vertex_program spec says "accurate to at least 10 bits".
* intel: Fix glBitmap top/bottom clipping.Eric Anholt2008-12-191-40/+35
| | | | Bug #19139.
* intel: Don't forget the source bitmap size when clipping the size we draw.Eric Anholt2008-12-191-1/+3
|
* intel: Update mesa state in blit operations that want post-scissor draw bounds.Eric Anholt2008-12-192-0/+7
|