spu: rm bunch of unused functions
[pcsx_rearmed.git] / plugins / dfsound / dma.c
CommitLineData
ef79bbde
P
1/***************************************************************************\r
2 dma.c - description\r
3 -------------------\r
4 begin : Wed May 15 2002\r
5 copyright : (C) 2002 by Pete Bernert\r
6 email : BlackDove@addcom.de\r
7 ***************************************************************************/\r
8/***************************************************************************\r
9 * *\r
10 * This program is free software; you can redistribute it and/or modify *\r
11 * it under the terms of the GNU General Public License as published by *\r
12 * the Free Software Foundation; either version 2 of the License, or *\r
13 * (at your option) any later version. See also the license.txt file for *\r
14 * additional informations. *\r
15 * *\r
16 ***************************************************************************/\r
17\r
18#include "stdafx.h"\r
19\r
20#define _IN_DMA\r
21\r
22#include "externals.h"\r
a5ff8be2 23#include "registers.h"\r
ef79bbde 24\r
ef79bbde
P
25////////////////////////////////////////////////////////////////////////\r
26// READ DMA (many values)\r
27////////////////////////////////////////////////////////////////////////\r
28\r
650adfd2 29void CALLBACK SPUreadDMAMem(unsigned short *pusPSXMem, int iSize,\r
30 unsigned int cycles)\r
ef79bbde 31{\r
a5ff8be2 32 unsigned int addr = spu.spuAddr, irq_addr = regAreaGet(H_SPUirqAddr) << 3;\r
33 int i, irq;\r
ef79bbde 34\r
63a4f6b6 35 do_samples_if_needed(cycles, 1);\r
a5ff8be2 36 irq = addr <= irq_addr && irq_addr < addr + iSize*2;\r
37\r
38 for(i = 0; i < iSize; i++)\r
39 {\r
40 *pusPSXMem++ = *(unsigned short *)(spu.spuMemC + addr);\r
41 addr += 2;\r
42 addr &= 0x7fffe;\r
43 }\r
44 if (irq && (spu.spuCtrl & CTRL_IRQ))\r
88b0dc1d 45 log_unhandled("rdma spu irq: %x/%x+%x\n", irq_addr, spu.spuAddr, iSize * 2);\r
a5ff8be2 46 spu.spuAddr = addr;\r
ef79bbde
P
47}\r
48\r
49////////////////////////////////////////////////////////////////////////\r
ef79bbde
P
50// WRITE DMA (many values)\r
51////////////////////////////////////////////////////////////////////////\r
52\r
650adfd2 53void CALLBACK SPUwriteDMAMem(unsigned short *pusPSXMem, int iSize,\r
54 unsigned int cycles)\r
ef79bbde 55{\r
a5ff8be2 56 unsigned int addr = spu.spuAddr, irq_addr = regAreaGet(H_SPUirqAddr) << 3;\r
57 int i, irq;\r
fb552464 58 \r
63a4f6b6 59 do_samples_if_needed(cycles, 1);\r
0c1151fe 60 spu.bMemDirty = 1;\r
a5ff8be2 61 irq = addr <= irq_addr && irq_addr < addr + iSize*2;\r
62\r
63 if (addr + iSize*2 < 0x80000)\r
64 {\r
65 memcpy(spu.spuMemC + addr, pusPSXMem, iSize*2);\r
66 addr += iSize*2;\r
67 }\r
68 else\r
69 {\r
70 irq |= irq_addr < ((addr + iSize*2) & 0x7ffff);\r
71 for (i = 0; i < iSize; i++)\r
ef79bbde 72 {\r
a5ff8be2 73 *(unsigned short *)(spu.spuMemC + addr) = *pusPSXMem++;\r
74 addr += 2;\r
75 addr &= 0x7fffe;\r
ef79bbde 76 }\r
a5ff8be2 77 }\r
78 if (irq && (spu.spuCtrl & CTRL_IRQ)) // unhandled because need to implement delay\r
79 log_unhandled("wdma spu irq: %x/%x+%x\n", irq_addr, spu.spuAddr, iSize * 2);\r
80 spu.spuAddr = addr;\r
ef79bbde
P
81}\r
82\r
83////////////////////////////////////////////////////////////////////////\r