Zephyr API Documentation 4.0.99
A Scalable Open Source RTOS
|
Data Structures | |
struct | lora_modem_config |
Structure containing the configuration of a LoRa modem. More... | |
Enumerations | |
enum | lora_signal_bandwidth { BW_125_KHZ = 0 , BW_250_KHZ , BW_500_KHZ } |
LoRa signal bandwidth. More... | |
enum | lora_datarate { SF_6 = 6 , SF_7 , SF_8 , SF_9 , SF_10 , SF_11 , SF_12 } |
LoRa data-rate. More... | |
enum | lora_coding_rate { CR_4_5 = 1 , CR_4_6 = 2 , CR_4_7 = 3 , CR_4_8 = 4 } |
LoRa coding rate. More... | |
Functions | |
static int | lora_config (const struct device *dev, struct lora_modem_config *config) |
Configure the LoRa modem. | |
static int | lora_send (const struct device *dev, uint8_t *data, uint32_t data_len) |
Send data over LoRa. | |
static int | lora_send_async (const struct device *dev, uint8_t *data, uint32_t data_len, struct k_poll_signal *async) |
Asynchronously send data over LoRa. | |
static int | lora_recv (const struct device *dev, uint8_t *data, uint8_t size, k_timeout_t timeout, int16_t *rssi, int8_t *snr) |
Receive data over LoRa. | |
static int | lora_recv_async (const struct device *dev, lora_recv_cb cb, void *user_data) |
Receive data asynchronously over LoRa. | |
static int | lora_test_cw (const struct device *dev, uint32_t frequency, int8_t tx_power, uint16_t duration) |
Transmit an unmodulated continuous wave at a given frequency. | |
enum lora_coding_rate |
enum lora_datarate |
|
inlinestatic |
#include <zephyr/drivers/lora.h>
Configure the LoRa modem.
dev | LoRa device |
config | Data structure containing the intended configuration for the modem |
|
inlinestatic |
#include <zephyr/drivers/lora.h>
Receive data over LoRa.
dev | LoRa device |
data | Buffer to hold received data |
size | Size of the buffer to hold the received data. Max size allowed is 255. |
timeout | Duration to wait for a packet. |
rssi | RSSI of received data |
snr | SNR of received data |
|
inlinestatic |
#include <zephyr/drivers/lora.h>
Receive data asynchronously over LoRa.
Receive packets continuously under the configuration previously setup by lora_config.
Reception is cancelled by calling this function again with cb
= NULL. This can be done within the callback handler.
dev | Modem to receive data on. |
cb | Callback to run on receiving data. If NULL, any pending asynchronous receptions will be cancelled. |
user_data | User data passed to callback |
#include <zephyr/drivers/lora.h>
Send data over LoRa.
dev | LoRa device |
data | Data to be sent |
data_len | Length of the data to be sent |
|
inlinestatic |
#include <zephyr/drivers/lora.h>
Asynchronously send data over LoRa.
dev | LoRa device |
data | Data to be sent |
data_len | Length of the data to be sent |
async | A pointer to a valid and ready to be signaled struct k_poll_signal. (Note: if NULL this function will not notify the end of the transmission). |
|
inlinestatic |
#include <zephyr/drivers/lora.h>
Transmit an unmodulated continuous wave at a given frequency.
dev | LoRa device |
frequency | Output frequency (Hertz) |
tx_power | TX power (dBm) |
duration | Transmission duration in seconds. |