Skip to content

ESP32 example project with NB-IoT or LTE-M communication using an LPWA modem (e.g. SIM7080G). ESP32 connects to AWS IoT Core using MQTT with mTLS (x509 certificates)

Notifications You must be signed in to change notification settings

wizzdev-pl/esp32-cellular-lpwa-modem-example

Repository files navigation

ESP32 Cellular LPWA Modem Example

Target board - ESP32

Build process is aimed for Ubuntu/Debian based Linux distributions.

0. Prerequisites

To compile you need to get the following packages:

sudo apt-get install git wget flex bison gperf python python-pip python-setuptools cmake ninja-build ccache libffi-dev libssl-dev dfu-util

Add the user to dialout group:

sudo usermod -a -G dialout $USER

1. Development

In this README, the following variables are assumed to be defined: $PROJECT_DIR, $BUILD_DIR, BUILD_TEST_DIR. E.g.:

PROJECT_DIR=`pwd`  # source root - directory of this README
BUILD_DIR=$(realpath $PROJECT_DIR/../build-<project_name>)
BUILD_TEST_DIR=$(realpath $PROJECT_DIR/../build-<project_name>-test)

1.1. Build environment preparation

Before first build, some one-time preparation is required

1.1.1. Don't forget to update the submodules first

git submodule init && git submodule update
git submodule update --init --recursive

To update the submodules to the tracked branch (set in .gitmodules file):

git submodule update --remote  

It will update the submodules in local repo. To commit them, call git add path/to/submodule and commit.

1.1.2. Build the esp compiler

cd $PROJECT_DIR
cd build
./install_esp32_compiler.sh 

1.2. Activate the environment in the terminal

Environment needs to be activated for all commands related to building, flashing and monitoring firmware. Needs to be run in every terminal.

. $PROJECT_DIR/externals/esp-idf/export.sh  

1.3. Building

To build the firmware, issue the following commands:

mkdir $BUILD_DIR
cd $BUILD_DIR
idf.py -B . -C $PROJECT_DIR/ build  

1.4. IDE editing

At this point you should be able to open the environment in the QtCreator.

  • Start QtCreator (e.g. run /opt/Qt/Tools/QtCreator/bin/qtcreator) from a terminal with active environment
  • Open the main CMakeLists.txt from the $PROJECT_DIR/
  • Import the automatically generated kit (the one that points to your $BUILD_DIR) and disable the desktop kit if active.

1.5. Flashing

To flash:

(if not in $BUILD_DIR change ./ to appropriate folder)

idf.py -B ./ -C $PROJECT_DIR/ --baud 921600 flash 

One can also start the terminal monitor afterwards:

idf.py -B ./ -C $PROJECT_DIR/ --baud 921600 flash monitor

Other commands to be combined: build, erase_flash, e.g.:

idf.py -B ./ -C ../pockethernet-esp32/ --baud 921600 erase_flash build flash monitor

If the board and serial port converter doesn't support automatic control of RESET and BOOT pins control, one may need to drive them manually, e.g. with buttons.

1.6. Testing

To prepare the testing environment, build and run tests, issue the following commands:

# Do NOT activate idf.py environment!
mkdir $BUILD_TEST_DIR
cd $BUILD_TEST_DIR
${PROJECT_DIR}/test/build_tests.sh  

Now to rebuild and rerun tests issue:

make && ./esp32_test_on_pc

Tests can be edited and run in QtCreator

1.7. Menuconfig

To configure the ESP32 build - run:

# Remember to activate the environment
cd $BUILD_DIR
idf.py -B ./ -C $PROJECT_DIR/ menuconfig

2. Hardware requirements

3. SIM7080G connection

  • VSYS needs to be connected to 3.7 - 4.2 V power supply. 3.3 V seems not to be efficient enough to provide stable power supply for the module
  • GND from power supply and and SIM7080G connected with ESP32 GND pin (next to pin 23)
  • DTR connected to GND (pin on SIM7080G next to DTR can be used)
  • PWR connected to ESP32 GPIO14
  • RXD connected to ESP32 pin 4
  • TXD connected to ESP32 pin 5
  • 3V3 (OUT) connected to ESP32 3V3 pin

4. Connection with AWS

In order to connect with AWS, you need to update AWS_ENDPOINT_URL, AWS_THINGNAME, AWS_CLIENT_CERTIFICATE and AWS_CLIENT_PRIVATE_KEY in app/src/connectivity/aws_configuration.h according to endpoint url and credentials required for the environment you are trying to connect to.

Please note that file is currently not being tracked, updates made in this file should not be pushed to the repository.

5. Switching between LTE-M and NB-IoT

Switching between LTE-M and NB-IoT modes can be done using CMake parameters USE_NB_IOT and USE_LTE_M, e.g. following command will compile the code to LTE-M variant:

idf.py -B . -p /dev/ttyUSB0 -C $PROJECT_DIR/ -DBUILD_WITH_PRINTS_AND_LOGS=ON -DIS_DEBUG_BUILD=OFF -DUSE_LTE_M=ON -DUSE_NB_IOT=OFF build

and following command will compile the code to NB-IOT variant

idf.py -B . -p /dev/ttyUSB0 -C $PROJECT_DIR/ -DBUILD_WITH_PRINTS_AND_LOGS=ON -DIS_DEBUG_BUILD=OFF -DUSE_LTE_M=OFF -DUSE_NB_IOT=ON build

Please note that:

  • at least one connectivity method has to be selected
  • both methods must not be selected at the same time

Otherwise, a compilation error will be generated.

Make sure to update APN_NAME for your variants in CMakeLists.txt file if you use different operators as well as NB_IOT_BANDS and LTE_M_BANDS in app/src/connectivity/lpwa_communication_controller/lpwa_communication_controller.h according to the configuration for your operator in your country.

About

ESP32 example project with NB-IoT or LTE-M communication using an LPWA modem (e.g. SIM7080G). ESP32 connects to AWS IoT Core using MQTT with mTLS (x509 certificates)

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published