Mesa (master): 40 new commits

Luca Barbieri lb at kemper.freedesktop.org
Sat Aug 21 18:44:50 UTC 2010


URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=d8e210eb111324482450c8bdbb19e29a805b088e
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Sat Aug 21 20:23:41 2010 +0200

    nvfx: slightly improve handling of overlong vps

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=5eddf95be992d1d6cafe567068ca4c12b0ee2b4a
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Sat Aug 21 20:14:35 2010 +0200

    nvfx: tweak CMP in fp

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=8983621c6b39d74e0f30fa97fb8b4b362eddc87c
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Sat Aug 21 20:14:16 2010 +0200

    nvfx: implement CMP in vp

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=923f5c97b14c107ba647c1c3eb81d81000c301f3
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Sat Aug 21 20:07:48 2010 +0200

    nvfx: implement TXL in fp

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=847ac88671ce4315eb03fcd1d746d20ee03379af
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Sat Aug 21 20:05:04 2010 +0200

    nvfx: implement SSG in fp

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=32d2525d645e4a06a116a1c0433bda0dd3bc245f
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Sat Aug 21 19:43:46 2010 +0200

    nvfx: implement DP2 in vp and fp

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=4aec8aa2e33b0bf9d5e8c292d604fe988e439bca
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Sat Aug 21 19:35:06 2010 +0200

    nvfx: implement TRUNC in vp and fp

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=587d26fdf9c58503333e4e7603a115881a80260b
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Sat Aug 21 19:45:06 2010 +0200

    nvfx: implement NOP

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=fe3c62dd7728f1cab64978d634fd0be4237d3b23
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Sat Aug 21 18:37:21 2010 +0200

    nvfx: add vertex program control flow

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=5287d86a0b818fd0a7cba6d7728b701663ea78a5
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Sat Aug 21 18:37:01 2010 +0200

    nvfx: fix vertex shader headers

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=af4a6eba55ad81e343db788a97f3eaa3cf184369
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Fri Aug 20 21:16:49 2010 +0200

    nv40: add fragment program control flow

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=cf0d15642289f0a4b8d40e61266c89fe09d6601b
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Sat Aug 21 12:32:59 2010 +0200

    nvfx: refactor shader assembler

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=28fa9451e1b3fe251923b0de352e34f84dbd6f4a
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Sat Aug 21 13:28:38 2010 +0200

    nvfx: add option to dump shaders in TGSI and native code

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=b2bad53478b6033038b51982db09094337f1f379
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Thu Feb 25 17:46:37 2010 +0100

    nvfx: improve and correct nvfx_shader.h

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=928cce672a613b2f7bfa5563eca828327b16dc27
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Thu Aug 19 22:47:03 2010 +0200

    nvfx: fix lodbias

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=1dea9bc369dea1215c9e10bf6d52507e618d11ca
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Thu Aug 19 22:36:00 2010 +0200

    nvfx: mostly fix inline corruption magically
    
    Not sure why this mostly works.

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=ed232adc80867a424978396e047f146cb94a1cc5
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Thu Aug 19 12:58:14 2010 +0200

    nvfx: fix GPU hardlocks when depth buffer is absent

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=6931a01222beab107cb65067270770e3406425e2
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Tue Aug 17 01:01:42 2010 +0200

    nvfx: fire ring after transfers
    
    Might reduce the risk of running out of memory

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=07b6fde4102bfa5097b3c16cf23a6d60357e5463
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Mon Aug 16 16:55:00 2010 +0200

    nv30: band-aid viewport issues
    
    For some reason nv30 seems to like to reset the viewport, even though
    attempts to isolate where exactly it does that have currently been
    inconclusive.

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=0d74956a1f895303a44bddc6f92c246ecce40023
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Sun Aug 15 10:15:40 2010 +0200

    nvfx: support flatshade_first

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=0184e298636370865bb8d511ca890acd70c1c4c6
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Sat Mar 13 02:28:59 2010 +0100

    nvfx: expose GLSL
    
    Still no control flow support, but basic stuff works.

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=4d765f7fa3751eae00bbf2b6ee9710bf5bdf95d0
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Tue Aug 10 23:09:53 2010 +0200

    nvfx: support proper shader linkage - adds glsl support

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=8eb0fc430a8c1687627156a06faf5762144022f3
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Sat Aug 7 05:39:18 2010 +0200

    nvfx: rewrite draw code and buffer code
    
    This is a full rewrite of the drawing and buffer management logic.
    
    It offers a lot of improvements:
    1. A copy of buffers is now always kept in system memory. This is
       necessary to allow software processing of them, which is necessary
       or improves performance in many cases.
    2. Support for pushing vertices on the FIFO, with index lookup if necessary.
    3. "Smart" draw code that tries to intelligently choose the cheapest
      way to draw something: whether to use inline vertices or hardware
      vertex buffer, and whether to use hardware index buffers
    4. Support for all vertex formats supported by the hardware
    5. Usage of translate to push vertices, supporting all formats that are
       sensible to use as vertex formats
    6. Support for base vertex
    7. Usage of Ben Skeggs' primitive splitter originally for nv50, allowing
       correct splitting of line loops, triangle fans, etc.
    8. Support for instancing
    9. Precomputation using the vertex elements CSO
    
    Thanks to Ben Skeggs for his primitive splitter originally for nv50.
    
    Thanks to Christoph Bumiller for his nv50 push code, that was the basis
    of this work, even though I changed his code dramatically, in particular
    to replace his ad-hoc vertex data emitter with translate.
    
    The changes could also go into nv50 too, but there are substantial
    differences due to the additional nv50 hardware features.

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=73b7c6fb336ad3e717f8e961f4e2df761e94cd2f
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Sat Aug 7 03:47:25 2010 +0200

    nvfx: refactor sampling code, add support for swizzles and depth tex
    
    This is a significant refactoring of the sampling code that:
    - Moves all generic functions in nvfx_fragtex.c
    - Adds a driver-specific sampler view structure and uses it to
      precompute texture setup as it should be done
    - Unifies a bit more of code between nv30 and nv40
    - Adds support for sampler view swizzles
    - Support for specifying as sampler view format different from the
      resource one (only trivially)
    - Support for sampler view specification of first and last level
    - Support for depth textures on nv30, both for reading depth and
      for compare
    - Support for sRGB textures
    - Unifies the format table between nv30 and nv40
    - Expands the format table to include essentially all supportable formats
      except mixed sign and "autonormal" formats
    - Fixes the "is format supported" logic, which was quite broken, and
      makes it use the format table
    
    Only tested on nv30 currently.

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=4e2080a86e0cbb93c72bbf4acace53867fac8276
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Tue Aug 3 22:49:19 2010 +0200

    nvfx: new 2D: unify textures and buffers
    
    Stop using the vtbl, and use real transfers for buffers too.

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=0481ed25c9c35178bf5151c80f4c36ad42b75648
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Sun Apr 18 16:43:19 2010 +0200

    nvfx: new 2D: use a CPU copy for up to 4 pixels, up from 0
    
    Seems a reasonable threshold for now.
    
    Significantly speeds up Piglit's 1x1 glReadPixels (but, you know,
    reading pixels in 1x1 blocks is NOT a good idea, especially if you
    might be running on a less-than-perfect driver).

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=28eb392a853bb43bdc6cfe7ba814f046c39ca7ae
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Tue Aug 3 05:47:41 2010 +0200

    nvfx: new 2D: new render temporaries with resources
    
    This patch adds support for creating temporary surfaces to allow
    rendering to surfaces that cannot be rendered to.
    It uses the _second_ version of the render temporary infrastructure.
    
    This is necessary for swizzled 3D textures and small mipmaps of
    swizzled 2D textures.
    
    This version of the patch creates a resource to use as a temporary
    instead of a raw BO, making the code simpler.

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=ff74143fcc80b0157875bb0ce4b34a80f92e09c2
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Thu Mar 11 18:06:28 2010 +0100

    nv30: new 2D: support ARB_texture_rectangle
    
    This uses nv30's _RECT formats.

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=4793f48a19465ad27c3a33d9453a0def78775736
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Tue Feb 23 12:47:45 2010 +0100

    nvfx: new 2D: optimize fragtex format lookup
    
    Use an array indexed by the pipe format instead of doing a linear scan.

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=d983701267de0083cc702e460c841741292cc9b8
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Mon Jan 18 23:40:22 2010 +0100

    nvfx: new 2D: enable swizzling for all surfaces
    
    Now that the new 2D code is in place, swizzling can be safely enabled.
    
    Render temporaries are needed in some cases, so this may degrade nv30
    a bit until it gets render temporaries too.

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=9ed0686e8e6157ce38c9fa284cd7399289a2e698
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Tue Aug 3 06:24:22 2010 +0200

    nvfx: new 2D: use new 2D engine in Gallium
    
    This patch implements nv04_surface_copy/fill using the new 2D engine module.
    It supports falling back to the 3D engine using the u_blitter module, which will be
    added in a later patch.
    
    Also adds support for using the 3D engine, reusing the u_blitter module
    created for r300.
    This is used for unswizzling and copies between swizzled surfaces.

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=24a4ea003f14a96ed07fdc4e92a67610655befad
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Tue Jan 19 18:51:10 2010 +0100

    nv04-nv40: new 2D: add new Gallium-independent 2D engine
    
    This patch add a brand new nv04-nv40 2D engine module.
    It should correctly implement all operations involving swizzled, and 3D-swizzled surfaces.
    
    This code is independent from the Gallium framework and can thus be reused in the DDX and classic Mesa drivers (it's only likely to be useful in the latter, though).
    
    Currently, surface_copy and surface_fill are broken for 3D textures, for swizzled source textures and possibly for some misaligned cases
    
    The code is based around the new nv04_region structure, which encapsulates the information from pipe_surface needed for the 2D engine and CPU copies.
    The use of nv04_region makes the code independent of the Gallium framework and allows to transform the nv04_region without clobbering the nv04_region.
    The existing M2MF, blitter, and SWIZZLED_SURFACE paths have been improved and a new CPU path has been added.
    There is also support to tell the caller to use the 3D engine.
    
    The main feature of the copy/fill setup algorithm is linearization/contiguous-linearization of swizzled surfaces.
    The idea of linearization is that some swizzled surfaces are laid out like linear ones (1xN, 2xN, Nx1) and can thus be used as such (e.g. useful for copying single pixels).
    Also, some rectangles (e.g. the whole surface) are contiguous in memory. If both the source and destination rectangles are swizzled but contiguous, then they can be regarded as both linear: this is the idea of "contiguous linearization".
    This, for instance, allows to use the 2D engine to duplicate the content of a swizzled surface to another swizzled surface, by pretending they are actually linear.
    After linearization, the result may not be 64-byte aligned. Another transformation is done to enlarge the linear surface so that it becomes 64-byte aligned.
    This is also used to 64-byte align swizzled texture mipmaps.
    
    The inner loop of the CPU path is as optimized as possible without using SSE/SSE2.
    Future improvements could include SSE/SSE2 support, and possibly a faster coordinate swizzling algorithm (which is however not used in the inner loop).
    It may be a good idea to autogenerate swizzling code at least for all possible POT 2D texture dimensions  (less than 256), maybe for all 3D ones too (less than 4096).
    Also, it woud be a very good idea to make a copy with the GPU first if the source surface is in uncached memory.

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=23639dc046435716042b68359ac6208d99be82f4
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Tue Aug 3 21:32:42 2010 +0200

    nvfx: new 2D: rewrite transfer code to use staging transfers
    
    This greatly simplifies the code, and avoids ad-hoc copy code.
    
    Also, these new transfers work for buffers too, even though they
    are still used for miptrees only.

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=ed2930e7e2c064458da33089cff902574008bf30
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Fri Jan 15 10:11:11 2010 +0100

    nvfx: new 2D: rewrite miptree code, adapt transfers
    
    Changes:
    - Disable swizzling on non-RGBA 2D textures, since the current 2D
      code is mostly broken in those cases. A later patch will fix this.
      Thanks to Andrew Randrianasulu who reported this.
    - Fix compressed texture transfers and hack around the current 2D
      code inability to copy compressed textures by using direct access.
      Thanks to Andrew Randrianasulu who reported this.
    
    This patch rewrites all the miptree layout and transfer code in the
    nvfx driver.
    
    The current code is broken in several ways:
    1. 3D textures are laid out first by face, then by level, which is
    incorrect
    2. Cube maps should have 128-byte aligned faces
    3. Swizzled textures have a strange alignment test that seems
    unnecessary
    4. We store the image_offsets for each face/slice but they can be
    easily computed instead
    5. "Swizzling" is not supported for compressed formats. They can be
    "swizzled" but swizzling only means that there are no gaps (pitch is
    level-dependant) and the layout is still linear
    6. Swizzling is not supported for non-RGBA formats. All formats (except
    possibly depth) can be swizzled according to my testing.
    
    The miptree layout is rewritten based on my empirical testing, which I
    posted in the "miptree findings" mail.
    The image_offset array is removed, since it can be calculated with a
    simple multiplication; the only array in the miptree structure is now
    the one for mipmap level starts, which it seems cannot be easily
    computed in constant time.
    
    Also, we now directly store a nouveau_bo instead of a pipe_buffer in
    the miptree structure, like nv50 does.
    
    Support for render temporaries is removed, and will be readded in a
    later patch.
    
    Note that the current temporary code is broken, because it does not
    copy the temporary back on render cache flushes.

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=ac97e8dba654b9b3c5a9459953ce27056bcbb021
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Sat Aug 7 01:56:01 2010 +0200

    nvfx: add nouveau_resource_on_gpu
    
    Add a function to get whether a resource is likely on the GPU or not.
    
    Currently always returns TRUE.

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=37fa0cf4eaf6e67876a1f6b33389f17f99b02461
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Tue Aug 3 22:50:19 2010 +0200

    nvfx: add linear flag for buffers

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=6a73d99a5236eeb822e9bdd26bd669638cf036c6
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Mon Aug 9 05:05:12 2010 +0200

    nvfx: properly unreference bound objects on context destruction

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=e189823eb4427e091e052d65cc9db3d7353f02bf
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Fri Aug 6 09:15:00 2010 +0200

    nvfx: reference count bound objects

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=95acfd0c8a53738a89fe91cf7643a8563bbe2b4f
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Sat Aug 7 02:49:48 2010 +0200

    nvfx: fix format support code for compressed texture
    
    A source line was put in the wrong place.

URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=e6ff995d14085caa447c4e8634bf069c8a94f0ec
Author: Luca Barbieri <luca at luca-barbieri.com>
Date:   Thu Feb 25 13:08:35 2010 +0100

    gallium/auxiliary: add semantic linkage utility code




More information about the mesa-commit mailing list