AgeCommit message (Collapse)AuthorFilesLines
2014-08-28st/egl: cleanup sw winsys header inclusionsEmil Velikov6-12/+8
- Drop duplicate include compiler directives. - Leave the sw/ prefix for all the software winsys headers. Signed-off-by: Emil Velikov <>
2014-08-28winsys/radeon: move radeon_cs_dump.h to drmEmil Velikov2-2/+2
... to ease packaging (make dist). Update it to fetch libdrm's include/libs via pkg-config. Cc: Marek Olšák <> Cc: Michel Dänzer <> Signed-off-by: Emil Velikov <> Reviewed-by: Marek Olšák <>
2014-08-28gallium/radeon: cleanup header inclusionEmil Velikov32-36/+36
- Add top_srcdir/src/gallium/winsys to GALLIUM_DRIVER_C{XXFLAGS}. - Remove top_srcdir/src/gallium/drivers/radeon from the includes. As a result: - Common radeon headers are prefixed with 'radeon/' - Winsys header inclusion is prefixed 'radeon/drm' Cc: Marek Olšák <> Cc: Michel Dänzer <> Signed-off-by: Emil Velikov <> Reviewed-by: Marek Olšák <>
2014-08-28winsys/svga: build: cleanup the includesEmil Velikov2-6/+1
gallium/drivers is already part fo GALLIUM_WINSYS_CFLAGS. Signed-off-by: Emil Velikov <>
2014-08-28winsys/i915: remove the software winsysEmil Velikov8-490/+0
We stopped building it recently as it was unused and not tested. Good bye, it's been nice knowing you :) Cc: Stephane Marchesin <> Signed-off-by: Emil Velikov <> Acked-by: Stephane Marchesin <>
2014-08-28gallium/ilo: cleanup intel_winsys.hEmil Velikov7-8/+13
Make the header location, inclusion and contents more common with its i915,r* and nouveau counterparts: - Move the header within drivers/ilo. - Separate out intel_winsys_create_for_fd into 'drm_public' header. - Cleanup the compiler includes. v2: Move the header to drivers/ilo. Suggested by Chia-I. v3: Correct intel_winsys.h inclusion. Spotted by Chia-I. Cc: Chia-I Wu <> Signed-off-by: Emil Velikov <> Reviewed-by: Chia-I Wu <>
2014-08-27docs: mark GL_MAX_VERTEX_ATTRIB_STRIDE as doneTimothy Arceri1-1/+1
Signed-off-by: Timothy Arceri <> Reviewed-by: Ian Romanick <>
2014-08-27gallium: add cap for MAX_VERTEX_ATTRIB_STRIDETimothy Arceri16-0/+37
Signed-off-by: Timothy Arceri <> Reviewed-by: Roland Scheidegger <>
2014-08-27mesa: implement GL_MAX_VERTEX_ATTRIB_STRIDETimothy Arceri5-0/+32
V2: moved test for the VertexAttrib*Pointer() functions to update_array(), and made constant available for drivers to set Signed-off-by: Timothy Arceri <> Reviewed-by: Ian Romanick <>
2014-08-28st/clover: Fix build against LLVM SVN >= r216583Michel Dänzer1-0/+5
Reviewed-by: Francisco Jerez <>
2014-08-28draw: fix base instance handling in llvm pathRoland Scheidegger5-12/+20
The base instance needs to be passed to the jited function, otherwise the instanced data fetch will only work with the same start instance when the jit function was created (and baking that into the key instead is not a viable option). This fixes piglit arb_base_instance-drawarrays (modulo some unrelated core/compat context trouble I get for the test). And fix the pipe cap bit in llvmpipe for it now that it actually works (it already worked for softpipe). Reviewed-by: Jose Fonseca <>
2014-08-28docs: fix up status of softpipe, llvmpipeRoland Scheidegger1-19/+21
The docs were never really up to date for them, missing just about everything. So mark them off as all done for GL 3.3 (though softpipe is in fact quite broken for some newer things especially wrt texturing, and both don't have compliant, real msaa support). And add the extensions missing too (no guarantee of completeness). Reviewed-by: Dave Airlie <>
2014-08-27glsl: Add strings.h on non-MSC platformsAlexander von Gluck IV1-0/+3
* IEEE Std 1003.1-2001 placed strcasecmp() in strings.h. * ISO C99 doesn't mention strcase* in string.h * On all platforms I could find, strcasecmp is in strings.h and string.h as a compatibility layer for software written pre-2001 POSIX * Technically strcasecmp should be only in strings.h and the man pages back this up. * Tested build on CentOS and Haiku Reviewed-by: Kenneth Graunke <>
2014-08-27radeon/uvd: remove comment about RV770Alex Deucher1-1/+0
It doesn't seem to support field based decode after testing. Signed-off-by: Alex Deucher <> Reviewed-by: Christian König <>
2014-08-26radeon/uvd: fix field handling on R6XX style UVDChristian König1-2/+5
The first UVD generation can only do frame based output. Signed-off-by: Christian König <>
2014-08-26vl/compositor: set the scissor before clearing the render targetChristian König1-1/+1
Otherwise we clear areas that shouldn't be cleared. Signed-off-by: Christian König <> Reviewed-by: Ilia Mirkin <> Cc:
2014-08-26st/vdpau: fix vlVdpOutputSurfaceRender(Output|Bitmap)SurfaceChristian König3-15/+71
Correctly handle that the source_surface is only optional. Bugzilla: Signed-off-by: Christian König <> Reviewed-by: Ilia Mirkin <> Cc:
2014-08-26ilo: use genhw command opcodesChia-I Wu5-134/+184
Replace ILO_GPE_MI and ILO_GPE_CMD with magic values by descriptive genhw macros.
2014-08-26ilo: rename intel_bo_map_unsynchronized()Chia-I Wu4-13/+11
Rename it to intel_bo_map_gtt_async().
2014-08-26ilo: remove max_batch_sizeChia-I Wu5-14/+4
It is used to derive an artificial limit on max relocs per bo. We choose not to export it anymore.
2014-08-26ilo: replace domains by reloc flagsChia-I Wu11-125/+90
It is simpler and is supported by the kernel. It cannot be used with libdrm_intel yet though.
2014-08-26docs: Update who is working on tessellationChris Forbes1-1/+1
Signed-off-by: Chris Forbes <>
2014-08-26glsl: Remove bogus "OUPTUT" tokenChris Forbes1-1/+1
This is never used. There is another token "OUTPUT" which the lexer can generate, though. This has been around since the dawn of time; is most likely a typo. Signed-off-by: Chris Forbes <>
2014-08-25radeonsi: handle PIPE_BIND_BLENDABLEMarek Olšák1-1/+5
Reviewed-by: Michel Dänzer <>
2014-08-25r600g: only set PIPE_BIND_BLENDABLE if colorbuffer rendering is supportedMarek Olšák2-20/+10
Reviewed-by: Michel Dänzer <>
2014-08-25r300g: handle PIPE_BIND_BLENDABLEMarek Olšák1-1/+44
Reviewed-by: Michel Dänzer <>
2014-08-24vc4: Stop doing qpu_inst(add, NOP) or qpu_inst(NOP, mul).Eric Anholt1-84/+47
Now that the extra WADDR is set, we can knock this off. Saves a lot of typing, and makes this code much more legible.
2014-08-24vc4: Set the other WADDR in the qpu instruction helpers.Eric Anholt1-1/+5
Now you don't need to qpu_inst() your instruction with a NOP to get the other waddr set.
2014-08-24vc4: Merge qpu_a_NOP() and qpu_m_NOP to a single qpu_NOP() helper.Eric Anholt3-57/+45
Now that qpu_inst() ignores the WADDR from the other half of the instruction, we can set both the ADD and MUL WADDRs in the NOP helper. Thanks to that, we also no longer need to qpu_inst(NOP, NOP).
2014-08-24vc4: Ignore WADDRs from the other half of the instruction when merging.Eric Anholt1-1/+2
This allows setting the opposite-side WADDR to NOP (a non-zero value) in qpu_* helpers, so that we don't need to qpu_inst() merge them with NOPs all the time just to get the waddr set.
2014-08-24vc4: Fix LT/GE set-0-or-1 compares.Eric Anholt1-1/+1
We were using the integer sub, which worked for the common case of EQ and NE. Fixes fs-lessThan-ivec2-ivec2 and other tests.
2014-08-24u_vbuf: Add a few more format fallbacks.Eric Anholt1-0/+32
Fixes piglit draw-vertices and gl-2.0-vertexattribpointer on vc4, where I'm only advertising R32F to RGBA32F support so far. Note: regresses gl-1.5-normal3b3s-invariance due to introduced flushes and missing depth buffer load/store support in the driver. Reviewed-by: Marek Olšák <>
2014-08-24u_vbuf: Simplify the format fallback translation.Eric Anholt3-117/+87
Individual caps made supporting new fallbacks more complicated than it needed to be. Instead, just make a table of fallbacks at context init time. v2: Fix inverted "do we need to install vbuf?" flagging caught by Marek. Reviewed-by: Marek Olšák <> (v2)
2014-08-24freedreno/a2xx: fix segfaultRob Clark1-0/+1
Signed-off-by: Rob Clark <>
2014-08-24freedreno/a3xx: handle first/last level properlyRob Clark3-9/+13
Fixes some assumptions about first_level being zero. Signed-off-by: Rob Clark <>
2014-08-24freedreno: implement pipe_flush_resource()Rob Clark1-1/+5
Signed-off-by: Rob Clark <>
2014-08-24freedreno: don't ignore src/dst levelRob Clark1-39/+63
Don't ignore src/dst_level in pipe_copy_region. Signed-off-by: Rob Clark <>
2014-08-23vc4: Fix save/restore of the VS/FS in the blitter.Eric Anholt1-2/+2
When I made the shader cache take the .fs member and moved the binding point to .bind_fs, I failed to update these. Fixes crashes in copyteximage-related tests.
2014-08-23vc4: Clear padding of ioctl arguments.Eric Anholt1-0/+1
Fixes valgrind complaints from valgrind being unaware of our ioctls.
2014-08-22auxilary/os: Add Solaris support in os_get_total_physical_memory.Vinson Lee1-2/+2
The patch fixes the build on Oracle Solaris. CC os/os_misc.lo "os/os_misc.c", line 59: #error: unexpected platform in os_sysinfo.c Signed-off-by: Vinson Lee <> Reviewed-by: Emil Velikov <>
2014-08-22gallium/targets: Haiku, Fix some improper type warningsAlexander von Gluck IV2-2/+2
2014-08-22gallium/targets: Clean up Haiku softpipe renderer visualAlexander von Gluck IV2-102/+98
* Drop creating gl_config first as it's only really used to create the state tracker visual.
2014-08-22glcpp: Don't use alternation in the lookahead for empty pragmas.Carl Worth1-2/+8
We've found that there's a buffer overrun bug in flex that's triggered by using alternation in a lookahead pattern. Fortunately, we don't need to match the exact {NEWLINE} expression to detect an empty pragma. It suffices to verify that there are no non-space characters before any newline character. So we can use a simple [\r\n] to get the desired behavior while avoiding the flex bug. Fixes the regression of piglit's 17000-consecutive-chars-identifier test, (which has been crashing since commit 04e40fd337a244ee77ef9553985e9398ff0344af ). Bugzilla: Signed-off-by: Carl Worth <> Reviewed-by: Kenneth Graunke <> CC: <>
2014-08-22i965: Disable try_emit_b2f_of_compare on Gen4-6.Kenneth Graunke1-0/+7
The optimization relies on CMP setting the destination to 0, which is equivalent to 0.0f. However, early platforms only set the least significant byte, leaving the other bits undefined. So, we must disable the optimization on those platforms. Oddly, Sandybridge wasn't reported as broken. The PRM states that it only sets the LSB, but the internal documentation says that it follows the IVB behavior. Since it wasn't reported as broken, we believe it really does follow the IVB behavior. v2: Allow the optimization on Sandybridge (requested by Matt). +32 piglits on Ironlake. Bugzilla: Signed-off-by: Kenneth Graunke <> Reviewed-by: Chris Forbes <> Reviewed-by: Matt Turner <>
2014-08-22i965/fs: Preserve CFG in predicated break pass.Matt Turner1-4/+25
Operating on this code, B0: ... (+f0) if(8) B1: break(8) B2: endif(8) We can delete B2 without attempting to merge any blocks, since the break/continue instruction necessarily ends the previous block. After deleting the if instruction, we attempt to merge blocks B0 and B1. Reviewed-by: Topi Pohjolainen <>
2014-08-22i965/fs: Rename variable in predicated break pass.Matt Turner1-7/+8
Reviewed-by: Topi Pohjolainen <>
2014-08-22i965/fs: Preserve CFG in the SEL peephole.Matt Turner1-6/+9
Reviewed-by: Topi Pohjolainen <>
2014-08-22i965: Preserve CFG when deleting dead control flow.Matt Turner1-9/+45
This pass deletes an IF/ELSE/ENDIF or IF/ENDIF sequence, or the ELSE in an ELSE/ENDIF sequence. In the typical case (where IF and ENDIF) aren't the only instructions in their basic blocks, we can simply remove the instructions (implicitly deleting the block containing only the ELSE), and attempt to merge blocks B0 and B2 together. B0: ... (+f0) if(8) B1: else(8) B2: endif(8) ... If the IF or ENDIF instructions are the only instructions in their respective basic blocks (which are deleted by the removal of the instructions), we'll want to instead merge the next blocks. Both B0 and B2 are possibly removed by the removal of if & endif. Same situation for if/endif. E.g., in the following example we'd remove blocks B1 and B2, and then attempt to combine B0 and B3. B0: ... B1: (+f0) if(8) B2: endif(8) B3: ... Reviewed-by: Topi Pohjolainen <>
2014-08-22i965/cfg: Add functions to combine basic blocks.Matt Turner2-0/+54
Reviewed-by: Topi Pohjolainen <>
2014-08-22i965/cfg: Point to bblock_t containing associated control flowMatt Turner3-27/+15
... rather than pointing directly to the associated instruction. This will let us set the block containing the IF statement's else-pointer to NULL, when we delete a useless ELSE instruction, as in the case (+f0) if(8) ... else(8) endif(8) Also, remove the pointer to the ENDIF, since it's unused, and it was also potentially wrong, in the case of a basic block containing both an ENDIF and an IF instruction: endif(8) ... (+f0) if(8) Reviewed-by: Topi Pohjolainen <>