m1n1.fw.asc: Add support for shutting down RTKit links

Signed-off-by: Hector Martin <marcan@marcan.st>
This commit is contained in:
Hector Martin 2021-11-23 17:20:09 +09:00
parent 0446838460
commit 99acc2675b
2 changed files with 29 additions and 7 deletions

View file

@ -81,6 +81,9 @@ class StandardASC(ASC):
self.mgmt.start()
self.mgmt.wait_boot()
def stop(self):
self.mgmt.stop()
def boot(self):
print("Booting ASC...")
super().boot()

View file

@ -29,10 +29,11 @@ class Mgmt_StartEP(ManagementMessage):
class Mgmt_Init(ManagementMessage):
TYPE = 59, 52, Constant(6)
UNK = 15, 0
CMD = 15, 0
class Mgmt_BootDone(ManagementMessage):
TYPE = 59, 52, Constant(7)
CMD = 15, 0
class Mgmt_EPMap(ManagementMessage):
TYPE = 59, 52, Constant(8)
@ -48,7 +49,7 @@ class Mgmt_EPMap_Ack(ManagementMessage):
class Mgmt_StartSyslog(ManagementMessage):
TYPE = 59, 52, Constant(0xb)
UNK1 = 15, 0
CMD = 15, 0
class ASCManagementEndpoint(ASCBaseEndpoint):
BASE_MESSAGE = ManagementMessage
@ -86,12 +87,17 @@ class ASCManagementEndpoint(ASCBaseEndpoint):
@msg_handler(0xb, Mgmt_StartSyslog)
def StartSyslogAck(self, msg):
if msg.CMD == 0x10:
self.syslog_started = False
else:
self.syslog_started = True
return True
@msg_handler(7, Mgmt_BootDone)
def BootDone(self, msg):
#self.start_syslog()
if msg.CMD == 0x10:
self.boot_done = False
else:
self.boot_done = True
return True
@ -101,7 +107,8 @@ class ASCManagementEndpoint(ASCBaseEndpoint):
def start(self):
self.log("Starting via message")
self.send(Mgmt_Init(UNK=0x220))
self.boot_done = False
self.send(Mgmt_Init(CMD=0x220))
def wait_boot(self):
while not self.boot_done or not self.syslog_started:
@ -112,7 +119,19 @@ class ASCManagementEndpoint(ASCBaseEndpoint):
self.send(Mgmt_StartEP(EP=epno, FLAG=1))
def start_syslog(self):
self.send(Mgmt_StartSyslog(UNK1=0x20))
self.send(Mgmt_StartSyslog(CMD=0x20))
def stop_syslog(self):
self.send(Mgmt_StartSyslog(CMD=0x10))
def ping(self):
self.send(Mgmt_Ping())
def stop(self):
self.log("Stopping via message")
self.stop_syslog()
while self.syslog_started:
self.asc.work()
self.send(Mgmt_Init(CMD=0x10))
while self.boot_done:
self.asc.work()