cariboulabs-cariboulite/software/libcariboulite/src/caribou_fpga/caribou_fpga.h

112 wiersze
3.0 KiB
C
Czysty Zwykły widok Historia

2021-06-13 11:45:08 +00:00
#ifndef __CARIBOU_FPGA_H__
#define __CARIBOU_FPGA_H__
2021-09-09 19:51:58 +00:00
#ifdef __cplusplus
extern "C" {
#endif
2021-06-13 11:45:08 +00:00
#include <stdio.h>
#include <stdint.h>
#include "io_utils/io_utils.h"
#include "io_utils/io_utils_spi.h"
#pragma pack(1)
typedef struct
{
uint8_t sys_ver;
uint8_t sys_manu_id;
uint8_t sys_ctrl_mod_ver;
uint8_t io_ctrl_mod_ver;
uint8_t smi_ctrl_mod_ver;
} caribou_fpga_versions_st;
typedef enum
{
caribou_fpga_ec_okay = 0x00,
caribou_fpga_ec_write_attempt_to_readonly = 0x01,
} caribou_fpga_ec_en; // error codes
typedef enum
{
caribou_fpga_io_ctrl_rfm_low_power = 0,
caribou_fpga_io_ctrl_rfm_bypass = 1,
caribou_fpga_io_ctrl_rfm_rx_lowpass = 2,
caribou_fpga_io_ctrl_rfm_rx_hipass = 3,
caribou_fpga_io_ctrl_rfm_tx_lowpass = 4,
caribou_fpga_io_ctrl_rfm_tx_hipass = 5,
} caribou_fpga_io_ctrl_rfm_en;
typedef struct
{
2021-07-14 13:11:06 +00:00
uint8_t mixer_en : 1; // LSB
2021-06-13 11:45:08 +00:00
uint8_t lna_rx_shdn : 1;
uint8_t lna_tx_shdn : 1;
uint8_t trvc2 : 1;
uint8_t trvc1_b : 1;
uint8_t trvc1 : 1;
uint8_t rx_h_tx_l_b : 1;
uint8_t rx_h_tx_l : 1; // MSB
} caribou_fpga_rf_pin_st;
2021-07-14 13:11:06 +00:00
typedef struct
{
uint8_t rx_fifo_09_empty : 1; // LSB
uint8_t rx_fifo_09_full : 1;
uint8_t rx_fifo_24_empty : 1;
uint8_t rx_fifo_24_full : 1;
uint8_t res : 4; // MSB
} caribou_fpga_smi_fifo_status_st;
2021-06-13 11:45:08 +00:00
#pragma pack()
typedef struct
{
// pinout
int reset_pin;
int irq_pin;
int cs_pin;
// spi device
int spi_dev;
int spi_channel;
// internal controls
io_utils_spi_st* io_spi;
int io_spi_handle;
int initialized;
} caribou_fpga_st;
int caribou_fpga_init(caribou_fpga_st* dev, io_utils_spi_st* io_spi);
int caribou_fpga_close(caribou_fpga_st* dev);
2021-07-14 13:11:06 +00:00
int caribou_fpga_soft_reset(caribou_fpga_st* dev);
2021-06-13 11:45:08 +00:00
// System Controller
int caribou_fpga_get_versions (caribou_fpga_st* dev, caribou_fpga_versions_st *vers);
int caribou_fpga_get_errors (caribou_fpga_st* dev, uint8_t *err_map);
// I/O Controller
int caribou_fpga_set_io_ctrl_mode (caribou_fpga_st* dev, uint8_t debug_mode, caribou_fpga_io_ctrl_rfm_en rfm);
int caribou_fpga_get_io_ctrl_mode (caribou_fpga_st* dev, uint8_t *debug_mode, caribou_fpga_io_ctrl_rfm_en *rfm);
int caribou_fpga_set_io_ctrl_dig (caribou_fpga_st* dev, int ldo, int led0, int led1);
int caribou_fpga_get_io_ctrl_dig (caribou_fpga_st* dev, int *ldo, int *led0, int *led1, int *btn, int *cfg);
int caribou_fpga_set_io_ctrl_pmod_dir (caribou_fpga_st* dev, uint8_t dir);
int caribou_fpga_get_io_ctrl_pmod_dir (caribou_fpga_st* dev, uint8_t *dir);
int caribou_fpga_set_io_ctrl_pmod_val (caribou_fpga_st* dev, uint8_t val);
int caribou_fpga_get_io_ctrl_pmod_val (caribou_fpga_st* dev, uint8_t *val);
int caribou_fpga_set_io_ctrl_rf_state (caribou_fpga_st* dev, caribou_fpga_rf_pin_st pins);
int caribou_fpga_get_io_ctrl_rf_state (caribou_fpga_st* dev, caribou_fpga_rf_pin_st *pins);
2021-07-14 13:11:06 +00:00
int caribou_fpga_get_smi_ctrl_fifo_status (caribou_fpga_st* dev, caribou_fpga_smi_fifo_status_st *status);
2021-09-09 19:51:58 +00:00
#ifdef __cplusplus
}
#endif
2021-06-13 11:45:08 +00:00
#endif // __CARIBOU_FPGA_H__