Модуль SIM7600 не подключается к сети после повторного подключения питания

У меня есть LilyGO SIM7600, с первого раза работает нормально, но перестает подключаться к сети при повторном подключении питания. Я использую 5В с 2А.

  1. Подключите источник питания: Плата включается и подключается к сети. Все в порядке.
  2. Отключите питание: плата выключится.
  3. Вновь подключите источник питания. Плата включается, но 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