blob: 96fab8e338790f20f6c67bb5377201571cf76a0c [file] [log] [blame]
/**************************************************************************
*
* Copyright 2007 VMware, Inc.
* All Rights Reserved.
* Copyright 2010 VMware, Inc. All rights reserved.
*
* Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the
* "Software"), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish,
* distribute, sub license, and/or sell copies of the Software, and to
* permit persons to whom the Software is furnished to do so, subject to
* the following conditions:
*
* The above copyright notice and this permission notice (including the
* next paragraph) shall be included in all copies or substantial portions
* of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
* IN NO EVENT SHALL VMWARE AND/OR ITS SUPPLIERS BE LIABLE FOR
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*
**************************************************************************/
#ifndef SP_TEX_SAMPLE_H
#define SP_TEX_SAMPLE_H
#include "tgsi/tgsi_exec.h"
struct sp_sampler_view;
struct sp_sampler;
typedef void (*wrap_nearest_func)(float s,
unsigned size,
int offset,
int *icoord);
typedef void (*wrap_linear_func)(float s,
unsigned size,
int offset,
int *icoord0,
int *icoord1,
float *w);
typedef float (*compute_lambda_func)(const struct sp_sampler_view *sp_sview,
const float s[TGSI_QUAD_SIZE],
const float t[TGSI_QUAD_SIZE],
const float p[TGSI_QUAD_SIZE]);
typedef float (*compute_lambda_from_grad_func)(const struct sp_sampler_view *sp_sview,
const float derivs[3][2][TGSI_QUAD_SIZE],
uint quad);
struct img_filter_args {
float s;
float t;
float p;
unsigned level;
unsigned face_id;
const int8_t *offset;
bool gather_only;
int gather_comp;
};
typedef void (*img_filter_func)(const struct sp_sampler_view *sp_sview,
const struct sp_sampler *sp_samp,
const struct img_filter_args *args,
float *rgba);
struct filter_args {
enum tgsi_sampler_control control;
const int8_t *offset;
const uint *faces;
};
typedef void (*mip_filter_func)(const struct sp_sampler_view *sp_sview,
const struct sp_sampler *sp_samp,
img_filter_func min_filter,
img_filter_func mag_filter,
const float s[TGSI_QUAD_SIZE],
const float t[TGSI_QUAD_SIZE],
const float p[TGSI_QUAD_SIZE],
int gather_comp,
const float lod[TGSI_QUAD_SIZE],
const struct filter_args *args,
float rgba[TGSI_NUM_CHANNELS][TGSI_QUAD_SIZE]);
typedef void (*mip_level_func)(const struct sp_sampler_view *sp_sview,
const struct sp_sampler *sp_samp,
const float lod[TGSI_QUAD_SIZE],
float level[TGSI_QUAD_SIZE]);
typedef void (*fetch_func)(struct sp_sampler_view *sp_sview,
const int i[TGSI_QUAD_SIZE],
const int j[TGSI_QUAD_SIZE], const int k[TGSI_QUAD_SIZE],
const int lod[TGSI_QUAD_SIZE], const int8_t offset[3],
float rgba[TGSI_NUM_CHANNELS][TGSI_QUAD_SIZE]);
struct sp_sampler_view
{
struct pipe_sampler_view base;
/* For sp_get_samples_2d_linear_POT:
*/
unsigned xpot;
unsigned ypot;
boolean need_swizzle;
boolean pot2d;
boolean need_cube_convert;
/* these are different per shader type */
struct softpipe_tex_tile_cache *cache;
compute_lambda_func compute_lambda;
compute_lambda_from_grad_func compute_lambda_from_grad;
union pipe_color_union border_color;
};
struct sp_filter_funcs {
mip_level_func relative_level;
mip_filter_func filter;
};
struct sp_sampler {
struct pipe_sampler_state base;
boolean min_mag_equal_repeat_linear;
boolean min_mag_equal;
unsigned min_img_filter;
wrap_nearest_func nearest_texcoord_s;
wrap_nearest_func nearest_texcoord_t;
wrap_nearest_func nearest_texcoord_p;
wrap_linear_func linear_texcoord_s;
wrap_linear_func linear_texcoord_t;
wrap_linear_func linear_texcoord_p;
const struct sp_filter_funcs *filter_funcs;
};
/**
* Subclass of tgsi_sampler
*/
struct sp_tgsi_sampler
{
struct tgsi_sampler base; /**< base class */
struct sp_sampler *sp_sampler[PIPE_MAX_SAMPLERS];
struct sp_sampler_view sp_sview[PIPE_MAX_SHADER_SAMPLER_VIEWS];
};
compute_lambda_func
softpipe_get_lambda_func(const struct pipe_sampler_view *view,
enum pipe_shader_type shader);
compute_lambda_from_grad_func
softpipe_get_lambda_from_grad_func(const struct pipe_sampler_view *view,
enum pipe_shader_type shader);
void *
softpipe_create_sampler_state(struct pipe_context *pipe,
const struct pipe_sampler_state *sampler);
struct pipe_sampler_view *
softpipe_create_sampler_view(struct pipe_context *pipe,
struct pipe_resource *resource,
const struct pipe_sampler_view *templ);
struct sp_tgsi_sampler *
sp_create_tgsi_sampler(void);
#endif /* SP_TEX_SAMPLE_H */