diff options
Diffstat (limited to 'src/gallium/docs/source')
| -rw-r--r-- | src/gallium/docs/source/context.rst | 41 | ||||
| -rw-r--r-- | src/gallium/docs/source/cso/rasterizer.rst | 76 | ||||
| -rw-r--r-- | src/gallium/docs/source/cso/velems.rst | 24 | 
3 files changed, 106 insertions, 35 deletions
| diff --git a/src/gallium/docs/source/context.rst b/src/gallium/docs/source/context.rst index 9080addba4..2b0941010b 100644 --- a/src/gallium/docs/source/context.rst +++ b/src/gallium/docs/source/context.rst @@ -24,6 +24,7 @@ CSO objects handled by the context object:  * :ref:`Depth, Stencil, & Alpha`: ``*_depth_stencil_alpha_state``  * :ref:`Shader`: These have two sets of methods. ``*_fs_state`` is for    fragment shaders, and ``*_vs_state`` is for vertex shaders. +* :ref:`Vertex Elements`: ``*_vertex_elements_state``  Resource Binding State @@ -39,8 +40,7 @@ buffers, surfaces) are bound to the driver.    are mostly restricted to the first one right now).  * ``set_framebuffer_state`` -* ``set_fragment_sampler_textures`` -* ``set_vertex_sampler_textures`` +  * ``set_vertex_buffers`` @@ -50,6 +50,7 @@ Non-CSO State  These pieces of state are too small, variable, and/or trivial to have CSO  objects. They all follow simple, one-method binding calls, e.g.  ``set_blend_color``. +  * ``set_stencil_ref`` sets the stencil front and back reference values    which are used as comparison values in stencil test.  * ``set_blend_color`` @@ -60,7 +61,41 @@ objects. They all follow simple, one-method binding calls, e.g.    not have the scissor test enabled, then the scissor bounds never need to    be set since they will not be used.  * ``set_viewport_state`` -* ``set_vertex_elements`` + + +Sampler Views +^^^^^^^^^^^^^ + +These are the means to bind textures to shader stages. To create one, specify +its format, swizzle and LOD range in sampler view template. + +If texture format is different than template format, it is said the texture +is being cast to another format. Casting can be done only between compatible +formats, that is formats that have matching component order and sizes. + +Swizzle fields specify they way in which fetched texel components are placed +in the result register. For example, ``swizzle_r`` specifies what is going to be +placed in first component of result register. + +The ``first_level`` and ``last_level`` fields of sampler view template specify +the LOD range the texture is going to be constrained to. + +* ``set_fragment_sampler_views`` binds an array of sampler views to +  fragment shader stage. Every binding point acquires a reference +  to a respective sampler view and releases a reference to the previous +  sampler view. + +* ``set_vertex_sampler_views`` binds an array of sampler views to vertex +  shader stage. Every binding point acquires a reference to a respective +  sampler view and releases a reference to the previous sampler view. + +* ``create_sampler_view`` creates a new sampler view. ``texture`` is associated +  with the sampler view which results in sampler view holding a reference +  to the texture. Format specified in template must be compatible +  with texture format. + +* ``sampler_view_destroy`` destroys a sampler view and releases its reference +  to associated texture.  Clearing diff --git a/src/gallium/docs/source/cso/rasterizer.rst b/src/gallium/docs/source/cso/rasterizer.rst index ccd9136a2e..e8dc82964f 100644 --- a/src/gallium/docs/source/cso/rasterizer.rst +++ b/src/gallium/docs/source/cso/rasterizer.rst @@ -7,7 +7,7 @@ The rasterizer state controls the rendering of points, lines and triangles.  Attributes include polygon culling state, line width, line stipple,  multisample state, scissoring and flat/smooth shading. -Members +Shading  -------  flatshade @@ -46,6 +46,49 @@ There are several important exceptions to the specification of this rule.    second vertex, not the first. This permits each segment of the fan to have    a different color. +Points +------ + +sprite_coord_enable +^^^^^^^^^^^^^^^^^^^ + +Specifies if a texture unit has its texture coordinates replaced or not. This +is a packed bitfield containing the enable for all texcoords -- if all bits +are zero, point sprites are effectively disabled. If any bit is set, then +point_smooth and point_quad_rasterization are ignored; point smoothing is +disabled and points are always rasterized as quads. If enabled, the four +vertices of the resulting quad will be assigned texture coordinates, +according to sprite_coord_mode. + +sprite_coord_mode +^^^^^^^^^^^^^^^^^ + +Specifies how the value for each shader output should be computed when drawing +point sprites. For PIPE_SPRITE_COORD_LOWER_LEFT, the lower-left vertex will +have coordinates (0,0,0,1). For PIPE_SPRITE_COORD_UPPER_LEFT, the upper-left +vertex will have coordinates (0,0,0,1). +This state is used by :ref:`Draw` to generate texcoords. + +.. note:: + +    When geometry shaders are available, a special geometry shader could be +    used instead of this functionality, to convert incoming points into quads +    with the proper texture coordinates. + +point_quad_rasterization +^^^^^^^^^^^^^^^^^^^^^^^^ + +Determines if points should be rasterized as quads or points. Certain APIs, +like Direct3D, always use quad rasterization for points, regardless of +whether point sprites are enabled or not. If this state is enabled, point +smoothing and antialiasing are disabled, and sprite coordinates are not +generated. + +.. note:: + +   Some renderers always internally translate points into quads; this state +   still affects those renderers by overriding other rasterization state. +  Other Members  ^^^^^^^^^^^^^ @@ -107,37 +150,6 @@ point_size_per_vertex      Whether vertices have a point size element.  point_size      The size of points, if not specified per-vertex. -sprite_coord_enable -    Specifies if a coord has its texture coordinates replaced or not. This -    is a packed bitfield containing the enable for all coords - if all are 0 -    point sprites are effectively disabled, though points may still be -    rendered slightly different according to point_quad_rasterization. -    If any coord is non-zero, point_smooth should be disabled, and -    point_quad_rasterization enabled. -    If enabled, the four vertices of the resulting quad will be assigned -    texture coordinates, according to sprite_coord_mode. -sprite_coord_mode -    Specifies how the value for each shader output should be computed when -    drawing sprites, for each coord which has sprite_coord_enable set. -    For PIPE_SPRITE_COORD_LOWER_LEFT, the lower left vertex will have -    coordinate (0,0,0,1). -    For PIPE_SPRITE_COORD_UPPER_LEFT, the upper-left vertex will have -    coordinate (0,0,0,1). -    This state is needed by :ref:`Draw` because that's where each -    point vertex is converted into four quad vertices.  There's no other -    place to emit the new vertex texture coordinates which are required for -    sprite rendering. -    Note that when geometry shaders are available, this state could be -    removed.  A special geometry shader defined by the state tracker could -    convert the incoming points into quads with the proper texture coords. -point_quad_rasterization -    This determines if points should be rasterized as quads or points. -    d3d always uses quad rasterization for points, regardless if point sprites -    are enabled or not, but OGL has different rules. If point_quad_rasterization -    is set, point_smooth should be disabled, and points will be rendered as -    squares even if multisample is enabled. -    sprite_coord_enable should be zero if point_quad_rasterization is not -    enabled.  scissor      Whether the scissor test is enabled. diff --git a/src/gallium/docs/source/cso/velems.rst b/src/gallium/docs/source/cso/velems.rst new file mode 100644 index 0000000000..92cde014fb --- /dev/null +++ b/src/gallium/docs/source/cso/velems.rst @@ -0,0 +1,24 @@ +.. _vertexelements: + +Vertex Elements +=============== + +This state controls format etc. of the input attributes contained +in the pipe_vertex_buffer(s). There's one pipe_vertex_element array member +for each input attribute. + +Members +------- + +src_offset +    The byte offset of the attribute in the buffer given by +    vertex_buffer_index for the first vertex. +instance_divisor +    The instance data rate divisor, used for instancing. +    0 means this is per-vertex data, n means per-instance data used for +    n consecutive instances (n > 0). +vertex_buffer_index +    The vertex buffer this attribute lives in. Several attributes may +    live in the same vertex buffer. +src_format +    The format of the attribute data. One of the PIPE_FORMAT tokens. | 
