[SerialICE] New patch to review for serialice: 78b8ac1 Convert io logging functions to provide hooks
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/465
-gerrit
commit 78b8ac1f3946a9d27584554e3c800bf27949606a
Author: Patrick Georgi <patrick.georgi at secunet.com>
Date: Thu Dec 1 14:31:58 2011 +0100
Convert io logging functions to provide hooks
Change-Id: Ib261b3812bba881d3a3124c5c0c36fa5e5ad2417
Signed-off-by: Patrick Georgi <patrick.georgi at secunet.com>
---
SerialICE/scripts/serialice.lua | 75 ++++++++++++++++++++++++---------------
1 files changed, 46 insertions(+), 29 deletions(-)
diff --git a/SerialICE/scripts/serialice.lua b/SerialICE/scripts/serialice.lua
index 2472b49..7346046 100644
--- a/SerialICE/scripts/serialice.lua
+++ b/SerialICE/scripts/serialice.lua
@@ -98,9 +98,49 @@ function walk_list(list, ...)
end
io_write_hooks = new_list()
+io_write_log_hooks = new_list()
+io_read_hooks = new_list()
+io_read_log_hooks = new_list()
msr_write_hooks = new_list()
msr_read_hooks = new_list()
+prepend_to_list(io_write_log_hooks, function(port, size, data, target)
+ if port == 0xcf9 then
+ printf("Reset triggered at %04x:%04x\n", regs.cs, regs.eip);
+ return true
+ end
+end)
+
+prepend_to_list(io_write_log_hooks, function(port, size, data, target)
+ if port == 0xcf8 then
+ return true -- Ignore
+ end
+ if port >= 0xcfc and port <= 0xcff then
+ printf("PCI %x:%02x.%x R.%02x <= %s\n",
+ bit.band(0xff,bit.rshift(SerialICE_pci_device, 16)),
+ bit.band(0x1f,bit.rshift(SerialICE_pci_device, 11)),
+ bit.band(0x7,bit.rshift(SerialICE_pci_device, 8)),
+ bit.band(0xff,SerialICE_pci_device + (port - 0xcfc)),
+ size_data(size, data))
+ return true
+ end
+end)
+
+prepend_to_list(io_read_log_hooks, function(port, size, data, target)
+ if port == 0xcf8 then
+ return true -- Ignore
+ end
+ if port >= 0xcfc and port <= 0xcff then
+ printf("PCI %x:%02x.%x R.%02x => %s\n",
+ bit.band(0xff,bit.rshift(SerialICE_pci_device, 16)),
+ bit.band(0x1f,bit.rshift(SerialICE_pci_device, 11)),
+ bit.band(0x7,bit.rshift(SerialICE_pci_device, 8)),
+ bit.band(0xff,SerialICE_pci_device + (port - 0xcfc)),
+ size_data(size, data))
+ return true
+ end
+end)
+
-- handle MTRRs
prepend_to_list(msr_write_hooks,
function(addr, hi, lo, filtered)
@@ -657,43 +697,20 @@ end
function SerialICE_io_write_log(port, size, data, target)
log_cs_ip()
-
- printf("IO: out%s %04x <= %s\n", size_suffix(size), port, size_data(size, data))
-
- -- **********************************************************
- --
-
- if port >= 0xcfc and port <= 0xcff then
- printf("PCI %x:%02x.%x R.%02x\n",
- bit.band(0xff,bit.rshift(SerialICE_pci_device, 16)),
- bit.band(0x1f,bit.rshift(SerialICE_pci_device, 11)),
- bit.band(0x7,bit.rshift(SerialICE_pci_device, 8)),
- bit.band(0xff,SerialICE_pci_device + (port - 0xcfc) ))
+ if walk_list(io_write_log_hooks, port, size, data, target) then
+ return
end
- -- **********************************************************
- --
-
- if port == 0xcf9 then
- printf("Reset triggered at %04x:%04x\n", regs.cs, regs.eip);
- end
+ printf("IO: out%s %04x <= %s\n", size_suffix(size), port, size_data(size, data))
end
function SerialICE_io_read_log(port, size, data, target)
log_cs_ip()
+ if walk_list(io_read_log_hooks, port, size, data, target) then
+ return
+ end
printf("IO: in%s %04x => %s\n", size_suffix(size), port, size_data(size, data))
-
- -- **********************************************************
- --
-
- if port >= 0xcfc and port <= 0xcff then
- printf("PCI %x:%02x.%x R.%02x\n",
- bit.band(0xff,bit.rshift(SerialICE_pci_device, 16)),
- bit.band(0x1f,bit.rshift(SerialICE_pci_device, 11)),
- bit.band(0x7,bit.rshift(SerialICE_pci_device, 8)),
- bit.band(0xff,SerialICE_pci_device + (port - 0xcfc) ))
- end
end
function SerialICE_msr_write_log(addr, hi, lo, filtered)
More information about the SerialICE
mailing list