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.