The Mesa Cell driver is part of the Gallium3D architecture.
Tungsten Graphics is leading the project. Two phases are planned. First, to implement the framework for parallel rasterization using the Cell SPEs, including texture mapping. Second, to implement a full-featured OpenGL driver with support for GLSL, etc. The second phase is now underway.
The latest Cell driver source code is on the gallium-0.2
branch
of the Mesa git repository.
After you've cloned the repository, check out the branch with:
git-checkout -b gallium-0.2 origin/gallium-0.2
To build the driver you'll need the IBM Cell SDK (version 2.1 or 3.0). To use the driver you'll need a Cell system, such as a PS3 running Linux, or the Cell Simulator (untested, though).
If using Cell SDK 2.1, see the configs/linux-cell file for some special changes.
To compile the code, run make linux-cell
.
To build in debug mode, run make linux-cell-debug
.
To use the library, make sure LD_LIBRARY_PATH
points the Mesa/lib/
directory that contains libGL.so
.
Verify that the Cell driver is being used by running glxinfo
and looking for:
OpenGL renderer string: Gallium 0.2, Cell on Xlib
Rasterization is parallelized across the SPUs in a tiled-based manner. Batches of transformed triangles are sent to the SPUs (actually, pulled by from main memory by the SPUs). Each SPU loops over a set of 32x32-pixel screen tiles, rendering the triangles into each tile. Because of the limited SPU memory, framebuffer tiles are paged in/out of SPU local store as needed. Similarly, textures are tiled and brought into local store as needed.
As of October 2008, the driver runs quite a few OpenGL demos. Features that work include:
Performance has recently improved with the addition of PPC code generation for vertex shaders, but the code quality isn't too great yet.
Another bottleneck is SwapBuffers. It may be the limiting factor for many simple GL tests.
The CELL_DEBUG env var can be set to a comma-separated list of one or more of the following debug options:
Note that some of these options may only work for linux-cell-debug builds.
If the GALLIUM_NOPPC env var is set, PPC code generation will not be used and vertex shaders will be run with the TGSI interpreter.
If the GALLIUM_NOCELL env var is set, the softpipe driver will be used intead of the Cell driver. This is useful for comparison/validation.
If you're interested in contributing to the effort, familiarize yourself with the code, join the mesa3d-dev mailing list, and describe what you'd like to do.