Forum: Mikrocontroller und Digitale Elektronik ATmega32 -> 644


von Ron (Gast)


Lesenswert?

Hi

Ich will upgraden und bevor ich mich an das neu compilieren meiner 
großen Anwendung wagte, wolllte ich einen einfachen Test laufen lassen 
und eine LED blinken lassen.
Im 32er klappts, doch wenn ich das dann mit WinAVR (akt. Version) für 
den 644er compiliere und programmiere, passiert nichts. Die Fusebits 
kann ich aber setzen und habe ich auch einiges ausprobiert (internen 
Teiler/Taktausgabe usw.). Das klappt wohl alles. Nur meine LED blinkt 
nicht.
Irgendeinen groben Schnitzer übersehen?
1
#include <avr/io.h>
2
#include <util/delay.h>    // definiert _delay_ms() 
3
4
// wartet ms Millisekunden
5
void delay_ms(uint16_t ms)
6
{
7
  for(uint16_t t=0; t<=ms; t++)
8
  _delay_ms(1); 
9
}
10
11
void main()
12
{
13
  unsigned int i;
14
15
  DDRB = 0xFF;              // PORTB als Ausgang
16
  for (i=0; i<5; i++)
17
  {
18
    PORTB = PINB ^ ( 1 << PB0 );    // LED an PB0 umschalten
19
    delay_ms (1000);
20
    PORTB = PINB ^ ( 1 << PB0 );    // LED an PB0 umschalten
21
    delay_ms (1000);
22
  }  
23
}

von Frank E. (erdi-soft)


Lesenswert?

Evtl. schlägt der Watchdog zu, der wohl bei einigen (oder sogar allen) 
von Haus aus aktiviert ist.
Hat mich auch schonmal reingelegt. :)
1
void WDT_off(void)
2
{
3
  uint8_t sreg = SREG;
4
  CLI();
5
  WDR();
6
  /* Clear WDRF in MCUSR */
7
  MCUSR &= ~(1<<WDRF);
8
  /* Write logical one to WDCE and WDE */
9
  /* Keep old prescaler setting to prevent unintentional time-out */
10
  WDTCSR |= (1<<WDCE) | (1<<WDE);
11
  /* Turn off WDT */
12
  WDTCSR = 0x00;
13
  SREG = sreg;
14
}

von Johannes M. (johnny-m)


Lesenswert?

Schau Dir mal die Appnote AVR505 
(http://www.atmel.com/dyn/resources/prod_documents/doc8001.pdf)
an. Da steht, was beim Wechsel zu beachten ist.

Bei pinkompatiblen µCs gibt ATMEL eigentlich immer eine solche Migration 
Note raus, so dass der erste Weg einen auf die ATMEL-Homepage führen 
sollte...

von Ron (Gast)


Lesenswert?

Argh!

Das hat man davon, wenn man so "neue" µCs nutzt: Die Programmer 
unterstützen das nicht richtig. Ich hatte schon danach gefragt 
(Beitrag "ATmega644 programmieren") und dachte, mit Bascom mein 
Glück gefunden zu haben. Aber nein, Bascom macht den Fehler. Mit der 
gepatchten PonyProg Version geht's. So ein ...

Also: Danke.

von Philipp Karbach (Gast)


Lesenswert?

warum benutzt du nicht einfach avrdude?

von malt (Gast)


Lesenswert?

Hi,

ich kriege meinen 644 auch nicht zum Laufen. Benutze AVRStudio (neueste 
Version) mit AVRISP mkII. Zugriff auf Ports geht nicht aber UART geht 
seltsamerweise. Kann nichts über Ports einlesen oder ausgeben. Auf die 
interenen Pullups reagiert er aber. Was ist denn da los?

Aus der Appnote werde ich auch nicht schlau. Wenn ich als Device den 644 
angebe, müsste doch alles korrekt sein. Was soll man denn da noch 
beachten?

Gruß
Malte

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.