| #!/usr/bin/env python |
| |
| import sys |
| import subprocess |
| import dbus |
| import string |
| import os |
| import fcntl |
| import glib |
| import gobject |
| import dbus.service |
| import dbus.mainloop.glib |
| |
| DBUS_NAME = "org.openbmc.HostIpmi" |
| OBJ_NAME = "/org/openbmc/HostIpmi/1" |
| |
| |
| def header(seq, netfn, lun, cmd): |
| return ("seq: 0x%02x\nnetfn: 0x%02x\n\nlun: 0x%02d\ncmd: 0x%02x\n") % ( |
| seq, |
| netfn, |
| lun, |
| cmd, |
| ) |
| |
| |
| def print_request(seq, netfn, lun, cmd, data): |
| str = header(seq, netfn, lun, cmd) |
| str += "data: [%s]" % ", ".join(["0x%02x" % x for x in data]) |
| print(str) |
| |
| |
| def print_response(seq, netfn, lun, cmd, cc, data): |
| str = header(seq, netfn, lun, cmd) |
| str += "cc: 0x%02x\ndata: [%s]" % ( |
| cc, |
| ", ".join(["0x%02x" % x for x in data]), |
| ) |
| print(str) |
| |
| |
| class IpmiDebug(dbus.service.Object): |
| def __init__(self, bus, name): |
| dbus.service.Object.__init__(self, bus, name) |
| |
| @dbus.service.signal(DBUS_NAME, "yyyyay") |
| def ReceivedMessage(self, seq, netfn, lun, cmd, data): |
| print("IPMI packet from host:") |
| print_request(seq, netfn, lun, cmd, data) |
| |
| @dbus.service.method(DBUS_NAME, "yyyyyay", "x") |
| def sendMessage(self, seq, netfn, lun, cmd, ccode, data): |
| print("IPMI packet sent to host:") |
| print_response(seq, netfn, lun, cmd, ccode, data) |
| return 0 |
| |
| @dbus.service.method(DBUS_NAME) |
| def setAttention(self): |
| print("IPMI SMS_ATN set") |
| |
| |
| class ConsoleReader(object): |
| def __init__(self, ipmi_obj): |
| self.buffer = "" |
| self.seq = 0 |
| self.ipmi_obj = ipmi_obj |
| flags = fcntl.fcntl(sys.stdin.fileno(), fcntl.F_GETFL) |
| flags |= os.O_NONBLOCK |
| fcntl.fcntl(sys.stdin.fileno(), fcntl.F_SETFL, flags) |
| glib.io_add_watch(sys.stdin, glib.IO_IN, self.io_callback) |
| |
| def io_callback(self, fd, condition): |
| chunk = fd.read() |
| for char in chunk: |
| self.buffer += char |
| if char == "\n": |
| self.line(self.buffer) |
| self.buffer = "" |
| |
| return True |
| |
| def line(self, data): |
| s = data.split(" ") |
| if len(s) < 2: |
| print("Not enough bytes to form a valid IPMI packet") |
| return |
| try: |
| data = [int(c, 16) for c in s] |
| except ValueError: |
| return |
| self.seq += 1 |
| self.ipmi_obj.ReceivedMessage(self.seq, data[0], 0, data[1], data[2:]) |
| |
| |
| def main(): |
| dbus.mainloop.glib.DBusGMainLoop(set_as_default=True) |
| bus = dbus.SystemBus() |
| obj = IpmiDebug(bus, OBJ_NAME) |
| mainloop = gobject.MainLoop() |
| r = ConsoleReader(obj) |
| |
| obj.unmask_signals() |
| name = dbus.service.BusName(DBUS_NAME, bus) |
| |
| print( |
| "Enter IPMI packet as hex values. First three bytes will be used" |
| "as netfn and cmd.\nlun will be zero." |
| ) |
| mainloop.run() |
| |
| |
| if __name__ == "__main__": |
| sys.exit(main()) |
| |
| # vim: tabstop=8 expandtab shiftwidth=4 softtabstop=4 |