To forum używa plików cookies
To forum wykorzystuje pliki cookies do przechowywania informacji o Twoim logowaniu, jeśli jesteś zarejestrowany, oraz informacji o Twojej ostatniej wizycie, jeśli nie jesteś zalogowany. Pliki cookies to niewielkie pliki tekstowe zapisywane na Twoim komputerze; cookies ustawiane przez to forum mogą być używane wyłącznie na tej stronie i nie stanowią zagrożenia dla bezpieczeństwa. Cookies na tym forum śledzą również, które tematy zostały przez Ciebie przeczytane oraz kiedy miało to miejsce. Prosimy o potwierdzenie, czy akceptujesz, czy odrzucasz zapisywanie tych plików cookies.

Niezależnie od wyboru w Twojej przeglądarce zostanie zapisany plik cookie, aby zapobiec ponownemu zadawaniu tego pytania. W każdej chwili będziesz mógł zmienić ustawienia cookies, korzystając z linku w stopce strony.

Ocena wątku:
  • 0 głosów - średnia: 0
  • 1
  • 2
  • 3
  • 4
  • 5
EmBitz (dawniej EmBlocks)
#6
Pierwszy, prosty program do obsługi wyświetlacza LCD 2x16 znaków napisałem w oparciu o SPL i środowisko EM Blocks. Środowisko jest ok aczkolwiek uruchomienie i konfiguracja ST-linka wymagała pomocy Piotra SP9FKP.

Zaletą bibliotek SPL jest to, że większość kursów i przykładów w sieci opiera się właśnie na nich. Również kilka projektów z kręgu naszych zainteresowań HM bazuje na SPL-u. Programy są proste, czytelne i wymagają minimalnej wiedzy na temat rejestrów procesora co spodoba się każdemu początkującemu programiście. Wykorzystanie SPL-a do inicjowania zasobów procesora jest proste i wygodne ale pochłania sporo kodu i czasu pracy procesora. Niestety po zapoznaniu się z kodem poszczególnych funkcji SPL fascynacja gotowymi funkcjami słabnie i zaczynamy się zastanawiać czy nie da się tego zrobić prościej. W sieci znajdziemy wiele postów krytycznych na temat SPL-a oraz przykładów jak pisać programy opierając się wyłącznie o rejestry procesora i funkcje CMSIS. Efekty (kod+czas) są zdecydowanie lepsze ale pisanie programów jest trudniejsze i wymaga to większej wiedzy o rejestrach procesora.

Biblioteka libopencm3 to przykład ominięcia "balastu" ciążącego na dotychczasowych standardach typu SPL, HAL czy nawet CMSIS. Podoba mi się bardzo oszczędne i optymalne napisanie podstawowych funkcji co z pewnością da bardzo dobre wyniki po kompilacji. Na początku poznawania procesorów STM wadą tego rozwiązania jest zerwanie ze standardem rdzenia opisanym w plikach CMSIS co może skutkować problemami w kompilacji wielu przykładów.

Najlepiej poznawać możliwości poszczególnych rozwiązać na praktycznych przykładach. Przydatność łatwiej jest ocenić po czytelności programu, wielkości kodu i czasie jego wykonywania.
73 Adam
Cytuj


Wiadomości w tym wątku
EmBitz (dawniej EmBlocks) - przez SP9FKP - 12-05-2016, 11:13

Skocz do:


Użytkownicy przeglądający ten wątek: 1 gości