Files
2021-05-11 20:43:42 +03:00
..
2021-05-11 20:43:42 +03:00
2021-05-11 20:43:42 +03:00
2021-05-11 20:43:42 +03:00
2021-05-11 20:43:42 +03:00
2021-05-11 20:43:42 +03:00
2021-05-11 20:43:42 +03:00
2021-05-11 20:43:42 +03:00
2021-05-11 20:43:42 +03:00
2021-05-11 20:43:42 +03:00
2021-05-11 20:43:42 +03:00

SX128X Library

This part of the SX12XX library supports the SX1280 and SX1281 2.4Ghz LoRa modules.

The objective of the SX12XX library is to allow the same program sketches to be used across the range of UHF LoRa modules SX126x and SX127x (UHF) as well as the 2.4Ghz SX128x modules.

###SX128X Considerations for pin usage

There is a range of SX128X modules available and they have slightly different pins usage.

The library only supports the SPI based LoRa modules and these all require that the SPI bus pins, SCK, MOSI and MISO are connected. All modules also need a NSS (chip select pin) and NRESET (reset) pin. All devices need the RFBUSY pin to be used also.

The basic SX1280 modules from NiceRF and Ebyte were used to test the examples in this library. There may be newer devices out there that have additional features, such as TCXOs, that may require different set-ups or pin usage.

Of the LoRa devices DIO pins the SX128X library in standard form only uses DIO1. Some SX128x modules have RX and TX enable pins that need to be appropriately activated when receiving or transmitting.

Thus a begin function that initialised all possible permutations of pins would look like this;

begin(NSS, NRESET, RFBUSY, DIO1, DIO2, DIO3, RX_EN, TX_EN, LORA_DEVICE);

Clearly the above begin statement is somewhat cumbersome and could potentially be shortened for the NiceRF SX128X devices to;

begin(NSS, NRESET, RFBUSY, DIO1, LORA_DEVICE);

And shortened for the Ebyte devices to;

begin(NSS, NRESET, RFBUSY, DIO1, RX_EN, TX_EN, LORA_DEVICE);

Which is a lot more manageable.

You can use the shorter formats of the begin commands can be used in your own programs if you have the appropriate module, NiceRF or Ebyte.

The full format of begin, see above, is still valid and is used in most of the example programs. If you have written your own programs using the earlier library these programs do not need changing. You could not have used the newer constructs of the begin command (to support the newer devices) in your programs since the newer constructs did not exist in the older version library.

Valid values for LORA_DEVICE are DEVICE_SX1280 and DEVICE_SX1281.

Accepted its all a bit confusing, but regrettably module manufacturers have different ideas about design.

SX128X Library - LoRa Settings

In the setModulationParams() function the Spreading factor, Bandwidth, CodeRate LoRa parameters can be set;

//LoRa Spreading factors
LORA_SF5   
LORA_SF6
LORA_SF7
LORA_SF8
LORA_SF9
LORA_SF10
LORA_SF11
LORA_SF12 

//LoRa Bandwidths
LORA_BW_0200  //actually 203125hz
LORA_BW_0400  //actually 406250hz
LORA_BW_0800  //actually 812500hz
LORA_BW_1600  //actually 1625000hz

//LoRa Coding rates
LORA_CR_4_5  
LORA_CR_4_6  
LORA_CR_4_7  
LORA_CR_4_8

The device types for the SX128X part of the library are;

DEVICE_SX1280 
DEVICE_SX1281

In the transmit() function the TXpower can be set from -18dBm to +12dBm.

In the setPacketType() function valid packet type are;

PACKET_TYPE_LORA
PACKET_TYPE_FLRC
PACKET_TYPE_RANGING
PACKET_TYPE_BLE (not implemented)
PACKET_TYPE_NONE

Stuart Robinson

April 2020