Zephyr API Documentation 4.0.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
lora.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2019 Manivannan Sadhasivam
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
11#ifndef ZEPHYR_INCLUDE_DRIVERS_LORA_H_
12#define ZEPHYR_INCLUDE_DRIVERS_LORA_H_
13
24#include <stdint.h>
25#include <zephyr/kernel.h>
26#include <zephyr/device.h>
27
28#ifdef __cplusplus
29extern "C" {
30#endif
31
40
53
58 CR_4_5 = 1,
59 CR_4_6 = 2,
60 CR_4_7 = 3,
61 CR_4_8 = 4,
62};
63
110
123typedef void (*lora_recv_cb)(const struct device *dev, uint8_t *data, uint16_t size,
124 int16_t rssi, int8_t snr, void *user_data);
125
132typedef int (*lora_api_config)(const struct device *dev,
133 struct lora_modem_config *config);
134
141typedef int (*lora_api_send)(const struct device *dev,
142 uint8_t *data, uint32_t data_len);
143
150typedef int (*lora_api_send_async)(const struct device *dev,
151 uint8_t *data, uint32_t data_len,
152 struct k_poll_signal *async);
153
160typedef int (*lora_api_recv)(const struct device *dev, uint8_t *data,
161 uint8_t size,
162 k_timeout_t timeout, int16_t *rssi, int8_t *snr);
163
171typedef int (*lora_api_recv_async)(const struct device *dev, lora_recv_cb cb,
172 void *user_data);
173
180typedef int (*lora_api_test_cw)(const struct device *dev, uint32_t frequency,
181 int8_t tx_power, uint16_t duration);
182
183__subsystem struct lora_driver_api {
184 lora_api_config config;
185 lora_api_send send;
186 lora_api_send_async send_async;
187 lora_api_recv recv;
188 lora_api_recv_async recv_async;
189 lora_api_test_cw test_cw;
190};
191
202static inline int lora_config(const struct device *dev,
203 struct lora_modem_config *config)
204{
205 const struct lora_driver_api *api =
206 (const struct lora_driver_api *)dev->api;
207
208 return api->config(dev, config);
209}
210
221static inline int lora_send(const struct device *dev,
222 uint8_t *data, uint32_t data_len)
223{
224 const struct lora_driver_api *api =
225 (const struct lora_driver_api *)dev->api;
226
227 return api->send(dev, data, data_len);
228}
229
244static inline int lora_send_async(const struct device *dev,
245 uint8_t *data, uint32_t data_len,
246 struct k_poll_signal *async)
247{
248 const struct lora_driver_api *api =
249 (const struct lora_driver_api *)dev->api;
250
251 return api->send_async(dev, data, data_len, async);
252}
253
268static inline int lora_recv(const struct device *dev, uint8_t *data,
269 uint8_t size,
270 k_timeout_t timeout, int16_t *rssi, int8_t *snr)
271{
272 const struct lora_driver_api *api =
273 (const struct lora_driver_api *)dev->api;
274
275 return api->recv(dev, data, size, timeout, rssi, snr);
276}
277
293static inline int lora_recv_async(const struct device *dev, lora_recv_cb cb,
294 void *user_data)
295{
296 const struct lora_driver_api *api =
297 (const struct lora_driver_api *)dev->api;
298
299 return api->recv_async(dev, cb, user_data);
300}
301
314static inline int lora_test_cw(const struct device *dev, uint32_t frequency,
315 int8_t tx_power, uint16_t duration)
316{
317 const struct lora_driver_api *api =
318 (const struct lora_driver_api *)dev->api;
319
320 if (api->test_cw == NULL) {
321 return -ENOSYS;
322 }
323
324 return api->test_cw(dev, frequency, tx_power, duration);
325}
326
327#ifdef __cplusplus
328}
329#endif
330
335#endif /* ZEPHYR_INCLUDE_DRIVERS_LORA_H_ */
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.
Definition lora.h:314
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.
Definition lora.h:268
lora_datarate
LoRa data-rate.
Definition lora.h:44
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.
Definition lora.h:244
lora_coding_rate
LoRa coding rate.
Definition lora.h:57
lora_signal_bandwidth
LoRa signal bandwidth.
Definition lora.h:35
static int lora_config(const struct device *dev, struct lora_modem_config *config)
Configure the LoRa modem.
Definition lora.h:202
static int lora_send(const struct device *dev, uint8_t *data, uint32_t data_len)
Send data over LoRa.
Definition lora.h:221
static int lora_recv_async(const struct device *dev, lora_recv_cb cb, void *user_data)
Receive data asynchronously over LoRa.
Definition lora.h:293
@ SF_12
Definition lora.h:51
@ SF_8
Definition lora.h:47
@ SF_11
Definition lora.h:50
@ SF_10
Definition lora.h:49
@ SF_9
Definition lora.h:48
@ SF_6
Definition lora.h:45
@ SF_7
Definition lora.h:46
@ CR_4_5
Definition lora.h:58
@ CR_4_6
Definition lora.h:59
@ CR_4_8
Definition lora.h:61
@ CR_4_7
Definition lora.h:60
@ BW_250_KHZ
Definition lora.h:37
@ BW_125_KHZ
Definition lora.h:36
@ BW_500_KHZ
Definition lora.h:38
#define ENOSYS
Function not implemented.
Definition errno.h:82
Public kernel APIs.
ssize_t send(int sock, const void *buf, size_t len, int flags)
ssize_t recv(int sock, void *buf, size_t max_len, int flags)
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINT16_TYPE__ uint16_t
Definition stdint.h:89
__INT8_TYPE__ int8_t
Definition stdint.h:72
__INT16_TYPE__ int16_t
Definition stdint.h:73
Runtime device structure (in ROM) per driver instance.
Definition device.h:411
void * data
Address of the device instance private data.
Definition device.h:421
const void * api
Address of the API structure exposed by the device instance.
Definition device.h:417
Definition kernel.h:5963
Kernel timeout type.
Definition sys_clock.h:65
Structure containing the configuration of a LoRa modem.
Definition lora.h:68
uint32_t frequency
Frequency in Hz to use for transceiving.
Definition lora.h:70
enum lora_signal_bandwidth bandwidth
The bandwidth to use for transceiving.
Definition lora.h:73
bool tx
Set to true for transmission, false for receiving.
Definition lora.h:88
int8_t tx_power
TX-power in dBm to use for transmission.
Definition lora.h:85
bool iq_inverted
Invert the In-Phase and Quadrature (IQ) signals.
Definition lora.h:97
enum lora_coding_rate coding_rate
The coding rate to use for transceiving.
Definition lora.h:79
uint16_t preamble_len
Length of the preamble.
Definition lora.h:82
enum lora_datarate datarate
The data-rate to use for transceiving.
Definition lora.h:76
bool public_network
Sets the sync-byte to use:
Definition lora.h:108