Chyby v MPLAB 8.02 - riesenie
j s
jarin.hw@gmail.com
Středa Srpen 13 09:17:11 CEST 2008
Takze, pozrel som sa na tie tri "chyby" v simulatore MPLAB-u. Namiesto
toho, aby som odpovedal strohou odpovedou "RTFM" a zacal Vas sekirovat
nutenim do studia bohatej zbierky dokumentov, ktore Microchip k svojim
nastrojom ponuka, ponizovat tym, ze je pomerne nevhodne prehlasovat
svoje chyby za chyby simulatora, vysvetlim Vam, co robite zle.
----------------------------------------------
Priklad 1 - "chyba" ohladom TMR1
Tu bude vysvetlenie najdlhsie. Ide o to, ze pokial TMR1 bezi, tak
sekvencne citanie registrov TMR1H a TMR1L by mohlo viest k nespravnym
vysledkom. Ak precitate TMR1L prave vo schvili ked preteka z 0xFFFF na
0x0000, tak dostanete v TMR1L hodnotu 0xFF, ak o niekolko instrukcii
neskor (lebo inak sa to neda) precitate TMR1H, mate hodnotu 0x00, teda
celkova hodnota TMR1 by bola chybna - 0x00FF namiesto 0xFFFF. To je
celkom prirodzene. Preto to Microchipaci urobili tak, ze TMR1H nie je
realny obraz TMR1, ale len bufferovana hodnota. TMR1L je realny obraz
dolneho bytu TMR1 a logika je taka, ze ked uzivatel precita TMR1L, v
presne tej istej chvili sa horny byte TMR1 nabufferuje do registra
TMR1H, takze ak si ho o niekolko instrukcii precita, tak ziska hodnotu
taku, ktora patri k TMR1L. Preto najprv citame TMR1L a potom TMR1H.
Pri zapise do timera je to naopak. Najprv zapiseme do buffera TMR1H,
potom zapiseme do TMR1L, cim sa zaroven zapise aj hodnota z buffera
TMR1H ako celistva 16-bitova hodnota.
A teraz, co z toho vyplyva. Ak si svoju simulaciu prejdete naozaj
pozorne, vsimnete si, ze hodnota timera1 sa nemi v hornom byte, ale
len v dolnom (TMR1L). Ta 256 krat pretecie z hodnoty 0xFF na 0x00 a
potom nastane prerusenie. Samozrejme vy ste si zrejme len dali
breakpoint na cas, ked je nastaveny TMR1IF flag a v tej chvili Vam
simulaor ukaze hodnotu taku, aka bola naposledy zapisana, nie skutocnu
hodnotu, pretoze TMR1H nebol PRECITANY, aby sa hodnota z timera1
nabufferovala do registra TMR1H. Takze bud to urobite tak, ze ich
hodnoty precitate takto
do {
if ( 1 == TM1IF ) {
TM1IF = 0;
TM1ON = 0;
testl = TMR1L;
testh = TMR1H;
TMR1H = 0x7D;
TMR1L = 0x00;
TM1ON = 1;
++PORTB;
}
} while (1);
a v premennych testl a testh su skutocne hodnoty timera1 v tej chvili,
ked sa cital TMR1L. Alebo, si dajte do Watch window virtualny register
(pre ucely simulacie) TMR1_Internal. Ten je obrazom skutocnej hodnoty
TMR1 a uvidite, ze pretecenie nastava pri hodnote 0xFFFF->0x0000.
----------------------------------------------
Priklad 2 - "chyba" okolo TMR3 a CCP4
Citujem:
"
// Dle PDFka CCP4 nenuluje časovače
// tak�e tady by měl mít TMR3 hodnotu 46085 (+/-)
// a pokračovat do hodnoty 0xFFFF
"
pricom
CCP4CON = 0x0B
T3CON = 0x71
Cize T3 je nastaveny ako zdroj pre CCP, CCP4 je v rezime 0x0B -> 1011
= Compare mode: trigger special event, reset timer, start A/D
conversion on CCPx match
V datasheete je jasne napisane, ze CCP4 v tomto rezime NULUJE citac.
Je to v datasheete PIC18F87J11 family, DS39778C, dostupneho na stranke
Microchipu, konkretne na strane 197. Neviem, z akeho "PDFka" mate
opacnu informaciu.
----------------------------------------------
Priklad 3 - chyba okolo Tad.
Ako mate nastavenu frekvenciu oscilatora v Debugger-Settings-Osc/Trace
- Processor frequency?
Ja ked si ju nastavim na 14,746MHz, ako predpokladate Vy, tak nevidim
nijaku hlasku o Tad, ked prejdem cez nastavenie AD. Samozrejme, ked je
frekvencia nastavena niekde mimo, tak simulator vidi nespravne
nastaveny Tad, a aj to reportuje - tak ako by aj na realnom kremiku by
Tad bol mimo pre takuto taktovaciu frekvenciu.
----------------------------------------------
Resume. Prosim, neurazte sa, ale su to pomerne dost zaciatocnicke
chyby. Pisem to bez snahy o Vase zosmiesnenie, ale ako realny fakt.
Kazdy raz zacinal, a prave v zaciatkoch je velmi vhodne, ak je clovek
pozorny a obozretny. Ak Vam nieco nefunguje, skuste sa najprv
zamysliet nad tym, co robite zle, bez toho aby ste s horucou hlavou
pisali zbytocne "kydanie" na Microchip a jeho support. Ja chapem, ze
pluvanie na Microchip je sucastou miestneho folkloru a clovek, ktory
nadava na PIC je potlapkavany komunitou po pleci, ale aj tu, ako vzdy
plati - dvakrat meraj a raz rez.
Amen ;-)
Další informace o konferenci Hw-list