mirror of
https://github.com/DarkFlippers/unleashed-firmware
synced 2024-12-22 10:43:11 +00:00
f58b322bb5
* enable transparent mode * rssi ok, transmit ok, fifo ok * I see the signal * successful async rx (registers from smartrf) * refactor rfstudio register config * rewrite config, found some issues * handle G0 interrupts * g0 irq enable after cc1101 init * update cube
69 lines
1.8 KiB
C
69 lines
1.8 KiB
C
#pragma once
|
|
#include "main.h"
|
|
#include "stdbool.h"
|
|
|
|
// this defined in xx_hal_gpio.c, so...
|
|
#define GPIO_NUMBER (16U)
|
|
|
|
typedef enum {
|
|
GpioModeInput = GPIO_MODE_INPUT,
|
|
GpioModeOutputPushPull = GPIO_MODE_OUTPUT_PP,
|
|
GpioModeOutputOpenDrain = GPIO_MODE_OUTPUT_OD,
|
|
GpioModeAltFunctionPushPull = GPIO_MODE_AF_PP,
|
|
GpioModeAltFunctionOpenDrain = GPIO_MODE_AF_OD,
|
|
GpioModeAnalog = GPIO_MODE_ANALOG,
|
|
GpioModeInterruptRise = GPIO_MODE_IT_RISING,
|
|
GpioModeInterruptFall = GPIO_MODE_IT_FALLING,
|
|
GpioModeInterruptRiseFall = GPIO_MODE_IT_RISING_FALLING,
|
|
GpioModeEventRise = GPIO_MODE_EVT_RISING,
|
|
GpioModeEventFall = GPIO_MODE_EVT_FALLING,
|
|
GpioModeEventRiseFall = GPIO_MODE_EVT_RISING_FALLING,
|
|
} GpioMode;
|
|
|
|
typedef enum {
|
|
GpioSpeedLow = GPIO_SPEED_FREQ_LOW,
|
|
GpioSpeedMedium = GPIO_SPEED_FREQ_MEDIUM,
|
|
GpioSpeedHigh = GPIO_SPEED_FREQ_HIGH,
|
|
GpioSpeedVeryHigh = GPIO_SPEED_FREQ_VERY_HIGH,
|
|
} GpioSpeed;
|
|
|
|
typedef enum {
|
|
GpioPullNo = GPIO_NOPULL,
|
|
GpioPullUp = GPIO_PULLUP,
|
|
GpioPullDown = GPIO_PULLDOWN,
|
|
} GpioPull;
|
|
|
|
typedef struct {
|
|
GPIO_TypeDef* port;
|
|
uint16_t pin;
|
|
} GpioPin;
|
|
|
|
// init GPIO
|
|
void hal_gpio_init(
|
|
const GpioPin* gpio,
|
|
const GpioMode mode,
|
|
const GpioPull pull,
|
|
const GpioSpeed speed);
|
|
|
|
// write value to GPIO, false = LOW, true = HIGH
|
|
static inline void hal_gpio_write(const GpioPin* gpio, const bool state) {
|
|
// writing to BSSR is an atomic operation
|
|
if(state == true) {
|
|
gpio->port->BSRR = gpio->pin;
|
|
} else {
|
|
gpio->port->BSRR = (uint32_t)gpio->pin << GPIO_NUMBER;
|
|
}
|
|
}
|
|
|
|
// read value from GPIO, false = LOW, true = HIGH
|
|
static inline bool hal_gpio_read(const GpioPin* gpio) {
|
|
if((gpio->port->IDR & gpio->pin) != 0x00U) {
|
|
return true;
|
|
} else {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
bool hal_gpio_read_sd_detect(void);
|
|
|
|
void enable_cc1101_irq();
|