Forum: Mikrocontroller und Digitale Elektronik ATTiny13 ADC Input 0-5V macht ADCH unstetig?


von Fredi W. (wigiware)


Lesenswert?

Hallo zusammen ich bin mit meinem ADC am verzweifeln, und garantiert 
habe ich im englischen Datenblatt wieder mal etwas überlesen oder falsch 
verstanden. Aber ich sehe es einfach nicht mehr, bitte um Hilfe.

Ich habe beim ATTiny13 an Pin B1 eine Kontroll-LED um ADC Wertlimiten 
anzuzeigen, und am Pin B4 ist mein Analog Input 0-5V mittels Poti. Ich 
habe meine ADC Daten linksbündig und ich lese nur die obersten 8 Bits 
aus dem ADCH. Meine Vref ist Vcc 5.0V, und der ADC Clock Prescaler ist 
auf 128 gesetzt.

Wenn nun in ADCH der Wert von 200 übersteigt, soll die Kontroll LED 
angehen, sonst ausgeschaltet bleiben.

Grundsätzlich funktioniert das und die LED geht ab ca. 4.0V an, aber sie 
geht auch an zwischen 2.15V und 2.55V. Dort müssten aber die Datenwerte 
ca. 108 bis 127 drinstehen, offenbar steht aber in diesem Bereich 255 
drin. Weiss jemand Rat und kann mir da helfen?

Danke und Gruss. Hier ist mein Code:


;Include Device Specific Register Defines
.Include “tn13def.inc"

;Setup the IO Ports
    ldi r16, 0x0F  ;Port B.0...B.3 Ausgang
    out DDRB, r16  ;Port B.4...B.5 Eingang
    ldi r16, 0x00  ;Port B Eingänge ohne Pull-Up's
    out PORTB, r16  ;Port B Ausgänge Low Driven
    nop    ;IO Clock Sync

;Setup the AD-Converter
    ldi r16, 0x87  ;1000'0111
    out ADCSRA, r16  ;Bit7= ADC Enable = 1
        ;Bit6= ADC Start = 0 (folgt später)
        ;Bit5= Auto Trigger = 0
        ;Bit4= Interrupt Flag = 0
        ;Bit3= Interrupt Enable = 0
        ;Bit2= Prescaler2 = 1
        ;Bit1= Prescaler1 = 1
        ;Bit0= Prescaler0 = 1

    ldi r16, 0x22  ;0010'0010
    out ADMUX, r16  ;Bit7= n/v
        ;Bit6= Ref. Voltage = 0
        ;Bit5= Left Adjust Result = 1
        ;Bit4= n/v
        ;Bit3= n/v
        ;Bit2= n/v
        ;Bit1= MUX1 = 1 ADC2 [PB4])
        ;Bit0= MUX0 = 0 ADC2 [PB4])

;MAIN PROGRAM

ADCStart:
    in r16, ADCSRA
    ori r16, 0x40  ;ADSC = 1 (ADC Start Conversion)
    out ADCSRA, r16
Wait:
    sbic ADCSRA, 6  ;Warten bis Conversion fertig > ADSC = 0
    rjmp Wait

    in r20, ADCH  ;nur die oberen Datenbits 9...2 nehmen
CheckH:
    cpi r20, 200    ;Obergrenze abfragen
    brge NOK
OK:
                cbi PORTB, 1  ;Upper Limit Control LED ausschalten
    rjmp ADCStart   ;von Vorne beginnen
NOK:
    sbi PORTB, 1    ;Upper Limit Control LED einschalten
    rjmp ADCStart   ;von Vorne beginnen

von Peter D. (peda)


Lesenswert?

Fredi W. schrieb:
> brge NOK

Macht einen signed Vergleich.

von Fredi W. (wigiware)


Lesenswert?

Danke Peter das wars! Habe mich da komplett im ADC verirrt, dabei sinds 
nur Basics... Wünsche dir einen schönen Tag LG

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.