2022-09-19 02:51:11 -04:00
|
|
|
/*
|
2023-02-18 10:16:46 -05:00
|
|
|
* Copyright (C) 2022, 2023 - Tillitis AB
|
2022-09-19 02:51:11 -04:00
|
|
|
* SPDX-License-Identifier: GPL-2.0-only
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "types.h"
|
|
|
|
|
|
|
|
#ifndef PROTO_H
|
|
|
|
#define PROTO_H
|
|
|
|
|
|
|
|
enum endpoints {
|
|
|
|
DST_HW_IFPGA,
|
|
|
|
DST_HW_AFPGA,
|
|
|
|
DST_FW,
|
|
|
|
DST_SW
|
|
|
|
};
|
|
|
|
|
|
|
|
enum cmdlen {
|
|
|
|
LEN_1,
|
|
|
|
LEN_4,
|
|
|
|
LEN_32,
|
2023-03-24 06:47:30 -04:00
|
|
|
LEN_128
|
2022-09-19 02:51:11 -04:00
|
|
|
};
|
|
|
|
|
2023-03-24 06:47:30 -04:00
|
|
|
#define CMDLEN_MAXBYTES 128
|
2022-09-19 02:51:11 -04:00
|
|
|
|
|
|
|
// clang-format off
|
|
|
|
enum fwcmd {
|
2022-11-03 06:30:00 -04:00
|
|
|
FW_CMD_NAME_VERSION = 0x01,
|
|
|
|
FW_RSP_NAME_VERSION = 0x02,
|
|
|
|
FW_CMD_LOAD_APP = 0x03,
|
|
|
|
FW_RSP_LOAD_APP = 0x04,
|
|
|
|
FW_CMD_LOAD_APP_DATA = 0x05,
|
|
|
|
FW_RSP_LOAD_APP_DATA = 0x06,
|
|
|
|
FW_RSP_LOAD_APP_DATA_READY = 0x07,
|
|
|
|
FW_CMD_GET_UDI = 0x08,
|
|
|
|
FW_RSP_GET_UDI = 0x09,
|
2023-03-07 09:08:24 -05:00
|
|
|
FW_CMD_MAX = 0x0a,
|
2022-09-19 02:51:11 -04:00
|
|
|
};
|
|
|
|
// clang-format on
|
|
|
|
|
|
|
|
enum status {
|
|
|
|
STATUS_OK,
|
|
|
|
STATUS_BAD
|
|
|
|
};
|
|
|
|
|
|
|
|
struct frame_header {
|
|
|
|
uint8_t id;
|
|
|
|
enum endpoints endpoint;
|
|
|
|
enum cmdlen len;
|
|
|
|
};
|
|
|
|
|
2024-03-21 07:32:08 -04:00
|
|
|
/*@ -exportlocal @*/
|
2022-09-19 02:51:11 -04:00
|
|
|
void writebyte(uint8_t b);
|
2024-03-04 09:53:12 -05:00
|
|
|
uint8_t readbyte(void);
|
2023-03-21 09:11:08 -04:00
|
|
|
void fwreply(struct frame_header hdr, enum fwcmd rspcode, uint8_t *buf);
|
2023-03-09 08:11:43 -05:00
|
|
|
int readcommand(struct frame_header *hdr, uint8_t *cmd, int state);
|
2022-09-19 02:51:11 -04:00
|
|
|
#endif
|