summaryrefslogtreecommitdiffstats
path: root/src
Commit message (Collapse)AuthorAgeFilesLines
* r300-gallium, radeon-gallium: Make add_buffer indicate when a flush is needed.Corbin Simpson2009-05-284-23/+50
| | | | On a side note, why is RADEON_MAX_BOS 24? Should ask airlied about that.
* nv50: some mipmapping fixesBen Skeggs2009-05-284-22/+31
|
* nv50: negate sources directly where supportedChristoph Bumiller2009-05-281-42/+68
|
* nv50: introduce emit_cvt and use itChristoph Bumiller2009-05-281-40/+48
| | | | | This makes some code cleaner, and we can now easily do CEIL and TRUNC.
* nv50: fix TXPChristoph Bumiller2009-05-281-23/+112
| | | | | | | | For TXP we need to divide texture coords by their w component, or use the coords' 1/w in the perspective interpolation instruction. This also tries to support 1D, 3D and CUBE textures, and lets the instruction only load the components that are used.
* nv50: use multiple constant buffersChristoph Bumiller2009-05-284-48/+105
| | | | | | | Use different buffers for immds, FP params, and VP params. One has to map constant buffer indices in shader code to buffers defined via CB_DEF. In principle, we could use more buffers so we'd have to change the shader code less frequently.
* nv50: don't look for unfreed temps in free_nv50_pcChristoph Bumiller2009-05-281-8/+0
| | | | | Since we stopped using alloc_temp to get hw indices for FP attrs there shouldn't be any non-deallocated temps left.
* nv50: release hw TEMPs earlyChristoph Bumiller2009-05-281-0/+19
| | | | | Since we know when we don't use a TEMP or FP ATTR register anymore, we can release their hw resources early.
* nv50: allow immediates for MOV, ADD and MULChristoph Bumiller2009-05-281-5/+22
| | | | | | Immediates are inlined now where possible, so we need to set pc->allow32 to FALSE in LIT where we have the conditional MOV, since immediates swallow the predicate bits.
* nv50: enable half insns for MOV and MULChristoph Bumiller2009-05-281-7/+12
|
* nv50: make sure half-long insns are pairedChristoph Bumiller2009-05-281-0/+72
| | | | | | | I chose to just convert unpaired 32 bit length instructions after parsing all instructions, although it might be possible to determine beforehand whether there would be any lone ones, and then even do some swapping to bring them together ...
* nv50: enable KIL in register 19a8Christoph Bumiller2009-05-281-0/+1
|
* nv50: don't overwrite sources before they're usedChristoph Bumiller2009-05-281-12/+83
| | | | | This would have happened in p.e. ADD TEMP[0], TEMP[0].xyxy, TEMP[1] or RCP/RSQ TEMP[i], TEMP[i].
* nv50: put FP outputs where they belongChristoph Bumiller2009-05-281-4/+37
| | | | | Depth output in fragment programs should end up in the first register after the color outputs.
* nv50: modified FP attribute loadingChristoph Bumiller2009-05-282-45/+147
| | | | | | | | VP outputs that should be loadable in the FP are mapped to interpolant indices by HPOS, COL0 etc.; of course HPOS is always written, so the highest byte of 1988 is a bitmask that selects which components of HPOS are used for interpolants, i.e. the FP inputs in COL0 start at index POPCNT(1988[24:28]).
* nv50: inspect decl semantic and interpolation modeChristoph Bumiller2009-05-281-1/+74
| | | | | | Record interpolation mode for attributes while parsing declarations, and also remember the indices of FP color inputs and FP depth output, which has to end up in the highest output register.
* nv50: record last access to temp and attr regsChristoph Bumiller2009-05-281-0/+127
| | | | | | | We now inspect the TGSI instructions in tx_prep to determine where temps and FP attrs are last accessed. This will enable us to reclaim some temporaries early and we also use it to omit pre-loading FP attributes that aren't used.
* nv50: save some space in immediate bufferChristoph Bumiller2009-05-281-1/+7
| | | | | We could do even better (like just allocating 1 value in alloc_immd), but that's fine for now I guess.
* nv50: fix SIGN_SET case in tgsi_srcChristoph Bumiller2009-05-281-1/+1
|
* nv50: set dst.z,w to 0,1 in SCS and XPDChristoph Bumiller2009-05-281-0/+14
| | | | | According to tgsi-instruction-set.txt, if they are written, z and w should be set to 0 and 1 respectively in SCS, and w to 1.0 in XPD.
* nv50: make LRP instruction nicerChristoph Bumiller2009-05-281-6/+3
|
* nv50: fix some memory leaks in shader assemblerChristoph Bumiller2009-05-281-25/+63
|
* nouveau: explicitly request mappable buffers for the momentBen Skeggs2009-05-281-0/+1
|
* draw: Fix assertion failure at fetch_emit_prepareMike Kaplinksiy2009-05-271-0/+6
|
* softpipe: commentsBrian Paul2009-05-271-0/+2
|
* softpipe: include sp_winsys.h to silence warning (unprototyped function)Brian Paul2009-05-271-0/+1
|
* softpipe: fix flat shading provoking vertex for PIPE_PRIM_POLYGONBrian Paul2009-05-273-1/+6
| | | | Use the first vertex, not the last.
* st/mesa: init Format field of vertex arrays for feedback modeBrian Paul2009-05-271-0/+1
| | | | Fixes segfault in glRasterPos()
* i915: Fall back on NPOT textured metaops on 830-class.Eric Anholt2009-05-263-0/+30
|
* i915: Restore the Viewport and DepthRange functions on 8xx.Eric Anholt2009-05-261-0/+21
| | | | | | | Fixes failed viewport updates on glxgears (and other apps) resize since e41780fedc2c1f22b43118da30a0103fa68b769f. Bug #20473.
* intel: Override MaxRenderbufferSize with hardware constraintsChris Wilson2009-05-261-0/+7
| | | | | Limit the maximum renderbuffer size to 8192 on i965 and to 2048 on earlier hardware.
* mesa: fix warning message in vbo_exec_DrawRangeElements()Brian Paul2009-05-221-1/+2
|
* mesa: add missing update_min() call in update_arrays()Brian Paul2009-05-221-1/+1
|
* mesa: reduce gl_array_object::VertexAttrib[] array from 32 to 16 elementsBrian Paul2009-05-221-2/+7
| | | | | | | | | | This array was mistakenly dimensioned with VERT_ATTRIB_MAX (32) but it should really be MAX_VERTEX_GENERIC_ATTRIBS (16). The generic vertex attributes are in addition to the conventional arrays (except in NV vertex program mode- they alias/overlay in that case) so the total of all conventional attributes plus generic attributes should total 32 (not 48).
* mesa: use Elements() for loop limitBrian Paul2009-05-221-3/+2
|
* mesa: use Elements() for loop limitBrian Paul2009-05-221-1/+1
|
* mesa: use Elements() for loop limitBrian Paul2009-05-221-1/+1
|
* mesa: use Elements() for loop limitBrian Paul2009-05-221-2/+2
|
* mesa: use Elements() for loop limitBrian Paul2009-05-221-1/+1
|
* mesa: simplify adjust_buffer_object_ref_counts()Brian Paul2009-05-221-12/+14
|
* mesa: minor code clean-upBrian Paul2009-05-221-18/+19
|
* mesa: use Elements() for loop limitBrian Paul2009-05-223-5/+5
|
* vbo: s/32/VERT_ATTRIB_MAX/Brian Paul2009-05-221-2/+2
|
* mesa: use Elements() for loop boundBrian Paul2009-05-221-2/+2
|
* mesa: minor code simplificationBrian Paul2009-05-221-9/+11
|
* Merge branch 'mesa_7_5_branch'Brian Paul2009-05-221-2/+2
|\
| * mesa: fix loop over generic attribs in update_arrays()Brian Paul2009-05-221-1/+1
| |
* | vbo: asst. reformatting, clean-upsBrian Paul2009-05-221-34/+46
| |
* | Merge branch 'mesa_7_5_branch'Brian Paul2009-05-221-0/+1
|\|
| * vbo: fix crash in vbo_exec_bind_arrays()Brian Paul2009-05-221-0/+1
| | | | | | | | | | | | | | | | | | When a vertex shader uses generic vertex attribute 0, but not gl_Vertex, we need to set attribute[16] to point to attribute[0]. We were setting the attribute size, but not the pointer. Fixes crash in glsl/multitex.c when using the VertCoord attribute instead of gl_Vertex.