Revert "r600g: precompute some of the hw state"
[mesa.git] / src / gallium / drivers / r600 / r600_resource.h
1 /*
2 * Copyright 2010 Marek Olšák <maraeo@gmail.com
3 *
4 * Permission is hereby granted, free of charge, to any person obtaining a
5 * copy of this software and associated documentation files (the "Software"),
6 * to deal in the Software without restriction, including without limitation
7 * on the rights to use, copy, modify, merge, publish, distribute, sub
8 * license, and/or sell copies of the Software, and to permit persons to whom
9 * the Software is furnished to do so, subject to the following conditions:
10 *
11 * The above copyright notice and this permission notice (including the next
12 * paragraph) shall be included in all copies or substantial portions of the
13 * Software.
14 *
15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL
18 * THE AUTHOR(S) AND/OR THEIR SUPPLIERS BE LIABLE FOR ANY CLAIM,
19 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
20 * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
21 * USE OR OTHER DEALINGS IN THE SOFTWARE.
22 */
23 #ifndef R600_RESOURCE_H
24 #define R600_RESOURCE_H
25
26 #include "util/u_transfer.h"
27
28 struct r600_context;
29 struct r600_screen;
30
31 /* This gets further specialized into either buffer or texture
32 * structures. Use the vtbl struct to choose between the two
33 * underlying implementations.
34 */
35 struct r600_resource {
36 struct u_resource base;
37 struct radeon_bo *bo;
38 u32 domain;
39 u32 flink;
40 struct pb_buffer *pb;
41 };
42
43 struct r600_resource_texture {
44 struct r600_resource resource;
45 unsigned long offset[PIPE_MAX_TEXTURE_LEVELS];
46 unsigned long pitch[PIPE_MAX_TEXTURE_LEVELS];
47 unsigned long width[PIPE_MAX_TEXTURE_LEVELS];
48 unsigned long height[PIPE_MAX_TEXTURE_LEVELS];
49 unsigned long layer_size[PIPE_MAX_TEXTURE_LEVELS];
50 unsigned long pitch_override;
51 unsigned long bpt;
52 unsigned long size;
53 unsigned tilled;
54 unsigned array_mode;
55 unsigned tile_type;
56 unsigned depth;
57 unsigned dirty;
58 struct radeon_bo *uncompressed;
59 struct radeon_state *scissor[PIPE_MAX_TEXTURE_LEVELS];
60 struct radeon_state *cb0[PIPE_MAX_TEXTURE_LEVELS];
61 struct radeon_state *db[PIPE_MAX_TEXTURE_LEVELS];
62 struct radeon_state *viewport[PIPE_MAX_TEXTURE_LEVELS];
63 };
64
65 void r600_init_context_resource_functions(struct r600_context *r600);
66 void r600_init_screen_resource_functions(struct r600_screen *r600screen);
67
68 /* r600_buffer */
69 u32 r600_domain_from_usage(unsigned usage);
70
71 /* r600_texture */
72 struct pipe_resource *r600_texture_create(struct pipe_screen *screen,
73 const struct pipe_resource *templ);
74 struct pipe_resource *r600_texture_from_handle(struct pipe_screen *screen,
75 const struct pipe_resource *base,
76 struct winsys_handle *whandle);
77
78 #endif