r300-gallium, radeon-gallium: Continue migration to DRI2 state_tracker, part 2.
[mesa.git] / src / gallium / drivers / r300 / r300_winsys.h
1 /*
2 * Copyright 2008 Corbin Simpson <MostAwesomeDude@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 R300_WINSYS_H
24 #define R300_WINSYS_H
25
26 #ifdef __cplusplus
27 extern "C" {
28 #endif
29
30 /* The public interface header for the r300 pipe driver.
31 * Any winsys hosting this pipe needs to implement r300_winsys and then
32 * call r300_create_context to start things. */
33
34 #include "pipe/p_defines.h"
35 #include "pipe/p_state.h"
36 #include "pipe/internal/p_winsys_screen.h"
37
38 struct radeon_cs;
39
40 struct r300_winsys {
41 /* Parent class */
42 struct pipe_winsys base;
43
44 /* Opaque Radeon-specific winsys object. */
45 void* radeon_winsys;
46
47 /* PCI ID */
48 uint32_t pci_id;
49
50 /* GB pipe count */
51 uint32_t gb_pipes;
52
53 /* CS object. This is very much like Intel's batchbuffer.
54 * Fill it full of dwords and relocs and then submit.
55 * Repeat as needed. */
56 struct radeon_cs* cs;
57
58 /* Check to see if there's room for commands. */
59 boolean (*check_cs)(struct radeon_cs* cs, int size);
60
61 /* Start a command emit. */
62 void (*begin_cs)(struct radeon_cs* cs,
63 int size,
64 const char* file,
65 const char* function,
66 int line);
67
68 /* Write a dword to the command buffer. */
69 void (*write_cs_dword)(struct radeon_cs* cs, uint32_t dword);
70
71 /* Write a relocated dword to the command buffer. */
72 void (*write_cs_reloc)(struct radeon_cs* cs,
73 struct pipe_buffer* bo,
74 uint32_t rd,
75 uint32_t wd,
76 uint32_t flags);
77
78 /* Finish a command emit. */
79 void (*end_cs)(struct radeon_cs* cs,
80 const char* file,
81 const char* function,
82 int line);
83
84 /* Flush the CS. */
85 void (*flush_cs)(struct radeon_cs* cs);
86 };
87
88 struct pipe_context* r300_create_context(struct pipe_screen* screen,
89 struct r300_winsys* r300_winsys);
90
91 #ifdef __cplusplus
92 }
93 #endif
94
95 boolean r300_get_texture_buffer(struct pipe_texture* texture,
96 struct pipe_buffer** buffer,
97 unsigned* stride);
98
99 #endif /* R300_WINSYS_H */