Christoph Bumiller [Tue, 17 Aug 2010 13:27:56 +0000 (15:27 +0200)]
nv50: check dst compatibility in CSE
Christoph Bumiller [Tue, 17 Aug 2010 11:07:12 +0000 (13:07 +0200)]
nv50: fix PSIZ and PRIMID mapping
Initializing map to 0x40 (0x80) instead of 0 now, so need to clear
it first.
Christoph Bumiller [Tue, 17 Aug 2010 09:51:51 +0000 (11:51 +0200)]
nv50: more TGSI opcodes (SIN, SCS, ARL, RET, KILP)
Christoph Bumiller [Mon, 16 Aug 2010 16:00:39 +0000 (18:00 +0200)]
nv50: generate JOINs for outermost IF clauses
Christoph Bumiller [Mon, 16 Aug 2010 15:18:30 +0000 (17:18 +0200)]
nv50: fix thinko in store to output reg possible check
Christoph Bumiller [Mon, 16 Aug 2010 13:21:23 +0000 (15:21 +0200)]
nv50: flatten simple IF/ELSE/ENDIF constructs
Less branching means less instructions and less thread divergence.
Christoph Bumiller [Sun, 15 Aug 2010 19:37:50 +0000 (21:37 +0200)]
nv50: loops part 2
At least the mesa demo glsl/mandelbrot should work now.
Christoph Bumiller [Wed, 11 Aug 2010 16:44:26 +0000 (18:44 +0200)]
nv50: more constant folding
Christoph Bumiller [Tue, 10 Aug 2010 15:36:25 +0000 (17:36 +0200)]
nv50: begin implementing loops
Christoph Bumiller [Thu, 5 Aug 2010 10:29:23 +0000 (12:29 +0200)]
nv50: fix reg count
Christoph Bumiller [Wed, 4 Aug 2010 22:11:56 +0000 (00:11 +0200)]
nv50: build proper phi functions in the first place
Christoph Bumiller [Sat, 31 Jul 2010 19:30:35 +0000 (21:30 +0200)]
nv50: fix constbuf validation
We only uploaded up to the highest offset a program would use,
and if the constant buffer isn't changed when a new program is
used, the new program is missing the rest of them.
Might want to introduce a "fill state" for user mem constbufs.
Christoph Bumiller [Sat, 31 Jul 2010 18:56:42 +0000 (20:56 +0200)]
nv50: don't eliminate loads to dedicated values
Christoph Bumiller [Sat, 31 Jul 2010 15:52:54 +0000 (17:52 +0200)]
nv50: fixes for nested IFs
Christoph Bumiller [Tue, 27 Jul 2010 16:25:37 +0000 (18:25 +0200)]
nv50: explicitly set src type for SET ops
Need to do this more nicely for all ops.
Christoph Bumiller [Tue, 27 Jul 2010 15:56:13 +0000 (17:56 +0200)]
nv50: insert MOVs also for PHI sources from dominating block
Otherwise we get live range conflicts for operands that are written
only in e.g. an ELSE block but not the IF block.
Christoph Bumiller [Mon, 26 Jul 2010 13:06:58 +0000 (15:06 +0200)]
nv50: fix for empty BBs
Christoph Bumiller [Mon, 26 Jul 2010 09:32:27 +0000 (11:32 +0200)]
nv50: add signed RGTC1 to format table, allow 2_10_10_10 for vbufs
Christoph Bumiller [Mon, 26 Jul 2010 09:18:56 +0000 (11:18 +0200)]
nv50: add missing 2nd source for POW multiplication
Christoph Bumiller [Sun, 25 Jul 2010 22:56:12 +0000 (00:56 +0200)]
nv50: permit usage of undefined TGSI TEMPs
Christoph Bumiller [Sun, 25 Jul 2010 21:32:18 +0000 (23:32 +0200)]
nv50: fix constant_operand opt mul by 2 case
Christoph Bumiller [Sun, 25 Jul 2010 20:21:38 +0000 (22:21 +0200)]
nv50: simple reload elimination and local CSE
Christoph Bumiller [Sat, 24 Jul 2010 20:16:05 +0000 (22:16 +0200)]
nv50: add/fix some license headers
Christoph Bumiller [Sat, 24 Jul 2010 19:18:51 +0000 (21:18 +0200)]
nv50: change back accidentally swapped UNORM,SNORM vertex type
Christoph Bumiller [Sat, 24 Jul 2010 19:17:21 +0000 (21:17 +0200)]
nv50: don't produce MOV immediate to output reg in store opt
Christoph Bumiller [Sat, 24 Jul 2010 12:46:44 +0000 (14:46 +0200)]
nv50: introduce the big formats table
Christoph Bumiller [Sat, 24 Jul 2010 10:49:15 +0000 (12:49 +0200)]
nouveau: update nouveau_class.h
Adds nvc0, new vertex formats, and dual source blending values.
Christoph Bumiller [Fri, 23 Jul 2010 19:21:25 +0000 (21:21 +0200)]
nv50: import new compiler
Eric Anholt [Fri, 23 Jul 2010 17:01:45 +0000 (10:01 -0700)]
i965: Cleanly fail programs with unsupported array access.
This should be more useful for developers and for bug triaging than
just generating wrong code.
Eric Anholt [Fri, 23 Jul 2010 17:34:29 +0000 (10:34 -0700)]
i965: Add support for VS relative addressing of temporary arrays.
Fixes glsl-vs-arrays. Bug #27388.
Brian Paul [Fri, 23 Jul 2010 16:32:25 +0000 (10:32 -0600)]
draw: add small ybias factor for drawing wide points
Fixes minor rasterization error detected by some tests.
Brian Paul [Thu, 22 Jul 2010 22:55:41 +0000 (16:55 -0600)]
docs: document new extensions for Gallium
Michal Krol [Thu, 22 Jul 2010 16:32:50 +0000 (18:32 +0200)]
softpipe: Check for NULL pointer in sp_destroy_tile_cache().
Michal Krol [Thu, 22 Jul 2010 16:32:31 +0000 (18:32 +0200)]
softpipe: Check for NULL pointer in sp_destroy_tex_tile_cache().
Christoph Bumiller [Fri, 23 Jul 2010 10:03:33 +0000 (12:03 +0200)]
nv50: implement depth clamp
Thomas Hellstrom [Fri, 23 Jul 2010 02:44:26 +0000 (04:44 +0200)]
xorg/vmwgfx: Implement early mode pruning based on max fb size.
Also move some initialization from screen init to pre-init, now
that it is possible.
Also import a new vmwgfx drm (1.3) header.
Signed-off-by: Thomas Hellstrom <thellstrom@vmware.com>
Thomas Hellstrom [Fri, 23 Jul 2010 02:36:43 +0000 (04:36 +0200)]
st/xorg: Init the Gallium3D / libkms resources in pre-init.
This makes it possible to prune modes already in pre-init.
We also keep these resources alive across server generations, and
they are implicitly closed on server exit.
Signed-off-by: Thomas Hellstrom <thellstrom@vmware.com>
Thomas Hellstrom [Thu, 22 Jul 2010 01:41:10 +0000 (03:41 +0200)]
st/xorg: Kill a couple of compilation warnings
Signed-off-by: Thomas Hellstrom <thellstrom@vmware.com>
Thomas Hellstrom [Thu, 22 Jul 2010 00:05:35 +0000 (02:05 +0200)]
st/xorg vmwgfx/xorg: Add a pre-init customizer callback
Add a customizer callback just before initial config setting, so that the
customizer code can initialize the mode validator using the drm
file-descriptor.
Signed-off-by: Thomas Hellstrom <thellstrom@vmware.com>
Thomas Hellstrom [Wed, 21 Jul 2010 23:49:46 +0000 (01:49 +0200)]
st/xorg: Add a possibility to prune modes and limit fb allocation size based on max fb size.
Signed-off-by: Thomas Hellstrom <thellstrom@vmware.com>
Jakob Bornecrantz [Fri, 23 Jul 2010 03:18:51 +0000 (20:18 -0700)]
llvmpipe: Partially fix resource texture from_handle
Jakob Bornecrantz [Fri, 23 Jul 2010 03:17:35 +0000 (20:17 -0700)]
llvmpipe: Don't align values already aligned
Jakob Bornecrantz [Fri, 23 Jul 2010 03:13:02 +0000 (20:13 -0700)]
i915g: Rename winsys debug options
Jakob Bornecrantz [Fri, 23 Jul 2010 03:11:20 +0000 (20:11 -0700)]
i915g: Allow wrapping with software pipes
Jakob Bornecrantz [Fri, 23 Jul 2010 03:03:29 +0000 (20:03 -0700)]
i915g: Set total_nblocksy in from_handle
Jakob Bornecrantz [Fri, 23 Jul 2010 03:02:58 +0000 (20:02 -0700)]
i915g: Add some debug prints in texture code
Jakob Bornecrantz [Fri, 23 Jul 2010 03:00:28 +0000 (20:00 -0700)]
i915g: Ifdef out debug code on non-debug builds
Jakob Bornecrantz [Fri, 16 Jul 2010 04:11:24 +0000 (21:11 -0700)]
tgsi: Fix error message on invalid swizzle parse
Kristian Høgsberg [Fri, 23 Jul 2010 02:36:37 +0000 (22:36 -0400)]
glx: Drop screen argument to GetGLXDRIDrawable
We'll just get it from the returned drawable when we need it.
Kristian Høgsberg [Fri, 23 Jul 2010 02:24:00 +0000 (22:24 -0400)]
glx: Move WaitGL, WaitX, UseXFont to context vtable functions
Kristian Høgsberg [Fri, 23 Jul 2010 01:24:14 +0000 (21:24 -0400)]
glx: Allocate the __GLXcontext in the DRI drivers
Kristian Høgsberg [Fri, 23 Jul 2010 01:11:02 +0000 (21:11 -0400)]
glx: Use _Xglobal_lock for protecting extension display list
Avoids double locking glXLock in the X wire to event handlers.
Brian Paul [Thu, 22 Jul 2010 22:35:43 +0000 (16:35 -0600)]
glsl: remove invalid _mesa_problem() call
Fixes fd.o bug 29206.
Brian Paul [Thu, 22 Jul 2010 22:07:18 +0000 (16:07 -0600)]
draw: re-order optimization passes depending on LLVM version, 32/64-bit
This is a work-around for an apparent bug in LLVM seen with piglit's
glsl-vs-sqrt-zero test.
Brian Paul [Thu, 22 Jul 2010 17:18:45 +0000 (11:18 -0600)]
draw: added new assertions to clipping code
Eric Anholt [Thu, 22 Jul 2010 17:04:24 +0000 (10:04 -0700)]
i965: Respect VS/VP point size result when enabled.
Fixes glsl-vs-point-size.
Eric Anholt [Thu, 22 Jul 2010 08:53:43 +0000 (01:53 -0700)]
i965: Fix the disasm output for da16 src widths.
This has confused me twice now. It's a fixed width of 4 (usually a
region description of <4,4,1>), not 1. If it was 1, we'd have been
skipping all over register space.
Eric Anholt [Thu, 22 Jul 2010 08:27:15 +0000 (01:27 -0700)]
i965: Avoid extra MOV in VS indirect register reads.
Eric Anholt [Thu, 22 Jul 2010 07:06:10 +0000 (00:06 -0700)]
i965: Fix up VS temporary array access for fixed index offset != 0.
Henri Verbeet [Thu, 22 Jul 2010 15:10:11 +0000 (11:10 -0400)]
r600: Flip point sprite coordinates when rendering to an FBO.
This supersedes http://lists.freedesktop.org/archives/mesa-dev/2010-July/001442.html.
Eric Anholt [Thu, 22 Jul 2010 04:45:34 +0000 (21:45 -0700)]
i965: In the VS, multiply the address reg by the appropriate register size.
The ARL value is increments of vec4 in the register file. But
PROGRAM_TEMPORARY or PROGRAM_INPUT are stored as vec4s interleaved
between the two verts being executed (thus a vec8 each), compared to
PROGRAM_STATE_VAR being packed vec4s.
Fixes:
glsl-vs-arrays-2
glsl-vs-mov-after-deref
(without regressing glsl-vs-arrays-3)
Eric Anholt [Thu, 22 Jul 2010 02:49:39 +0000 (19:49 -0700)]
i965: Clean up brw_dp_READ_4_vs() now that it has fewer options to support.
Eric Anholt [Thu, 22 Jul 2010 01:29:06 +0000 (18:29 -0700)]
i965: Support relative addressed VS constant reads using the appropriate msg.
The previous support was overly complicated by trying to use the same
1-OWORD message for both offsets.
Eric Anholt [Thu, 22 Jul 2010 01:41:06 +0000 (18:41 -0700)]
i965: Fix the DP read msg_control definitions other than plain OWORD.
Eric Anholt [Thu, 22 Jul 2010 00:35:21 +0000 (17:35 -0700)]
i965: Clean up dead code from the VS get_constant/get_reladdr_constant split.
Eric Anholt [Wed, 21 Jul 2010 22:54:53 +0000 (15:54 -0700)]
i956: Set the execution size correctly for scratch space writes.
Otherwise, the second half isn't written, and we end up reading back
black.
Fixes the remaining junk drawn in glsl-max-varyings, and will likely
help with a number of large real-world shaders.
Eric Anholt [Wed, 21 Jul 2010 20:52:37 +0000 (13:52 -0700)]
i965: Set the GEM domain flags for the scratch space.
They go into the render cache, so while we don't care about their
contents after execution, failing to note them could cause the writes
to be flushed over important buffer contents later.
Eric Anholt [Wed, 21 Jul 2010 20:49:14 +0000 (13:49 -0700)]
i965: Use the pretty define for 4-oword DP reads.
Eric Anholt [Wed, 21 Jul 2010 20:07:12 +0000 (13:07 -0700)]
i965: Set the send commit bit on register spills as required pre-gen6.
Otherwise, the subsequent read may not get the written value.
Eric Anholt [Wed, 21 Jul 2010 18:19:52 +0000 (11:19 -0700)]
i965: Add disasm for dataport reads (register unspilling).
Kristian Høgsberg [Wed, 21 Jul 2010 18:09:49 +0000 (14:09 -0400)]
glx: Move last few dri_interface.h types out of glxclient.h and drop include
Kristian Høgsberg [Wed, 21 Jul 2010 17:55:30 +0000 (13:55 -0400)]
glx: Move __driContext field out of __GLXcontextRec
Brian Paul [Wed, 21 Jul 2010 22:48:45 +0000 (16:48 -0600)]
softpipe: add missing support for PIPE_FORMAT_S8_USCALED surfaces
And remove checks of surface depth bits. The state tracker should
not turn on depth/stencil testing if the framebuffer doesn't have
depth/stencil.
Brian Paul [Wed, 21 Jul 2010 22:00:42 +0000 (16:00 -0600)]
softpipe: fix sp_tile_cache_flush_clear() regression
Jerome Glisse [Wed, 21 Jul 2010 21:40:37 +0000 (17:40 -0400)]
Revert "dri2: Remove an unused variable."
glx_info is used if X_DRI2SwapBuffers is defined
This reverts commit
c0ca2bfb2ad8cf7fb9d756b5ae52cb77236ff605.
Jerome Glisse [Wed, 21 Jul 2010 21:03:38 +0000 (17:03 -0400)]
r600g: add support for all R6XX/R7XX asic
This configure some of the value properly based on
asic so others asic than RV710 works too.
Signed-off-by: Jerome Glisse <jglisse@redhat.com>
Dave Airlie [Wed, 21 Jul 2010 05:39:23 +0000 (15:39 +1000)]
r600g: add r600 compile mode to compiler.
some of the ALU instructions are different on r6xx vs r7xx,
separate the alu translation to separate files, and use family
to pick which compile stage to use.
Dave Airlie [Wed, 21 Jul 2010 05:39:01 +0000 (15:39 +1000)]
r600g: add family retrival
allow pipe driver to get the family of the gpu.
Marek Olšák [Wed, 21 Jul 2010 20:31:59 +0000 (22:31 +0200)]
llvmpipe: say no to depth clamp
The other drivers just return 0 without the assert.
Marek Olšák [Tue, 20 Jul 2010 14:37:22 +0000 (16:37 +0200)]
r300g: implement depth clamp
Depth clamping seems to be implicit if clipping is disabled.
It's not perfect, but it's good enough for wine and passes
the corresponding piglit tests.
Marek Olšák [Wed, 21 Jul 2010 18:41:04 +0000 (20:41 +0200)]
r300g: cleanup clip state emission
Marek Olšák [Wed, 21 Jul 2010 18:31:39 +0000 (20:31 +0200)]
draw: disable depth clipping if depth clamp is enabled
Marek Olšák [Wed, 21 Jul 2010 07:14:43 +0000 (09:14 +0200)]
st/mesa: implement depth clamp
Marek Olšák [Wed, 21 Jul 2010 07:14:21 +0000 (09:14 +0200)]
cso: handle depth clamp
Marek Olšák [Wed, 21 Jul 2010 07:13:53 +0000 (09:13 +0200)]
gallium: add depth clamp to the interface
Carl Worth [Wed, 21 Jul 2010 20:26:26 +0000 (13:26 -0700)]
Add missing initialization of inOutFlags pointer.
This quiets a compiler warning, (and ensures a segmentation fault rather
than memory corruption if this variable is written through before being
initialized elsewhere).
Carl Worth [Tue, 20 Jul 2010 22:59:56 +0000 (15:59 -0700)]
Makefiles: Don't complain if depend file to be included doesn't exist.
While bootstrapping the dependencies, make will see the "include depend"
directive before the depend file has been created. To avoid a spurious
warning in this case we use "-include" instead, (which differs precisely
in the fact that it will not emit a diagnostic if the named file does
not exist).
Carl Worth [Wed, 21 Jul 2010 20:17:22 +0000 (13:17 -0700)]
i965: Remove an unused variable.
To quiet a compiler warning.
Carl Worth [Wed, 21 Jul 2010 20:17:05 +0000 (13:17 -0700)]
dri2: Remove an unused variable.
To quiet a compiler warning.
Carl Worth [Wed, 21 Jul 2010 20:13:46 +0000 (13:13 -0700)]
Regenerate program/lex.yy.c
Based on the two recent changes to program_lexer.l.
Carl Worth [Wed, 21 Jul 2010 20:11:46 +0000 (13:11 -0700)]
Avoid more warnings in flex-generated code.
This avoids two "function defined but not used" warnings. For the yyinput
function we define YY_NO_INPUT which tells flex to simply not generate this
function.
For unput, we add a call to this function, but inside a while(0) so
that it will quiet the warning without actually changing any
functionality.
Carl Worth [Wed, 21 Jul 2010 19:49:01 +0000 (12:49 -0700)]
Avoid warnings in flex-generated code.
Add declarations for two functions generated in the flex ouput. It
would be nicer if flex simply declared these generated functions as
static, but for now we can at least avoid the warning this way.
Brian Paul [Wed, 21 Jul 2010 17:37:13 +0000 (11:37 -0600)]
draw: tweak aa line width threshold and sampling
Set sampler max_lod to avoid sampling the 1x1 and 2x2 mipmap levels.
Fixes piglit line-aa-width test, fd.o bug 29160.
Patrice Mandin [Wed, 21 Jul 2010 17:28:45 +0000 (19:28 +0200)]
nouveau/nvfx: Add new PIPE_CAP values
Signed-off-by: Patrice Mandin <patmandin@gmail.com>
Brian Paul [Wed, 21 Jul 2010 15:59:23 +0000 (09:59 -0600)]
gallivm: replace has_indirect_addressing field with indirect_files field
Instead of one big boolean indicating indirect addressing, use a
bitfield indicating which register files are accessed with indirect
addressing.
Most shaders that use indirect addressing only use it to access the
constant buffer. So no need to use an array for temporary registers
in this case.
Brian Paul [Wed, 21 Jul 2010 15:51:11 +0000 (09:51 -0600)]
tgsi: added tgsi_shader_info::indirect_files field
Indicates which register files are accessed with indirect addressing.
Brian Paul [Wed, 21 Jul 2010 15:42:11 +0000 (09:42 -0600)]
gallivm: refactor code into get_indirect_offsets() function
Brian Paul [Wed, 21 Jul 2010 15:17:47 +0000 (09:17 -0600)]
gallivm: added comment
Brian Paul [Wed, 21 Jul 2010 15:16:02 +0000 (09:16 -0600)]
gallivm: remove extraneous braces
Brian Paul [Wed, 21 Jul 2010 15:15:30 +0000 (09:15 -0600)]
gallivm: no longer do indirect addressing in get_temp_ptr()