[SerialICE] New patch to review for serialice: b1c818a Convert memory logging to hooks
Patrick Georgi (patrick@georgi-clan.de)
gerrit at coreboot.org
Thu Dec 1 15:38:27 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/467
-gerrit
commit b1c818a593947a0a2a6df79782d8e54b3cd5f36d
Author: Patrick Georgi <patrick.georgi at secunet.com>
Date: Thu Dec 1 15:23:14 2011 +0100
Convert memory logging to hooks
Change-Id: I09c2a97964d4e3101000a10fac86df283eb9506c
Signed-off-by: Patrick Georgi <patrick.georgi at secunet.com>
---
SerialICE/scripts/serialice.lua | 64 +++++++++++++++++++++++---------------
1 files changed, 39 insertions(+), 25 deletions(-)
diff --git a/SerialICE/scripts/serialice.lua b/SerialICE/scripts/serialice.lua
index 3a8bf74..0e7e902 100644
--- a/SerialICE/scripts/serialice.lua
+++ b/SerialICE/scripts/serialice.lua
@@ -97,12 +97,40 @@ function walk_list(list, ...)
return false
end
-io_write_hooks = new_list()
-io_write_log_hooks = new_list()
io_read_hooks = new_list()
+io_write_hooks = new_list()
io_read_log_hooks = new_list()
-msr_write_hooks = new_list()
+io_write_log_hooks = new_list()
+
msr_read_hooks = new_list()
+msr_write_hooks = new_list()
+
+mem_read_log_hooks = new_list()
+mem_write_log_hooks = new_list()
+
+prepend_to_list(mem_read_log_hooks, function(addr, size, data, target)
+ if (PCIe_bar ~= 0) and addr >= PCIe_bar and addr <= (PCIe_bar + PCIe_size) then
+ printf("PCIe %x:%02x.%x R.%02x => %s\n",
+ bit.band(0xff,bit.rshift(addr, 20)),
+ bit.band(0x1f,bit.rshift(addr, 15)),
+ bit.band(0x7,bit.rshift(addr, 12)),
+ bit.band(0xfff,addr),
+ size_data(size, data))
+ return true
+ end
+end)
+
+prepend_to_list(mem_write_log_hooks, function(addr, size, data, target)
+ if (PCIe_bar ~= 0) and addr >= PCIe_bar and addr <= (PCIe_bar + PCIe_size) then
+ printf("PCIe %x:%02x.%x R.%02x <= %s\n",
+ bit.band(0xff,bit.rshift(addr, 20)),
+ bit.band(0x1f,bit.rshift(addr, 15)),
+ bit.band(0x7,bit.rshift(addr, 12)),
+ bit.band(0xfff,addr),
+ size_data(size, data))
+ return true
+ end
+end)
prepend_to_list(io_write_log_hooks, function(port, size, data, target)
if port == 0xcf9 then
@@ -646,22 +674,15 @@ function SerialICE_memory_write_log(addr, size, data, target)
log_cs_ip()
+ if walk_list(mem_write_log_hooks, addr, size, data, target) then
+ return
+ end
+
printf("MEM: write%s %08x <= %s", size_suffix(size), addr, size_data(size, data))
if target then
printf(" *")
end
printf("\n")
-
- -- **********************************************************
- --
-
- if (PCIe_bar ~= 0) and addr >= PCIe_bar and addr <= (PCIe_bar + PCIe_size) then
- printf("PCIe %x:%02x.%x R.%02x\n",
- bit.band(0xff,bit.rshift(addr, 20)),
- bit.band(0x1f,bit.rshift(addr, 15)),
- bit.band(0x7,bit.rshift(addr, 12)),
- bit.band(0xfff,addr))
- end
end
function SerialICE_memory_read_log(addr, size, data, target)
@@ -680,22 +701,15 @@ function SerialICE_memory_read_log(addr, size, data, target)
log_cs_ip()
+ if walk_list(mem_read_log_hooks, addr, size, data, target) then
+ return
+ end
+
printf("MEM: read%s %08x => %s", size_suffix(size), addr, size_data(size, data))
if target then
printf(" *")
end
printf("\n")
-
- -- **********************************************************
- --
-
- if (PCIe_bar ~= 0) and addr >= PCIe_bar and addr <= (PCIe_bar + PCIe_size) then
- printf("PCIe %x:%02x.%x R.%02x\n",
- bit.band(0xff,bit.rshift(addr, 20)),
- bit.band(0x1f,bit.rshift(addr, 15)),
- bit.band(0x7,bit.rshift(addr, 12)),
- bit.band(0xfff,addr))
- end
end
function SerialICE_io_write_log(port, size, data, target)
More information about the SerialICE
mailing list