[SerialICE] New patch to review for serialice: 9309452 Refactor CAR region code

Patrick Georgi (patrick@georgi-clan.de) gerrit at coreboot.org
Thu Dec 1 15:38:26 CET 2011


Patrick Georgi (patrick at georgi-clan.de) just uploaded a new patch set to gerrit, which you can find at http://review.coreboot.org/464

-gerrit

commit 93094522ace3e7b7f508f4d41f3550de660a3be9
Author: Patrick Georgi <patrick.georgi at secunet.com>
Date:   Thu Dec 1 14:00:41 2011 +0100

    Refactor CAR region code
    
    Change-Id: If7c4cff1690c4d48cca50d03d75ec533b26c8d9f
    Signed-off-by: Patrick Georgi <patrick.georgi at secunet.com>
---
 SerialICE/scripts/serialice.lua |   56 ++++++++++++++++++++++++++------------
 1 files changed, 38 insertions(+), 18 deletions(-)

diff --git a/SerialICE/scripts/serialice.lua b/SerialICE/scripts/serialice.lua
index a41988a..2472b49 100644
--- a/SerialICE/scripts/serialice.lua
+++ b/SerialICE/scripts/serialice.lua
@@ -54,6 +54,27 @@ function pci_bdf(bus, dev, func, reg)
 	return 0x80000000 + bus*65536 + dev*2048 + func*256 + reg
 end
 
+car_regions = { list = nil }
+
+function new_car_region(start, size)
+	car_regions.list = { next = car_regions.list, start = start, size = size }
+	SerialICE_register_physical(start, size)
+end
+
+function is_car(addr)
+	if car_regions.list == nil then
+		return false
+	end
+	local l = car_regions.list
+	while l do
+		if addr >= l.start and addr < l.start + l.size then
+			return true
+		end
+		l = l.next
+	end
+	return false
+end
+
 function new_list()
 	return { list = nil }
 end
@@ -389,6 +410,12 @@ function SerialICE_memory_read_filter(addr, size)
 	-- 	return false, false, 0x23232323
 	-- end
 
+	-- Cache-As-RAM is exclusively
+	-- handled by Qemu (RAM backed)
+	if is_car(addr) then
+		return false, true, 0
+	end
+
 	if	addr >= 0xfff00000 and addr <= 0xffffffff then
 		-- ROM accesses go to Qemu only
 		return false, true, 0
@@ -401,14 +428,6 @@ function SerialICE_memory_read_filter(addr, size)
 		-- Intel chipset BARs are exclusively 
 		-- handled by the SerialICE target
 		return true, false, 0
-	elseif	addr >= 0xffd80000 and addr <= 0xffdfffff then
-		-- coreboot Cache-As-RAM is exclusively
-		-- handled by Qemu (RAM backed)
-		return false, true, 0
-	elseif	addr >= 0xffbc0000 and addr <= 0xffbfffff then
-		-- AMI Cache-As-RAM is exclusively
-		-- handled by Qemu (RAM backed)
-		return false, true, 0
 	elseif	addr >= 0xfee00000 and addr <= 0xfeefffff then
 		-- Local APIC.. Hm, not sure what to do here.
 		-- We should avoid that someone wakes up cores
@@ -467,6 +486,12 @@ end
 --   result	Data to be written (may be changed in filter)
 
 function SerialICE_memory_write_filter(addr, size, data)
+	-- Cache-As-RAM is exclusively
+	-- handled by Qemu (RAM backed)
+	if is_car(addr) then
+		return false, true, data
+	end
+
 	if	addr >= 0xfff00000 and addr <= 0xffffffff then
 		printf("\nWARNING: write access to ROM?\n")
 		-- ROM accesses go to Qemu only
@@ -480,14 +505,6 @@ function SerialICE_memory_write_filter(addr, size, data)
 		-- Intel chipset BARs are exclusively 
 		-- handled by the SerialICE target
 		return true, false, data
-	elseif	addr >= 0xffd80000 and addr <= 0xffdfffff then
-		-- coreboot Cache-As-RAM is exclusively
-		-- handled by Qemu (RAM backed)
-		return false, true, data
-	elseif	addr >= 0xffbc0000 and addr <= 0xffbfffff then
-		-- AMI Cache-As-RAM is exclusively
-		-- handled by Qemu (RAM backed)
-		return false, true, data
 	elseif	addr >= 0xfee00000 and addr <= 0xfeefffff then
 		-- Local APIC.. Hm, not sure what to do here.
 		-- We should avoid that someone wakes up cores
@@ -707,11 +724,14 @@ printf("SerialICE: Registering physical memory areas for Cache-As-Ram:\n")
 
 -- Register Phoenix BIOS Cache as RAM area as normal RAM 
 -- 0xffd80000 - 0xffdfffff
-SerialICE_register_physical(0xffd80000, 0x80000)
+new_car_region(0xffd80000, 0x80000)
 
 -- Register AMI BIOS Cache as RAM area as normal RAM
 -- 0xffbc0000 - 0xffbfffff
-SerialICE_register_physical(0xffbc0000, 0x40000)
+new_car_region(0xffbc0000, 0x40000)
+
+-- current Phoenix BIOS
+new_car_region(0xde000, 0x2000)
 
 printf("SerialICE: LUA script initialized.\n")
 



More information about the SerialICE mailing list