2022-11-30 12:17:30 +00:00
|
|
|
// SPDX-License-Identifier: MIT
|
2022-09-25 08:58:59 +00:00
|
|
|
#ifndef _LIBBLISP_H
|
|
|
|
#define _LIBBLISP_H
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include "blisp_chip.h"
|
2023-05-08 21:39:25 +00:00
|
|
|
#include "error_codes.h"
|
2023-01-07 12:34:33 +00:00
|
|
|
|
2022-10-05 09:35:44 +00:00
|
|
|
struct blisp_segment_header {
|
2023-01-07 10:50:51 +00:00
|
|
|
uint32_t dest_addr;
|
|
|
|
uint32_t length;
|
|
|
|
uint32_t reserved;
|
|
|
|
uint32_t crc32;
|
2022-10-05 09:35:44 +00:00
|
|
|
};
|
|
|
|
|
2022-09-25 08:58:59 +00:00
|
|
|
struct blisp_device {
|
2023-01-07 10:50:51 +00:00
|
|
|
struct blisp_chip* chip;
|
|
|
|
void* serial_port;
|
|
|
|
bool is_usb;
|
|
|
|
uint32_t current_baud_rate;
|
|
|
|
uint8_t rx_buffer[5000]; // TODO:
|
|
|
|
uint8_t tx_buffer[5000];
|
|
|
|
uint16_t error_code;
|
2022-09-25 08:58:59 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
struct blisp_boot_info {
|
2023-01-07 10:50:51 +00:00
|
|
|
uint8_t boot_rom_version[4];
|
|
|
|
uint8_t chip_id[8]; // TODO: BL60X only 6 bytes
|
2022-09-25 08:58:59 +00:00
|
|
|
};
|
|
|
|
|
2023-01-07 10:50:51 +00:00
|
|
|
// TODO: Refactor variable names, so all will follow same semantic, like
|
|
|
|
// image_run, image_check etc.
|
2022-11-08 18:35:51 +00:00
|
|
|
|
2022-09-25 08:58:59 +00:00
|
|
|
int32_t blisp_device_init(struct blisp_device* device, struct blisp_chip* chip);
|
|
|
|
int32_t blisp_device_open(struct blisp_device* device, const char* port_name);
|
2022-11-07 09:20:38 +00:00
|
|
|
int32_t blisp_device_handshake(struct blisp_device* device, bool in_ef_loader);
|
2023-01-07 10:50:51 +00:00
|
|
|
int32_t blisp_device_get_boot_info(struct blisp_device* device,
|
|
|
|
struct blisp_boot_info* boot_info);
|
|
|
|
int32_t blisp_device_load_boot_header(struct blisp_device* device,
|
|
|
|
uint8_t* boot_header);
|
|
|
|
int32_t blisp_device_load_segment_header(
|
|
|
|
struct blisp_device* device,
|
|
|
|
struct blisp_segment_header* segment_header);
|
|
|
|
int32_t blisp_device_load_segment_data(struct blisp_device* device,
|
|
|
|
uint8_t* segment_data,
|
|
|
|
uint32_t segment_data_length);
|
2022-11-07 09:20:38 +00:00
|
|
|
int32_t blisp_device_write_memory(struct blisp_device* device,
|
2023-01-07 10:50:51 +00:00
|
|
|
uint32_t address,
|
|
|
|
uint32_t value,
|
2022-11-07 09:20:38 +00:00
|
|
|
bool wait_for_res);
|
2022-10-05 09:35:44 +00:00
|
|
|
int32_t blisp_device_check_image(struct blisp_device* device);
|
|
|
|
int32_t blisp_device_run_image(struct blisp_device* device);
|
2023-01-07 10:50:51 +00:00
|
|
|
int32_t blisp_device_flash_erase(struct blisp_device* device,
|
|
|
|
uint32_t start_address,
|
|
|
|
uint32_t end_address);
|
|
|
|
int32_t blisp_device_flash_write(struct blisp_device* device,
|
|
|
|
uint32_t start_address,
|
|
|
|
uint8_t* payload,
|
|
|
|
uint32_t payload_size);
|
2022-11-08 18:35:51 +00:00
|
|
|
int32_t blisp_device_program_check(struct blisp_device* device);
|
|
|
|
int32_t blisp_device_reset(struct blisp_device* device);
|
2022-09-25 08:58:59 +00:00
|
|
|
void blisp_device_close(struct blisp_device* device);
|
|
|
|
|
|
|
|
#endif
|