aboutsummaryrefslogtreecommitdiff
path: root/applications/message_handler/test/message_client.cpp
blob: 39d1392c2e29f802b650268129e228cd9efebafb (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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
/*
 * Copyright (c) 2022 Arm Limited.
 *
 * SPDX-License-Identifier: Apache-2.0
 *
 * Licensed under the Apache License, Version 2.0 (the License); you may
 * not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an AS IS BASIS, WITHOUT
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#include "FreeRTOS.h"
#include "task.h"

#include "ethosu_core_interface.h"
#include "message_client.hpp"

using namespace EthosU;

namespace MessageHandler {

MessageClient::MessageClient(EthosU::ethosu_core_queue &_inputMessageQueue,
                             EthosU::ethosu_core_queue &_outputMessageQueue,
                             Mailbox::Mailbox &_mailbox) :
    input(_inputMessageQueue),
    output(_outputMessageQueue), mailbox(_mailbox) {}

bool MessageClient::sendInputMessage(const uint32_t type, const void *src, uint32_t length) {
    if (!input.write(type, src, length)) {
        printf("ERROR: Msg: Failed to write message request. No mailbox message sent\n");
        return false;
    }

    mailbox.sendMessage();
    mailbox.handleMessage();
    return true;
}

bool MessageClient::waitAndReadOutputMessage(const uint32_t expected_type, uint8_t *dst, uint32_t length) {
    constexpr TickType_t delay    = pdMS_TO_TICKS(5);
    constexpr TickType_t deadline = pdMS_TO_TICKS(/* 1 minute */ 60 * 1000 * 1000);
    struct ethosu_core_msg msg;

    TickType_t totalDelay = 0;
    while (output.available() == 0) {
        vTaskDelay(delay);
        totalDelay += delay;
        if (totalDelay >= deadline) {
            return false;
        }
    }

    if (!output.read(msg)) {
        printf("ERROR: Failed to read msg header\n");
        return false;
    }

    if (msg.magic != ETHOSU_CORE_MSG_MAGIC) {
        printf("ERROR: Invalid Magic\n");
        return false;
    }

    if (msg.type != expected_type) {
        printf("ERROR: Wrong message type. Got %" PRIu32 " expected %" PRIu32 "\n", msg.type, expected_type);
        return false;
    }

    if (msg.length != length) {
        printf("ERROR: Wrong message size\n");
        return false;
    }

    if (length == 0) {
        return true;
    }

    if (!output.read(dst, length)) {
        printf("ERROR: Failed to read msg payload\n");
        return false;
    }

    return true;
}
} // namespace MessageHandler