summaryrefslogtreecommitdiffstats
path: root/utils/hwstub/tools/lua/jz/misc.lua
blob: fb4185de337050b8b53e598a26a40c6da4e345f7 (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
----------
-- MISC --
----------

JZ.misc = {}

function JZ.misc.enable_sram()
    HW.CPM.CLKGATE1.SRAM.clr()
    HW.CPM.CLKGATE1.AHB1.clr()
end

function JZ.misc.test_sram()
    DEV.write32(0xb32d0000, 0xaaaa5555)
    if DEV.read32(0xb32d0000) ~= 0xaaaa5555 then
        error("SRAM is not working")
    end
    DEV.write32(0xb32d0000, 0xdeadbeef)
    if DEV.read32(0xb32d0000) ~= 0xdeadbeef then
        error("SRAM is not working")
    end
    print("SRAM seems to be working")
    size = 0
    for i=4,64*1024,4 do
        DEV.write32(0xb32d0000, 0xdeadbeef)
        DEV.write32(0xb32d0000 + i, 0xcafebabe)
        if DEV.read32(0xb32d0000 + i) ~= 0xcafebabe or DEV.read32(0xb32d0000) == 0xcafebabe then
            size = i
            break
        end
    end
    print(string.format("SRAM size: 0x%x (%d KiB)", size, size / 1024))
    -- double check
    for i=0,size-1,2 do
        DEV.write16(0xb32d0000 + i, i)
    end
    for i=0,size-1,2 do
        if DEV.read16(0xb32d0000 + i) ~= i then
            error(string.format("SRAM size is not confirmed: read @%x gives %d instead of %d",
                0xb32d0000 + i, DEV.read16(0xb32d0000 + i), i))
        end
    end
    print("SRAM size confirmed and working")
end