vl_idct.h revision be4de05c1093db27b3fca12b782055ab8a1eba13
1/**************************************************************************
2 *
3 * Copyright 2010 Christian König
4 * All Rights Reserved.
5 *
6 * Permission is hereby granted, free of charge, to any person obtaining a
7 * copy of this software and associated documentation files (the
8 * "Software"), to deal in the Software without restriction, including
9 * without limitation the rights to use, copy, modify, merge, publish,
10 * distribute, sub license, and/or sell copies of the Software, and to
11 * permit persons to whom the Software is furnished to do so, subject to
12 * the following conditions:
13 *
14 * The above copyright notice and this permission notice (including the
15 * next paragraph) shall be included in all copies or substantial portions
16 * of the Software.
17 *
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
19 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
20 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
21 * IN NO EVENT SHALL TUNGSTEN GRAPHICS AND/OR ITS SUPPLIERS BE LIABLE FOR
22 * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
23 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
24 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
25 *
26 **************************************************************************/
27
28#ifndef vl_idct_h
29#define vl_idct_h
30
31#include <pipe/p_state.h>
32#include "vl_vertex_buffers.h"
33
34struct vl_idct
35{
36   struct pipe_context *pipe;
37
38   unsigned buffer_width;
39   unsigned buffer_height;
40
41   unsigned max_blocks;
42
43   void *rs_state;
44   void *vertex_elems_state;
45
46   union
47   {
48      void *all[4];
49      void *stage[2][2];
50      struct {
51         void *matrix, *source;
52         void *transpose, *intermediate;
53      } individual;
54   } samplers;
55
56   void *matrix_vs, *transpose_vs;
57   void *matrix_fs, *transpose_fs;
58
59   struct pipe_resource *matrix;
60   struct pipe_vertex_buffer quad;
61
62   unsigned vertex_buffer_stride;
63};
64
65struct vl_idct_buffer
66{
67   struct pipe_viewport_state viewport[2];
68   struct pipe_framebuffer_state fb_state[2];
69
70   struct pipe_resource *destination;
71
72   union
73   {
74      struct pipe_sampler_view *all[4];
75      struct pipe_sampler_view *stage[2][2];
76      struct {
77         struct pipe_sampler_view *matrix, *source;
78         struct pipe_sampler_view *transpose, *intermediate;
79      } individual;
80   } sampler_views;
81
82   union
83   {
84      struct pipe_resource *all[4];
85      struct pipe_resource *stage[2][2];
86      struct {
87         struct pipe_resource *matrix, *source;
88         struct pipe_resource *transpose, *intermediate;
89      } individual;
90   } textures;
91
92   union
93   {
94      struct pipe_vertex_buffer all[2];
95      struct { struct pipe_vertex_buffer quad, pos; } individual;
96   } vertex_bufs;
97
98   struct vl_vertex_buffer blocks;
99
100   struct pipe_transfer *tex_transfer;
101   short *texels;
102};
103
104struct pipe_resource *vl_idct_upload_matrix(struct pipe_context *pipe);
105
106bool vl_idct_init(struct vl_idct *idct, struct pipe_context *pipe,
107                  unsigned buffer_width, unsigned buffer_height,
108                  struct pipe_resource *matrix);
109
110void vl_idct_cleanup(struct vl_idct *idct);
111
112bool vl_idct_init_buffer(struct vl_idct *idct, struct vl_idct_buffer *buffer, struct pipe_resource *dst);
113
114void vl_idct_cleanup_buffer(struct vl_idct *idct, struct vl_idct_buffer *buffer);
115
116void vl_idct_map_buffers(struct vl_idct *idct, struct vl_idct_buffer *buffer);
117
118void vl_idct_add_block(struct vl_idct_buffer *buffer, unsigned x, unsigned y, short *block);
119
120void vl_idct_unmap_buffers(struct vl_idct *idct, struct vl_idct_buffer *buffer);
121
122void vl_idct_flush(struct vl_idct *idct, struct vl_idct_buffer *buffer);
123
124#endif
125