mirror of
				https://github.com/Rockbox/rockbox.git
				synced 2025-10-24 23:47:38 -04:00 
			
		
		
		
	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
		
			
				
	
	
		
			72 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
			
		
		
	
	
			72 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
| ---
 | |
| --- Chip Identification
 | |
| ---
 | |
| 
 | |
| PP = { info = {} }
 | |
| 
 | |
| local h = HELP:create_topic("PP")
 | |
| h:add("This table contains the abstraction of the different device blocks for the Portal Player / GoForce")
 | |
| 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 PP families.")
 | |
| 
 | |
| local function identify(name, family, desc)
 | |
|     PP.chipid = hwstub.dev.pp.chipid
 | |
|     PP.info.chip = name
 | |
|     PP.info.revision = hwstub.dev.pp.rev
 | |
|     PP.desc = desc
 | |
|     PP.family = family
 | |
|     print("Chip identified as " .. name ..", ROM " .. PP.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_pp611x")
 | |
| hh:add("PP.is_pp611x() returns true if the chip ID reports a PP611x")
 | |
| 
 | |
| function PP.is_pp611x()
 | |
|     return hwstub.dev.pp.chipid >= 0x6110
 | |
| end
 | |
| 
 | |
| hh = h:create_topic("is_pp502x")
 | |
| hh:add("PP.is_pp502x() returns true if the chip ID reports a PP502x")
 | |
| 
 | |
| function PP.is_pp502x()
 | |
|     return hwstub.dev.pp.chipid >= 0x5020 and hwstub.dev.pp.chipid < 0x6100
 | |
| end
 | |
| 
 | |
| hh = h:create_topic("is_pp500x")
 | |
| hh:add("PP.is_pp500x() returns true if the chip ID reports a PP500x")
 | |
| 
 | |
| function PP.is_pp500x()
 | |
|     return hwstub.dev.pp.chipid >= 0x5000 and hwstub.dev.pp.chipid < 0x5010
 | |
| end
 | |
| 
 | |
| hh = h:create_topic("debug")
 | |
| hh:add("PP.debug(...) prints some debug output if PP.debug_on is true and does nothing otherwise.")
 | |
| 
 | |
| PP.debug_on = false
 | |
| 
 | |
| function PP.debug(...)
 | |
|     if PP.debug_on then print(...) end
 | |
| end
 | |
| 
 | |
| hh = h:create_topic("debug")
 | |
| hh:add("PP.debug(...) prints some debug output if PP.debug_on is true and does nothing otherwise.")
 | |
| 
 | |
| PP.debug_on = false
 | |
| 
 | |
| -- init
 | |
| function PP.init()
 | |
|     if PP.is_pp611x() then
 | |
|         identify("PP611x (aka GoForce6110)", "pp6110", "pp6110")
 | |
|     elseif PP.is_pp502x() then
 | |
|         identify("PP502x", "pp502x", "pp502x")
 | |
|     elseif PP.is_pp500x() then
 | |
|         identify("PP500x", "pp500x", "pp500x")
 | |
|     else
 | |
|         print(string.format("Unable to identify this chip as a PP: chipid=0x%x", hwstub.dev.pp.chipid));
 | |
|     end
 | |
| end
 | |
| 
 | |
| require "pp/gpio"
 |