具有两个不同函数Arduino值的全局变量

时间:2017-04-01 23:27:47

标签: c function arduino global-variables hardware

我正在使用名为IDCartao的全局String变量来保存rfid卡中的id。在我使用enc28j60在服务器上搜索id之后,如果id在服务器上,我发出一声嘟嘟声,如果没有,我发出两声哔哔声。

但是,我在函数循环中遇到全局String IDCartao问题它有正确的ID值,但是当我在另一个名为my_callback的函数中搜索这个值时,我没有正确的值,我只是有空字符串“”。

/**
 * Pinagem Leitor RFID:
 * CLK     - Pino 13
 * MISO    - Pino 12
 * MOSI    - Pino 11
 * SDA     - Pino 10
 * RST     - Pino 09
 * GND     - GND Arduino
 * 3.3     - 3.3v do Arduino
 * NC      - Não Conectado
 */

/**
 * Pinagem Módulo Ethernet:
 * 5v     - Não Conectado
 * LNT    - Não Conectado
 * CLK    - Não Conectado
 * SO     - Pino 12
 * WOL    - Não Conectado
 * SCK    - Pino 13
 * ST     - Pino 11
 * RST    - Não Conectado
 * CS     - Pino 8
 * Q3     - 3.3v do Arduino
 * GND    - GND Arduino
 */

/**
 * Pinagem de Outros componentes:
 * BUZZER  - Pino 7
 */

//DECLARAÇÃO DAS BIBLIOTECAS UTILIZADAS NO PROJETO
#include <SPI.h> //Biblioteca que permite a comunicação com dispositivos SPI (Serial Peripheral Interface), sendo o Arduino como dispositivo principal
#include <MFRC522.h> //Biblioteca do Leitor RFID
#include <EtherCard.h> //Biblioteca do Módulo Ethernet


//DECLARAÇÃO DOS PINOS UTILIZADOS NO ARDUINO
#define PINO_SDA 10 //Constante que define onde o pino SDA do leitor RFID está ligado
#define PINO_RST 9 
#define BUZZER 7

MFRC522 mfrc522 (PINO_SDA, PINO_RST); //Cria instância MFRC522
static byte mymac[] = { 0x74,0x69,0x69,0x2D,0x30,0x31 }; //mac do módulo ethernet
byte Ethernet::buffer[500];
static uint32_t timer;
const char website[] PROGMEM = "192.168.0.103"; //endereço IP do servidor no Raspberry Pi
String conteudo;        //Armazena nessa variável todas as informações contidas no servidor
unsigned int tamanho;   //variável para guardar o tamanho do retorno do servidor
static char *IDCartao;

//ESCOPO DAS FUNÇÕES
void lerID ();
void my_callback (byte status, word off, word len);
void acessoLiberado();
void acessoNegado();
void testaValor();

void setup() {
  Serial.begin(9600);
  Serial.println ("Iniciando setup");


  SPI.begin();
  pinMode (BUZZER, OUTPUT);
  mfrc522.PCD_Init(); //Inicia MFRC522 (Leitor RFID)
  delay(100);
  if (ether.begin(sizeof Ethernet::buffer, mymac, 8) == 0) {
    Serial.println("Falha ao acessar o Modulo Ethernet");
  }
  else {
    Serial.println("Modulo Ethernet conectado!");
  }
  if (!ether.dhcpSetup()) {
    Serial.println("DHCP failed");
  }
  ether.printIp("IP:  ", ether.myip);
  ether.printIp("GW:  ", ether.gwip);  
  ether.printIp("DNS: ", ether.dnsip);

  if (!ether.dnsLookup(website)) {
    Serial.println("DNS failed");
  }
  ether.printIp("SRV: ", ether.hisip);
  delay(100);
  IDCartao = (char*) calloc (12, sizeof(char));
  Serial.println("Setup finalizado!");
  Serial.println ("Aproxima");
  *IDCartao = "WAGNER";
}

void loop() {
  ether.packetLoop(ether.packetReceive());
  //String card = lerID();
  //card.toCharArray(IDCartao, card.length()+1);
  //*IDCartao = lerID();
  lerID();
  if (IDCartao[0] != '\0') { //Se um cartão tiver sido aproximado e sua ID lida com sucesso
    //Serial.print ("ID DO CARTAO: ");
    //Serial.write (IDCartao);
    delay(100);
    if (millis() > timer) {
      Serial.println("VAI LER SITE");
      timer = millis() + 5000;
      Serial.println();
      testaValor();
      ether.browseUrl(PSTR("/"), "", website, my_callback);
    }
    delay(5000);
    testaValor3();
    Serial.println("CONTEUDO:");
    Serial.print(conteudo);
  }

}

void testaValor() {
  Serial.println ("DENTRO DO TESTA VALOR");
  Serial.write(IDCartao);
  Serial.println ("\nSUCESSO");
}
void testaValor2() {
  Serial.println ("DENTRO DO TESTA VALOR 2");
  Serial.write(IDCartao);
  Serial.println ("\nSUCESSO");
}
void testaValor3() {
  Serial.println ("DENTRO DO TESTA VALOR 3");
  Serial.write(IDCartao);
  Serial.println ("\nSUCESSO");
}

void lerID () {
     if (mfrc522.PICC_IsNewCardPresent ()) {
       if (mfrc522.PICC_ReadCardSerial ()) {
         String conteudorfid = "";
         byte letra;
         for (byte i = 0; i < mfrc522.uid.size; i++) {
           conteudorfid.concat (String (mfrc522.uid.uidByte[i] < 0x10 ? " 0" : " "));
           conteudorfid.concat (String (mfrc522.uid.uidByte[i], HEX));
         }
         conteudorfid.toUpperCase ();
         int i;
         for (i = 0; i < conteudorfid.substring(1).length(); i++) {
          IDCartao[i] = conteudorfid.substring(1)[i];
         }
         i++;
         IDCartao[i] = '\0';
       }

     //Serial.println(IDCartao); //ID do cartão lida com sucesso
     }
     else {
      IDCartao[0] = '\0';
     }
}

/**
 * Função que faz a leitura do servidor armazenando seu conteudo numa String
 */
void my_callback (byte status, word off, word len) {
  testaValor2();  
  Ethernet::buffer[off+500] = 0;

  conteudo = (const char*) Ethernet::buffer + off;

  String verifica(IDCartao);

  if (conteudo.indexOf(verifica) > 0) { //procura pela ID do cartão no servidor
    Serial.println("Acesso liberado");
    Serial.println(verifica);
    Serial.print ("POSICAO: ");
    Serial.println (conteudo.indexOf(verifica));
    acessoLiberado();
  }
  else {
    Serial.println ("ACESSO NEGADO!");
    Serial.print ("CARTAO VERIFICA: ");
    Serial.println (verifica);
    Serial.print ("IDCartao: ");
    Serial.write (IDCartao);
    acessoNegado();  
  }
}

void acessoLiberado() {
  tone(BUZZER, 1000); //1kHz
  //digitalWrite (LED_VERDE, HIGH);
  delay (300);
  noTone (BUZZER);
  //digitalWrite (LED_VERDE, LOW);
  *IDCartao = "";
}

void acessoNegado() {
  tone (BUZZER, 1000);
  //digitalWrite (LED_VERMELHO, HIGH);
  delay (150);
  noTone (BUZZER);
  delay (150);
  tone (BUZZER, 1000);
  delay (150);
  noTone (BUZZER);
  //digitalWrite (LED_VERMELHO, LOW);
  *IDCartao = "";
}

This is what happens. Look at the function testaValor2(), is the second function wich is called but she is called after testaValor3(). I don't know why this is happening. Sorry for the bad quality

1 个答案:

答案 0 :(得分:0)

当多个函数正在编辑全局变量时,您需要使它们变得不稳定。例如,像这样实例化IDCartao

volatile String IDCartao;

这会强制Arduino在每次请求时从内存中获取IDCartao的最新值。

此处有更多信息:https://www.arduino.cc/en/reference/volatile