Quectel BC95-G-TE-B

Learn how to setup and integrate dev-kit Quectel BV95-G-TE-B with IoT Creators NB-IoT network and Data Provisioning Service (SCS)

713

QUECTEL BC95-G

Links

Links to the AT command samples:

Setup the Device


In the following I will describe you how to setup your devkit so that you are able to send AT commands directly from your computer to the Quectel modem.

Connect your devkit with your computer

Your devkit will be connected with your computer by using mini USB and can be accessed with a terminal program such as "putty" on Windows or "screen" or "minicom" on Linux.

In case you are working with Linux your are lucky. The USB/Serial drivers should be already available on your system and you don't need to install anything else.
After you connected your devkit via USB with your computer you should find the device file
/dev/ttyXRUSB0 (or /dev/ttyACM0). It is automatically created when you connect your devkit with your computer and if you disconnects it your devkit disappears again.

Unfortunately I can not tell you how to enable the serial terminal connection via USB on Window or Mac because I am only working with Linux. Sorry :disappointed_relieved:.

Execute AT commands on your devkit the first time.

To execute AT commands on your devkit you need start on your computer a terminal program such as putty on Windows or minicom or screen on Linux and connect it with your devkit via the serial USB line. After this you can send AT commands to the modem of your devkit.

In the following I will explain to you how to do this stuff on Linux by using the minicom and to send those AT commands to the modem to query device product and IMEI information.

📘

I tryed to use screen as terminal progam instead of minicom. But for any reason I couldn't activate the local echo of my input on the terminal window. Out of this reason I use minicom for some QUECTEL devices.
If you can activate the local echo of your input with screen please let me know, I am highly interested in it.

Connect your devkit with your Linux computer via terminal program minicom

In case minicom is not already installed on your computer you can install it with

$ sudo apt-get install minicom

After that you can configure minicom by executing

$ sudo minicom -s

478

Main configuration menu of minicom.

🚧

It is important that you run the configuration of minicom as root because the resulting configuration file will be stored in the directory /etc/minicom to which root has only write permissions.

In the minicom configuration menu change the following settings:

  • Enter Serial port setup
    • Set Serial Device to /dev/ttyXRUSB0
    • Set the baudrate (Bps/Par/Bits) to 9600 8N1
  • Enter Screen and keyboard
    • Set Local echo to Yes
  • Enter Save setup as
    • Give bc95-g as the name to save the configuration
  • Enter Exit from Minicom

After configuring minicom for your Quectel devkit you can start minicom with the configuration _bc95-g'_ which just created before.

$ minicom bc95-g

📘

In case you have any problems to access the device file /dev/ttyXRUSB0 because you don't have enough access privilages for this file execute the following command

$ sudo usermod -a -G dialout YOUR-USER-NAME

As very first AT command you should input the command AT. This command shall always return OK. If not, there is something wrong.

AT
AT
OK

Afterwards you should input the command ATE0 to deactivate the device echo.

ATE0
ATE0
OK

👍

Congratulations

If you reached this point you equipped your QUECTEL BC95-G with the capabiltiy to pass your AT commands from the serial USB terminal interface directly through to the ublox modem.

Now the fun begins! :smiley: :smiley:

AT Commands to get IMEI, IMSI and other product information from your devkit

In the following various AT commands are shown to query the IMEI and other product information from your devkit.

# Request IMEI
AT+CGSN=1
                                                                                
+CGSN: 357518080495450

OK

# Request IMSI of the SIM card
AT+CIMI

901405700009293

OK

# Request SIM card identification number
AT+NCCID

+NCCID: 89882280000001294327

OK

# Device statistics
AT+NUESTATS

Signal power:-32768                                                             
Total power:-32768                                                              
TX power:-32768                                                                 
TX time:0                                                                       
RX time:0                                                                       
Cell ID:4294967295                                                              
ECL:255                                                                         
SNR:-32768                                                                      
EARFCN:4294967295                                                               
PCI:65535                                                                       
RSRQ:-32768                                                                     
OPERATOR MODE:0                                                                 
CURRENT BAND:255                                                                            
                                                                                
OK                                    
# Request manufacturer identification
AT+CGMI

Quectel

OK

# Rquest model identification 
AT+CGMM

BC95GJB-02-STD 

OK

# Request firmware version identification  
AT+CGMR

SB,V150R100C10B200SP1                                                         
SECURITY_A,V150R100C20B300SP7                                                            
PROTOCOL_A,V150R100C20B300SP7                                              
APPLICATION_A,V150R100C20B300SP7                                           
SECURITY_B,V150R100C20B300SP7                                                            
RADIO,Hi2115_RF0

OK

# Request prodct type number
ATI

Quectel                                                                         
BC95-G                                                                          
Revision:BC95GJBR01A07   

OK

Attach to the NB-IoT Network


This chapter explains how you can attach your QUECTEL BC95-G devkit to the NB-IoT network. I recommend to read the chapter "Setup QUECTEL BC95-G" first.

🚧

If you are only interested in the conclusion of the AT commands to configure the network setup go to chapter "'AT Commands Only"

❗️

Before you send any UDP or COAP message to IoT Creators make sure you registered the device IMEI before.

If you forget, you will have problems to register your device afterwards. In this case please get in contact with IoT Creators support team.

A few assumptions and notes before starting with this manual

  • You should be able to send AT commands to your devkit with a terminal program such as putty, screen, minicom, etc.
  • Your device is on the latest firmware
  • Be gentle to your device and have some patience. After each AT command he/she/it needs a few seconds to execute the command and respond

In the following we will walk through together the AT commands with which you can perform the following actions:

  • Setup network configuration of you devkit.
  • Attach to the network and verify your network configuration.
  • Ping an IP address.

Setup Network Configuration

After switching on your devkit deactivate the radio functionality with +CFUN. You should do this to make sure no miss-configured automatic dial-in action makes your setup difficult.

AT+CFUN=0

Switch on some basic configuration parameters of the modem with +NCONFIGsuch as autoconnect, scambling.

AT+NCONFIG="AUTOCONNECT","TRUE"
AT+NCONFIG="CR_0354_0338_SCRAMBLING","TRUE"
AT+NCONFIG="CR_0859_SI_AVOID","TRUE"

❗️

Roaming via Vodafone in UK

In case of romaing via Vodafone in UK you probably need to use AT+NCONFIG="CR_0859_SI_AVOID","FALSE".

Set the APN of IoT Creators with +CGDCONT

🚧

Choosing the correct APN for your sim card

The command below represent an example, different sim cards can have different APNs, for the correct APN check this doc page here: https://docs.iotcreators.com/docs/general-settings

AT+CGDCONT=0,"IP","cdp.iot.t-mobile.nl"

Sometimes you get an ERROR response of the +CGDCONT command. Reason for this can be that the radio is not deactivated with +CFUN=0 and the modem already attached to the network. In this case just deactivat the radio and try it again.

Set the bands with +NBANDcommand.

AT+NBAND=8,20

Set the EPS network registration status with +CEREG command.

AT+CEREG=5

Select the network operator of your choice with +COPS command manually (1) by given the numeric identification (2) of the operator ("26201", "20416", "26002", etc.) (https://docs.iotcreators.com/docs/roaming-mobile-iot-networks)

AT+COPS=1,2,"20416"
AT+COPS=1,2,"26201"
AT+COPS=1,2,"26002"

👍

:+1: Great! Your setup of network configuration is complete now.

The next step is it to test if it is correct and if your devkit is able to attach the network with it.

Good Luck :smirk:

The setup of the network configuration is complete. Because we deactivated the radio in the
beginning with +CFUN=0 nothing should happen so far.
To see your configuration in action you can trigger a reboot of your devkit with the +NRB command.

AT+NRB

After you triggered the reboot with ```+NRB you should see the following on your terminal and your devkit should attach to the network automatically.


REBOOTING
�"�
Boot: Unsigned
Security B.. Verified
Protocol A.. Verified
Apps A...... Verified

REBOOT_CAUSE_APPLICATION_AT
Neul 
OK

As next we will verify if your devkit is actually attached to the network and verify the network configuration with some more AT commands.

Attach to the Network and verify your Network Configuration

After you have rebooted your devkit the most interesting question is if your devkit got an IP address assigned by the network.
You can query the assigned IP address from your devkit with the +CGPADDR command.

AT+CGPADDR

+CGPADDR: 0,10.128.1.157
OK

As the result your devkit returns the current IP address. In this sample it is 10.128.1.157

📘

:angry: What to do if it doesn't work :imp:

If you are not able to get established a network attachment double check the following

  • Did you configure the correct APN?
  • Did you configure the correct mobile network operator in your country?
  • Did you make sure your SIM card has active roaming in case you are not in the home country of your network operator?

AT Commands to query Network Information

In the following I show you some more AT commands with which you can query other information regarding mobile connection status.

# Query if the devkit is attached to the network
AT+CGATT?
+CGATT: 1
OK

# Query the configured MNO (Mobile Network Operator)
AT+COPS?
+COPS: 0,2,"26201"
OK

# Query the configured APN
AT+CGDCONT?
+CGDCONT: 0,"IP","cdp.iot.t-mobile.nl",,0,0,,,,,0
OK

# Query the configuration
AT+NCONFIG?
+NCONFIG:AUTOCONNECT,TRUE
+NCONFIG:CR_0354_0338_SCRAMBLING,TRUE
+NCONFIG:CR_0859_SI_AVOID,TRUE
+NCONFIG:COMBINE_ATTACH,FALSE
+NCONFIG:CELL_RESELECTION,FALSE
+NCONFIG:ENABLE_BIP,FALSE
+NCONFIG:MULTITONE,TRUE
+NCONFIG:NAS_SIM_POWER_SAVING_ENABLE,TRUE
+NCONFIG:BARRING_RELEASE_DELAY,64                                               
+NCONFIG:RELEASE_VERSION,13                                                     
+NCONFIG:RPM,FALSE                                                              
+NCONFIG:SYNC_TIME_PERIOD,0                                                     
+NCONFIG:IPV6_GET_PREFIX_TIME,15                                                
+NCONFIG:NB_CATEGORY,1                                                          
+NCONFIG:RAI,FALSE                                                              
+NCONFIG:HEAD_COMPRESS,FALSE                                                    
+NCONFIG:RLF_UPDATE,FALSE                                                       
+NCONFIG:CONNECTION_REESTABLISHMENT,FALSE                                       
+NCONFIG:PCO_IE_TYPE,EPCO                                                       
OK

# Query signal power and quality
# Power should be between 0-31 and NOT 99. 99 means "no network detactable"
# Quality should be between 0-9. 99 means not know or not detactable.
AT+CSQ
+CSQ: 99,99
OK

Ping the first IP address

With the AT+CGPADDR command you could query the current IP address of your devkit. But you still not know if your devkit is able communicate in the IP network correctly.
To test this you should ping the UDP server of IoT Creators platform with the +NPING command.

📘

PING Service

Check the correct ping address here: IoT Configuration Parameter

AT+NPING=172.27.131.100

OK

+NPING: "172.27.131.100",253,7478

In case your devkit could ping the given IP address response will be
´´´
+NPINGERR: 1
´´´

👍

:+1: Congratulations :+1:

If you reached this point and if you were able to ping successfully the IoT Creators' UDP server, you reached a very important milestone.

Experience has shown that most of the problems arise during the devkit commissioning and the first attachment with the network.

The rest journey and the next steps of the tutorial will be easy :smirk:

AT Commands Only

#######################################################################
# Network attach
#######################################################################
# Switch off radio
AT+CFUN=0

# Switch autoconnect and scrambling on:
AT+NCONFIG="AUTOCONNECT","TRUE"
AT+NCONFIG="CR_0354_0338_SCRAMBLING","TRUE"
AT+NCONFIG="CR_0859_SI_AVOID","TRUE"

# Set the APN
AT+CGDCONT=0,"IP","cdp.iot.t-mobile.nl"

# Set the bands
AT+NBAND=8

# EPS network registration status
AT+CEREG=2

# select an operator DE:"26201", NL:"20416"
AT+COPS=1,2,"26201"

# Reboot the device
AT+NRB

#######################################################################
# Network attach verification
#######################################################################
# Check IP address
AT+CGPADDR

# Check if attached to network
AT+CGATT?

# Check MNO
AT+COPS?

# Check APN
AT+CGDCONT?

# Check the configuration
AT+NCONFIG?

# Check signal strength and qualitay
AT+CSQ

# Device statistics
AT+NUESTATS

# Extended error report
AT+CEER

#######################################################################
# Ping UDP server of IoT Creators
#######################################################################
AT+NPING=172.27.131.100

Send and Receive via UDP


In the following chapters I will explain to you how you can send a "Hello World" message from the device to the IoT Creators SCS and how you can receive a a "Hello Device" message on your devkit from IoT Creators SCS.

Send "Hello World"

❗️

Register your device first!

Make sure that you have registered your device with its IMEI at the IoT Creators portal BEFORE you send your first message to the UDP or CoAP server of IoT Creators.

If you forget, you will have problems to register your device afterwards. In this case please get in contact with IoT Creators support team.

Welcome to this step of tutorial. You probably ended up here because you could successfully connect your devkit to the network.
Before you continue make sure your device has an IP address assigned and you can ping the UDP server of IoT Creators. You test both with the +CGPADDR and the +NPING command.

AT+CGPADDR
+CGPADDR: 0,"10.128.4.109"
OK

AT+NPING=172.27.131.100
OK
+NPING: "172.27.131.100",253,2396

In the next steps you will

  • Open local UDP socket to send UDP messages.
  • Create a hex coded "Hello World" message.
  • Send the hex coded "Hello World" message to the UDP server of IoT Creators.
  • Verify if the messages have arrived at the IoT Creators platform.

Open local UDP Socket to send message

To send UDP messages to a UDP server you need to open a local UDP socket. For this you can use the +NSOCR command. The returned value of this command ("0" in the sample below) represents the identifier of the opened socket.

AT+NSOCR=DGRAM,17,7000,1

0
OK

The +NSOCR command opens a UDP socket with the following parameters:

ParameterDescription
typeType of the socket.
Currently only "DGRAM" is supported.
protocolProtocol id which shall be used.
Currently only 17 for UDP is supported.
listen_portLocal port which is included in the sent message and on which messages can be received from the IoT Creators UDP server.
receive_control0 := incomming messages are ignored
1 := incomming messages will trigger a +NSONMI event.

To close the UDP socket you can use the command +NSOCL later. The "0" as command parameter references the socket identifier as it has been returned by the +NSOCR command before.

AT+NSOCL=0

OK

Create a HEX coded "Hello World" Message

I recommend not to send plain text or binary data from the device to your backend applications or vice versa. You can use a hex or a base64 encoding format of data. In our sample we send Hello World as a hex converted string to the IoT Creators.

To convert Hello World you can use online tool http://string-functions.com/string-hex.aspx

757

Tool to convert "Hello World" string to hex format.

The hex string for Hello World is 48656c6c6f20576f726c64.

Sending HEX coded "Hello World" Message to UDP Server

To let your device send this message via UDP to the UDP server of IoT Creators you can use the +NSOST command as shown in the following.
The +NSOST command returns the socket identification as a first digiti and the length of successfully sent data as second digit.

AT+NSOST=0,172.27.131.100,15683,11,48656c6c6f20576f726c64

0,11
OK

The +NSOST command sends a UDP message with the following parameters:

ParameterDescription
socketSocket identifier as it has been returned from the +NSOCR command.
remote_ip_addressIP address of the UDP server to which the the message shall be sent.
remote_portPort on which the UDP server listens for messages.
lengthLength of the original data to be sent, not of the hex converted data.
The max. length is 512 bytes.
dataData to be sent in hex format.

👍

CONGRATULATIONS :clap: :cake:

If you see OK on the device console CONGRATULATIONS! you just sent your first UDP message from your device to an UDP server of IoT Creators.

📘

The data length which is assigned to the command AT+NSOST describes the length of the original data. It does NOT desribes the length of the data in hex format which has a length of 22 bytes in the "Hello World" case.

View the received Messages in IoT Creators Portal

For each device the IoT Creators Portal makes the laste received message available by showing it in the Payload column. In case of our Hello World message:

888

Project view of IoT Creators portal with device and last sent data.

If you click on the payload the value of it is copied to the clipboard.

247

Click on payload to copy into clipboard.

As already mentioned above it is a nice behaviour to transfer strings and binary data not as they are. It is better to encode them to hex or base64 for the transfer.
We sent our Hello World as hex encoded string on its way. Out if this reason we see in the IoT Creators Portal the string 48656c6c6f20576f726c64.

To decode the received message back from hex to a readable string we can use the online tool http://string-functions.com/hex-string.aspx.

757

Online tool to convert hex to string.

👍

:clap: CONGRATULATIONS :clap: :cake:

If you can decode your received message to Hello World **CONGRATULATIONS**! You just sent your first UDP message from your device via NB-IoT to IoT Creators platform.

🚧

Maybe you have to send the first message twice. The first message will be considered as a registration message, so the it will not be forwarded to the GUI.

AT Commands to send Hello World

# Open local UDP socket on port 7000
AT+NSOCR=DGRAM,17,7000,1
0
OK

# Send UDP message to UDP server via socket=0
AT+NSOST=0,172.27.131.100,15683,11,48656c6c6f20576f726c64
0,11
OK

# Close socket=0
AT+NSOCL=0
OK

Receive "Hello Device"

Welcome back to the tutorial :+1:.
In this step I will explain to you how you can receive the "Hello Device" downlink message 48656c6c6f20446576696365 via UDP which you have posted before to the IoT Creators platform.

The downlink message which you posted to IoT Creators API before is queued by the IoT Creators platform. The queued downlink message is sent to the device after IoT Creators platform received the uplink message from the device.

In this tutorial you will perform the following steps:

  • Open local UDP socket.
  • Send a "i am alive" heartbeat message via UDP to the UDP server of IoT Creators.
  • Receive the previous queued "Hello Device" message from the IoT Creators platform.

Open local UDP socket and send "i am alive" heartbeat

You can open the UDP socket and send a UDP message with the commands +NSOCR and NSOST.

Before you open the UDP socket you can verify your IP address and if you are able to heartbeat the UDP server of IoT Creators.

AT+CGPADDR
+CGPADDR: 0,"10.128.5.88"
OK

AT+NPING=172.27.131.100
OK
+NPING: "172.27.131.100",253,4934

Send "i am alive" heartbeat message and receive downlink message

After you verified the network attach of your device you can open the UDP socket on your device and send a "i am alive" heartbeat message to the UDP server of IoT Creators. The message should be in hex format.

AT+NSOCR=DGRAM,17,7000,1
0
OK

AT+NSOST=0,172.27.131.100,15683,10,6920616d20616c697665
0,10
OK

The "i am alive" message causes the UDP server of the IoT Creator portal to send out the previous queued "Hallo Device" message to the device.
Because you used as last parameter "1" in the +NSOCR command to open the socket the device notifiers you with an URC (Unsolicited Result Code) code as soon data has been been received by the modem of the device.

+NSONMI: 0,12

AT+NSORF=0,12
0,"172.27.131.100",15683,12,"48616C6C6F20446576696365",0
OK

The +NSONMI in the sample above indicats that 12 bytes of data have been received on socket 0.

To retrieve the 12 bytes of the received data from socket 0 you can use the +NSORF=0,12`command. +NSORF``` returns the following elements:

ValueDescription
0Id of the socket on which the data has been received.
172.27.131.100IP address of the remote host (UDP server) which sent the data.
15683Remote port the messages were sent from.
12Amount of data returned as a decimal byte length
"48616C6C6F20446576696365"Data received in hexadecimal format.
0Amount of data still to be read

To decode the hex data 48616C6C6F20446576696365 into a readable string you can use the online tool http://string-functions.com/hex-string.aspx.

849

Online tool to decode hex data to string data.

🚧

Downlink only possible after uplink

If you try to send a downlink message to a device that has not send any uplink messages you will receive the error : Serial number not found.
After sending an uplink message the device registration is completed and downlinking will work.

AT Commands to receive Hello Device

#  Test if device has an IP address asigned
AT+CGPADDR 
+CGPADDR: 0,"10.0.5.112"
OK

# Ping UDP server of IoT Creators
AT+NPING=172.27.131.100 
OK
+NPING: "172.27.131.100",253,4135

# Open local UDP socket 
AT+NSOCR=DGRAM,17,7000,1 
0
OK

# Send "i am alive" message to UDP server
AT+NSOST=0,172.27.131.100,15683,10,6920616d20616c697665
0,10
OK

# URC about received data
+NSONMI: 0,12

# Retrieve the received data
AT+NSORF=0,12
0,"172.27.131.100",15683,12,"48616C6C6F20446576696365",0
OK

Other useful functions

Retrieve time from the network

You can retrieve the local time from the network (not all mobile networks support this command) by issuing:

AT+CCLK?

+CCLK: 2023/02/06,13:17:08GMT+1

Configuring DNS

📘

DNS configuration

The DNS configuration only makes sense only when using the public APN to reach the external internet, when using the private APN, please use the direct IP for the service of your choice.

DNS should be automatically retrieved by the local network, just make sure that the ePCO (extended protocol configuration options) is enabled with command

AT+QCFG="nccconf",101

🚧

DNS not configured

If DNS are not automatically retrieved by the network, it couldbe possible that the local network is not providing those. In this case, configure them manually.

Configure DNS manually

Alternatively, you can explicitely configure the DNS with command

AT+QIDNSCFG="primarydnsipv4","secondarydnsipv4"