Forum: Mikrocontroller und Digitale Elektronik Übelste Anfängerfrage zum AVR GCC Tutorial -> Taster


von Bastian F. (bastian_f)


Angehängte Dateien:

Lesenswert?

Ich arbeite mich grade durch das Tutorial durch und bin schon froh, dass 
ich bis jetzt alles halbwegs auf die Reihe bekommen habe...

Nur kriege ich den Tasterteil nicht auf die Reihe.
Ich gehe mal davon aus, dass ich den einfach völlig falsch eingebaut 
habe (siehe Foto) aber alle anderen Versuche haben nichts außer 
Kurzschlüsse verursacht ;).
Kann mir also jemand sagen, was ich wie wo zuschalten/umschalten muss?

Danke!
1
#include <avr/io.h>
2
#include <inttypes.h>
3
#include <util/delay.h>     /* bei alter avr-libc: #include <avr/delay.h> */      
4
#include "pins.h"
5
#include <stdint.h>
6
7
8
/* Einfache Funktion zum Entprellen eines Tasters */
9
inline uint8_t debounce(volatile uint8_t *port, uint8_t pin)
10
{
11
    if ( !(*port & (1 << pin)) )
12
    {
13
        /* Pin wurde auf Masse gezogen, 100ms warten   */
14
        _delay_ms(50);   // Maximalwert des Parameters an _delay_ms 
15
        _delay_ms(50);   // beachten, vgl. Dokumentation der avr-libc
16
        if ( *port & (1 << pin) )
17
        {
18
            /* Anwender Zeit zum Loslassen des Tasters geben */
19
            _delay_ms(50);
20
            _delay_ms(50); 
21
            return 1;
22
        }
23
    }
24
    return 0;
25
}
26
 
27
int main(void)
28
{
29
30
  DDRB &= ~( 1 << PB0 );        /* PIN PB0 auf Eingang Taster)  */
31
    PORTB |= ( 1 << PB0 );        /* Pullup-Widerstand aktivieren */
32
    DDRC = (1 << DDC5); 
33
34
    while (debounce(&PINB, PB0))
35
  //  while(1)
36
  {
37
       /* Falls Taster an PIN PB0 gedrueckt     */
38
       /* LED an Port PC5 an- bzw. ausschalten: */
39
40
  PORTC |= (1<<PC5);
41
42
    }
43
44
 
45
46
return 0;
47
}

von fz (Gast)


Lesenswert?

Probier es mal mit einem Pullup oder Pulldown Wiederstand

von Bastian F. (bastian_f)


Lesenswert?

Das habe ich auch probiert.
Also einen 10K Widerstand entweder an Masser oder Vcc zu legen und dann 
über den Schalter an den Pin, aber funktioniert auch nicht.

von Hc Z. (mizch)


Lesenswert?

Mir fehlt die Stelle, wo der Ausgang wieder ausgemacht wird, also das 
Gegenstück zu

>   PORTC |= (1<<PC5);

Das Ganze dann bitte in einer Schleife, denn bei nicht gedrückter Taste 
beendet sich main() in nullkommanix und das war's dann schon gewesen. 
Der Anwender bekommt gar keine Chance, eine Taste zu drücken, außer er 
hat sie beim Start bereits gedrückt.

P.S.  Das hier

>         _delay_ms(50);   // Maximalwert des Parameters an _delay_ms
>         _delay_ms(50);   // beachten, vgl. Dokumentation der avr-libc

kann natürlich durch ein  _delay_ms(100) ersetzt werden.  Ich bitte 
das, was im Kommentar gefordert wird, auch wirklich vollständig zu tun 
und nicht nach dem ersten Satz mit Lesen aufzuhören.

von Bastian F. (bastian_f)


Lesenswert?

Naja, bin jedenfalls froh, dass es "nur" am Code lag und ich nicht zu 
doof für die Schaltung war.
Mit dieser Lösung (wahrscheinlich nicht wirklich elegant) geht es 
jedenfalls.
Danke für eure Hilfe!
1
while(1){
2
   
3
   if (!(PIND & (1<<PINC7))) 
4
  {
5
    PORTC |= (1<<PC5);
6
    _delay_ms(1000);
7
    PORTC &= ~ (1<<PC5);
8
     }
9
 }

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.