libdragon
surface.h
Go to the documentation of this file.
1
52#ifndef __LIBDRAGON_SURFACE_H
53#define __LIBDRAGON_SURFACE_H
54
55#include <stdint.h>
56#include <stddef.h>
57#include <stdbool.h>
58
59#ifdef __cplusplus
60extern "C" {
61#endif
62
64// Macro to create a texture format, combining the RDP native "fmt/size" tuple.
65// This macro is used to genearte the #tex_format_t enums creating identifiers
66// which are easy to convert back into RDP native fields.
67#define _RDP_FORMAT_CODE(rdp_fmt, rdp_size) (((rdp_fmt)<<2)|(rdp_size))
69
74#define TEX_FORMAT_BITDEPTH(fmt) (4 << ((fmt) & 0x3))
82#define TEX_FORMAT_PIX2BYTES(fmt, pixels) ((((pixels) << (((fmt) & 3) + 2)) + 7) >> 3)
89#define TEX_FORMAT_BYTES2PIX(fmt, bytes) (((bytes) << 1) >> ((fmt) & 3))
90
103typedef enum {
105
106 FMT_RGBA16 = _RDP_FORMAT_CODE(0, 2),
107 FMT_RGBA32 = _RDP_FORMAT_CODE(0, 3),
108 FMT_YUV16 = _RDP_FORMAT_CODE(1, 2),
109 FMT_CI4 = _RDP_FORMAT_CODE(2, 0),
110 FMT_CI8 = _RDP_FORMAT_CODE(2, 1),
111 FMT_IA4 = _RDP_FORMAT_CODE(3, 0),
112 FMT_IA8 = _RDP_FORMAT_CODE(3, 1),
113 FMT_IA16 = _RDP_FORMAT_CODE(3, 2),
114 FMT_I4 = _RDP_FORMAT_CODE(4, 0),
115 FMT_I8 = _RDP_FORMAT_CODE(4, 1),
117
119const char* tex_format_name(tex_format_t fmt);
120
121#define SURFACE_FLAGS_TEXFORMAT 0x001F
122#define SURFACE_FLAGS_OWNEDBUFFER 0x0020
123#define SURFACE_FLAGS_TEXINDEX 0x0F00
124
137typedef struct surface_s
138{
139 uint16_t flags;
140 uint16_t width;
141 uint16_t height;
142 uint16_t stride;
143 void *buffer;
144} surface_t;
145
168inline surface_t surface_make(void *buffer, tex_format_t format, uint16_t width, uint16_t height, uint16_t stride) {
169 return (surface_t){
170 .flags = format,
171 .width = width,
172 .height = height,
173 .stride = stride,
174 .buffer = buffer,
175 };
176}
177
195inline surface_t surface_make_linear(void *buffer, tex_format_t format, uint16_t width, uint16_t height) {
196 return surface_make(buffer, format, width, height, TEX_FORMAT_PIX2BYTES(format, width));
197}
198
216surface_t surface_alloc(tex_format_t format, uint16_t width, uint16_t height);
217
233 uint16_t x0, uint16_t y0, uint16_t width, uint16_t height);
234
247void surface_free(surface_t *surface);
248
256{
257 return (tex_format_t)(surface->flags & SURFACE_FLAGS_TEXFORMAT);
258}
259
266inline bool surface_has_owned_buffer(const surface_t *surface)
267{
268 return surface->buffer != NULL && surface->flags & SURFACE_FLAGS_OWNEDBUFFER;
269}
270
293inline surface_t surface_make_placeholder(int index, tex_format_t format, uint16_t width, uint16_t height, uint16_t stride) {
294 return (surface_t){
295 .flags = (uint16_t)(format | ((index & 0xF) << 8)),
296 .width = width,
297 .height = height,
298 .stride = stride,
299 .buffer = NULL,
300 };
301}
302
318inline surface_t surface_make_placeholder_linear(int index, tex_format_t format, uint16_t width, uint16_t height) {
319 return surface_make_placeholder(index, format, width, height, TEX_FORMAT_PIX2BYTES(format, width));
320}
321
332inline int surface_get_placeholder_index(const surface_t *surface)
333{
334 return (surface->flags >> 8) & 0xF;
335}
336
337
338#ifdef __cplusplus
339}
340#endif
341
342#endif
tex_format_t
Pixel format enum.
Definition: surface.h:103
@ FMT_RGBA32
Format RGBA 8888 (32-bit)
Definition: surface.h:107
@ FMT_CI8
Format CI8: color index 8-bit (paletted, 1 index per byte)
Definition: surface.h:110
@ FMT_YUV16
Format YUV2 4:2:2 (data interleaved as YUYV)
Definition: surface.h:108
@ FMT_IA4
Format IA4: 3-bit intensity + 1-bit alpha (4-bit per pixel)
Definition: surface.h:111
@ FMT_I8
Format I8: 8-bit intensity (8-bit per pixel)
Definition: surface.h:115
@ FMT_IA16
Format IA16: 8-bit intensity + 8-bit alpha (16-bit per pixel)
Definition: surface.h:113
@ FMT_NONE
Placeholder for no format defined.
Definition: surface.h:104
@ FMT_RGBA16
Format RGBA 5551 (16-bit)
Definition: surface.h:106
@ FMT_CI4
Format CI4: color index 4-bit (paletted, 2 indices per byte)
Definition: surface.h:109
@ FMT_I4
Format I4: 4-bit intensity (4-bit per pixel)
Definition: surface.h:114
@ FMT_IA8
Format IA8: 4-bit intensity + 4-bit alpha (8-bit per pixel)
Definition: surface.h:112
bool surface_has_owned_buffer(const surface_t *surface)
Checks whether this surface owns the buffer that it contains.
Definition: surface.h:266
uint16_t stride
Stride in bytes (length of a row)
Definition: surface.h:142
#define SURFACE_FLAGS_OWNEDBUFFER
Set if the buffer must be freed.
Definition: surface.h:122
surface_t surface_make_sub(surface_t *parent, uint16_t x0, uint16_t y0, uint16_t width, uint16_t height)
Initialize a surface_t structure, pointing to a rectangular portion of another surface.
Definition: surface.c:57
void * buffer
Buffer pointer.
Definition: surface.h:143
surface_t surface_make(void *buffer, tex_format_t format, uint16_t width, uint16_t height, uint16_t stride)
Initialize a surface_t structure with the provided buffer.
Definition: surface.h:168
uint16_t width
Width in pixels.
Definition: surface.h:140
int surface_get_placeholder_index(const surface_t *surface)
Returns the lookup index of a placeholder surface.
Definition: surface.h:332
surface_t surface_alloc(tex_format_t format, uint16_t width, uint16_t height)
Allocate a new surface in memory.
Definition: surface.c:32
surface_t surface_make_placeholder_linear(int index, tex_format_t format, uint16_t width, uint16_t height)
Create a linear placeholder surface, that can be used during rdpq block recording.
Definition: surface.h:318
#define TEX_FORMAT_PIX2BYTES(fmt, pixels)
Convert the specified number of pixels to bytes.
Definition: surface.h:82
uint16_t height
Height in pixels.
Definition: surface.h:141
surface_t surface_make_linear(void *buffer, tex_format_t format, uint16_t width, uint16_t height)
Initialize a surface_t structure with the provided linear buffer.
Definition: surface.h:195
void surface_free(surface_t *surface)
Free the buffer allocated in a surface.
Definition: surface.c:49
surface_t surface_make_placeholder(int index, tex_format_t format, uint16_t width, uint16_t height, uint16_t stride)
Create a placeholder surface, that can be used during rdpq block recording.
Definition: surface.h:293
const char * tex_format_name(tex_format_t fmt)
Return the name of the texture format as a string (for debugging purposes)
Definition: surface.c:14
tex_format_t surface_get_format(const surface_t *surface)
Returns the pixel format of a surface.
Definition: surface.h:255
#define SURFACE_FLAGS_TEXFORMAT
Pixel format of the surface.
Definition: surface.h:121
uint16_t flags
Flags (including pixel format)
Definition: surface.h:139
A surface buffer for graphics.
Definition: surface.h:138