Age | Commit message (Collapse) | Author | |
---|---|---|---|
2008-11-19 | mesa: rework GLSL array code generation | Brian Paul | |
We now express arrays in terms of indirect addressing. For example: dst = a[i]; becomes: MOV dst, TEMP[1 + TEMP[2].y]; At instruction-emit time indirect addressing is converted into ARL/ ADDR-relative form: ARL ADDR.x, TEMP[2].y; MOV dst, TEMP[1 + ADDR.x]; This fixes a number of array-related issues. Arrays of arrays and complex array/struct nesting works now. There may be some regressions, but more work is coming. | |||
2008-11-19 | mesa: don't realloc instruction buffer so often | Brian Paul | |
2008-11-19 | mesa: updated comment | Brian Paul | |
2008-11-19 | mesa: clamp luminance if needed. | Xiang, Haihao | |
This fixes glReadPixels(GL_LUMINANCE, GL_FLOAT)/glGetTexImage(GL_LUMINANCE, GL_FLOAT) issue on fixed-point color buffers. | |||
2008-11-13 | mesa: no longer need Writemask field in GLSL IR nodes | Brian Paul | |
The Swizzle and Size fields carry all the info we need now. | |||
2008-11-13 | mesa: revamp GLSL instruction emit code | Brian Paul | |
This is a step toward better array handling code. In particular, when more than one operand of an instruction uses indirect addressing, we'll need some temporary instructions and registers. By converting IR storage to instruction operands all in one place (emit_instruction()) we can be smarter about this. Also, somewhat better handling of dst register swizzle/writemask handling. This results in tighter writemasks on some instructions which is good for SOA execution. And, cleaner instruction commenting with inst_comment(). Next: remove some more dead code and additional clean-ups... | |||
2008-11-13 | mesa: make writemask_string() non-static | Brian Paul | |
2008-11-13 | mesa: remove some do-nothing GLSL code | Brian Paul | |
2008-11-13 | mesa: fix accidental regression in GLSL built-in texture matrix lookup | Brian Paul | |
Was broken by commit 9aca9a4b72b2a7b378e50bd88f9c3324d07375ec. | |||
2008-11-13 | mesa: use the tighter definition of GLSL ftransform() from the gallium branches | Brian Paul | |
2008-11-13 | mesa: remove unused/obsolete __NormalMatrixTranspose matrix | Brian Paul | |
2008-11-13 | mesa: fix bug in GLSL built-in matrix state lookup | Brian Paul | |
2008-11-13 | mesa: tweak program register printing for RelAddr case | Brian Paul | |
2008-11-13 | mesa: fix generation of fixed function state when no vp exists | Alan Hourihane | |
2008-11-12 | i965: Upload state on primitive switch, don't just prepare it. | Eric Anholt | |
This was a regression in 59b2c2adbbece27ccf54e58b598ea29cb3a5aa85 that broke blender, among other apps. | |||
2008-11-12 | i965: Fix VB refcount leak on aperture overflow. | Eric Anholt | |
2008-11-12 | i965: Fix up VS max_threads for G4X and removing a magic number. | Eric Anholt | |
As far as I can read in the docs, VS threads can be 1:1 with the pairs of VUE handles allocated for them. Also, G4X can run twice as many threads as before (though we won't unless the we bump the preferred URB entries for VS). | |||
2008-11-12 | i965: Fix up SF max_threads. | Eric Anholt | |
We were dividing the number of URB entries by two to get number of threads, which looks suspiciously like a copy'n'paste-o from brw_vs_state.c. Also, the maximum number of threads is 24, not 12. | |||
2008-11-12 | i965: Fix up clip min_nr_entries, preferred_nr_entries, and max_threads. | Eric Anholt | |
The clip thread could potentially deadlock when processing tristrips since being moved back to dual-thread mode, as the two threads could each have 4 VUEs referenced and not be able to allocate another one since SF processing wasn't able to continue (needing 5 entries before it freed 2). In constrained URB mode, similar deadlock could even have occurred with polygons (so we cut back max_threads if we can't handle it any primitive type). | |||
2008-11-12 | i965: Update WM maximum threads for G4X. | Eric Anholt | |
2008-11-12 | i965: Add a big comment explaining my understanding of URB management. | Eric Anholt | |
It shouldn't offer anything new over what's in the docs (except for G4X notes), but here it's all in one place. | |||
2008-11-12 | glFlush before CopySubBuffer, fix coordinates and extension name typo. | Kristian Høgsberg | |
2008-11-12 | glx: fix xcb build | Hanno Böck | |
2008-11-11 | mesa: allow relative indexing into all register files and indirect dst ↵ | Brian Paul | |
register indexing | |||
2008-11-11 | Don't mess with emacs tab width. | Kristian Høgsberg | |
2008-11-11 | intel: reset cliprect_mode to IGNORE_CLIPRECTS. | Xiang, Haihao | |
This ensures all batchbuffers have a same cliprect mode after calling _intel_batchbuffer_flush even if there aren't invalid commands in the current batch buffer. (fix bug#18362). | |||
2008-11-11 | mesa: restore the negate flag of dots in build_lighting. | Xiang, Haihao | |
Dots is re-used if more than one light is enabled. Previously the negate flag of dots may affect next light. | |||
2008-11-11 | mesa: update new state for RasterPos like other operations. | Xiang, Haihao | |
This fixes a lighting issue when drawing a bitmap. | |||
2008-11-10 | mesa: new _mesa_is_pow_two() function | Brian | |
2008-11-10 | mesa: restore glapi/ prefix on #include | Brian Paul | |
2008-11-10 | mesa: fix some misc breakage caused by editing auto-generated files rather ↵ | Brian Paul | |
than the python generators Specifically: #include "glapitable.h" in src/mesa/main/glapi/dispatch.h Call _mesa_bsearch() in src/mesa/main/enums.c. | |||
2008-11-10 | GLX: fix out-of-bounds memory issue in indirect glAreTexturesResident() | Brian Paul | |
See bug 18445. When getting array results, __glXReadReply() always reads a multiple of four bytes. This can cause writing to invalid memory when 'n' is not a multiple of four. Special-case the glAreTexturesResident() functions now. To fix the bug, we use a temporary buffer that's a multiple of four bytes in length. NOTE: this commit also reverts part of commit 919ec22ecf72aa163e1b97d8c7381002131ed32c (glx/x11: Added some #ifdef GLX_DIRECT_RENDERING protection) which directly edited the indirect.c file rather than the python generator! I'm not repairing that issue at this time. | |||
2008-11-10 | dri: alloc __DRIscreen object with calloc() | Brian Paul | |
2008-11-10 | mesa: track initialization status of uniform variables. Plus, asst clean-ups. | Brian Paul | |
2008-11-10 | mesa: initial support for uniform variable initializers. | Brian Paul | |
This lets one specify initial values for uniforms in the code, avoiding the need to call glUniform() in some cases. | |||
2008-11-10 | mesa: fix logic error in GLSL linker when looking for main() shaders | Brian Paul | |
2008-11-10 | mesa: allows 'f' suffix on GLSL float literals | Brian Paul | |
2008-11-08 | mesa: remove OPCODE_INT #define | Brian | |
2008-11-08 | mesa: use NRM3 in emit_normalize_vec3() when drivers are ready | Brian | |
2008-11-07 | mesa: add support for 'centroid' qualifier in GLSL 1.20 | Brian Paul | |
2008-11-07 | mesa: add support for 'invariant' keyword for GLSL 1.20 | Brian Paul | |
2008-11-07 | mesa: reformat comments, rewrap lines, etc for a little better readability | Brian Paul | |
2008-11-07 | mesa: forgot sqrt in NRM3/4 instructions | Brian Paul | |
2008-11-07 | mesa: fix opcode table order bug | Brian Paul | |
2008-11-07 | mesa: add GLSL support for DP2, NRM3, NRM4 instructions (not actually ↵ | Brian Paul | |
emitted yet though) | |||
2008-11-07 | mesa: added DP2, DP2A instructions | Brian Paul | |
2008-11-07 | mesa: added AND/OR/NOT/XOR instructions | Brian Paul | |
2008-11-07 | mesa: include shader/prog_instruction.h | Brian Paul | |
Seems to fix a mysteriously missing build dependency. | |||
2008-11-07 | mesa: added OPCODE_NRM3/NRM4 instructions for vector normalization. | Brian Paul | |
We may emit these instructions from GLSL instead of DP3/RCP/MUL. Also, implement SSG (set sign) instruction in the interpreter. | |||
2008-11-07 | mesa: use _bfc0 instead of _col0 when building back face lighting. | Xiang, Haihao | |