Модуль SIM7600 не подключается к сети после повторного подключения питания
У меня есть LilyGO SIM7600, с первого раза работает нормально, но перестает подключаться к сети при повторном подключении питания. Я использую 5В с 2А.
- Подключите источник питания: Плата включается и подключается к сети. Все в порядке.
- Отключите питание: плата выключится.
- Вновь подключите источник питания. Плата включается, но SIM-карта не подключается к сети.
Команды AT сообщают мне, что SIM-карта находится в "состоянии занятости".
AT+CMGS
+CME ERROR: SIM busy
AT+CGREG?
+CGREG: 0,0
Даже если я перезапущу модем, он все равно останется в этом состоянии. Похоже, что SIM-карта зависла в предыдущем состоянии соединения.
Чтобы SIM-карта снова могла подключаться к сети, я вставляю SIM-карту в сотовый телефон, ВЫКЛЮЧАЮ сотовый телефон и вынимаю SIM-карту, и все снова работает.
Это происходит с любым кодом, даже с самым простым. Я использую диагностический код от TinyGSM.
#define TINY_GSM_MODEM_SIM7600
// Установить серийный номер для консоли отладки (в Serial Monitor, скорость по умолчанию 115200)
#define SerialMon Serial
// Установить серийный номер для AT-команд (к модулю)
// Использовать аппаратный серийный номер на Mega, Leonardo, Micro
#ifndef __AVR_ATmega328P__
#define SerialAT Serial1
// или Software Serial на Uno, Nano
#else
#include <SoftwareSerial.h>
SoftwareSerial SerialAT(2, 3); // прием, передача
#endif
// Увеличиваем буфер RX, чтобы захватить весь ответ
// Чипы без внутренней буферизации (A6/A7, ESP8266, M590)
// нужно достаточно места в буфере для всего ответа
// иначе данные будут потеряны (и библиотека http выйдет из строя).
#ifndef TINY_GSM_RX_BUFFER
#define TINY_GSM_RX_BUFFER 1024
#endif
// Посмотреть все AT-команды, если нужно
// # определить DUMP_AT_COMMANDS
// При необходимости определяем последовательную консоль для отладочной печати
#define TINY_GSM_DEBUG SerialMon
// Диапазон для попытки автоматической передачи данных
// ПРИМЕЧАНИЕ: НЕ ИСПОЛЬЗУЙТЕ АВТОМАТИЧЕСКУЮ БОДИНКУ в производственном коде. Как только вы установили
// связь, установите фиксированную скорость передачи с помощью modem.setBaud(#).
#define GSM_AUTOBAUD_MIN 9600
#define GSM_AUTOBAUD_MAX 115200
// Добавляем задержку приема - может понадобиться для быстрого процессора при медленном боде
// скорость #define TINY_GSM_YIELD() { delay(2); }
// Раскомментируйте это, если хотите использовать SSL
// #определить USE_SSL
#define TINY_GSM_USE_GPRS true
#define TINY_GSM_USE_WIFI false
// установить PIN-код GSM, если есть
#define GSM_PIN ""
// Ваши учетные данные GPRS, если есть
const char apn[] = "wap.tmovil.cl";
const char gprsUser[] = "wap";
const char gprsPass[] = "wap";
// Ваши учетные данные для подключения к WiFi, если применимо
const char wifiSSID[] = "YourSSID";
const char wifiPass[] = "YourWiFiPass";
// Детали сервера
const char server[] = "vsh.pp.ua";
const char resource[] = "/TinyGSM/logo.txt";
#include <TinyGsmClient.h>
// На всякий случай, если кто-то определил не то..
#if TINY_GSM_USE_GPRS && not defined TINY_GSM_MODEM_HAS_GPRS
#undef TINY_GSM_USE_GPRS
#undef TINY_GSM_USE_WIFI
#define TINY_GSM_USE_GPRS false
#define TINY_GSM_USE_WIFI true
#endif
#if TINY_GSM_USE_WIFI && not defined TINY_GSM_MODEM_HAS_WIFI
#undef TINY_GSM_USE_GPRS
#undef TINY_GSM_USE_WIFI
#define TINY_GSM_USE_GPRS true
#define TINY_GSM_USE_WIFI false
#endif
#ifdef DUMP_AT_COMMANDS
#include <StreamDebugger.h>
StreamDebugger debugger(SerialAT, SerialMon);
TinyGsm modem(debugger);
#else
TinyGsm modem(SerialAT);
#endif
#ifdef USE_SSL&& defined TINY_GSM_MODEM_HAS_SSL
TinyGsmClientSecure client(modem);
const int port = 443;
#else
TinyGsmClient client(modem);
const int port = 80;
#endif
void setup() {
// Установить скорость передачи данных консоли
SerialMon.begin(115200);
delay(10);
// Включаем SIM7600
pinMode(4, OUTPUT);
digitalWrite(4, LOW);
delay(100);
digitalWrite(4, HIGH);
delay(100);
SerialAT.begin(115200, SERIAL_8N1, 26, 27);
delay(6000);
}
void loop() {
// Перезапуск занимает довольно много времени
// Чтобы пропустить его, вызовите init() вместо restart()
SerialMon.print("Initializing modem...");
//если (!modem.restart()) {
if (!modem.init()) {
SerialMon.println(F(" [fail]"));
SerialMon.println(F("************************"));
SerialMon.println(F(" Is your modem connected properly?"));
SerialMon.println(F(" Is your serial speed (baud rate) correct?"));
SerialMon.println(F(" Is your modem powered on?"));
SerialMon.println(F(" Do you use a good, stable power source?"));
SerialMon.println(F(" Try using File -> Examples -> TinyGSM -> tools -> AT_Debug to find correct configuration"));
SerialMon.println(F("************************"));
delay(10000);
return;
}
SerialMon.println(F(" [OK]"));
String modemInfo = modem.getModemInfo();
SerialMon.print("Modem Info: ");
SerialMon.println(modemInfo);
#if TINY_GSM_USE_GPRS
// Разблокируйте SIM-карту с помощью PIN-кода, если это необходимо
if (GSM_PIN && modem.getSimStatus() != 3) { modem.simUnlock(GSM_PIN); }
#endif
#if TINY_GSM_USE_WIFI
// параметры соединения Wi-Fi должны быть установлены перед ожиданием сети
SerialMon.print(F("Setting SSID/password..."));
if (!modem.networkConnect(wifiSSID, wifiPass)) {
SerialMon.println(" fail");
delay(10000);
return;
}
SerialMon.println(" success");
#endif
#if TINY_GSM_USE_GPRS && defined TINY_GSM_MODEM_XBEE
// XBee должен запустить функцию gprsConnect ПЕРЕД ожиданием сети!
modem.gprsConnect(apn, gprsUser, gprsPass);
#endif
SerialMon.print("Waiting for network...");
if (!modem.waitForNetwork(
600000L)) { // Вам может понадобиться увеличить это значение в районах с плохим обслуживанием
SerialMon.println(F(" [fail]"));
SerialMon.println(F("************************"));
SerialMon.println(F(" Is your sim card locked?"));
SerialMon.println(F(" Do you have a good signal?"));
SerialMon.println(F(" Is antenna attached?"));
SerialMon.println(F(" Does the SIM card work with your phone?"));
SerialMon.println(F("************************"));
delay(10000);
return;
}
SerialMon.println(F(" [OK]"));
#if TINY_GSM_USE_GPRS
// Параметры GPRS-соединения обычно задаются после регистрации в сети
SerialMon.print("Connecting to ");
SerialMon.print(apn);
if (!modem.gprsConnect(apn, gprsUser, gprsPass)) {
SerialMon.println(F(" [fail]"));
SerialMon.println(F("************************"));
SerialMon.println(F(" Is GPRS enabled by network provider?"));
SerialMon.println(F(" Try checking your card balance."));
SerialMon.println(F("************************"));
delay(10000);
return;
}
SerialMon.println(F(" [OK]"));
#endif
IPAddress local = modem.localIP();
SerialMon.print("Local IP: ");
SerialMon.println(local);
SerialMon.print(F("Connecting to "));
SerialMon.print(server);
if (!client.connect(server, port)) {
SerialMon.println(F(" [fail]"));
delay(10000);
return;
}
SerialMon.println(F(" [OK]"));
// Делаем запрос HTTP GET:
client.print(String("GET ") + resource + " HTTP/1.0\r\n");
client.print(String("Host: ") + server + "\r\n");
client.print("Connection: close\r\n\r\n");
// ждем поступления данных
while (client.connected() && !client.available()) {
delay(100);
SerialMon.print('.');
};
SerialMon.println();
// Пропустить все заголовки
client.find("\r\n\r\n");
// Чтение данных
uint32_t timeout = millis();
uint32_t bytesReceived = 0;
while (client.connected() && millis() - timeout < 10000L) {
while (client.available()) {
char c = client.read();
// SerialMon.print(c);
bytesReceived += 1;
timeout = millis();
}
}
client.stop();
SerialMon.println(F("Server disconnected"));
#if TINY_GSM_USE_WIFI
modem.networkDisconnect();
SerialMon.println(F("WiFi disconnected"));
#endif
#if TINY_GSM_USE_GPRS
modem.gprsDisconnect();
SerialMon.println(F("GPRS disconnected"));
#endif
SerialMon.println();
SerialMon.println(F("************************"));
SerialMon.print(F(" Received: "));
SerialMon.print(bytesReceived);
SerialMon.println(F(" bytes"));
SerialMon.print(F(" Test: "));
SerialMon.println((bytesReceived == 121) ? "PASSED" : "FAILED");
SerialMon.println(F("************************"));
// ничего не делать навсегда
while (true) { delay(1000); }
}
Спасибо.
0
Смотрите также:
- СВЕТОДИОД SIM800L не мигает
- ArduinoHTTPClient POST multipart/form-data с SD-карты, возвращающий 400 неверных запросов
- Как перехватывать ответы GSM SIM800L всякий раз, когда отправляется AT-команда?
- esp32, platformio A fatal error occurred: Packet content transfer stopped (received 8 bytes) *** [upload] Error 2
- Как выбрать альтернативные контакты I2C на ESP32?
- Драйверы для чипа последовательного порта CH9102X
- Проблема с получением SMS - GSM-модуль Arduino Uno и SIM900A
- SIM900 3G? Или SIM900A умеет подключаться к 3G?