Ogólnie, kontroler wyświetlacza potrzebny jest po to, aby móc odpowiednio często wysyłać kompletne ramki pikseli obrazu. W praktyce częstotliwość odświeżania ekranu wynosi najczęściej ok. 60 Hz, co oznacza, że ilość przesyłanych danych na sekundę jest dosyć duża. Może się wydawać, że będzie to silnie obciążać jednostkę obliczeniową, ale w mikrokontrolerach takich, jak Microchip PIC32, które obsługują DMA (Direct Memory Access), obciążenie procesora nie przekracza 5%. Bezpośredni dostęp do pamięci sprawia, że większość czasochłonnych operacji wykonywanych jest z pominięciem jednostki obliczeniowej.
Podstawowe pojęcia
Kontroler przesyła do wyświetlacza informacje o kolorach pikseli z częstotliwością odświeżania, wyrażoną w hercach. Ilość danych koniecznych do przesłania zależy przede wszystkim od rozdzielczości ekranu: np. 320×240 pikseli. Częstotliwość przesyłania pikseli zależna jest od ich liczby, a więc rozdzielczości oraz odświeżania. Aby móc je sprawnie przesyłać, należy je przygotować wcześniej i zapisać w pamięci – w praktyce w RAMie, w postaci tzw. ramki. Trzeba też uwzględnić paletę kolorów wyświetlacza, wyrażoną w bitach. Typowo, jeśli wyświetlacz prezentuje 16-bitową gamę barw, po 5 bitów poświęconych jest na kolor czerwony i niebieski, a 6 na zielony.
Sposób użycia DMA
Ponadto, w przypadku modeli z obsługą interfejsu zewnętrznej magistrali (EBI – External Bus Interface), EBI może zostać wykorzystany jako zegar taktujący przesył danych pikseli. Zazwyczaj pozwala to uzyskać wyższą częstotliwość taktowania, niż przy wykorzystaniu portu PMP, przy czym EBI bazuje na tych samych wyprowadzeniach, co PMP.
Bufor z ramką obrazu może znajdować się w pamięci RAM wewnętrznej lub zewnętrznej. Sposób komunikacji z użyciem zewnętrznej pamięci pokazano na rysunku 1. Wykorzystanie wbudowanej pamięci zilustrowano na rysunku 2.
Wyświetlacze TFT LCD
Omawiana metoda pozwala na sterowanie zarówno wyświetlaczami TFT LCD, jak i CSTN lub MSTN, o ile zostanie poddana drobnym modyfikacjom. Linie danych odpowiadają bitom potrzebnym na przesyłanie informacji o kolorach pikseli. Większość wyświetlaczy spotykanych na rynku ma od 8 do 24 linii danych, zależnie od palety barw.
Linie HSYNC, VSYNC, DEN i PCLK służą do synchronizacji przesyłanych danych pomiędzy ramką obrazu, a panelem wyświetlacza. Informują LCD o tym, kiedy zaczyna się i kończy linia (sygnał HSYNC), lub cała ramka (sygnał VSYNC). Sygnał DEN informuje wyświetlacz o tym, że dane są do niego przesyłane. Jest to wymagane przez niektóre z paneli TFT LCD, by te zdążyły przygotować się na przyjęcie informacji o pikselu.
Każdy cykl zegara PCLK aktualizuje zawartość wyświetlacza. Pozostałe sygnały muszą być zsynchronizowane z sygnałem PCLK. W przypadku wyświetlaczy, które nie obsługują sygnałów HSYNC ani VSYNC, wystarczy odpowiednie taktowanie z użyciem PCLK.
Przykład oparty o zestaw
Firma Microchip opracowała płytkę Low-Cost Controllerless Graphics PICtail Plus daughter board (LCC graphics board), która pozwala zademonstrować opisaną technikę w praktyce i działa z wieloma istniejącymi zestawami do mikrokontrolerów PIC32. Przygotowane oprogramowanie ułatwia synchronizację i wymaga jedynie podania parametrów podłączanego wyświetlacza i obsługiwanych przez niego sygnałów. Wartości te trzeba wpisać do kodu i można go skompilować, by zacząć wyświetlanie ramek obrazu na ekranie.
Na ilustracji 3 pokazano, co dzieje się wewnątrz mikrokontrolera, kiedy ramka obrazu jest przesyłana do wyświetlenia. Ilość zdań dla CPU jest znikoma, w porównaniu do obciążenia DMA. W praktyce konieczne staje się tylko napisanie kodu obsługiwania przerwań DMA oraz konfiguracji DMA i PMP. Przykładowy kod inicjalizacji został przedstawiony na listingu 1.
Przygotowywanie nowych pikseli
Wyświetlając obraz nie należy zapominać o konieczności aktualizacji samego bufora pamięci obrazu. To tam zapisywana jest treść do wyświetlenia i procesor musi zadbać, by była aktualna. Jeśli ramka zapisywana jest w pamięci zewnętrznej, transfery DMA są zawieszane na czas aktualizacji treści ramki. Jest ot konieczne, gdyż mikrokontroler zawiera tylko jeden podukład PMP i jest on dzielony z wirtualnym kontrolerem grafiki. Oznacza to, że częstotliwość odświeżania wyświetlacza jest zaburzana przez aktualizację treści do wyświetlenia.
Jeśli wykorzystane zostaną obwody EBI, czas potrzebny na aktualizację treści ramki jest silnie skrócony. Użycie EBI do zapisywania pozwala ograniczyć ilość przeładowywanych danych, gdyż rejestry PMP przestają być wykorzystywane zarówno do zapisu, jak i odczytu. Ponadto EBI po prostu pozwala na szybszą transmisję z zewnętrzną pamięcią RAM.
Oprogramowanie
8-bitowa paleta w przypadku kolorowego obrazu oznacza w praktyce, że po trzy bity przeznaczone są na składową czerwoną i zieloną, a dwa pozostałe bity na kolor niebieski. Ten, jak i poprzedni sposób podziału bitów są powszechnie stosowane w wyświetlaczach ze względu na specyfikę ludzkiego oka, które jest najbardziej wrażliwe na kolor zielony, a następnie czerwony, a kolor niebieski rozróżnia najgorzej.
W przypadku metody z użyciem zewnętrznej pamięci, sygnał odczytu PMP jest sygnałem zegarowym pikseli. W tym celu należy wstawić zworki 2 i 3 na płytce LCC graphics board. W trybie tym stosowana jest 16-bitowa paleta barw, z podziałem składowych takim, jak podano wcześniej. Jeśli podłączany jest panel o więcej niż 16 liniach danych kolorów, nieużywane linie należy podłączyć do najbardziej znaczących bitów dla poszczególnych barw składowych. Dzięki temu możliwe będzie użycie pełnej skali barw – od czerni do bieli.
Podsumowanie
Jeśli prezentowany na ekranie obraz nie ma zmieniać się zbyt często, a rozdzielczość wyświetlacza nie jest bardzo duża, nawet zwykły, 32-bitowy mikrokontroler z łatwością samodzielnie poradzi sobie z obsługą ekranu, bez potrzeby dodawania dodatkowych podzespołów. Omówiona metoda pozwala więc uprościć projekt i zmniejszyć jego łączny koszt produkcji.
Marcin Karbowniczek, EP