aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.Client/PS3/SPU_Tasks/Common
diff options
context:
space:
mode:
authordaoge_cmd <3523206925@qq.com>2026-03-01 12:16:08 +0800
committerdaoge_cmd <3523206925@qq.com>2026-03-01 12:16:08 +0800
commitb691c43c44ff180d10e7d4a9afc83b98551ff586 (patch)
tree3e9849222cbc6ba49f2f1fc6e5fe7179632c7390 /Minecraft.Client/PS3/SPU_Tasks/Common
parentdef8cb415354ac390b7e89052a50605285f1aca9 (diff)
Initial commit
Diffstat (limited to 'Minecraft.Client/PS3/SPU_Tasks/Common')
-rw-r--r--Minecraft.Client/PS3/SPU_Tasks/Common/DmaData.h117
-rw-r--r--Minecraft.Client/PS3/SPU_Tasks/Common/spu_assert.h24
2 files changed, 141 insertions, 0 deletions
diff --git a/Minecraft.Client/PS3/SPU_Tasks/Common/DmaData.h b/Minecraft.Client/PS3/SPU_Tasks/Common/DmaData.h
new file mode 100644
index 00000000..959ec09c
--- /dev/null
+++ b/Minecraft.Client/PS3/SPU_Tasks/Common/DmaData.h
@@ -0,0 +1,117 @@
+/* SCE CONFIDENTIAL
+PlayStation(R)3 Programmer Tool Runtime Library 430.001
+* Copyright (C) 2007 Sony Computer Entertainment Inc.
+* All Rights Reserved.
+*/
+
+/* common headers */
+#include "spu_assert.h"
+#include <cell/dma.h>
+#include <cell/spurs/job_queue.h>
+
+extern CellSpursJobContext2* g_pSpursJobContext;
+
+class DmaData_SPU
+{
+public:
+ static const bool sc_verbose = false;
+
+ static int roundUpDMASize(int size)
+ {
+ return (size + 0x0f) & (~0x0f);
+ }
+
+ static void get(void* dest, uintptr_t ea, unsigned int dmaSize)
+ {
+ spu_assert((ea % 0x10) == 0); // make sure we're 16 byte aligned
+ spu_assert((uint32_t(dest) % 0x10) == 0); // make sure we're 16 byte aligned
+ spu_assert((dmaSize % 0x10) == 0); // and that the transfer is a multiple of 16 bytes
+ spu_assert(ea >256*1024); // and that we're not targetting SPU memory
+ // start memory transfer
+ if(sc_verbose)
+ spu_print("DMA PPU->SPU start: 0x%08x -> 0x%08x : size : %d bytes : tag %d .... ", (unsigned int)ea, (unsigned int)dest, dmaSize, g_pSpursJobContext->dmaTag);
+
+ cellDmaLargeGet(dest, ea, dmaSize, g_pSpursJobContext->dmaTag, 0, 0);
+ }
+
+ static void getUnaligned(void* dest, uintptr_t ea, unsigned int dmaSize)
+ {
+ spu_assert(ea >256*1024); // and that we're not targetting SPU memory
+ // start memory transfer
+ if(sc_verbose)
+ spu_print("DMA PPU->SPU start: 0x%08x -> 0x%08x : size : %d bytes : tag %d .... ", (unsigned int)ea, (unsigned int)dest, dmaSize, g_pSpursJobContext->dmaTag);
+
+ cellDmaUnalignedGet(dest, ea, dmaSize, g_pSpursJobContext->dmaTag, 0, 0);
+ }
+
+
+ static uint32_t getValue32(uintptr_t ea)
+ {
+ return cellDmaGetUint32(ea, g_pSpursJobContext->dmaTag, 0, 0);
+ }
+ static uint32_t getValue16(uintptr_t ea)
+ {
+ return cellDmaGetUint16(ea, g_pSpursJobContext->dmaTag, 0, 0);
+ }
+ static uint32_t getValue64(uintptr_t ea)
+ {
+ return cellDmaGetUint64(ea, g_pSpursJobContext->dmaTag, 0, 0);
+ }
+
+
+ static void wait()
+ {
+ cellDmaWaitTagStatusAll(1 << g_pSpursJobContext->dmaTag);
+ if(sc_verbose)
+ spu_print("DMA PPU->SPU done!\n");
+ }
+
+ static void getAndWait(void* dest, uintptr_t ea, unsigned int dmaSize)
+ {
+ get(dest, ea, dmaSize);
+ wait();
+ }
+
+ static void getAndWaitUnaligned(void* dest, uintptr_t ea, unsigned int dmaSize)
+ {
+ getUnaligned(dest, ea, dmaSize);
+ wait();
+ }
+
+ static void put(void* src, uintptr_t ea, unsigned int dmaSize)
+ {
+ if(sc_verbose)
+ spu_print("DMA SPU->PPU start: 0x%08x -> 0x%08x : size : %d bytes .... ", (unsigned int)src, (unsigned int)ea, dmaSize);
+ spu_assert((ea % 0x10) == 0); // make sure we're 16 byte aligned
+ spu_assert((uint32_t(src) % 0x10) == 0); // make sure we're 16 byte aligned
+ spu_assert((dmaSize % 0x10) == 0); // and that the transfer is a multiple of 16 bytes
+ spu_assert(ea >256*1024); // and that we're not targetting SPU memory
+ cellDmaLargePut(src, ea, dmaSize, g_pSpursJobContext->dmaTag, 0, 0);
+ }
+
+ static void putAndWait(void* src, uintptr_t ea, unsigned int dmaSize)
+ {
+ put(src, ea, dmaSize);
+ wait();
+ }
+ static void putAndWaitUnaligned(void* src, uintptr_t ea, unsigned int dmaSize)
+ {
+ if(sc_verbose)
+ spu_print("DMA SPU->PPU : 0x%08x -> 0x%08x : size : %d bytes\n", (unsigned int)src, (unsigned int)ea, dmaSize);
+ spu_assert((ea % 0x10) == 0); // make sure we're 16 byte aligned
+ spu_assert((uint32_t(src) % 0x10) == 0); // make sure we're 16 byte aligned
+ spu_assert((dmaSize % 0x10) == 0); // and that the transfer is a multiple of 16 bytes
+ spu_assert(ea >256*1024); // and that we're not targetting SPU memory
+ cellDmaUnalignedPut(src, ea, dmaSize, g_pSpursJobContext->dmaTag, 0, 0);
+ cellDmaWaitTagStatusAll(1 << g_pSpursJobContext->dmaTag);
+ if(sc_verbose)
+ spu_print("DMA SPU->PPU complete\n");
+ }
+
+ static void putValue32(uint32_t val, uintptr_t ea)
+ {
+ cellDmaPutUint32(val, ea, g_pSpursJobContext->dmaTag, 0, 0);
+ }
+
+};
+
diff --git a/Minecraft.Client/PS3/SPU_Tasks/Common/spu_assert.h b/Minecraft.Client/PS3/SPU_Tasks/Common/spu_assert.h
new file mode 100644
index 00000000..b4ff73bd
--- /dev/null
+++ b/Minecraft.Client/PS3/SPU_Tasks/Common/spu_assert.h
@@ -0,0 +1,24 @@
+#pragma once
+
+
+
+#ifdef _CONTENT_PACKAGE
+
+#define spu_assert(a) {}
+#define spu_print(...) {}
+
+#else
+
+#include <spu_printf.h>
+#define spu_print spu_printf
+#define spu_assert(a) { \
+ if(!(a)) \
+ { \
+ spu_printf( "===================================\n" \
+ "spu_assert : \t%s \n Func : \t%s \n File : \t%s \n Line : \t%d\n" \
+ "===================================\n", #a, __PRETTY_FUNCTION__, __FILE__, __LINE__); \
+ si_stop(2); \
+ } \
+ }
+
+#endif // _CONTENT_PACKAGE \ No newline at end of file