Super SIM can empower a huge range of IoT devices. This guide focuses on just one of them: Sixfab’s Cellular IoT Hat, a development board which equips a low-cost Raspberry Pi computer with a Quectel BG96 cellular modem. The BG96 is a particularly good modem with which to try out Super SIM: it supports the key IoT-oriented cellular standard enabled by Super SIM, Cat-M. The European version also provides 2G for back-up where that is still available.
In addition to your configured Super SIM, you will need the following hardware to proceed with this guide:
- A Sixfab Cellular IoT Hat. It’s available in Worldwide and Verizon USA-certified forms; select the one that’s right for your location.
- A Raspberry Pi. This guide was written using the Pi 4 Model B, but there are other versions of the Pi available — it should work with any of them, but we’ve only tested the 4 and 3B. The Cellular IoT Hat works with all but the very first Pi. To run the Pi, you will also need:
- A Micro SD card of 8GB or above.
- A monitor and an HDMI-to-micro-HDMI cable.
- A keyboard and a mouse
- A 5V, 2A (10W) USB-C AC adaptor.
The Raspberry Pi has its own setup procedure which involves downloading and installing its Linux operating system, called Raspberry Pi OS, onto the Micro SD card. The Raspberry Pi Foundation has a very good walkthrough of its own that covers this process — you should use this to get your Pi ready before proceeding to the next stage of this guide.
During setup you should connect your Pi 4 to your WiFi network as you will need to download extra software later. We’ll disable WiFi in due course to demonstrate data access over cellular.
The Cellular IoT Hat ships with all you need to fit it onto the Pi. Just follow these steps to set everything up:
- If it’s powered up, turn off the Pi.
- If you’re at the command line, enter
sudo shutdown -hnow.
- If you’re at the desktop, select Shutdown... from the Raspberry menu and then click Shutdown.
- Remove the power cable when the Pi’s activity LED has flashed yellow ten times.
- If you’re at the command line, enter
- Fit either of the two headers supplied with the Hat to the Pi’s paired row of GPIO pins and then slot the Cellular IoT Hat onto the extended header pins:
- Fit your Super SIM into the Cellular IoT Hat’s SIM slot. The slot takes a 3FF Micro SIM, so take care removing your Super SIM from its mount, or use an adaptor if you have removed the Super SIM as a 4FF Nano SIM:
- Connect the bundled cellular antenna to the Cellular IoT Hat. Match up the LTE line on the antenna with the LTE connector on the board. This guide doesn’t use the GPS antenna but we recommend fitting both antennas to reduce the strain on a single connector:
- Connect the supplied USB cable to the micro USB port on the Cellular IoT Hat and a USB port on the Pi:
- Finally, power up the Pi by re-inserting the power cable.
We now need to run through a few steps to get the Pi ready to talk to the Cellular IoT Hat. Some of these will require you to restart the Pi.
- At the command line run
- Use the cursor keys to highlight Interfacing Options, then hit Enter:
- Now highlight Serial Port and hit Enter:
- When you are asked Would you like a login shell to be accessible over serial? select No and hit Enter:
- When you are asked Would you like the serial port hardware to be enabled? select Yes and hit Enter:
- Select Finish.
raspi-configutility will offer to restart the Pi — accept its suggestion.
When the Pi is back up, you should see that the Cellular IoT Hat’s POWER Led is lit green. Now press the PWRKEY button on the board — after a brief moment, the STATUS LED should light up too.
At the command line or in a desktop Terminal run:
You should see a list of items all beginning with
ttyUSB and including
ttyUSB3, which is the device you will use in subsequent steps. With a Pi 4 and the current version of Raspberry Pi OS as of November 16, 2020 you should be good to go, but if you don’t see a list of TTYs, first check that the Cellular IoT Hat’s PWR and STATUS LEDs are lit. If they are, you will need to adjust the Pi’s system software; please see this section before proceeding.
The Cellular IoT Hat can be controlled using a software library written in Python. Enter the following at the command line or in a desktop Terminal:
git clone https://github.com/sixfab/Sixfab_RPi_CellularIoT_Library.git sixfab
Jump into the
sixfab directory and install the library:
sudo python3 setup.py install
You will need to enter your Pi password. If you are in a location with Cat-M1 coverage, run
This script will give the Hat’s BG96 modem a minute to connect to the cellular network and then display some network information. At the
Waiting Time: prompt, just hit Enter. You should see something like this when it’s done:
+COPS: 0,0,"vodafone UK Twilio”,0
Exactly what you will see will depend on where in the world you are connecting from. If you see something like:
then you are not in a region served with Cat-M1. To connect to a 2G network instead, run:
If you have worked through this tutorial before, please note that the following section was updated February 2021 with a new, replacement Sixfab script so some parts of this step may be different than the last time you viewed it.
Now we know we have a cellular connection, we can connect to the Internet. We can set up the Pi’s required PPP (Point-to-Point Protocol) connection using software. Let’s install it now. Run the following at the command line or in a desktop Terminal:
The script will take a second or two to download. Now run:
chmod +x ppp_install_standalone.sh
The script will prompt you for setup information:
- When it asks Please choose your Sixfab Shield/HAT, enter
4for the Pi Cellular IoT Hat.
- When it asks What is your carrier APN?, enter
- When it asks if you need to enter a username and password, just hit
- When it asks What is your device communication PORT?, enter
Last of all, the script will also ask Do you want to activate auto connect/reconnect service at R.Pi boot up? You can enter
y (yes) or
n (no) according to preference. If you select no, you will need to start the PPP connection manually — this is what the remainder of this section of the tutoral assumes you have chosen. However, if you select yes, you can reboot the Pi and jump straight to testing.
When the installation is done you’ll see the message Press ENTER key to reboot — do so.
After the Pi has rebooted, you’re all set to access the Internet over cellular. To be sure it’s working, turn off WiFi — this is easiest to do this from the icon in the Desktop menu bar.
To initiate an Internet connection, at the command line or in a desktop terminal run:
You’ll see a stack of lines displayed at the command line.
When the prompt is back, you’re ready to try out the Internet connection:
- Open up a browser and navigate to twilio.com/docs/iot:
- At the command line or in a desktop terminal, enter
ifconfigand look for the
ppp0entry — it should have a valid IP address listed under
Well done! You now have a Raspberry Pi computer that’s connected to the Internet via Twilio Super SIM. You can now start experimenting with cellular Internet connectivity, or begin developing your own IoT application proof-of-concept.
Your Raspberry Pi and Sixfab Cellular IoT Hub are now able to access the cellular network. Over to you: what are you going to build? We can’t wait to find out.
In the meantime, here are some suggestions for things to try:
- Write some code to get data from a cloud service API via cellular. Here’s a good selection of public APIs.
- Use the Console or Super SIM API to monitor your Super SIM’s data usage.
- Check out our guide Introduction to AT commands and try sending to your modem some of the more useful commands it lists.
Versions of Raspberry Pi OS’ Linux kernel above 5.4.65 have known problems connecting to the Cellular IoT Hat’s BG96 modem. To remedy this, you need to downgrade the kernel to version 5.4.65. You may need to do this after updating the Pi’s on-board software using
sudo apt update and then
sudo apt upgrade.
Here’s what to do. Run the following three commands at the command line or in a desktop terminal:
sudo apt update
sudo rpi-update a995f0c9a9b3e5dbd2a41f69f5c4c82cdf33c7ec
You’ll now be able to access the modem and its Internet connection. You can now continue with the setup process.