// READ DMA (many values)\r
////////////////////////////////////////////////////////////////////////\r
\r
// READ DMA (many values)\r
////////////////////////////////////////////////////////////////////////\r
\r
- *pusPSXMem++=spuMem[spuAddr>>1]; // spu addr got by writeregister\r
- spuAddr+=2; // inc spu addr\r
- if(spuAddr>0x7ffff) spuAddr=0; // wrap\r
+ *pusPSXMem++ = *(unsigned short *)(spu.spuMemC + spu.spuAddr);\r
+ spu.spuAddr += 2;\r
+ spu.spuAddr &= 0x7fffe;\r
}\r
\r
////////////////////////////////////////////////////////////////////////\r
// WRITE DMA (many values)\r
////////////////////////////////////////////////////////////////////////\r
\r
}\r
\r
////////////////////////////////////////////////////////////////////////\r
// WRITE DMA (many values)\r
////////////////////////////////////////////////////////////////////////\r
\r
- memcpy(&spuMem[spuAddr>>1], pusPSXMem, iSize*2);\r
- spuAddr += iSize*2;\r
+ memcpy(spu.spuMemC + spu.spuAddr, pusPSXMem, iSize*2);\r
+ spu.spuAddr += iSize*2;\r
- spuMem[spuAddr>>1] = *pusPSXMem++; // spu addr got by writeregister\r
- spuAddr+=2; // inc spu addr\r
- spuAddr&=0x7ffff; // wrap\r
+ *(unsigned short *)(spu.spuMemC + spu.spuAddr) = *pusPSXMem++;\r
+ spu.spuAddr += 2;\r
+ spu.spuAddr &= 0x7fffe;\r