Supported MC60 Development Board List #
-
Arduino uno R3
-
Arduino uno R3 SMD
-
Arduino Zero
-
Arduino Yun Rev2
-
Arduino UNO Wi-Fi Rev2
-
Arduino UNO R4 Wi-Fi
-
Arduino uno R4 Minima
-
Arduino Leonardo
Feature List #
MC60 Development Board Feature
-
Quad-band: 850/900/1800/1900MHz
-
AT Commands: GSM 07.07, 07.05 and Enhanced AT Commands
-
TCP/UDP/HTTP/FTP/PPP
-
Jamming Detection
-
Audio
-
FOTA
-
Dual SIM, Single Standby
-
OpenCPU
-
GPS+GLONASS
-
QuecFastFix
MC60 Arduino Feature #
The MC60 header Development board is a compact and portable board designed specifically for Arduino. The main equipped modules are the mc60 series wireless communication modules.
The MC60 Development board has a USB Type-C interface, making it convenient for development. Developers only need a USB Type-C cable to easily use the MC60 Development board.
Additionally, the MC60 Development board is compatible with the expansion board of Arduino, which can be directly used on the MC60 Development board.
MC60 Development Board Resources #
Function Description #
The main component and interface placement of the MC60 Development Board is shown in the following figure:
MC60 Development Board Configuration #
The detailed assignment of the peripheral interfaces on the MC60 Development board is as follows:
| NO. | Name | Silkscreen | Comment |
|---|---|---|---|
| 1 | USB Type-C Interface | – | – |
| 2 | Audio jack 3.5 mm | – | – |
| 3 | Sim card case | – | 4FF SIM Card 12.3 × 8 mm |
| 4 | SD card case | – | Micro SD Card |
| 5 | Manual boot | Manual Boot | Push button |
| 6 | External GNSS Antenna | GNSS ANT | UFL Antenna |
| 7 | 18pin | – | Header 2.54 mm |
| 8 | External GSM Antenna | GSM ANT | UFL Antenna |
| 9 | Button | Button | If pushed, connects RST pin to ground |
| 10 | Boot | BOOT | If pushed, connects PWRKEY pin to ground and turns on/off MC60 Development Board |
| 11 | UART Switch | UART Arduino/USB | If the switch is on the Arduino UART side, communication between Arduino and MC60 Development Board is established; if on the USB UART side, communication between USB and MC60 Development Board is established |
The MC60 Development Board has 3 functional indication LEDs, as follows:
- D4: LED Connect 1PPS
- D3: LED Connect NETLIGHT
- D2: Power indication LED


MC60 Development Board Dimensions #

The main pin placement of the MC60 Development Board is shown in the following figure:


MC60 Development Board Interfaces #
Power Header #
| NO. | Name | Silkscreen | Comment |
|---|---|---|---|
| 8-Pin | NC | NC | – |
| 8-Pin | IOREF | IOREF | This provides a logic reference voltage for shields that use it; it is connected to the 5 V bus. |
| 8-Pin | RST | RST | Reset Arduino. |
| 8-Pin | 3v3 | 3v3 | 3.3 V Arduino regulator; don’t connect to power the module. |
| 8-Pin | 5v | 5v | 5 V Arduino regulator; do not power the module from the Arduino, but the module can power the Arduino. |
| 8-Pin | GND | GND | Ground. |
| 8-Pin | GND | GND | Ground. |
| 8-Pin | Vin | Vin | This pin is used to power the Arduino Uno using an external power source. The voltage should be within the supported range. |
ADC Header #
| NO. | Name | Silkscreen | Comment |
|---|---|---|---|
| 6-Pin | ADC0 | A0 | Analog input (ADC). |
| 6-Pin | ADC1 | A1 | The Arduino Uno has 6 analog pins which utilize ADC (Analog-to-Digital Converter). |
| 6-Pin | ADC2 | A2 | These pins serve as analog inputs and can also function as digital inputs or outputs. |
| 6-Pin | ADC3 | A3 | These pins serve as analog inputs and can also function as digital inputs or outputs. |
| 6-Pin | ADC4 | A4 | These pins serve as analog inputs and can also function as digital inputs or outputs. |
| 6-Pin | ADC5 | A5 | These pins serve as analog inputs and can also function as digital inputs or outputs. |
Analog to Digital Conversion #
ADC stands for Analog to Digital Converter. ADC is an electronic circuit used to convert analog signals into digital signals. This digital representation of analog signals allows the processor (which is a digital device) to measure the analog signal and use it through its operation.
Arduino Pins A0-A5 are capable of reading analog voltages. On Arduino the ADC has 10-bit resolution, meaning it can represent analog voltage by 1,024 digital levels. The ADC converts voltage into bits which the microprocessor can understand.
One common example of an ADC is Voice over IP (VoIP). Every smartphone has a microphone that converts sound waves (voice) into analog voltage. This goes through the device’s ADC, gets converted into digital data, which is transmitted to the receiving side over the internet.
Digital Header #
| NO. | Name | Silkscreen | Comment |
|---|---|---|---|
| 18-Pin | PD0/TX | 0 | Serial |
| 18-Pin | PD1/RX | 1 | Communication |
| 18-Pin | PD2 | 2 | — |
| 18-Pin | PD3/PWM | 3 | — |
| 18-Pin | PD4 | 4 | — |
| 18-Pin | PD5/PWM | 5 | — |
| 18-Pin | PD6/PWM | 6 | — |
| 18-Pin | PD7 | 7 | — |
| 18-Pin | PB0 | 8 | — |
| 18-Pin | PB1/PWM | 9 | — |
| 18-Pin | PB2/PWM/SS | 10 | — |
| 18-Pin | PB3/PWM/MOSI | 11 | SPI |
| 18-Pin | PB4/MISO | 12 | Communication |
| 18-Pin | PB5/SCK | 13 | — |
| 18-Pin | Ground | GND | — |
| 18-Pin | AREF | AREF | — |
| 18-Pin | PC4/SDA | SDA | I2C |
| 18-Pin | PC5/SCL | SCL | Communication |
MC60 Header 2*9 #
| NO. | Name | Silkscreen | Comment |
|---|---|---|---|
| 2*9-Pin | Sim2-DATA | SDATA | You can use it as an output and input. |
| 2*9-Pin | Sim-CLK | SCLK | Digital output |
| 2*9-Pin | Sim2-VDD | SVDD | Power output |
| 2*9-Pin | Sim2-RST | SRST | Digital output |
| 2*9-Pin | Clear to send | CTS | Digital output |
| 2*9-Pin | Analog input | ADC | Analog input |
| 2*9-Pin | GNSS-RX | GNRX | Connect GNSS-RX to AUX-TX by jumpers. |
| 2*9-Pin | GNSS-TX | GNTX | Connect GNSS-TX to AUX-RX by jumpers. |
| 2*9-Pin | AUX-TX | AUTX | For internal communication. |
| 2*9-Pin | AUX-RX | AURX | For internal communication between the GPS module and itself. |
| 2*9-Pin | Data carrier detection | DCD | You can use it as an output and input. |
| 2*9-Pin | Data terminal ready | DTR | Digital output |
| 2*9-Pin | DBG-RX | DBRX | You can use it as an output and input. |
| 2*9-Pin | Ring indication | RI | Digital output |
| 2*9-Pin | DBG-TX | DBTX | You can use it as an output and input. |
| 2*9-Pin | VBUS | VBUS | This pin is powered by USB. |
| 2*9-Pin | Ground | GND | – |
| 2*9-Pin | Ground | GND | – |
Getting Started Preparation #

Suppose you want to make a call, send an SMS, or even get the location of a device in your project. There are many solutions available, and the Quectel modules are one of the good choices as a powerful platform for wireless communications. In this tutorial, we will show you how to connect the MC60 hat to an Arduino using the TinyGSM library and use it to send SMS messages and make voice calls.
Okay, before we dive into the coding part, let’s get the required components and libraries ready:
- MC60 hat: This hat is fully compatible with Arduino and is pin-to-pin. No additional wiring is needed.
- SoftwareSerial Library: This library is used for the software serial communication between the Arduino and the MC60 hat.
- Jumpers: You will need jumpers to place the MC60 hat on the Arduino and to set the UART mode to software mode.
Preparation Steps #
- Place the MC60 hat on the Arduino.
- Set the UART switch to the software mode.
- Configure the jumpers to the software mode.
Now that everything is ready, we can start coding and use the MC60 hat to send SMS messages and make voice calls.

Download the Library: Download the TinyGSM library from the provided EICUT GitHub link:

In next step downloading the library, we need to add it to the compiler.
(Like the image below).

Once the library has been added, go to File -> Examples > TinyGSM > smsandvoicecall to select that example.

After opening the example, we need to make a few changes to the code:
- In the first line, replace it with the following code:
#define TINY_GSM_MODEM_MC60
- In line 12, enter the number that you want the module to call.
- In line 15, change:
SoftwareSerial SerialAT(2, 3); // RX, TX
to set the baud rate to 115200, since the default baud rate of the module is 115200
After opening the example, we need to make a few changes to the code:
- In the first line, replace it with the following code:
#define TINY_GSM_MODEM_MC60
- In line 12, enter the number that you want the module to call.
- In line 15, change:
SoftwareSerial SerialAT(2, 3); // RX, TX
to set the baud rate to 115200, since the default baud rate of the module is 115200

You need to search for and download the required libraries from this section. After downloading, a message indicating successful download and installation will be displayed in the output.

If you have followed the above steps correctly, the code will compile and be ready to upload to the Arduino. According to the image below, enter the model and COM port to which the Arduino is connected, and click on the option marked with 3 in the image to start uploading the code.

Upon completion of the compilation, place a nano SIM card into the MC60 hat (the operator does not matter) and connect the antenna to the UFL connector on the board.
The power supply for the MC60 hat is 5V, which you can connect from the header pins or via the USB Type-C port.
A very important note is that your power supply must be able to provide a peak current of 1.5 amps for the MC60 hat; otherwise, the module will reset.
Following the completion of the above steps, open the Arduino Serial Monitor and set the baud rate to 115200. The Arduino and the MC60 hat will start communicating with each other via UART, and their messages will be visible on the Arduino’s serial port.”



Tutorial Code #
// This line of code specifies that the MC60 modem is being used, which uses AT commands similar to the M66
#define TINY_GSM_MODEM_MC60
// These two lines of code include the necessary libraries for working with the MC60 modem and using SoftwareSerial
#include <TinyGsmClient.h>
#include <SoftwareSerial.h>
// These three lines of code define the GPRS network access details. In this example, they are not needed as we are only sending SMS and making calls
const char apn[] = "your_apn"; // Not needed for SMS/Call, only for GPRS
const char user[] = "";
const char pass[] = "";
// This line of code defines the destination phone number
const char phoneNumber[] = "+1234567890";
// This line of code defines the SoftwareSerial pins for communication with the modem
SoftwareSerial SerialAT(2, 3); // RX, TX
// This line of code creates an object of the TinyGsm class to work with the MC60 modem
TinyGsm modem(SerialAT);
void setup() {
// This section of code initializes the modem. It first sets up the debug serial, then establishes communication with the modem. After that, it restarts the modem and waits for a network connection
Serial.begin(115200);
delay(10);
SerialAT.begin(115200);
delay(3000);
Serial.println("Initializing modem...");
modem.restart(); // or modem.init();
// This line of code allows unlocking the SIM card with a PIN
// modem.simUnlock("1234");
// This section of code waits for a network connection
Serial.print("Waiting for network...");
if (!modem.waitForNetwork()) {
Serial.println(" failed");
while (true);
}
Serial.println(" connected");
// This section of code sends an SMS with the message "Hello from MC60!" to the specified phone number
Serial.println("Sending SMS...");
if (modem.sendSMS(phoneNumber, "Hello from MC60!")) {
Serial.println("SMS sent successfully!");
} else {
Serial.println("SMS failed to send.");
}
// This line of code creates a 5-second delay before making a phone call
delay(5000);
// This section of code makes a call to the same phone number and hangs up after 20 seconds
Serial.print("Calling ");
Serial.println(phoneNumber);
modem.callNumber(phoneNumber);
delay(20000);
modem.callHangup();
Serial.println("Call ended.");
}
// This function has no code written in it, as all operations are performed in the `setup()` function
void loop() {
}

