blob: c2a2af2ab1f353572998455cf3457e60572a338e [file] [log] [blame]
Norman James42c1be82015-10-22 14:34:26 -05001#!/usr/bin/python -u
Norman Jamese2765102015-08-19 22:00:55 -05002
Norman James471ab592015-08-30 22:29:40 -05003import sys
Adriana Kobylak08d3bdb2015-10-20 16:59:14 -05004import uuid
Norman James6f8d0422015-09-14 18:48:00 -05005#from gi.repository import GObject
6import gobject
Norman Jamese2765102015-08-19 22:00:55 -05007import dbus
8import dbus.service
9import dbus.mainloop.glib
Norman James5e792e32015-10-07 17:36:17 -050010import Openbmc
Norman Jamese2765102015-08-19 22:00:55 -050011
Norman James3f97c5d2015-08-26 17:44:14 -050012DBUS_NAME = 'org.openbmc.control.Chassis'
Norman James362a80f2015-09-14 14:04:39 -050013OBJ_NAME = '/org/openbmc/control/'+sys.argv[1]
Norman Jamesa3e47c42015-10-18 14:43:10 -050014CONTROL_INTF = 'org.openbmc.Control'
Norman James3f97c5d2015-08-26 17:44:14 -050015
Norman James2a3d20b2015-08-20 07:09:33 -050016POWER_OFF = 0
17POWER_ON = 1
18
Norman James9e6acf92015-09-08 07:00:04 -050019BOOTED = 100
20
Norman James2656f332015-10-26 06:42:41 -050021class ChassisControlObject(Openbmc.DbusProperties):
Norman Jamese2765102015-08-19 22:00:55 -050022 def __init__(self,bus,name):
Norman James471ab592015-08-30 22:29:40 -050023 self.dbus_objects = { }
Norman James2656f332015-10-26 06:42:41 -050024 Openbmc.DbusProperties.__init__(self)
Norman James9e6acf92015-09-08 07:00:04 -050025 dbus.service.Object.__init__(self,bus,name)
Norman James90baede2015-09-02 20:32:49 -050026 ## load utilized objects
Norman James362a80f2015-09-14 14:04:39 -050027 self.dbus_objects = {
28 'power_control' : {
29 'bus_name' : 'org.openbmc.control.Power',
Norman Jamesa3e47c42015-10-18 14:43:10 -050030 'object_name' : '/org/openbmc/control/power0',
Norman James362a80f2015-09-14 14:04:39 -050031 'interface_name' : 'org.openbmc.control.Power'
32 },
33 'identify_led' : {
Norman Jamesa3e47c42015-10-18 14:43:10 -050034 'bus_name' : 'org.openbmc.control.led',
35 'object_name' : '/org/openbmc/led/IDENTIFY',
Norman James362a80f2015-09-14 14:04:39 -050036 'interface_name' : 'org.openbmc.Led'
37 }
Norman James471ab592015-08-30 22:29:40 -050038 }
Norman James90baede2015-09-02 20:32:49 -050039
Adriana Kobylak08d3bdb2015-10-20 16:59:14 -050040 #uuid
Norman James2656f332015-10-26 06:42:41 -050041 self.Set(DBUS_NAME,"uuid",str(uuid.uuid1()))
42 self.Set(DBUS_NAME,"reboot",0)
43 self.Set(DBUS_NAME,"power_policy",0)
44 self.Set(DBUS_NAME,"last_system_state","")
Adriana Kobylak08d3bdb2015-10-20 16:59:14 -050045
Norman James471ab592015-08-30 22:29:40 -050046 bus.add_signal_receiver(self.power_button_signal_handler,
47 dbus_interface = "org.openbmc.Button", signal_name = "ButtonPressed",
Norman James362a80f2015-09-14 14:04:39 -050048 path="/org/openbmc/buttons/PowerButton_0" )
Norman James9e6acf92015-09-08 07:00:04 -050049 bus.add_signal_receiver(self.host_watchdog_signal_handler,
50 dbus_interface = "org.openbmc.Watchdog", signal_name = "WatchdogError")
Norman James362a80f2015-09-14 14:04:39 -050051 bus.add_signal_receiver(self.SystemStateHandler,signal_name = "GotoSystemState")
Norman James471ab592015-08-30 22:29:40 -050052
Norman James9e6acf92015-09-08 07:00:04 -050053
Norman James362a80f2015-09-14 14:04:39 -050054 def getInterface(self,name):
55 o = self.dbus_objects[name]
56 obj = bus.get_object(o['bus_name'],o['object_name'])
57 return dbus.Interface(obj,o['interface_name'])
Norman Jamese2765102015-08-19 22:00:55 -050058
Norman Jamese2765102015-08-19 22:00:55 -050059
Norman James3f97c5d2015-08-26 17:44:14 -050060 @dbus.service.method(DBUS_NAME,
Norman Jamese2765102015-08-19 22:00:55 -050061 in_signature='', out_signature='')
62 def setIdentify(self):
63 print "Turn on identify"
Norman James362a80f2015-09-14 14:04:39 -050064 intf = self.getInterface('identify_led')
65 intf.setOn()
Norman Jamese2765102015-08-19 22:00:55 -050066 return None
67
Norman James3f97c5d2015-08-26 17:44:14 -050068 @dbus.service.method(DBUS_NAME,
Norman Jamese2765102015-08-19 22:00:55 -050069 in_signature='', out_signature='')
70 def clearIdentify(self):
Norman James362a80f2015-09-14 14:04:39 -050071 print "Turn on identify"
72 intf = self.getInterface('identify_led')
73 intf.setOff()
Norman Jamese2765102015-08-19 22:00:55 -050074 return None
75
Norman James3f97c5d2015-08-26 17:44:14 -050076 @dbus.service.method(DBUS_NAME,
Norman Jamese2765102015-08-19 22:00:55 -050077 in_signature='', out_signature='')
Norman James362a80f2015-09-14 14:04:39 -050078 def powerOn(self):
Norman Jamese2765102015-08-19 22:00:55 -050079 print "Turn on power and boot"
Norman James2656f332015-10-26 06:42:41 -050080 self.Set(DBUS_NAME,"reboot",0)
Norman Jamese2765102015-08-19 22:00:55 -050081 if (self.getPowerState()==0):
Norman James362a80f2015-09-14 14:04:39 -050082 intf = self.getInterface('power_control')
83 intf.setPowerState(POWER_ON)
Norman Jamese2765102015-08-19 22:00:55 -050084 return None
85
Norman James3f97c5d2015-08-26 17:44:14 -050086 @dbus.service.method(DBUS_NAME,
Norman Jamese2765102015-08-19 22:00:55 -050087 in_signature='', out_signature='')
Norman James362a80f2015-09-14 14:04:39 -050088 def powerOff(self):
Norman Jamese2765102015-08-19 22:00:55 -050089 print "Turn off power"
Norman James362a80f2015-09-14 14:04:39 -050090 intf = self.getInterface('power_control')
91 intf.setPowerState(POWER_OFF)
92 return None
93
94 @dbus.service.method(DBUS_NAME,
95 in_signature='', out_signature='')
96 def softPowerOff(self):
97 print "Soft off power"
Norman James2656f332015-10-26 06:42:41 -050098 ## TODO: Somehow tell host to shutdown via ipmi
99 ## for now hard power off
100 self.powerOff()
Norman James362a80f2015-09-14 14:04:39 -0500101 return None
102
103 @dbus.service.method(DBUS_NAME,
104 in_signature='', out_signature='')
105 def reboot(self):
106 print "Rebooting"
Norman James2656f332015-10-26 06:42:41 -0500107 self.Set(DBUS_NAME,"reboot",1)
Norman James362a80f2015-09-14 14:04:39 -0500108 intf.softPowerOff()
Norman Jamese2765102015-08-19 22:00:55 -0500109 return None
110
Norman James3f97c5d2015-08-26 17:44:14 -0500111 @dbus.service.method(DBUS_NAME,
Norman Jamese2765102015-08-19 22:00:55 -0500112 in_signature='', out_signature='i')
113 def getPowerState(self):
Norman James362a80f2015-09-14 14:04:39 -0500114 intf = self.getInterface('power_control')
115 return intf.getPowerState()
Norman Jamese2765102015-08-19 22:00:55 -0500116
Norman James3f97c5d2015-08-26 17:44:14 -0500117 @dbus.service.method(DBUS_NAME,
Norman Jamese2765102015-08-19 22:00:55 -0500118 in_signature='', out_signature='')
119 def setDebugMode(self):
120 return None
121
Norman James3f97c5d2015-08-26 17:44:14 -0500122 @dbus.service.method(DBUS_NAME,
Norman Jamese2765102015-08-19 22:00:55 -0500123 in_signature='i', out_signature='')
124 def setPowerPolicy(self,policy):
Norman James2656f332015-10-26 06:42:41 -0500125 self.Set(DBUS_NAME,"power_policy",policy)
Norman Jamese2765102015-08-19 22:00:55 -0500126 return None
127
Norman James9e6acf92015-09-08 07:00:04 -0500128
Norman Jamese2765102015-08-19 22:00:55 -0500129 ## Signal handler
Norman James362a80f2015-09-14 14:04:39 -0500130
131 def SystemStateHandler(self,state_name):
Norman James2656f332015-10-26 06:42:41 -0500132 self.Set(DBUS_NAME,"last_system_state",state_name)
133 if (state_name == "HOST_POWERED_OFF" and self.Get(DBUS_NAME,"reboot")==1):
Norman James362a80f2015-09-14 14:04:39 -0500134 self.powerOn()
135
136
Norman Jamese2765102015-08-19 22:00:55 -0500137 def power_button_signal_handler(self):
Norman James9e6acf92015-09-08 07:00:04 -0500138 # toggle power
Norman Jamese2765102015-08-19 22:00:55 -0500139 state = self.getPowerState()
Norman James2a3d20b2015-08-20 07:09:33 -0500140 if state == POWER_OFF:
Norman James362a80f2015-09-14 14:04:39 -0500141 self.powerOn()
Norman James2a3d20b2015-08-20 07:09:33 -0500142 elif state == POWER_ON:
Norman James362a80f2015-09-14 14:04:39 -0500143 self.powerOff();
Norman Jamese2765102015-08-19 22:00:55 -0500144
145 # TODO: handle long press and reset
146
Norman James9e6acf92015-09-08 07:00:04 -0500147 def host_watchdog_signal_handler(self):
Norman James362a80f2015-09-14 14:04:39 -0500148 print "Watchdog Error, Hard Rebooting"
Norman James2656f332015-10-26 06:42:41 -0500149 self.Set(DBUS_NAME,"reboot",1)
150 self.powerOff()
Norman James9e6acf92015-09-08 07:00:04 -0500151
Norman Jamese2765102015-08-19 22:00:55 -0500152
153if __name__ == '__main__':
154 dbus.mainloop.glib.DBusGMainLoop(set_as_default=True)
155
Norman James5e792e32015-10-07 17:36:17 -0500156 bus = Openbmc.getDBus()
Norman James3f97c5d2015-08-26 17:44:14 -0500157 name = dbus.service.BusName(DBUS_NAME, bus)
158 obj = ChassisControlObject(bus, OBJ_NAME)
Norman James6f8d0422015-09-14 18:48:00 -0500159 mainloop = gobject.MainLoop()
Norman James81dbd352015-08-19 22:44:53 -0500160
Norman Jamese2765102015-08-19 22:00:55 -0500161 print "Running ChassisControlService"
162 mainloop.run()
163