Merge remote branch 'nouveau/gallium-0.1' into gallium-0.2
[mesa.git] / src / mesa / drivers / dri / intel / intel_fbo.h
1 /**************************************************************************
2 *
3 * Copyright 2006 Tungsten Graphics, Inc., Cedar Park, Texas.
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 INTEL_FBO_H
29 #define INTEL_FBO_H
30
31 #include "intel_screen.h"
32
33 struct intel_context;
34
35 /**
36 * Intel framebuffer, derived from gl_framebuffer.
37 */
38 struct intel_framebuffer
39 {
40 struct gl_framebuffer Base;
41
42 struct intel_renderbuffer *color_rb[3];
43
44 /* Drawable page flipping state */
45 GLboolean pf_active;
46 GLuint pf_seq;
47 GLint pf_planes;
48 GLint pf_current_page;
49 GLint pf_num_pages;
50
51 /* VBI
52 */
53 GLuint vbl_waited;
54
55 int64_t swap_ust;
56 int64_t swap_missed_ust;
57
58 GLuint swap_count;
59 GLuint swap_missed_count;
60 };
61
62
63 /**
64 * Intel renderbuffer, derived from gl_renderbuffer.
65 * Note: The PairedDepth and PairedStencil fields use renderbuffer IDs,
66 * not pointers because in some circumstances a deleted renderbuffer could
67 * result in a dangling pointer here.
68 */
69 struct intel_renderbuffer
70 {
71 struct gl_renderbuffer Base;
72 struct intel_region *region;
73 GLuint pfPitch; /* possibly paged flipped pitch */
74 GLboolean RenderToTexture; /* RTT? */
75
76 GLuint PairedDepth; /**< only used if this is a depth renderbuffer */
77 GLuint PairedStencil; /**< only used if this is a stencil renderbuffer */
78
79 GLuint pf_pending; /**< sequence number of pending flip */
80
81 GLuint vbl_pending; /**< vblank sequence number of pending flip */
82
83 uint8_t *span_cache;
84 unsigned long span_cache_offset;
85 };
86
87 extern struct intel_renderbuffer *intel_renderbuffer(struct gl_renderbuffer
88 *rb);
89
90 extern void
91 intel_renderbuffer_set_region(struct intel_renderbuffer *irb,
92 struct intel_region *region);
93
94 extern struct intel_renderbuffer *
95 intel_create_renderbuffer(GLenum intFormat);
96
97 extern void intel_fbo_init(struct intel_context *intel);
98
99
100 /* XXX make inline or macro */
101 extern struct intel_renderbuffer *intel_get_renderbuffer(struct gl_framebuffer
102 *fb,
103 int attIndex);
104
105 extern void intel_flip_renderbuffers(struct intel_framebuffer *intel_fb);
106
107
108 /* XXX make inline or macro */
109 extern struct intel_region *intel_get_rb_region(struct gl_framebuffer *fb,
110 GLuint attIndex);
111
112
113
114
115 #endif /* INTEL_FBO_H */