summaryrefslogtreecommitdiff
path: root/tools/proxyclient/m1n1/fw/asc/syslog.py
blob: 3387c271d15816b12af4cbbe8cc7f69849caf702 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
# SPDX-License-Identifier: MIT
import struct

from .base import *
from ...utils import *

## Syslog endpoint

class SyslogMessage(Register64):
    TYPE        = 59, 52

class Syslog_Init(SyslogMessage):
    TYPE        = 59, 52, Constant(8)
    ENTRYSIZE   = 39, 24
    COUNT       = 15, 0

class Syslog_GetBuf(SyslogMessage):
    TYPE        = 59, 52, Constant(1)
    SIZE        = 51, 44
    DVA         = 43, 0

class Syslog_Log(SyslogMessage):
    TYPE        = 59, 52, Constant(5)
    INDEX       = 7, 0

class ASCSysLogEndpoint(ASCBaseEndpoint):
    BASE_MESSAGE = SyslogMessage
    SHORT = "syslog"

    def __init__(self, *args, **kwargs):
        super().__init__(*args, **kwargs)
        self.entrysize = None
        self.count = None
        self.iobuffer = None
        self.iobuffer_dva = None
        self.started = False

    @msg_handler(8, Syslog_Init)
    def Init(self, msg):
        self.entrysize = msg.ENTRYSIZE
        self.count = msg.COUNT
        self.log(f"count {self.count}, entrysize {self.entrysize}")
        return True

    @msg_handler(1, Syslog_GetBuf)
    def GetBuf(self, msg):
        size = align(0x1000 * msg.SIZE, 0x4000)

        if self.iobuffer:
            print("WARNING: trying to reset iobuffer!")

        if msg.DVA:
            self.iobuffer_dva = msg.DVA
            self.log(f"buf prealloc at dva {self.iobuffer_dva:#x}")
        else:
            self.iobuffer, self.iobuffer_dva = self.asc.ioalloc(size)
            self.log(f"buf {self.iobuffer:#x} / {self.iobuffer_dva:#x}")
            self.send(Syslog_GetBuf(SIZE=size // 0x1000, DVA=self.iobuffer_dva))

        self.started = True
        return True

    @msg_handler(5, Syslog_Log)
    def Log(self, msg):
        stride = 0x20 + self.entrysize
        log = self.asc.ioread(self.iobuffer_dva + msg.INDEX * stride, stride)
        hdr, unk, context, logmsg = struct.unpack(f"<II24s{self.entrysize}s", log)
        context = context.split(b"\x00")[0].decode("ascii")
        logmsg = logmsg.split(b"\x00")[0].decode("ascii").rstrip("\n")
        self.log(f"* [{context}]{logmsg}")
        self.send(msg)
        return True