# sx1278-LoRa-RaspberryPi
May work with all sx127x chips, i didn't test it on these chips
This source uses libpigpio. Installation on raspbian: apt install pigpio
Quick start:
0. apt install pigpio
1. Wire raspberry and lora chip by the table below
raspi | LoRa | |
GPIO4 | RESET | |
GPIO17 | DIO0 | |
MOSI | MOSI | |
MISO | MISO | |
CLK | SCK | |
SPI_CE0 | NSS |
2. Clone the repo
3. Enter cloned repo dir
4. make
5. Try files under sudo: transmit_explicit, transmit_implicit, receive_explicit, receive_implicit
All transmitt examples just ones send "LoRa" string with its '\0' terminating byte.
- int LoRa_begin(LoRa_ctl *modem) - Configures radio module. Returns spi handle >= 0 if OK, otherwise error number < 0
- void LoRa_send(LoRa_ctl *modem) - Commands radio module to send data from buffer
- void LoRa_receive(LoRa_ctl *modem) - Commands radio module to switch to continuous receive mode
- void LoRa_calculate_packet_t(LoRa_ctl *modem) - Calculates onair time, payload symbols and other fields.
- _Bool LoRa_check_conn(LoRa_ctl *modem) - Checks connection with module. Return True/False
- void LoRa_end(LoRa_ctl *modem) - Ends up working with module. Switches to sleep mode, closes spi and so on.
- void LoRa_stop_receive(LoRa_ctl *modem) - Removes callback from IRQ pin, switches module to idle mode.
- void LoRa_sleep(LoRa_ctl *modem) - Switches module to sleep mode
- unsigned char LoRa_get_op_mode(LoRa_ctl *modem) - Returns current module operational mode - SLEEP_MODE, RXCONT_MODE, SLEEP_MODE, STDBY_MODE
- struct LoRa_ctl - view LoRa.h
Function void LoRa_receive(LoRa_ctl *modem) uses continuous mode on module. Radio module will continiuously receive packets and each time execute user callback. It's in case you need to exchange data larger than 255 bytes(FIFO buffer). You have to manually stop receiving by void LoRa_stop_receive(LoRa_ctl *modem).
Updated library to handle radio module from user Rx\Tx callbacks. Backward compatibility retained.
Now you can start sending data from Rx callback, or vice versa, or any other operation with radio module.
New examples "ping.c" and "pong.c" to explain new features. Make, then execute on different devices first "pong" then "ping".
Supported by ITT ltd