summaryrefslogtreecommitdiff
path: root/libloragw/inc/loragw_hal.h
blob: 022313f51683ebf626597da782070b154f46597c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
/*
 / _____)             _              | |
( (____  _____ ____ _| |_ _____  ____| |__
 \____ \| ___ |    (_   _) ___ |/ ___)  _ \
 _____) ) ____| | | || |_| ____( (___| | | |
(______/|_____)_|_|_| \__)_____)\____)_| |_|
    ©2013 Semtech-Cycleo

Description:
	Lora gateway Hardware Abstraction Layer

License: Revised BSD License, see LICENSE.TXT file include in the project
Maintainer: Sylvain Miermont
*/


#ifndef _LORAGW_HAL_H
#define _LORAGW_HAL_H

/* -------------------------------------------------------------------------- */
/* --- DEPENDANCIES --------------------------------------------------------- */

#include <stdint.h>		/* C99 types */
#include <stdbool.h>	/* bool type */

/* -------------------------------------------------------------------------- */
/* --- PUBLIC MACROS -------------------------------------------------------- */

#define IS_LORA_BW(bw)			((bw == BW_125KHZ) || (bw == BW_250KHZ) || (bw == BW_500KHZ))
#define IS_LORA_STD_DR(dr)		((dr == DR_LORA_SF7) || (dr == DR_LORA_SF8) || (dr == DR_LORA_SF9) || (dr == DR_LORA_SF10) || (dr == DR_LORA_SF11) || (dr == DR_LORA_SF12))
#define IS_LORA_MULTI_DR(dr)	((dr & ~DR_LORA_MULTI) == 0) /* ones outside of DR_LORA_MULTI bitmask -> not a combination of Lora datarates */
#define IS_LORA_CR(cr)			((cr == CR_LORA_4_5) || (cr == CR_LORA_4_6) || (cr == CR_LORA_4_7) || (cr == CR_LORA_4_8))

#define IS_FSK_BW(bw)			((bw >= 1) && (bw <= 7))
#define IS_FSK_DR(dr)			((dr >= DR_FSK_MIN) && (dr <= DR_FSK_MAX))

#define	IS_TX_MODE(mode)		((mode == IMMEDIATE) || (mode == TIMESTAMPED) || (mode == ON_GPS))

/* -------------------------------------------------------------------------- */
/* --- PUBLIC CONSTANTS ----------------------------------------------------- */

/* return status code */
#define LGW_HAL_SUCCESS		0
#define LGW_HAL_ERROR		-1

/* hardware characteristics */
#define LGW_RF_CHAIN_NB		2	/* number of RF chains */
#define LGW_IF_CHAIN_NB		10	/* number of IF+modem RX chains */
#define LGW_MULTI_NB		4	/* number of Lora 'multi SF' chains */

#define LGW_PKT_FIFO_SIZE	8			/* depth of the RX packet FIFO */
#define LGW_DATABUFF_SIZE	1024		/* size in bytes of the RX data buffer (contains payload & metadata) */
#define LGW_REF_BW			125000		/* typical bandwidth of data channel */
#define LGW_XTAL_FREQU		32000000	/* frequency of the RF reference oscillator */

/* to use those parameters, declare a local constant, and use 'rf_chain' as index */
#define LGW_RF_RX_LOWFREQ	{863000000, 863000000}	/* lower limit of the usable band in RX for each radio */
#define LGW_RF_RX_UPFREQ	{870000000, 870000000}	/* upper limit of the usable band in RX for each radio */
#define LGW_RF_RX_BANDWIDTH	{800000, 	800000}		/* bandwidth of the radios */
#define LGW_RF_TX_LOWFREQ	{863000000, 863000000}	/* lower limit of the usable band in TX for each radio */
#define LGW_RF_TX_UPFREQ	{870000000, 870000000}	/* upper limit of the usable band in TX for each radio */

/* type of if_chain + modem */
#define IF_UNDEFINED		0
#define IF_LORA_STD			0x10	/* if + standard single-SF Lora modem */
#define IF_LORA_MULTI		0x11	/* if + Lora receiver with multi-SF capability */
#define IF_FSK_STD			0x20	/* if + standard FSK modem */

/* configuration of available IF chains and modems on the hardware */
/* to use, declare a local constant, and use 'if_chain' as index */
#define LGW_IFMODEM_CONFIG {\
	IF_LORA_MULTI, \
	IF_LORA_MULTI, \
	IF_LORA_MULTI, \
	IF_LORA_MULTI, \
	IF_UNDEFINED, \
	IF_UNDEFINED, \
	IF_UNDEFINED, \
	IF_UNDEFINED, \
	IF_LORA_STD, \
	IF_FSK_STD }

/* values available for the 'modulation' parameters */
/* NOTE: arbitrary values */
#define MOD_UNDEFINED	0
#define MOD_LORA		0x10
#define MOD_FSK			0x20

/* values available for the 'bandwidth' parameters (Lora & FSK) */
/* NOTE: directly encode FSK RX bandwidth, do not change */
#define BW_UNDEFINED	0
#define BW_500KHZ		0x01
#define BW_250KHZ		0x02
#define BW_125KHZ		0x03
#define BW_62K5HZ		0x04
#define BW_31K2HZ		0x05
#define BW_15K6HZ		0x06
#define BW_7K8HZ		0x07

/* values available for the 'datarate' parameters */
/* NOTE: Lora values used directly to code SF bitmask in 'multi' modem, do not change */
#define DR_UNDEFINED	0
#define DR_LORA_SF7		0x02
#define DR_LORA_SF8		0x04
#define DR_LORA_SF9		0x08
#define DR_LORA_SF10	0x10
#define DR_LORA_SF11	0x20
#define DR_LORA_SF12	0x40
#define DR_LORA_MULTI	0x7E
/* NOTE: for FSK directly use baudrate between 500 bauds and 250 kbauds */
#define DR_FSK_MIN		500
#define DR_FSK_MAX		250000

/* values available for the 'coderate' parameters (Lora only) */
/* NOTE: arbitrary values */
#define CR_UNDEFINED	0
#define CR_LORA_4_5		0x01
#define CR_LORA_4_6		0x02
#define CR_LORA_4_7		0x03
#define CR_LORA_4_8		0x04

/* values available for the 'status' parameter */
/* NOTE: values according to hardware specification */
#define STAT_UNDEFINED	0x00
#define STAT_NO_CRC		0x01
#define STAT_CRC_BAD	0x11
#define STAT_CRC_OK		0x10

/* values available for the 'tx_mode' parameter */
#define IMMEDIATE		0
#define TIMESTAMPED		1
#define ON_GPS			2
//#define ON_EVENT		  3
//#define GPS_DELAYED	  4
//#define EVENT_DELAYED	  5

/* values available for 'select' in the status function */
#define	TX_STATUS		1
#define	RX_STATUS		2

/* status code for TX_STATUS */
/* NOTE: arbitrary values */
#define TX_STATUS_UNKNOWN	0
#define	TX_OFF				1	/* TX modem disabled, it will ignore commands */
#define TX_FREE				2	/* TX modem is free, ready to receive a command */
#define TX_SCHEDULED		3	/* TX modem is loaded, ready to send the packet after an event and/or delay */
#define TX_EMITTING			4	/* TX modem is emitting */

/* status code for RX_STATUS */
/* NOTE: arbitrary values */
#define RX_STATUS_UNKNOWN	0
#define RX_OFF				1	/* RX modem is disabled, it will ignore commands  */
#define RX_ON				2	/* RX modem is receiving */
#define RX_SUSPENDED		3	/* RX is suspended while a TX is ongoing */

/* -------------------------------------------------------------------------- */
/* --- PUBLIC TYPES --------------------------------------------------------- */

/**
@struct lgw_conf_rxrf_s
@brief Configuration structure for a RF chain
*/
struct lgw_conf_rxrf_s {
	bool		enable;		/*!> enable or disable that RF chain */
	uint32_t	freq_hz;	/*!> center frequency of the radio in Hz */
};

/**
@struct lgw_conf_rxif_s
@brief Configuration structure for an IF chain
*/
struct lgw_conf_rxif_s {
	bool		enable;		/*!> enable or disable that IF chain */
	uint8_t		rf_chain;	/*!> to which RF chain is that IF chain associated */
	int32_t		freq_hz;	/*!> center frequ of the IF chain, relative to RF chain frequency */
	uint8_t		bandwidth;	/*!> RX bandwidth, 0 for default */
	uint32_t	datarate;	/*!> RX datarate, 0 for default */
};

/**
@struct lgw_pkt_rx_s
@brief Structure containing the metadata of a packet that was received and a pointer to the payload
*/
struct lgw_pkt_rx_s {
	uint32_t	freq_hz;	/*!> central frequency of the IF chain */
	uint8_t		if_chain;	/*!> by which IF chain was packet received */
	uint8_t		status;		/*!> status of the received packet */
	uint32_t	count_us;	/*!> internal gateway counter for timestamping, 1 microsecond resolution */
	uint8_t		rf_chain;	/*!> through which RF chain the packet was received */
	uint8_t		modulation; /*!> modulation used by the packet */
	uint8_t		bandwidth;	/*!> modulation bandwidth (Lora only) */
	uint32_t	datarate;	/*!> RX datarate of the packet (SF for Lora) */
	uint8_t		coderate;	/*!> error-correcting code of the packet (Lora only) */
	float		rssi;		/*!> average packet RSSI in dB */
	float		snr;		/*!> average packet SNR, in dB (Lora only) */
	float		snr_min;	/*!> minimum packet SNR, in dB (Lora only) */
	float		snr_max;	/*!> maximum packet SNR, in dB (Lora only) */
	uint16_t	crc;		/*!> CRC that was received in the payload */
	uint16_t	size;		/*!> payload size in bytes */
	uint8_t		payload[256]; /*!> buffer containing the payload */
};

/**
@struct lgw_pkt_tx_s
@brief Structure containing the configuration of a packet to send and a pointer to the payload
*/
struct lgw_pkt_tx_s {
	uint32_t	freq_hz;	/*!> center frequency of TX */
	uint8_t		tx_mode;	/*!> select on what event/time the TX is triggered */
	uint32_t	count_us;	/*!> timestamp or delay in microseconds for TX trigger */
	uint8_t		rf_chain;	/*!> through which RF chain will the packet be sent */
	int8_t		rf_power;	/*!> TX power, in dBm */
	uint8_t		modulation; /*!> modulation to use for the packet */
	uint8_t		bandwidth;	/*!> modulation bandwidth (Lora only) */
	uint32_t	datarate;	/*!> TX datarate (baudrate for FSK, SF for Lora) */
	uint8_t		coderate;	/*!> error-correcting code of the packet (Lora only) */
	bool		invert_pol;	/*!> invert signal polarity, for orthogonal downlinks (Lora only) */
	uint8_t		f_dev;		/*!> frequency deviation, in kHz (FSK only) */
	uint16_t	preamble;	/*!> set the preamble length, 0 for default */
	bool		no_crc;		/*!> if true, do not send a CRC in the packet */
	bool		no_header;	/*!> if true, enable implicit header mode (Lora), fixed length (FSK) */
	uint16_t	size;		/*!> payload size in bytes */
	uint8_t		payload[256]; /*!> buffer containing the payload */
};

/* -------------------------------------------------------------------------- */
/* --- PUBLIC FUNCTIONS PROTOTYPES ------------------------------------------ */

/**
@brief Configure an RF chain (must configure before start)
@param rf_chain number of the RF chain to configure [0, LGW_RF_CHAIN_NB - 1]
@param conf structure containing the configuration parameters
@return LGW_HAL_ERROR id the operation failed, LGW_HAL_SUCCESS else
*/
int lgw_rxrf_setconf(uint8_t rf_chain, struct lgw_conf_rxrf_s conf);

/**
@brief Configure an IF chain + modem (must configure before start)
@param if_chain number of the IF chain + modem to configure [0, LGW_IF_CHAIN_NB - 1]
@param conf structure containing the configuration parameters
@return LGW_HAL_ERROR id the operation failed, LGW_HAL_SUCCESS else
*/
int lgw_rxif_setconf(uint8_t if_chain, struct lgw_conf_rxif_s conf);

/**
@brief Connect to the Lora gateway, reset it and configure it according to previously set parameters
@return LGW_HAL_ERROR id the operation failed, LGW_HAL_SUCCESS else
*/
int lgw_start(void);

/**
@brief Stop the Lora gateway and disconnect it
@return LGW_HAL_ERROR id the operation failed, LGW_HAL_SUCCESS else
*/
int lgw_stop(void);

/**
@brief A non-blocking function that will fetch up to 'max_pkt' packets from the Lora gateway FIFO and data buffer
@param max_pkt maximum number of packet that must be retrieved (equal to the size of the array of struct)
@param pkt_data pointer to an array of struct that will receive the packet metadata and payload pointers
@return LGW_HAL_ERROR id the operation failed, else the number of packets retrieved
*/
int lgw_receive(uint8_t max_pkt, struct lgw_pkt_rx_s *pkt_data);

/**
@brief Schedule a packet to be send immediately or after a delay depending on tx_mode
@param pkt_data structure containing the data and metadata for the packet to send
@return LGW_HAL_ERROR id the operation failed, LGW_HAL_SUCCESS else
*/
int lgw_send(struct lgw_pkt_tx_s pkt_data);

/**
@brief Give the the status of different part of the Lora gateway
@param select is used to select what status we want to know 
@param code is used to return the status code
@return LGW_HAL_ERROR id the operation failed, LGW_HAL_SUCCESS else
*/
int lgw_status(uint8_t select, uint8_t *code);

/**
@brief Return value of internal counter when latest event (eg GPS pulse) was captured
@param trig_cnt_us pointer to receive timestamp value
@return LGW_HAL_ERROR id the operation failed, LGW_HAL_SUCCESS else
*/
int lgw_get_trigcnt(uint32_t* trig_cnt_us);

/**
@brief Allow user to check the version/options of the library once compiled
@return pointer on a human-readable null terminated string
*/
const char* lgw_version_info(void);

#endif

/* --- EOF ------------------------------------------------------------------ */