rockbox/utils/hwstub/tools/lua/stmp.lua
Amaury Pouly f6c61eb11a hwstub: port hwstub_shell to the new library
Also use this opportunity to cleanup support for multiple devices: the shell
now supports dynamic changes in the device and will call init() everytime
a new device is selected, to prepare a new environment. The shell now
honors register width on register read/write. The shell also provides access
to variants as follows by creating a subtable under the register using the
variant type in UPPER case and having the same layout as a register.
For example if register HW.GPIO.DIR has variants "set" and "clr", those can
be used like this:
HW.GPIO.DIR.SET.write(0xff)
HW.GPIO.DIR.CLR.write(0xff00)

Change-Id: I943947fa98bce875de0cba4338e8b7196a4c1165
2016-04-08 19:38:18 +02:00

80 lines
No EOL
2.4 KiB
Lua

---
--- Chip Identification
---
STMP = { info = {} }
local h = HELP:create_topic("STMP")
h:add("This table contains the abstraction of the different device blocks for the STMP.")
h:add("It allows one to use higher-level primitives rather than poking at register directly.")
h:add("Furthermore, it tries as much as possible to hide the differences between the different STMP families.")
local function identify(name, family, desc)
STMP.chipid = hwstub.dev.stmp.chipid
STMP.info.chip = name
STMP.info.revision = "TA" .. tostring(hwstub.dev.stmp.rev+1)
STMP.desc = desc
STMP.family = family
print("Chip identified as " .. name ..", ROM " .. STMP.info.revision)
if not hwstub.soc:select(desc) then
print("Looking for soc " .. desc .. ": not found. Please load a soc by hand.")
end
end
local hh = h:create_topic("is_imx233")
hh:add("STMP.is_imx233() returns true if the chip ID reports a i.MX233")
function STMP.is_imx233()
return hwstub.dev.stmp.chipid == 0x3780
end
hh = h:create_topic("is_stmp3700")
hh:add("STMP.is_stmp3700() returns true if the chip ID reports a STMP3700")
function STMP.is_stmp3700()
return hwstub.dev.stmp.chipid == 0x3700
end
hh = h:create_topic("is_stmp3770")
hh:add("STMP.is_stmp3770() returns true if the chip ID reports a STMP3770")
function STMP.is_stmp3770()
return hwstub.dev.stmp.chipid == 0x37b0
end
hh = h:create_topic("is_stmp3600")
hh:add("STMP.is_stmp3600() returns true if the chip ID reports a STMP36xx")
function STMP.is_stmp3600()
return hwstub.dev.stmp.chipid >= 0x3600 and hwstub.dev.stmp.chipid < 0x3700
end
hh = h:create_topic("debug")
hh:add("STMP.debug(...) prints some debug output if STMP.debug_on is true and does nothing otherwise.")
STMP.debug_on = false
function STMP.debug(...)
if STMP.debug_on then print(...) end
end
-- init
function STMP.init()
if STMP.is_imx233() then
identify("STMP3780 (aka i.MX233)", "imx233", "imx233")
elseif STMP.is_stmp3700() then
identify("STMP3700", "stmp3700", "stmp3700")
elseif STMP.is_stmp3770() then
identify("STMP3770", "stmp3770", "stmp3700")
elseif STMP.is_stmp3600() then
identify("STMP3600", "stmp3600", "stmp3600")
else
print(string.format("Unable to identify this chip as a STMP: chipid=0x%x", hwstub.dev.stmp.chipid));
end
end
require "stmp/digctl"
require "stmp/pinctrl"
require "stmp/lcdif"
require "stmp/pwm"
require "stmp/clkctrl"
require "stmp/i2c"