mirror of
https://github.com/Lime3DS/Lime3DS
synced 2025-01-09 13:43:27 +00:00
GPU: Add documentation.
This commit is contained in:
parent
4b141791ed
commit
61e2ffd448
1 changed files with 14 additions and 2 deletions
|
@ -84,11 +84,14 @@ struct Regs::Struct<Regs::FramebufferTop> {
|
||||||
union {
|
union {
|
||||||
u32 active_fb;
|
u32 active_fb;
|
||||||
|
|
||||||
|
// 0: Use parameters ending with "1"
|
||||||
|
// 1: Use parameters ending with "2"
|
||||||
BitField<0, 1, u32> second_fb_active;
|
BitField<0, 1, u32> second_fb_active;
|
||||||
};
|
};
|
||||||
|
|
||||||
u32 pad2[5];
|
u32 pad2[5];
|
||||||
|
|
||||||
|
// Distance between two pixel rows, in bytes
|
||||||
u32 stride;
|
u32 stride;
|
||||||
|
|
||||||
u32 address_right1;
|
u32 address_right1;
|
||||||
|
@ -132,23 +135,32 @@ struct Regs::Struct<Regs::DisplayTransfer> {
|
||||||
union {
|
union {
|
||||||
u32 flags;
|
u32 flags;
|
||||||
|
|
||||||
BitField< 0, 1, u32> flip_data;
|
BitField< 0, 1, u32> flip_data; // flips input data horizontally (TODO) if true
|
||||||
BitField< 8, 3, Format> input_format;
|
BitField< 8, 3, Format> input_format;
|
||||||
BitField<12, 3, Format> output_format;
|
BitField<12, 3, Format> output_format;
|
||||||
BitField<16, 1, u32> output_tiled;
|
BitField<16, 1, u32> output_tiled; // stores output in a tiled format
|
||||||
};
|
};
|
||||||
|
|
||||||
u32 unknown;
|
u32 unknown;
|
||||||
|
|
||||||
|
// it seems that writing to this field triggers the display transfer
|
||||||
u32 trigger;
|
u32 trigger;
|
||||||
};
|
};
|
||||||
static_assert(sizeof(Regs::Struct<Regs::DisplayTransfer>) == 0x1C, "Structure size and register block length don't match");
|
static_assert(sizeof(Regs::Struct<Regs::DisplayTransfer>) == 0x1C, "Structure size and register block length don't match");
|
||||||
|
|
||||||
template<>
|
template<>
|
||||||
struct Regs::Struct<Regs::CommandProcessor> {
|
struct Regs::Struct<Regs::CommandProcessor> {
|
||||||
|
// command list size
|
||||||
u32 size;
|
u32 size;
|
||||||
|
|
||||||
u32 pad0;
|
u32 pad0;
|
||||||
|
|
||||||
|
// command list address
|
||||||
u32 address;
|
u32 address;
|
||||||
|
|
||||||
u32 pad1;
|
u32 pad1;
|
||||||
|
|
||||||
|
// it seems that writing to this field triggers command list processing
|
||||||
u32 trigger;
|
u32 trigger;
|
||||||
};
|
};
|
||||||
static_assert(sizeof(Regs::Struct<Regs::CommandProcessor>) == 0x14, "Structure size and register block length don't match");
|
static_assert(sizeof(Regs::Struct<Regs::CommandProcessor>) == 0x14, "Structure size and register block length don't match");
|
||||||
|
|
Loading…
Reference in a new issue