X-Git-Url: https://git.libre-soc.org/?a=blobdiff_plain;f=src%2Fgallium%2Fdrivers%2Fr300%2Fr300_texture.h;h=bfc72962c5ea4ff3d5db0b1a646de58a9cc44654;hb=d2f8105b606269c0e71cd599f57997279385d300;hp=46a5fb6188b6107459813f8132d67d8c6c3a7053;hpb=3c244dac47195cce3fdcb05176e38d33b2cad8ed;p=mesa.git diff --git a/src/gallium/drivers/r300/r300_texture.h b/src/gallium/drivers/r300/r300_texture.h index 46a5fb6188b..bfc72962c5e 100644 --- a/src/gallium/drivers/r300/r300_texture.h +++ b/src/gallium/drivers/r300/r300_texture.h @@ -23,24 +23,29 @@ #ifndef R300_TEXTURE_H #define R300_TEXTURE_H -#include "pipe/p_video_state.h" -#include "util/u_format.h" - -#include "r300_reg.h" - -struct r300_texture; - -void r300_init_screen_texture_functions(struct pipe_screen* screen); - -unsigned r300_texture_get_stride(struct r300_screen* screen, - struct r300_texture* tex, unsigned level); - -unsigned r300_texture_get_offset(struct r300_texture* tex, unsigned level, - unsigned zslice, unsigned face); - -void r300_texture_reinterpret_format(struct pipe_screen *screen, - struct pipe_texture *tex, - enum pipe_format new_format); +#include "pipe/p_compiler.h" +#include "pipe/p_format.h" +#include "pipe/p_screen.h" + +struct pipe_screen; +struct pipe_context; +struct pipe_resource; +struct winsys_handle; +struct r300_texture_format_state; +struct r300_texture_desc; +struct r300_resource; +struct r300_screen; + +unsigned r300_get_swizzle_combined(const unsigned char *swizzle_format, + const unsigned char *swizzle_view, + boolean dxtc_swizzle); + +uint32_t r300_translate_texformat(enum pipe_format format, + const unsigned char *swizzle_view, + boolean is_r500, + boolean dxtc_swizzle); + +uint32_t r500_tx_format_msb_bit(enum pipe_format format); boolean r300_is_colorbuffer_format_supported(enum pipe_format format); @@ -48,25 +53,40 @@ boolean r300_is_zs_format_supported(enum pipe_format format); boolean r300_is_sampler_format_supported(enum pipe_format format); -struct r300_video_surface -{ - struct pipe_video_surface base; - struct pipe_texture *tex; -}; - -static INLINE struct r300_video_surface * -r300_video_surface(struct pipe_video_surface *pvs) -{ - return (struct r300_video_surface *)pvs; -} - -#ifndef R300_WINSYS_H - -boolean r300_get_texture_buffer(struct pipe_screen* screen, - struct pipe_texture* texture, - struct pipe_buffer** buffer, - unsigned* stride); - -#endif /* R300_WINSYS_H */ +void r300_texture_setup_format_state(struct r300_screen *screen, + struct r300_resource *tex, + enum pipe_format format, + unsigned level, + unsigned width0_override, + unsigned height0_override, + struct r300_texture_format_state *out); + +bool r300_resource_get_handle(struct pipe_screen* screen, + struct pipe_context *ctx, + struct pipe_resource *texture, + struct winsys_handle *whandle, + unsigned usage); + +struct pipe_resource* +r300_texture_from_handle(struct pipe_screen* screen, + const struct pipe_resource* base, + struct winsys_handle *whandle, + unsigned usage); + +struct pipe_resource* +r300_texture_create(struct pipe_screen* screen, + const struct pipe_resource* templ); + +struct pipe_surface* r300_create_surface_custom(struct pipe_context * ctx, + struct pipe_resource* texture, + const struct pipe_surface *surf_tmpl, + unsigned width0_override, + unsigned height0_override); + +struct pipe_surface* r300_create_surface(struct pipe_context *ctx, + struct pipe_resource* texture, + const struct pipe_surface *surf_tmpl); + +void r300_surface_destroy(struct pipe_context *ctx, struct pipe_surface* s); #endif /* R300_TEXTURE_H */