Ethernet Shield останавливается через некоторое время - PullRequest
0 голосов
/ 16 января 2019

Я использую Ethernet щит (W5100) и RC522 на моем Arduino Uno. Работает 1 или 2 часа (иногда 15 минут, иногда 2 дня). По истечении этого случайного времени перестает работать. Я имею в виду, что модуль RC-522 не читает карты, а Ethernet-щит не может подключиться к серверу. Когда я отключаю питание (от 1,5 до 12 В) и снова подключаю, оно начинает работать успешно.

Мне нужно, чтобы эта система работала вечно ... Эта система читает карту mifare и отправляет ее на сервер, после чего она проверяет ответ, и если ответ равен "1", она запускает ретрансляцию. (реле 5V простое реле)

Некоторые люди говорили «Измените свой адаптер», и я изменил его, ничего не изменилось. Некоторые люди говорят, что «используйте конденсатор 10 микрофарад между первым и последним контактом», и ничего не изменилось. и некоторые люди говорили: «Это Arduino чувак, это просто для того, чтобы бросить учебу и использовать stm32», и я пока не применял это предложение. Я хочу знать, почему это происходит.

#include <SPI.h>
#include <Ethernet.h>
#include <MFRC522.h>

//Mac address of ethernet shield
byte mac[] = { 0xDE, 0xAD, 0xBE, 0xEF, 0xFE, 0xEA }; 

//My Network info, i use static ip
byte ip[] = { 172, 16, 64, 78 }; 
byte gateway[] = { 172, 16, 64, 1 }; 
byte myserver[] = { 172, 16, 64, 46 }; 
byte subnet[] = { 255, 255, 255, 0 }; 

String CardInfo = "";
EthernetClient client;
String GateNo = "0";
String DeviceNo = "100";

String Answer = "";


MFRC522 mfrc522;
byte Key[] = { 0xff,0xff,0xff,0xff,0xff,0xff };
MFRC522::MIFARE_Key key;


void setup(){
  //Disabling SD Card
  pinMode(4,OUTPUT);
  digitalWrite(4,HIGH);

  Ethernet.begin(mac, ip, subnet, gateway);

  KeyCreate();

  mfrc522.PCD_Init(2, 8); 
  mfrc522.PCD_DumpVersionToSerial();

}



void sendGET()
{
  //I used this line to guarantee the disconnect from server
  client.stop();
  Answer = "";
  if (client.connect(myserver, 81)) {  
    client.println("GET /AccessCheck/CardNo=" + CardInfo + "&GateNo=" + GateNo + "&DeviceNo=" + DeviceNo + " HTTP/1.0");
    client.println("Authorization: Basic xxxxxxxxxxxx");
    client.println(); 
  } 
  else {
    //Ethernet.begin(mac, ip, subnet, gateway);
    return;
  }

  int connectLoop = 0;
  while(client.connected())
  {
    while(client.available())
    {
      char c = client.read();
      Answer = Answer + c;
      connectLoop = 0;
    }

    delay(1);
    connectLoop++;
    if(connectLoop > 5000)
    {
      client.stop();
      return;
    }
  }
  client.stop();
}

//This function disables eth and enable rc522 (and reverse)
void Switch(int i)
{
  switch (i)
  {
    case 0:
      digitalWrite(10, HIGH);
      digitalWrite(2, LOW);
      break;
    case 1:
      digitalWrite(2, HIGH);
      digitalWrite(10, LOW);
      break;
  }
}

void AccessControl()
{
  int AnswerLength = Answer.length();

  pinMode(5, OUTPUT);
  digitalWrite(5, HIGH);

  if(Answer[AnswerLength-1] == 49)
  {
    digitalWrite(5, LOW);
    delay(100);
    digitalWrite(5, HIGH);
  }
  pinMode(5, INPUT);
  pinMode(6, INPUT);
  delay(1000);
}

void ReadCard()
{
  byte len = 18;
  MFRC522::StatusCode status;

  byte MyBuffer[18];
  status = mfrc522.PCD_Authenticate(MFRC522::PICC_CMD_MF_AUTH_KEY_A, 10, &key, &(mfrc522.uid));
  status = mfrc522.MIFARE_Read(10, MyBuffer, &len);
  int counter = 0;
  //This line is check for turkish character
  if(MyBuffer[0] == 221)
  {
    CardInfo = "X";
    for (int i = 1; i < 16; i++)
    {
      if (MyBuffer[i] != 32)
      {
        CardInfo = CardInfo + (char)MyBuffer[i];
      }
    }
  }
  else
  {
    CardInfo = "";
    for (int i = 0; i < 16; i++)
    {
      if (MyBuffer[i] != 32)
      {
        CardInfo = CardInfo + (char)MyBuffer[i];
      }
    }
  }

  mfrc522.PICC_HaltA();
  mfrc522.PCD_StopCrypto1();
  return;
}

void KeyCreate()
{
  for (int i = 0; i < 6; i++)
  {
    key.keyByte[i] = Key[i];
  }
}

void loop(){
  Switch(0);
  if (mfrc522.PICC_IsNewCardPresent() && mfrc522.PICC_ReadCardSerial()) {
        ReadCard(); 
        Switch(1);
        sendGET();
        AccessControl();
  }
} 

Я ожидаю, что он работает без замораживания

Фактический результат - экран Ethernet через некоторое время зависает

1 Ответ

0 голосов
/ 16 января 2019

Я использую сторожевой таймер в каком-то скрипте. Эта функция может автоматически сбросить ваш Arduino, если вы не сбросили сторожевой таймер во время перерыва.

вы выполняете wdt_enable () в setup () и wd_reset () в начале цикла

time before watchdog firing    argument of wdt_enable()
-------------------------------------------------------
15mS                           WDTO_15MS
30mS                           WDTO_30MS
60mS                           WDTO_60MS
120mS                          WDTO_120MS
250mS                          WDTO_250MS
500mS                          WDTO_500MS
1S                             WDTO_1S            
2S                             WDTO_2S
4S                             WDTO_4S
8S                             WDTO_8S

пример использования:

#include <avr/wdt.h>

void setup()
{
  wdt_enable(WDTO_4S);       // enable the watchdog
                             // will fire after 4s without reset
}

void loop(){
 wdt_reset();              // resets the watchdog timer count
     :
     :
                     // if program hangs more than 4s, launch the reset of arduino
}
...