hallo, ich habe versucht eine tastatur an meinen atmel uC anzuschliessen
und werte das clock signal über einen interupt aus.
komischerweise erhielt ich bei jedem tastendruck immer einen anderen
Wert, der sich nach 11 Perioden widerholte. Es sieht so aus, als ob die
bits bei jedem tastendruck nach links geshiftet werden. Trotzdem sind
es aber 11 Perioden und nicht 8.
Nach einigem rumprobieren, hab ich dann auf den standart algorythmus
aus einem pdf-document zurückgegriffen, aber der fehler ist nach wie
vor der gleiche.
Wahrscheinlich handelt es sich um einen simplem Denkfehler, den ich
aber einfach nicht finden kann.
Also hier der code (Ausschnitt):
SIGNAL(SIG_INTERRUPT0) //wird aufgerufen beim interrupt auf int0
{
static unsigned char data; // Holds the received scan code
if ((bitcount < 11) && (bitcount > 2)) // Bit 3 to 10 is data.
Parity bit is ignored
{
data = (data >> 1);
if(bit_is_set(PIND, 3)) data = data | 0x80;
}
if((--bitcount) == 0) // All bits received
{
SendeChar(data);
data=0;
bitcount = 11;
}
}
bitcount ist global deklariert.
Wär echt nett, wenn sichs mal jemand anschauen könnete, Danke!
Hallo tubbu! Hast Du mal logisch versucht, nachzuvollziehen, was da in Deiner ISR überhaupt passiert? Ein kleiner Tipp: unsigned char ist genau ein byte groß! Gruß, Patrick...
Uh oh... Sorry, da hab ich wohl gepennt! Hab das "if ((bitcount < 11) && (bitcount > 2))" völlig überlesen! Ich habe mal in den mspgcc examples nachgeschaut, da ist ebenfalls ein Beispiel für ein PC-Keyboard drin, das sieht allerdings etwas anders aus. Ich habe mal die Makros aufgelöst und nur die ISR in ein file gepackt, ich denke, das solltest Du auf den AVR anpassen können... Die Routine sendechar solltest Du von Deinem main aus aufrufen. Dazu einfach in der ISR noch ein Flag setzen (z.B. received = TRUE oder so ähnlich) und in der main auf TRUE prüfen. nach dem verarbeiten das Flag einfach wieder auf FALSE setzen. Gruß, Patrick...
hi,
ich bin mit dem code aus dem appnote 910 auch nicht so ganz
klargekommen, also hab ich alles neu programmiert.
meine interruptroutine (clock) sieht so aus:
SIGNAL(SIG_INTERRUPT0)
{
if(bitcount == 0)
key = 0;
if(bitcount > 0 && bitcount < 9)
{
unsigned char data = 0;
data = PIN(KB_PORT);
data >>= KB_DATAPIN;
if(data & 1)
key |= 1 << (bitcount-1);
}
bitcount++;
if(bitcount == 11)
{
if(bufcount < KB_BUFSIZE-1)
{
if(key != 0xF0)
{
if(lku == 0)
{
keybuf[bufcount] = key;
bufcount++;
}
lku = 0;
}
else
lku = 1;
}
bitcount = 0;
}
}
ich möchte dich ja nicht zum c&p verleiten, aber hoffe das hilft dir.
die variablen sollten klar sein, den rest solltest du auch hinbekommen.
Vielen Dank, jetzt hat es funktioniert. Allerdings erst, nachdem ich nicht 11, sondern 12 Bits gezählt habe, keine Ahung warum, aber ist mir auch irgendwie egal, thx
Hallo Leute,
ich komme mit den Beiden Zeilen nicht klar:
data = PIN(KB_PORT);
data >>= KB_DATAPIN;
Was ist PIN() für eine funktion und wo finde ich die?
und verstehe ich das richtig das KB_PORT zb PORTB ist und KB_DATAPIN
zb. PD6 ist ?
Danke im voraus
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.