blob: 1b7536a9581059187af738ad4e994e85ae987bd1 [file] [log] [blame]
Wiktor Gołgowskiba6727e2020-03-13 18:25:01 +01001/* SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later */
2
3#include "test-utils.h"
4
Andrew Jeffery5ab78252022-02-17 21:04:59 +10305#include "compiler.h"
6#include "libmctp.h"
7#include "libmctp-alloc.h"
8#include "libmctp-cmds.h"
9
Wiktor Gołgowskiba6727e2020-03-13 18:25:01 +010010#include <stdio.h>
11#include <string.h>
12#include <assert.h>
13
Wiktor Gołgowskiba6727e2020-03-13 18:25:01 +010014#ifdef NDEBUG
15#undef NDEBUG
16#endif
17
18static const mctp_eid_t eid_1 = 9;
19static const mctp_eid_t eid_2 = 10;
20
21struct msg_payload {
22 struct mctp_hdr hdr;
23 struct mctp_ctrl_msg_hdr ctrl_hdr;
24};
25
26struct callback_data {
27 uint8_t invoked;
28 union {
29 uint8_t command_code;
30 uint8_t completion_code;
31 };
32};
33
Andrew Jefferyb93b6112020-06-05 14:13:44 +093034static void control_message_transport_callback(mctp_eid_t src __unused,
35 void *data, void *buf,
36 size_t len __unused)
Wiktor Gołgowskiba6727e2020-03-13 18:25:01 +010037{
38 struct callback_data *ctx = data;
39 struct mctp_ctrl_msg_hdr *msg_hdr = buf;
40 printf("Transport control message received - command code: 0x%X\n",
41 msg_hdr->command_code);
42 ctx->invoked++;
43 assert(msg_hdr->command_code == ctx->command_code);
44}
45
46static void rcv_ctrl_msg(struct mctp_binding *b, const void *buf, size_t len)
47{
48 struct mctp_pktbuf *pkt = mctp_pktbuf_alloc(b, len);
49 memcpy(mctp_pktbuf_hdr(pkt), buf, len);
50 mctp_bus_rx(b, pkt);
51}
52
53static void setup_test_binding(struct mctp_binding *test_binding,
54 struct mctp *test_endpoint, void *callback_ctx)
55{
56 assert(test_binding != NULL);
57 assert(test_endpoint != NULL);
58 assert(callback_ctx != NULL);
59
60 memset(test_binding, 0, sizeof(*test_binding));
61 test_binding->name = "test";
62 test_binding->version = 1;
63 test_binding->tx = NULL;
64 test_binding->pkt_size = MCTP_PACKET_SIZE(MCTP_BTU);
Andrew Jeffery39da3d02021-03-12 16:51:26 +103065 test_binding->pkt_header = 0;
66 test_binding->pkt_trailer = 0;
Wiktor Gołgowskiba6727e2020-03-13 18:25:01 +010067 test_binding->control_rx = control_message_transport_callback;
68 test_binding->control_rx_data = callback_ctx;
69
70 mctp_register_bus(test_endpoint, test_binding, eid_1);
71 mctp_binding_set_tx_enabled(test_binding, true);
72}
73
74static void send_transport_control_message(void)
75{
76 struct mctp *endpoint = mctp_init();
77 struct mctp_binding binding;
78 struct callback_data ctx;
79 static const struct msg_payload send_control_message_payload = {
80 .hdr = {
81 .dest = eid_1,
82 .src = eid_2,
83 .flags_seq_tag = MCTP_HDR_FLAG_SOM | MCTP_HDR_FLAG_EOM,
84 },
85 .ctrl_hdr = {
86 .ic_msg_type = MCTP_CTRL_HDR_MSG_TYPE,
87 .rq_dgram_inst = MCTP_CTRL_HDR_FLAG_REQUEST,
88 .command_code = 0xF2,
89 },
90 };
91
92 memset(&ctx, 0, sizeof(ctx));
93 setup_test_binding(&binding, endpoint, &ctx);
94 ctx.command_code = send_control_message_payload.ctrl_hdr.command_code;
95 printf("Sending transport control message: 0x%X\n",
96 send_control_message_payload.ctrl_hdr.command_code);
97 rcv_ctrl_msg(&binding, (void *)&send_control_message_payload,
98 sizeof(send_control_message_payload));
99 assert(ctx.invoked == 1);
100
101 mctp_destroy(endpoint);
102}
103
Andrew Jefferyb93b6112020-06-05 14:13:44 +0930104int main(void)
Wiktor Gołgowskiba6727e2020-03-13 18:25:01 +0100105{
106 send_transport_control_message();
107
108 return EXIT_SUCCESS;
109}