Hallo, Wie kann ich den ADC beim Mega64 aktivieren? Beim Mega 8 habe ich es bis jetzt so gemacht: ldi temp, ((1<<ADEN)|(1<<ADSC)|(1<<ADFR))+7 out ADCSR, temp Aus dem Datasheet werde ich auch nicht so richtig schlau, den da gibt es die Register ADCSRA und ADCSRB. Nur wie muss ich die beschreiben, damit ich das gleiche rausbekomme wie bei dem code mit dem Mega8? Mfg Jochen Tontch.
Ich habe es beim ATMEGA 128 so gemacht. Damit sollte es wahrscheinlich auch beim ATMEGA 64 gehen. Du musst das nur in ASM umsetzen: Initialisierung: cli(); DDRF = 0x00; /* set adc ports to input */ ADMUX = 1<<REFS1 | 1<<REFS0; /* 2,56V internal reference, measure adc0 */ ADCSRA = 1<<ADPS2 | 1<<ADPS1 | 1<<ADPS0 | 1<<ADEN; /* prescaler / 128 */ sei(); Auslesen: // unter ADMUX den entsprechenden MUX-Kanal einstellen ADCSRA |= 1<<ADSC; while (ADCSRA & (1<<ADSC)); // der Wert steht dann in ADC .. bzw. ADCH und ADCL
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
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.