Go Down

Topic: Arduino 2560 problema comunicazione (Read 620 times) previous topic - next topic

Ciao,

Ho un'arduino 2560 e ho qualche problema di "timeout()"
Ho provato a modificare il file boards.txt con varie ed evantuali dal forum ma nulla di che sempre lo stesso problema,
inizialmente lo sketch si carica fino al 99,9% poi si pianta per delle ore.
Dopo un bel po esce la simpatica scritta timeout()....

nello specifico:

avrdude: Recv:
avrdude: stk500v2_ReceiveMessage(): timeout
avrdude: Send: . [1b] . [2e] . [00] . [01] . [0e] . [01] ; [3b]


Ho notato una cosa però... Se carico sketch senza la libreria lcd tutto funziona alla perfezione, viceversa si pianta tutto...
Che fare? Devo modificare la libreria?
(Ps con il 2009 funziona tutto bene...)
(PPS Ho vindows 7 64bit)

Ciao grazie...

Michele Menniti

Probabilmente la libreria ha qualche incompatibilità con il core della 2560. Prova con la "vecchia" IDE0022 o 0023, oppure cerca una versione aggiornata della libreria, niente di più facile che esista....
Guida alla programmazione ISP e seriale dei micro ATMEL (Caricare bootloader e sketch):
http://www.michelemenniti.it/Arduino_burn_bootloader.php
Guida alla Programmazione ATmega328 noP:
http://www.michelemenniti.it/atmega328nop.html
Articoli su Elettronica In:
http://www.michelemenniti.it/elettronica_in.html

Resoconto finale:

Ho provato con dei vecchi IDE (stesso problema)
Ho provato ad installarlo su Linux (Più veloce ma alla fine stesso problema)
Ho provato a cercare una libreria aggiornata dell LCD (non ho trovato niente)

Quindi che fare ora?
Dite che è un problema del firmare del 8u2?
Come lo aggiorno eventualmente? Devo fare dei contatti volanti?

Ciao a tutti

astrobeed

Dato che il problema si presenta solo in fase di caricamento dello sketch sulla MEGA2560 non è una problema di libreria o di versione IDE dato che la fase di compilazione è già stata eseguita con successo, semmai potrebbe essere un problema di lunghezza dello sketch, sopratutto se va oltre le 64kWord.
Posta l'intero sketch, e le eventuali libreria di terze parti, in modo che posso provare sulla mia MEGA2560 altrimenti non ne verremo mai a capo andando a tastoni.

Ecco qui, (Grazie mille!!!)

Code: [Select]

#include <Timer.h>
#include <Keypad.h>
#include <LiquidCrystal.h>
#include <Tone.h>
#define pound = 14
byte block[8] =

{B11111,
  B11111,
  B11111,
  B11111,
  B11111,
  B11111,
  B11111,
  B11111};


Tone tone1;
int Scount = 0; // count seconds
int Mcount = 0; // count minutes
int Hcount = 0; // count hours
int Dcount = 0; // count days
int val = 0;
long secMillis = 0; // store last time for second
long interval = 1000; // interval for seconds
char password[4];
int currentLength = 0;
int i = 0;
char entered[4];

LiquidCrystal lcd(12, 13, 11, 10, 9, 8);
const byte ROWS = 4; //four rows
const byte COLS = 4; //three columns
char keys[ROWS][COLS] =
 
 
  {
  {'1','2','3','A'},
  {'4','5','6','B'},
  {'7','8','9','C'},
  {'*','0','#','D'}
  };
 
 
byte rowPins[ROWS] = {
  3, 2, 1, 0}; //connect to the row pinouts of the keypad
byte colPins[COLS] = {
  7, 6, 5, 4}; //connect to the column pinouts of the keypad

Keypad keypad = Keypad( makeKeymap(keys), rowPins, colPins, ROWS, COLS );
void setup()
{
   
  lcd.createChar(7,block);
  tone1.begin(A0);
  lcd.begin(20, 4);
  Serial.begin(9600);
  lcd.clear();
  lcd.setCursor(1,0);
  lcd.print("Enter disarm code: ");
  while (currentLength < 4)
  {
  lcd.setCursor(currentLength + 6, 1);
  lcd.cursor();
  char key = keypad.getKey();
  key == NO_KEY;
  if (key != NO_KEY)
 
{lcd.print(key);
  password[currentLength] = key;
  currentLength++;
  delay(200);}
  } 
 
  if (currentLength == 4)
    {
    lcd.noCursor();
    lcd.clear();
    lcd.home();
    lcd.setCursor(0,1);
    lcd.print("<<<<<BOMB ARMED>>>>> ");
    lcd.setCursor(6,2);
    lcd.print(password[0]);
    lcd.print(password[1]);
    lcd.print(password[2]);
    lcd.print(password[3]);
    delay(3000);
    lcd.clear();
    currentLength = 0;}
}


void loop()
{
  lcd.clear();
  lcd.setCursor(0,0);
  lcd.print("Mixing chemical");
  lcd.setCursor(0,1);
  lcd.print("solution");
  //for (int positionCounter = 0; positionCounter < 24; positionCounter++) {
  // scroll one position left:
  //lcd.scrollDisplayLeft();
  delay(300);
  //}
  lcd.home();
  lcd.setCursor(0,2);
  for (int x=0; x < 21 ; x++)
 
  {delay(1000);
  lcd.write(7);}
 
  char key2 = keypad.getKey(); // get the key
  lcd.setCursor(0,4);

  if (key2 != NO_KEY)
  {
    while (key2 == NO_KEY)
   
    {key2 = keypad.getKey();}
   
    if (key2 != NO_KEY)
   
     {lcd.clear();
      lcd.setCursor(0,0);
      lcd.print("Enter Code: ");
      while (currentLength < 4){
        lcd.setCursor(currentLength + 6, 1);
        lcd.cursor();
        char key2 = keypad.getKey();
        if (key2 != NO_KEY)
       
          {lcd.print(key2);
          entered[currentLength] = key2;
          currentLength++;
          delay(200);
          lcd.noCursor();
          lcd.setCursor(currentLength + 5, 1);
          lcd.print("*");
          lcd.setCursor(currentLength + 6, 1);
          lcd.cursor();}
      } 
     
      if (currentLength == 4){
        if (entered[0] == password[0] && entered[1] == password[1] && entered[2] == password[2] && entered[3] == password[3])
        {
          lcd.noCursor();
          lcd.clear();
          lcd.home();
          lcd.print("Disarm loading...");
          currentLength = 0;
          delay(10000);
          lcd.setCursor(0,1);
          lcd.print("STATUS:");
          delay(5000);
          lcd.setCursor(9,1);
          lcd.print("<DISARMED>");
          //delay(5000);
        }
        else
        {

          lcd.noCursor();
          lcd.clear();
          lcd.home();
          lcd.print("Protection mode");
          lcd.setCursor(0,1);
          lcd.print("TIME - 1:30 ");
          if (Mcount < 14)
          {
            Mcount = Mcount + 1;
          }
          if (Scount < 59)
          {
            Scount = Scount + 30;
          }
          delay(1500);
          currentLength = 0;
        }
      }
    }
  }
}

void timer(){
  if ( Mcount >= 15 )
  {
    while ( Mcount >= 15)
    {
      lcd.noCursor();
      lcd.clear();
      lcd.home();
      lcd.print("YOU ARE DIED!!!");
      tone1.play(NOTE_A2, 200);
      tone1.play(NOTE_A2, 200);
      delay(10); // waits for a second
      tone1.play(NOTE_A2, 200);
      delay(10); // waits for a second
      tone1.play(NOTE_A2, 200);
      delay(10); // waits for a second
      tone1.play(NOTE_A2, 200);
      delay(10); // waits for a second

      char key4 = keypad.getKey();
      if (key4 != NO_KEY){
        while (key4 == NO_KEY){
          key4 = keypad.getKey();
        }
        if (key4 = '#')
        {
          lcd.clear();
          lcd.print("Reset the Bomb");
        }
      }
    }
    if ( Mcount == 60) // if Mcount is 60 do this operation
   
     {delay (10); // good place to fine tune timing 32
      Mcount = 0; // reset Mcount
      Hcount ++;}
   
    if (Hcount> 23)
   
     {Dcount++;
      Hcount = 0;} // have to reset Hcount to "0" after 24hrs
   

    lcd.setCursor (0,4); // sets cursor to 2nd line
    lcd.print ("Timer: ");
    lcd.print (Dcount);
    lcd.print (":");
    lcd.print (Hcount);
    lcd.print (":");
    lcd.print (Mcount);
    lcd.print (":");
    lcd.print (Scount);
    if (Scount >59) // if 60 do this operation
   
      {Mcount ++; // add 1 to Mcount
      Scount = 0; // reset Scount
      delay (58);} // changes ms per min
   
    if (Scount < 60) // do this oper. 59 times
   
      {unsigned long currentMillis = millis();//
      delay (988); // changing by one = 60 ms a min
      if(currentMillis - secMillis > interval)
      {tone1.play(NOTE_G5, 200);
        secMillis = currentMillis;
        Scount ++; // add 1 to Scount
        delay(10); // waits for a second
        delay(10);}} // waits for a second
       
     
   
  }
}





Go Up