Reference   Language | Libraries | Comparison | Changes

MKRGSM library

The MKR GSM library can be installed using the Arduino library manager.

With the Arduino MKR GSM 1400 and this library you can do most of the operations you can do with a GSM phone: place and receive voice calls, send and receive SMS, and connect to the internet over a GPRS network. The on board module, operates in 3G with a 2G fallback.

Arduino MKR GSM 1400 has a modem that transfers data from a serial port to the GSM network. The modem executes operations via a series of AT commands. The library abstracts low level communications between the modem and SIM card. It relies on the Serial library for communication between the modem and Arduino.

Typically, each individual command is part of a larger series necessary to execute a particular function. The library can also receive information and return it to you when necessary.

This library is based on the GSM library of the Arduino GSM shield, adding new features like UDP, SSL and DTMF tone recognition.

Library structure

As the library enables multiple types of functionality, there are a number of different classes.

  • The GSM class takes care of commands to the radio modem. This handles the connectivity aspects of the module and registers your system in the GSM infrastructure. All of your GSM/GPRS programs will need to include an object of this class to handle the necessary low level communication.

  • Voice call handling, managed by the GSMVoiceCall class.

  • Send/receive SMS messages, managed by the GSM_SMS class.

  • The GPRSClass is for connecting to the internet.

  • GSMClient includes implementations for a client, similar to the Ethernet and WiFi libraries.

  • GSMServer includes implementations for a server, similar to the Ethernet and WiFi libraries. NB : A number of network operators do not allow for incoming connections from the public internet, but will allow them from inside their own. Check with your operator to see what restrictions there are on data use.

  • A number of utility classes such as GSMScanner and GSMModem

Library compatibility

The library tries to be as compatible as possible with the current Ethernet and WiFi101 library. Porting a program from an Arduino Ethernet or WiFi101 library to an Arduino with the MKR GSM 1400 should be fairly easy. While it is not possible to simply run Ethernet or WiFi101 compatible code on the MKR GSM 1400 as-is, some minor, library specific, modifications will be necessary, like including the GSM and GPRS specific libraries and getting network configuration settings from your cellular network provider.

Examples

There are two groups of examples for the Arduino MKR GSM 1400. There are examples to illustrate the possibilities of the board, like how to send SMS messages and connect to the internet. There is also set of example tools that you can use to debug the functionality of the library and the hardware at lower level.

  • Gsm Web Client: Download the content of a website to your Arduino board through GPRS.
  • Gsm SSL Web Client: Download the content of a website to your Arduino board through GPRS and SSL.
  • Gsm Web Server: Create a wireless web server through GPRS.
  • Make Voice Call: Get your board to make phone calls from the Serial Monitor.
  • Send SMS: Use the Serial Monitor to type in SMS messages to different phone numbers.
  • Receive Voice Call: Check the status of the modem while getting voice calls.
  • Receive SMS: Read SMS messages and prompt them to the Serial Monitor.
  • GPRS Ping:Continuously ping an host name
  • GPRS UDP NTP: Use GPRS to retrieve time from NTP
TOOLS

For additional information on the Arduino MKR GSM 1400, see the Getting Started page and the Arduino MKR GSM 1400 hardware page.


GSM class

This class prepares the functions that will communicate with the modem.

GSMVoiceCall class

Enables voice communication through the modem. A microphone and speaker need to be added for full use.

GSM_SMS class

Facilitates sending and receiving Short Message Service (SMS) messages.

GPRS class

This class is responsible for including the files that are part of the library that involve TCP, UDP and SSL communication.

GSMClient and GSMSSLClient class

The client class creates clients that can connect to servers and send and receive data.

GSMServer class

The Server class creates servers which can send data to and receive data from connected clients (programs running on other computers or devices).

GSMModem class

The GSMModem class facilitates diagnostic communication with the modem.

GSMScanner class

The GSMScanner class provides diagnostic information about the network and carrier.

GSMPIN class

The GSMPIN class has utilities for communicating with the SIM card.

GSMBand class

The GSMBand class provides information about the frequency band the modem connects to. There are also methods for setting the band.

GSMUDP class

The UDP class enables UDP message to be sent and received.

Reference Home

Corrections, suggestions, and new documentation should be posted to the Forum.

The text of the Arduino reference is licensed under a Creative Commons Attribution-ShareAlike 3.0 License. Code samples in the reference are released into the public domain.