Hallo Ihr,
Ich habe n kleines Problem:
es ist ein 16f628, aber ich denke mal, dass das alle pics machen:
und zwar setze ich das 1.Bit meines Ports auf 1, danach das 0.Bit. Was
passiert in der Simulation? das 1. Bit wird auf 0 gesetzt und das 0.Bit
auf 1!! Kann mir das jemand erklären?
Ich nehme an bei avr ist es ähnlich? Ich habe da leider kaum planung..
Danke im Voraus Hannes
#pragma bit SCK @ PORTA.0; //CLCK
#pragma bit SDO @ PORTA.1; //DATA
char sende(char out)
{
char i;
for (i=0;i<8;i++)
{
nop();
SCK=0;
nop();
SDO=out.7; //letzte bit von out
nop();
out=out<<1; //verschieben von out um 1
nop();
SCK=1;
nop();
}
}
Deine Beschreibung kann ich nicht ganz nachvollziehen. SCK wurde definiert als das 0-te Bit im Port und im Code wird als erstes dieses Bit auf 1 gesetzt. Genau wie du es beschreibst. ???
nun, eigentlich sollte aus z.b. PORTA: 0b.0000.0010 -> 0b.0000.0011 werden. Dich was wird simuliert? in dieser Situation kommt 0b.0000.0001 raus! Das heisst, das das vorherige Bit einfach überschriben wird! Kann man das jetzt nachvollziehen? nop(); SCK=0; //-> PORTA:0b.0000.0000 nop(); SDO=out.7; //PORTA:0b.0000.0010 nop(); out=out<<1; //verschieben von out um 1 nop(); SCK=1; //PORTA:0b.0000.0001, aber sollte eigentlcih 0b.0000.0011 sein! nop(); Mfg Hannes
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.