summaryrefslogtreecommitdiff
path: root/gflib/dma3.h
diff options
context:
space:
mode:
authorKurausukun <lord.uber1@gmail.com>2021-07-03 17:39:33 -0400
committerKurausukun <lord.uber1@gmail.com>2021-07-03 17:39:33 -0400
commit42730a8315be6abceeb95bc1cd29f4c54077bd2e (patch)
tree1be39d17e751cf4343fe87ca9cff08cdfb0d96dc /gflib/dma3.h
parent10c80230c4b24074a8a9e46661db91fa8d465780 (diff)
Revert "remove gflib"
This reverts commit 8b59909ac5eb6e3540aeb78396943d57a9702e4d.
Diffstat (limited to 'gflib/dma3.h')
-rw-r--r--gflib/dma3.h55
1 files changed, 55 insertions, 0 deletions
diff --git a/gflib/dma3.h b/gflib/dma3.h
new file mode 100644
index 000000000..8eff34f55
--- /dev/null
+++ b/gflib/dma3.h
@@ -0,0 +1,55 @@
+#ifndef GUARD_DMA3_H
+#define GUARD_DMA3_H
+
+// Maximum amount of data we will transfer in one operation
+#define MAX_DMA_BLOCK_SIZE 0x1000
+
+#define Dma3CopyLarge_(src, dest, size, bit) \
+{ \
+ const void *_src = src; \
+ void *_dest = dest; \
+ u32 _size = size; \
+ while (1) \
+ { \
+ if (_size <= MAX_DMA_BLOCK_SIZE) \
+ { \
+ DmaCopy##bit(3, _src, _dest, _size); \
+ break; \
+ } \
+ DmaCopy##bit(3, _src, _dest, MAX_DMA_BLOCK_SIZE); \
+ _src += MAX_DMA_BLOCK_SIZE; \
+ _dest += MAX_DMA_BLOCK_SIZE; \
+ _size -= MAX_DMA_BLOCK_SIZE; \
+ } \
+}
+
+#define Dma3CopyLarge16_(src, dest, size) Dma3CopyLarge_(src, dest, size, 16)
+#define Dma3CopyLarge32_(src, dest, size) Dma3CopyLarge_(src, dest, size, 32)
+
+#define Dma3FillLarge_(value, dest, size, bit) \
+{ \
+ void *_dest = dest; \
+ u32 _size = size; \
+ while (1) \
+ { \
+ if (_size <= MAX_DMA_BLOCK_SIZE) \
+ { \
+ DmaFill##bit(3, value, _dest, _size); \
+ break; \
+ } \
+ DmaFill##bit(3, value, _dest, MAX_DMA_BLOCK_SIZE); \
+ _dest += MAX_DMA_BLOCK_SIZE; \
+ _size -= MAX_DMA_BLOCK_SIZE; \
+ } \
+}
+
+#define Dma3FillLarge16_(value, dest, size) Dma3FillLarge_(value, dest, size, 16)
+#define Dma3FillLarge32_(value, dest, size) Dma3FillLarge_(value, dest, size, 32)
+
+void ClearDma3Requests(void);
+void ProcessDma3Requests(void);
+s16 RequestDma3Copy(const void *src, void *dest, u16 size, u8 mode);
+s16 RequestDma3Fill(s32 value, void *dest, u16 size, u8 mode);
+s16 CheckForSpaceForDma3Request(s16 index);
+
+#endif // GUARD_DMA3_H