mesa.git
15 years agollvmpipe: Replace lp_fs_llvm.c.
José Fonseca [Tue, 11 Aug 2009 12:19:16 +0000 (13:19 +0100)]
llvmpipe: Replace lp_fs_llvm.c.

Based on lp_fs_exec.c/lp_fs_sse.c and tgsi_exec.c.

15 years agollvmpipe: TGSI -> LLVM SoA IR converstion.
José Fonseca [Tue, 11 Aug 2009 12:17:24 +0000 (13:17 +0100)]
llvmpipe: TGSI -> LLVM SoA IR converstion.

Based on tgsi_sse2.c.

15 years agollvmpipe: Dump only the generated function.
José Fonseca [Tue, 11 Aug 2009 12:10:15 +0000 (13:10 +0100)]
llvmpipe: Dump only the generated function.

15 years agollvmpipe: Scalar -> vector broadcasting.
José Fonseca [Tue, 11 Aug 2009 12:09:54 +0000 (13:09 +0100)]
llvmpipe: Scalar -> vector broadcasting.

15 years agollvmpipe: More arithmetic ops.
José Fonseca [Tue, 11 Aug 2009 12:09:35 +0000 (13:09 +0100)]
llvmpipe: More arithmetic ops.

Mostly untested.

15 years agollvmpipe: More intrinsic helpers.
José Fonseca [Mon, 10 Aug 2009 22:22:40 +0000 (23:22 +0100)]
llvmpipe: More intrinsic helpers.

15 years agollvmpipe: Fix typo.
José Fonseca [Mon, 10 Aug 2009 15:12:51 +0000 (16:12 +0100)]
llvmpipe: Fix typo.

15 years agoutil: Fix SCons build.
José Fonseca [Mon, 10 Aug 2009 15:12:41 +0000 (16:12 +0100)]
util: Fix SCons build.

15 years agollvmpipe: Document the typo in llvm-c/Core.h.
José Fonseca [Mon, 10 Aug 2009 14:43:04 +0000 (15:43 +0100)]
llvmpipe: Document the typo in llvm-c/Core.h.

15 years agoutil: Auto-generate u_format_table.c from SConscript.
José Fonseca [Mon, 10 Aug 2009 14:23:35 +0000 (15:23 +0100)]
util: Auto-generate u_format_table.c from SConscript.

15 years agollvmpipe: Simple description/instructions.
José Fonseca [Mon, 10 Aug 2009 11:35:16 +0000 (12:35 +0100)]
llvmpipe: Simple description/instructions.

15 years agollvmpipe: Add missing include.
José Fonseca [Mon, 10 Aug 2009 10:37:55 +0000 (11:37 +0100)]
llvmpipe: Add missing include.

15 years agollvmpipe: Tiles in rgba8 format.
José Fonseca [Mon, 10 Aug 2009 07:16:31 +0000 (08:16 +0100)]
llvmpipe: Tiles in rgba8 format.

15 years agollvmpipe: Store tile color in SoA.
José Fonseca [Sun, 9 Aug 2009 22:58:06 +0000 (23:58 +0100)]
llvmpipe: Store tile color in SoA.

15 years agollvmpipe: Code generate color masking.
José Fonseca [Sun, 9 Aug 2009 22:34:01 +0000 (23:34 +0100)]
llvmpipe: Code generate color masking.

15 years agollvmpipe: Use the generated SoA blending code.
José Fonseca [Sun, 9 Aug 2009 22:10:19 +0000 (23:10 +0100)]
llvmpipe: Use the generated SoA blending code.

15 years agollvmpipe: Handle disabled blending too.
José Fonseca [Sun, 9 Aug 2009 21:59:52 +0000 (22:59 +0100)]
llvmpipe: Handle disabled blending too.

15 years agoxlib: Ensure one screen instance.
José Fonseca [Sun, 9 Aug 2009 21:59:12 +0000 (22:59 +0100)]
xlib: Ensure one screen instance.

15 years agollvmpipe: Split the texture cache from the color/depth/stencil cache.
José Fonseca [Sun, 9 Aug 2009 16:22:01 +0000 (17:22 +0100)]
llvmpipe: Split the texture cache from the color/depth/stencil cache.

15 years agoxlib: Complete llvmpipe integration.
José Fonseca [Sun, 9 Aug 2009 16:15:17 +0000 (17:15 +0100)]
xlib: Complete llvmpipe integration.

15 years agollvmpipe: SoA blending.
José Fonseca [Sun, 9 Aug 2009 11:39:38 +0000 (12:39 +0100)]
llvmpipe: SoA blending.

Throughput seems to be 4x higher.

15 years agoutil: Fix blend factor dumping.
José Fonseca [Sun, 9 Aug 2009 11:32:37 +0000 (12:32 +0100)]
util: Fix blend factor dumping.

15 years agollvmpipe: Update blending test.
José Fonseca [Sat, 8 Aug 2009 22:15:05 +0000 (23:15 +0100)]
llvmpipe: Update blending test.

15 years agollvmpipe: Handle more conversions.
José Fonseca [Sat, 8 Aug 2009 22:10:59 +0000 (23:10 +0100)]
llvmpipe: Handle more conversions.

Not all successfully yet though..

15 years agollvmpipe: Use full set of sse4 min/max intrinsics.
José Fonseca [Sat, 8 Aug 2009 21:57:03 +0000 (22:57 +0100)]
llvmpipe: Use full set of sse4 min/max intrinsics.

15 years agollvmpipe: Fix one const generation for some signed integers.
José Fonseca [Sat, 8 Aug 2009 21:56:22 +0000 (22:56 +0100)]
llvmpipe: Fix one const generation for some signed integers.

15 years agollvmpipe: Allow floating types without sign.
José Fonseca [Sat, 8 Aug 2009 21:51:11 +0000 (22:51 +0100)]
llvmpipe: Allow floating types without sign.

With the meaning that all values are assumed to be positive.

15 years agollvmpipe: Centralize lp_build_context initialization.
José Fonseca [Sat, 8 Aug 2009 21:49:23 +0000 (22:49 +0100)]
llvmpipe: Centralize lp_build_context initialization.

15 years agollvmpipe: Normalize the cycles with the number of channel.
José Fonseca [Sat, 8 Aug 2009 19:38:01 +0000 (20:38 +0100)]
llvmpipe: Normalize the cycles with the number of channel.

So that we have a comparable number for different formats.

15 years agollvmpipe: Handle ubyte -> float conversion too.
José Fonseca [Fri, 7 Aug 2009 13:34:13 +0000 (14:34 +0100)]
llvmpipe: Handle ubyte -> float conversion too.

15 years agollvmpipe: Make lp_const_offset visible.
José Fonseca [Fri, 7 Aug 2009 13:33:07 +0000 (14:33 +0100)]
llvmpipe: Make lp_const_offset visible.

15 years agollvmpipe: Only get the preprocessor flags from llvm-config.
José Fonseca [Fri, 7 Aug 2009 13:20:57 +0000 (14:20 +0100)]
llvmpipe: Only get the preprocessor flags from llvm-config.

Otherwise we get -O2 optimization flag, preventing proper debugging.

15 years agollvmpipe: Bootstrap type conversions.
José Fonseca [Fri, 7 Aug 2009 08:51:48 +0000 (09:51 +0100)]
llvmpipe: Bootstrap type conversions.

15 years agollvmpipe: Use same type for reference vectors.
José Fonseca [Fri, 7 Aug 2009 08:51:04 +0000 (09:51 +0100)]
llvmpipe: Use same type for reference vectors.

15 years agollvmpipe: Fix floating point const scale factor.
José Fonseca [Fri, 7 Aug 2009 08:28:58 +0000 (09:28 +0100)]
llvmpipe: Fix floating point const scale factor.

15 years agollvmpipe: Factor out shared test code into a separate module.
José Fonseca [Fri, 7 Aug 2009 00:20:01 +0000 (01:20 +0100)]
llvmpipe: Factor out shared test code into a separate module.

15 years agollvmpipe: Cleanup constant helpers.
José Fonseca [Fri, 7 Aug 2009 00:18:49 +0000 (01:18 +0100)]
llvmpipe: Cleanup constant helpers.

15 years agollvmpipe: Move intrinsic helpers to a separate module.
José Fonseca [Fri, 7 Aug 2009 00:16:59 +0000 (01:16 +0100)]
llvmpipe: Move intrinsic helpers to a separate module.

15 years agollvmpipe: Collect richer blend data.
José Fonseca [Tue, 4 Aug 2009 12:39:28 +0000 (13:39 +0100)]
llvmpipe: Collect richer blend data.

15 years agollvmpipe: Some notes about PSHUF.
José Fonseca [Tue, 4 Aug 2009 11:32:24 +0000 (12:32 +0100)]
llvmpipe: Some notes about PSHUF.

15 years agollvmpipe: Optimize blend swizzles by using bitmasks instead of shuffles for ubytes.
José Fonseca [Tue, 4 Aug 2009 11:09:52 +0000 (12:09 +0100)]
llvmpipe: Optimize blend swizzles by using bitmasks instead of shuffles for ubytes.

15 years agollvmpipe: Write data to a tsv file for posterior analysis.
José Fonseca [Tue, 4 Aug 2009 10:52:54 +0000 (11:52 +0100)]
llvmpipe: Write data to a tsv file for posterior analysis.

15 years agollvmpipe: Move p_build_context to lp_bld_type.h
José Fonseca [Tue, 4 Aug 2009 10:51:13 +0000 (11:51 +0100)]
llvmpipe: Move p_build_context to lp_bld_type.h

As it will be shared with more modules.

15 years agoutil: New file dedicated to dump state in human/machine readable format.
José Fonseca [Tue, 4 Aug 2009 10:50:13 +0000 (11:50 +0100)]
util: New file dedicated to dump state in human/machine readable format.

15 years agollvmpipe: Don't use llvm.readcyclecounter.
José Fonseca [Tue, 4 Aug 2009 01:10:35 +0000 (02:10 +0100)]
llvmpipe: Don't use llvm.readcyclecounter.

LLVM during optimization reorders the rdtsc instructions next to each
other, which makes it pretty useless.

15 years agollvmpipe: Separate constant building.
José Fonseca [Mon, 3 Aug 2009 21:31:08 +0000 (22:31 +0100)]
llvmpipe: Separate constant building.

15 years agollvmpipe: Move type support functions into a separate file.
José Fonseca [Mon, 3 Aug 2009 21:24:01 +0000 (22:24 +0100)]
llvmpipe: Move type support functions into a separate file.

15 years agollvmpipe: Measure the number of cycles taken for blending.
José Fonseca [Mon, 3 Aug 2009 18:35:28 +0000 (19:35 +0100)]
llvmpipe: Measure the number of cycles taken for blending.

15 years agollvmpipe: Minor comments / debug mnemonics.
José Fonseca [Mon, 3 Aug 2009 18:32:57 +0000 (19:32 +0100)]
llvmpipe: Minor comments / debug mnemonics.

15 years agollvmpipe: Optimize away min/max with equal operands.
José Fonseca [Mon, 3 Aug 2009 18:31:56 +0000 (19:31 +0100)]
llvmpipe: Optimize away min/max with equal operands.

15 years agollvmpipe: Improve generated 8bit blending code.
José Fonseca [Mon, 3 Aug 2009 01:06:42 +0000 (02:06 +0100)]
llvmpipe: Improve generated 8bit blending code.

15 years agollvmpipe: Get blending of normalized 8bit unsigned integers working.
José Fonseca [Sun, 2 Aug 2009 23:01:27 +0000 (00:01 +0100)]
llvmpipe: Get blending of normalized 8bit unsigned integers working.

15 years agollvmpipe: Specialize arithmetic operations.
José Fonseca [Sun, 2 Aug 2009 16:54:53 +0000 (17:54 +0100)]
llvmpipe: Specialize arithmetic operations.

15 years agollvmpipe: Introduce a custom typing system.
José Fonseca [Sun, 2 Aug 2009 12:52:40 +0000 (13:52 +0100)]
llvmpipe: Introduce a custom typing system.

Straightforward representation of floating-point/fixed-point/integer,
normalized/scaled, signed/unsigned SIMD vector types.

15 years agollvmpipe: Avoid C99-isms.
José Fonseca [Sun, 2 Aug 2009 12:48:16 +0000 (13:48 +0100)]
llvmpipe: Avoid C99-isms.

15 years agollvmpipe: Factor out intrisic calling code into a reusable function.
José Fonseca [Sun, 2 Aug 2009 08:59:12 +0000 (09:59 +0100)]
llvmpipe: Factor out intrisic calling code into a reusable function.

15 years agollvmpipe: Cleanup test programs.
José Fonseca [Sat, 1 Aug 2009 17:35:04 +0000 (18:35 +0100)]
llvmpipe: Cleanup test programs.

15 years agollvmpipe: Blending.
José Fonseca [Sat, 1 Aug 2009 16:59:19 +0000 (17:59 +0100)]
llvmpipe: Blending.

The code

15 years agollvmpipe: Arithmetic helpers.
José Fonseca [Sat, 1 Aug 2009 16:27:05 +0000 (17:27 +0100)]
llvmpipe: Arithmetic helpers.

15 years agollvmpipe: fastpath for interpolated z16 less depthtesting
Keith Whitwell [Mon, 27 Jul 2009 11:11:16 +0000 (12:11 +0100)]
llvmpipe: fastpath for interpolated z16 less depthtesting

Because this is interpolated (ie. early) depth, we can build in an
assumption about the quads emitted by triangle setup, ie that they
are actually linear spans.  Interpolate z over those spans in z16
format to save on math & conversion.

15 years agollvmpipe: cope with nr_cbufs == 0
Keith Whitwell [Mon, 27 Jul 2009 10:23:51 +0000 (11:23 +0100)]
llvmpipe: cope with nr_cbufs == 0

Disable blend code when no color buffer

15 years agollvmpipe: Translate logicops.
José Fonseca [Wed, 29 Jul 2009 07:29:13 +0000 (08:29 +0100)]
llvmpipe: Translate logicops.

15 years agollvmpipe: Separate pixel packing/unpacking from loading/storing.
José Fonseca [Wed, 29 Jul 2009 06:58:27 +0000 (07:58 +0100)]
llvmpipe: Separate pixel packing/unpacking from loading/storing.

15 years agoxlib: Integrate with llvmpipe.
José Fonseca [Tue, 28 Jul 2009 07:49:40 +0000 (08:49 +0100)]
xlib: Integrate with llvmpipe.

Actually, the makefile/sconscript changes were already commit by mistake.

15 years agollvmpipe: Adjust for pixel layout changes.
José Fonseca [Tue, 28 Jul 2009 07:47:35 +0000 (08:47 +0100)]
llvmpipe: Adjust for pixel layout changes.

15 years agoutil: Make pixel format layout more meaningful.
José Fonseca [Tue, 28 Jul 2009 07:47:13 +0000 (08:47 +0100)]
util: Make pixel format layout more meaningful.

Namelly, explicitly distinguish formats coded by arithmetic manipulation,
from formats layed out in array.

15 years agoutil: Don't commit u_format_table.c
José Fonseca [Tue, 28 Jul 2009 07:42:27 +0000 (08:42 +0100)]
util: Don't commit u_format_table.c

At least not until stabilizes, to reduce noise.

15 years agollvmpipe: Fix typo in copyright.
José Fonseca [Tue, 28 Jul 2009 07:14:10 +0000 (08:14 +0100)]
llvmpipe: Fix typo in copyright.

15 years agollvmpipe: Add test cases for pixels.
José Fonseca [Mon, 27 Jul 2009 22:18:44 +0000 (23:18 +0100)]
llvmpipe: Add test cases for pixels.

Actually some of this test cases need more testing...

15 years agoutil: Fix r5g6b5 description.
José Fonseca [Mon, 27 Jul 2009 22:16:32 +0000 (23:16 +0100)]
util: Fix r5g6b5 description.

15 years agollvmpipe: Update SConscript.
José Fonseca [Mon, 27 Jul 2009 10:45:50 +0000 (11:45 +0100)]
llvmpipe: Update SConscript.

15 years agollvmpipe: Simple shell script to aid port softpipe changes to llvmpipe.
José Fonseca [Mon, 27 Jul 2009 10:45:36 +0000 (11:45 +0100)]
llvmpipe: Simple shell script to aid port softpipe changes to llvmpipe.

15 years agollvmpipe: move all depth/stencil/alpha pixel processing into one stage
Keith Whitwell [Mon, 27 Jul 2009 07:17:45 +0000 (08:17 +0100)]
llvmpipe: move all depth/stencil/alpha pixel processing into one stage

15 years agollvmpipe: fix error in scissor state dependencies
Keith Whitwell [Sat, 25 Jul 2009 10:01:48 +0000 (11:01 +0100)]
llvmpipe: fix error in scissor state dependencies

15 years agollvmpipe: cleanup framebuffer state routine slightly
Keith Whitwell [Sat, 25 Jul 2009 09:01:06 +0000 (10:01 +0100)]
llvmpipe: cleanup framebuffer state routine slightly

15 years agollvmpipe: move all color-combine code into lp_quad_blend.c
Keith Whitwell [Fri, 24 Jul 2009 19:19:18 +0000 (20:19 +0100)]
llvmpipe: move all color-combine code into lp_quad_blend.c

Consolidate the read-modify-write color combining code from
the blend, colormask and output stages.

15 years agollvmpipe: fix typo
Keith Whitwell [Fri, 24 Jul 2009 19:18:52 +0000 (20:18 +0100)]
llvmpipe: fix typo

15 years agollvmpipe: example fastpaths in blending
Keith Whitwell [Fri, 24 Jul 2009 17:46:17 +0000 (18:46 +0100)]
llvmpipe: example fastpaths in blending

15 years agollvmpipe: actually pass >1 quad from triangle routine
Keith Whitwell [Fri, 24 Jul 2009 17:17:05 +0000 (18:17 +0100)]
llvmpipe: actually pass >1 quad from triangle routine

First attempt

15 years agollvmpipe: expand quad pipeline to process >1 quad at a time
Keith Whitwell [Fri, 24 Jul 2009 15:49:35 +0000 (16:49 +0100)]
llvmpipe:  expand quad pipeline to process >1 quad at a time

This is part one -- we still only pass a single quad down, but
the code can now cope with more.  The quads must all be from the same
tile.

15 years agollvmpipe: rip out old mulithread support
Keith Whitwell [Fri, 24 Jul 2009 15:12:48 +0000 (16:12 +0100)]
llvmpipe: rip out old mulithread support

15 years agollvmpipe: avoid flushing depth buffer cache on swapbuffers
Keith Whitwell [Thu, 23 Jul 2009 10:14:39 +0000 (11:14 +0100)]
llvmpipe: avoid flushing depth buffer cache on swapbuffers

There's no need to push out depth buffer contents on swapbuffers.

Note that this change doesn't throw away depth buffer changes, it simply
holds them in the cache over calls to swapbuffers.  The hope is
that swapbuffers will be followed by a clear() which means in that case
we won't have to write the changes out.

15 years agollvmpipe: also shortcircuit non-texture tile lookups
Keith Whitwell [Wed, 22 Jul 2009 14:36:25 +0000 (15:36 +0100)]
llvmpipe: also shortcircuit non-texture tile lookups

15 years agollvmpipe: shortcircuit repeated lookups of the same tile
Keith Whitwell [Wed, 22 Jul 2009 14:08:42 +0000 (15:08 +0100)]
llvmpipe: shortcircuit repeated lookups of the same tile

The lp_tile_cache is often called repeatedly to look up the same
tile.  Add a cache (to the cache) of the single tile most recently
retreived and make a quick inline check to see if this matches the
subsequent request.

Add a tile_address bitfield struct to make this check easier.

15 years agollvmpipe: remove unused vars in lp_setup.c
Keith Whitwell [Fri, 17 Jul 2009 11:12:04 +0000 (12:12 +0100)]
llvmpipe: remove unused vars in lp_setup.c

15 years agollvmpipe: use bitwise logic to setup quad masks in lp_setup
Keith Whitwell [Fri, 17 Jul 2009 11:03:51 +0000 (12:03 +0100)]
llvmpipe: use bitwise logic to setup quad masks in lp_setup

15 years agollvmpipe: simplify flush_spans
Keith Whitwell [Fri, 17 Jul 2009 09:47:32 +0000 (10:47 +0100)]
llvmpipe: simplify flush_spans

No loss of performance, but simpler code.

15 years agollvmpipe: make some small steps to flush texture cache less frequently
Keith Whitwell [Fri, 17 Jul 2009 09:44:22 +0000 (10:44 +0100)]
llvmpipe: make some small steps to flush texture cache less frequently

No performance gain yet, but the code is a bit cleaner.

15 years agollvmpipe: remove backwards dependency from tilecache to llvmpipe
Keith Whitwell [Thu, 16 Jul 2009 13:14:32 +0000 (14:14 +0100)]
llvmpipe: remove backwards dependency from tilecache to llvmpipe

The tile cache is a utility, it shouldn't know anything about the
entity which is making use of it (ie llvmpipe).

Remove llvmpipe parameter to all the tilecache function calls, and
also remove the need to keep a llvmpipe pointer in the sampler structs.

15 years agollvmpipe: Rename preprocessor symbols too.
José Fonseca [Mon, 27 Jul 2009 10:36:24 +0000 (11:36 +0100)]
llvmpipe: Rename preprocessor symbols too.

15 years agollvmpipe: Pixel packing/unpacking and loop code generators.
José Fonseca [Mon, 27 Jul 2009 00:23:15 +0000 (01:23 +0100)]
llvmpipe: Pixel packing/unpacking and loop code generators.

Just a small proof of concept plus a standalone test app. Not integrated
with the rest of the driver yet.

15 years agoutil: Pixel format database.
José Fonseca [Sun, 26 Jul 2009 22:50:00 +0000 (23:50 +0100)]
util: Pixel format database.

There are some inconsistencies in pipe_format, but above all, there
simply aren't enough bits in an enum to conveniently store all
information about a pixel format we need to be able to dynamically
generate pixel packing/unpacking code.

15 years agollvmpipe: Fork softpipe for experimentation with llvm.
José Fonseca [Sun, 26 Jul 2009 22:44:38 +0000 (23:44 +0100)]
llvmpipe: Fork softpipe for experimentation with llvm.

15 years agoPut 'extern' first on the line to silence GCC warnings.
Ian Romanick [Sat, 29 Aug 2009 03:12:36 +0000 (20:12 -0700)]
Put 'extern' first on the line to silence GCC warnings.

15 years agoi965: Use VBOs in the VBO module on 965, now that we have ARB_map_buffer_range.
Eric Anholt [Fri, 28 Aug 2009 22:01:56 +0000 (15:01 -0700)]
i965: Use VBOs in the VBO module on 965, now that we have ARB_map_buffer_range.

This looks like it's a small win on blender.

15 years agovbo: Fix array pointer calculation for MapBufferRange-mapped vertex data.
Eric Anholt [Fri, 28 Aug 2009 21:44:55 +0000 (14:44 -0700)]
vbo: Fix array pointer calculation for MapBufferRange-mapped vertex data.

We would end up with the offset from the start of the mapping rather than
the offset from the start of the buffer.

15 years agointel: Add support for GL_ARB_map_buffer_range.
Eric Anholt [Thu, 27 Aug 2009 01:08:52 +0000 (18:08 -0700)]
intel: Add support for GL_ARB_map_buffer_range.

Passes glean's bufferObject test, and should provide good performance in the
cases applications are expected to use.

15 years agoi965: Implement ARB_oq CheckQuery in the intended way.
Eric Anholt [Fri, 28 Aug 2009 01:34:11 +0000 (18:34 -0700)]
i965: Implement ARB_oq CheckQuery in the intended way.

Previously we blocked because I hadn't added the libdrm function.  Now it's
there, so update your libdrm.

15 years agoradeon: Fix swtcl emit pediction.
Pauli Nieminen [Fri, 28 Aug 2009 21:46:08 +0000 (00:46 +0300)]
radeon: Fix swtcl emit pediction.

Problem was to find the correct place to run prediction. Only place that is
called for every primitive is ALLOC_VERTS so we have to do prediction there
before allocation.

15 years agoi915g: Add cursor case for scanout layout
Jakob Bornecrantz [Fri, 28 Aug 2009 21:39:29 +0000 (22:39 +0100)]
i915g: Add cursor case for scanout layout