2 * Copyright 2010 Marek Olšák <maraeo@gmail.com
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:
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
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.
23 #ifndef R600_RESOURCE_H
24 #define R600_RESOURCE_H
26 #include "util/u_transfer.h"
31 /* This gets further specialized into either buffer or texture
32 * structures. Use the vtbl struct to choose between the two
33 * underlying implementations.
35 struct r600_resource
{
36 struct u_resource base
;
37 struct radeon_ws_bo
*bo
;
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
;
58 struct r600_resource_texture
*flushed_depth_texture
;
61 void r600_init_context_resource_functions(struct r600_context
*r600
);
62 void r600_init_screen_resource_functions(struct pipe_screen
*screen
);
65 u32
r600_domain_from_usage(unsigned usage
);
68 struct pipe_resource
*r600_texture_create(struct pipe_screen
*screen
,
69 const struct pipe_resource
*templ
);
70 struct pipe_resource
*r600_texture_from_handle(struct pipe_screen
*screen
,
71 const struct pipe_resource
*base
,
72 struct winsys_handle
*whandle
);
74 #define R600_BUFFER_MAGIC 0xabcd1600
75 #define R600_BUFFER_MAX_RANGES 32
77 struct r600_buffer_range
{
82 struct r600_resource_buffer
{
83 struct r600_resource r
;
86 struct r600_buffer_range ranges
[R600_BUFFER_MAX_RANGES
];
91 static INLINE
struct r600_resource_buffer
*r600_buffer(struct pipe_resource
*buffer
)
94 assert(((struct r600_resource_buffer
*)buffer
)->magic
== R600_BUFFER_MAGIC
);
95 return (struct r600_resource_buffer
*)buffer
;
100 static INLINE boolean
r600_buffer_is_user_buffer(struct pipe_resource
*buffer
)
102 return r600_buffer(buffer
)->user_buffer
? TRUE
: FALSE
;
105 int r600_texture_depth_flush(struct pipe_context
*ctx
,
106 struct pipe_resource
*texture
);
108 extern int (*r600_blit_uncompress_depth_ptr
)(struct pipe_context
*ctx
, struct r600_resource_texture
*texture
);