summaryrefslogtreecommitdiff
path: root/plugins/ao/eng_dsf/arm7memil.c
blob: c1872a2c97935a238d15f67dee833fa2d51e1d9f (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
54
55
56
// memory inline functions shared by ARM and THUMB modes

static INLINE void arm7_write_32(struct sARM7 *cpu, UINT32 addr, UINT32 data )
{
	addr &= ~3;
	dc_write32(cpu, addr,data);
}


static INLINE void arm7_write_16(struct sARM7 *cpu, UINT32 addr, UINT16 data)
{
	addr &= ~1;
	dc_write16(cpu, addr,data);
}

static INLINE void arm7_write_8(struct sARM7 *cpu, UINT32 addr, UINT8 data)
{
	dc_write8(cpu, addr,data);
}

static INLINE UINT32 arm7_read_32(struct sARM7 *cpu, UINT32 addr)
{
    UINT32 result;
    int k = (addr & 3) << 3;

    if (k)
    {
        result = dc_read32 (cpu, addr & ~3);
        result = (result >> k) | (result << (32 - k));
    }
    else
    {
    	result = dc_read32(cpu, addr);
    }
    return result;
}

static INLINE UINT16 arm7_read_16(struct sARM7 *cpu, UINT32 addr)
{
	UINT16 result;

	result = dc_read16(cpu, addr & ~1);

	if (addr & 1)
	{
		result = ((result>>8) & 0xff) | ((result&0xff)<<8);
	}

	return result;
}

static INLINE UINT8 arm7_read_8(struct sARM7 *cpu, UINT32 addr)
{
    return dc_read8(cpu, addr);
}