Professional Documents
Culture Documents
Programowy emulator
DS1990
Oprogramowanie dla trybu 1-Wire Slave
Chyba każdy z elektroników zna interfejs 1-Wire. Wystarczy wspomnieć, jaką
popularnością cieszyły się niegdyś układy DS1990 powszechnie stosowane
we wszelkiego rodzaju systemach kontroli dostępu czy też popularne
i chętnie stosowane także dzisiaj termometry scalone typu DS18x20. Nie
była to popularność przypadkowa. Oprócz funkcjonalności, którą miały,
nie bez znaczenia był fakt względnie łatwej, programowej implementacji
zastosowanego w nich niezmiernie ciekawego i oryginalnego interfejsu
komunikacyjnego, który nie ma swoich odpowiedników w świecie elektroniki.
Każdy element z interfejsem 1-Wire ma swój uni- (stąd nazwa interfejsu), który oprócz linii danych może
kalny numer seryjny i dlatego szereg układów wyposa- jednocześnie pełnić rolę przewodu zasilającego w kon-
żonych w ten interfejs komunikacyjny może pracować figuracji tzw. zasilania pasożytniczego. Na magistrali
na jednej i – co ważne – pojedynczej magistrali danych 1-Wire transmisja przebiega w konfiguracji Master <–>
będącej jednocześnie źródłem zasilania. Stanowiło to Slave. Układ nadrzędny (Master) steruje wyszukiwaniem
o niespotykanej oryginalności interfejsu opracowanego i adresowaniem układów podrzędnych (Slave), steruje
przez firmę Dallas Semiconductor (w tej chwili Maxim). przepływem danych oraz generuje sygnał zegarowy, ini-
Pomimo tych niepodważalnych zalet, nie spotkałem się cjuje wysyłanie i odbieranie danych. Dane przesyłane są
z systemami, które interfejs 1-Wire wykorzystywałyby do synchronicznie z prędkością do 16,3 kbps w trybie stan-
komunikacji pomiędzy własnymi rozwiązaniami sprzę- dard oraz do 115 kbps w trybie overdrive. Należy szcze-
towymi, a spotykane rozwiązania ograniczały się do gólnie podkreślić, iż przesłanie każdego bitu informacji
programowej realizacji obsługi wspomnianej magistrali – niezależnie od kierunku transmisji – jest inicjowane
wyłącznie w celu umożliwienia współpracy z firmowy- wyłącznie przez układ Master za pomocą opadającego
mi peryferiami producenta, mimo że udostępnił on (co zbocza sygnału (ściągnięcie magistrali do logicznego „0”
oczywiste) pełną specyfikację interfejsu. Z jednej strony przez czas z zakresu 1…5 ms). Po wystąpieniu takiego
nie budzi to zdziwienia, ponieważ firma Maxim dyspo- zbocza sygnału układ Slave podejmuje różne działania,
nuje prawem patentowym na specyfikację tej magistrali, których scenariusz zależy od oczekiwanego kierunku
z drugiej zaś nic nie stoi na przeszkodzie, by ten arcy- transmisji. Tego typu organizacja protokołu transmisji
ciekawy interfejs komunikacyjny z jego wszystkimi za- zapewnia prawidłową synchronizację przesyłanych da-
letami wykorzystać we własnych konstrukcjach w celu nych bez potrzeby stosowania dodatkowych linii steru-
umożliwienia obustronnej współpracy urządzeń niebę- jących. Minimalny czas trwania pojedynczego bitu jest
dących produktami firmy Maxim. Sprowadza się to do ściśle określony i wynosi 60 ms + 1 ms na tak zwany
opracowania własnego elementu typu Slave, który ob- czas odtworzenia zasilania (recovery time). Wyznacza
sługiwałby oferowaną przez interfejs 1-wire funkcjonal- on maksymalną prędkość transmisji w trybie standard
ność, włączając w to mechanizm wyszukiwania adresów (1/61 ms=16,3 kbps). Co ważne, każde z urządzeń dołą-
podłączonych do magistrali peryferiów (tzw. SEARCH czonych do magistrali musi mieć wyjście typu otwarty
ROM). Zademonstrujemy to na przykładzie programowej dren lub otwarty kolektor, a linia danych jest dołączona
realizacji układu DS1990, opartej o dowolny mikrokon- do zasilania przez rezystor podciągający o typowej war-
troler wyposażony w przerwanie zewnętrzne oraz timer tości 4,7 kV. W stanie bezczynności powoduje to utrzy-
sprzętowy (w naszym przypadku wybrano popularny mi- mywanie się poziomu wysokiego na tej linii i zapewnia
krokontroler AVR typu ATmega8 taktowany wewnętrz- zasilanie urządzeń z 1-Wire pracujących w trybie zasila-
nym oscylatorem 8 MHz). nia pasożytniczego.
Przesyłane słowa są zawsze 1-bajtowe, a jako pierw-
Podstawowe wiadomości szy jest transmitowany bit najmniej znaczący. Dodatko-
o 1-Wire wą i jedną z najważniejszych cech urządzeń z interfej-
Zanim jednak przejdę do opisu warstwy programowej sem 1-Wire jednocześnie odróżniającą je np. od urządzeń
(tym razem w języku C) niezbędne jest przypomnienie z interfejsem I2C, jest unikatowy, 8-bajtowy identyfikator
choćby podstawowych informacji na temat samego in- układu zapisany w pamięci ROM. Jest on niepowtarzal-
terfejsu będącego przedmiotem naszych rozważań, tym ny i właściwy tylko, i wyłącznie pojedynczemu układowi
razem jednak z punktu widzenia układu podrzędnego scalonemu (w pamięci komponentów produkowanych
typu Slave. Jak wspomniano, komunikacja na magistrali przez firmę Maxim-Dallas jest zapisywany na etapie pro-
1-Wire odbywa się za pomocą pojedynczego przewodu dukcji). Najmniej znaczący bajt tego identyfikatora za-
Rysunek 5. Sekwencja sygnałów sterujących obrazująca mechanizm znajdowania numerów ID układów Slave
(z punktu widzenia tychże układów).
#define RESET_1WIRE WIRE1_DDR |= (1<<WIRE1_NR) //Ściągnięcie magistrali 1-wire do „0” poprzez ustawienie
kierunku portu jako wyjściowy
#define SET_1WIRE WIRE1_DDR &= ~(1<<WIRE1_NR) //Zwolnienie magistrali 1-wire i tym samym podciągnięcie
rezystorem do plusa zasilania
Listing 5. Czynności wykonywane przez program w stanie IDLE iż magistrala 1-wire wymusza dość rygorystyczne
case IDLE:
//Uruchamiamy Timer odmierzający czas oczekiwanego impulsu RESET wymogi czasowe, więc wykorzystanie typowe-
START_TIMER1;
//Czekamy, aż Master zwolni magistralę 1-wire go portu I/O i tzw. pollingu jest niewystarczające
while(!(WIRE1_PIN & (1<<WIRE1_NR))); w przypadku, gdy układ Slave miałby wykonywać
STOP_TIMER1;
//Odebrano oczekiwany sygnał RESET jeszcze inne czasowo zależne operacje niezwiąza-
if(TCNT1 > microSeconds(460))
{ ne z obsługą magistrali. Wykorzystanie przerwania
//Wystawiamy sygnał PRESENCE by zasygnalizować obecność zewnętrznego niesie za sobą tę dodatkową zaletę,
//układu Slave na magistrali 1-wire
RESET_1WIRE; iż cała obsługa protokołu zostanie „zamknięta”
_delay_us(240); w ramach jednej, krótkiej funkcji ISR, a program
SET_1WIRE;
//Zerowanie zmiennych pomocniczych główny może realizować inną funkcjonalność, nie-
Command = 0;
bitIndex = 0; zbędną z punktu widzenia konkretnej aplikacji.
//Zmiana stanu procedury obsługi magistrali 1-wire Zadeklarujmy, zatem dwie podstawowe zmienne
slaveStatus = WAIT_FOR_COMMAND;
//Uruchamiamy zegar odmierzający timeout = 1ms globalne: numer seryjny naszego urządzenia Sla-
//(oczekiwanie na rozkaz) ve oraz zmienną przechowującą aktualny stan
START_TIMEOUT(1000);
} procedury obsługi układu Slave magistrali 1-wire
break;
(listing 1). Dodatkowo, aby poprawić czytelność
programu obsługi, wprowadzimy typ wyliczenio-
pozostaje nieaktywny aż do następnego sygnału Reset wy opisujący stan pracy wspomnianej procedury (listing 2).
i żądania wyszukiwania numerów ID (rozkazu 0xF0). W związku z tym, że obsługa protokołu odbywa się w cało-
W ten prosty sposób układ Master, po przejściu przez ści w ramach procedury obsługi przerwania INT0 (INT0_
każde 64 bity numeru ID, dysponuje każdorazowo ko- vect) funkcja główna naszego programu obsługi ogranicza
lejnym, znalezionym numerem ID układu pracującego się wyłącznie do konfiguracji niezbędnych peryferiów mi-
na magistrali 1-wire. Oczywiście opis ten przedstawio- krokontrolera (listing 3)
no z punktu widzenia układu Slave, gdyż algorytm dla W programie obsługi jest używany także timer sprzę-
układu Master jest nieco bardziej skomplikowany (ba- towy (w tym przypadku 16-bitowy Timer1) oraz przerwa-
zuje na algorytmie tzw. drzewa binarnego). nie od jego przepełnienia (TIMER1_OVF_vect). Użycie tego
REKLAMA