summaryrefslogtreecommitdiff
path: root/arm9/lib/NitroSDK/include/GX_dma.h
blob: 98f6a4a26e7a27528e39beefc07ebcbe24e6e6ff (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
#ifndef GUARD_GX_DMA_H
#define GUARD_GX_DMA_H

#define GX_DMA_NOT_USE -1
#define GX_CPU_FASTER32_SIZE 0x30
#define GX_CPU_FASTER16_SIZE 0x1C

static inline void GXi_DmaCopy32(u32 dmaNo, const void *src, void *dest, u32 size)
{
    if (dmaNo != GX_DMA_NOT_USE && size > GX_CPU_FASTER32_SIZE)
    {
        MI_DmaCopy32(dmaNo, src, dest, size);
    }
    else
    {
        MIi_CpuCopy32(src, dest, size);
    }
}

static inline void GXi_DmaCopy16(u32 dmaNo, const void *src, void *dest, u32 size)
{
    if (dmaNo != GX_DMA_NOT_USE && size > GX_CPU_FASTER16_SIZE)
    {
        MI_DmaCopy16(dmaNo, src, dest, size);
    }
    else
    {
        MIi_CpuCopy16(src, dest, size);
    }
}

static inline void GXi_DmaCopy32Async(u32 dmaNo, const void *src, void *dest, u32 size,
                                      MIDmaCallback callback, void *arg)
{
    if (dmaNo != GX_DMA_NOT_USE)
    {
        MI_DmaCopy32Async(dmaNo, src, dest, size, callback, arg);
    }
    else
    {
        MIi_CpuCopy32(src, dest, size);
    }
}

static inline void GXi_WaitDma(u32 dmaNo)
{
    if (dmaNo != GX_DMA_NOT_USE)
    {
        MI_WaitDma(dmaNo);
    }
}

#endif //GUARD_GX_DMA_H