-
Path: news-archive.icm.edu.pl!news.rmf.pl!agh.edu.pl!news.agh.edu.pl!news.onet.pl!not
-for-mail
From: Jerry1111 <j...@w...pl.pl.wp>
Newsgroups: pl.comp.programming
Subject: Re: printf i wielozadaniowosc (MicroC/OS-II)
Date: Tue, 29 Sep 2009 22:04:24 +0100
Organization: http://onet.pl
Lines: 59
Message-ID: <h9tsp1$pfi$1@news.onet.pl>
References: <h...@p...onet.pl>
NNTP-Posting-Host: 94-195-52-21.zone9.bethere.co.uk
Mime-Version: 1.0
Content-Type: text/plain; charset=ISO-8859-2; format=flowed
Content-Transfer-Encoding: 8bit
X-Trace: news.onet.pl 1254258273 26098 94.195.52.21 (29 Sep 2009 21:04:33 GMT)
X-Complaints-To: n...@o...pl
NNTP-Posting-Date: Tue, 29 Sep 2009 21:04:33 +0000 (UTC)
User-Agent: Thunderbird 2.0.0.23 (Windows/20090812)
In-Reply-To: <h...@p...onet.pl>
X-Antivirus: avast! (VPS 090928-0, 28/09/2009), Outbound message
X-Antivirus-Status: Clean
Xref: news-archive.icm.edu.pl pl.comp.programming:183680
[ ukryj nagłówki ]Pszemol wrote:
> W systemie MicroC/OS-II wszystkie wątki uszeregowane są według swoich
> priorytetów i wątek o niższym priorytecie dostaje procesor TYLKO WTEDY
> gdy wątek o wyższym priorytecie nie ma nic do roboty i czeka na zdarzenie.
>
> W swoim programie wielowątkowym dorobiłem na szybkiego logowanie
> zdarzeń w celach debugging i używam "zakazanej" funkcji printf, jako że
> jest
> ona bardzo wygodna zwłaszcza z parsingiem argumentów typu %d lub %x
> w tekście... :-)
Wcale nie jest zakazana.
> Spodziewałem się jakichś efektów związanych z niereentrantnością tej
> funkcji, ale to co dostałem trochę mnie zaskoczyło...
Bo tu nie chodzi o printf, tylko o reentrancje calej biblioteki newlib.
Z drugiej strony Altera ma to zalatwione, wiec nie rozumiem czemu problem?
> Otóż co widzę, to że na wyjściu generowanym przez tą funkcję fprintf
> (strumień znaków RS232, "plikiem" dla fprintf jest port szeregowy)
> widzę że wątek o niższym priorytecie wchodzi z butami w linię tekstu
> wątka o wyższym priorytecie i wcięcie jest tam, gdzie fprintf robi ten
> parsing argumentów %d.
Bo nie masz tego jako atomic operation. Jestem na 99% pewny ze jako
atomic jest tylko zrobione wysylanie pojedynczych znakow.
Ma to sens, bo inaczej blokowalbys system na dosc dlugi czas (chyba ze
masz duze fifo - wtedy mozna sie o to pokusic).
> Task o priorytecie 3 schodki niżej, wciął się w środek fprintf'a od tasku
> o prawie najwyższym priorytecie i to w miejscu, gdzie skończyło się
> parsowanie argumentu %x i zaczął text printf'a.
Bo w miedzyczasie byla zmiana kontekstu. Czemu? Bo wyzszy watek czekal
na wyslanie znaku...
> Rozumiem, że skoro wywołania fprintf'a z tasków dotyczą tego samego
> portu szeregowego, przekazanego fprintf'owi jako argument nazwy pliku
> (globalna zmienna) to może się coś kiepścić, i linie się będa przeplatać,
> ale nie rozumiem jak taski o niższym priorytecie mogły się wstrzelić
> z TRZEMA OSOBNYMI WYWOŁANIAMI fprintf'a w jedną linię tasku
> o wyższym priorytecie? Przecież według filozofii MicroC/OS-II task
> bariery 0, w czasie chodzenia sobie po kodzie fprintfa nie powinien być
> przerwany i taski o priorytetach 4 czy tym bardziej 8 powinny grzecznie
> czekać aż fprintf wywołany przez task o priorytecie 1 ukończy zadanie
> i odda sterowanie systemowi operacyjnemu (nie ma tu wywłaszczania).
>
> Czy ktoś mógłby mi to wytłumaczyć?
A jak w priority 0 wstawic OSTimeDly(10), to tez nic innego sie nie
uruchomi? AFAIR driver usart Altery czeka na signal jak ma pelny bufor,
wiec w miedzyczasie inny watek idzie.
--
Jerry1111
Następne wpisy z tego wątku
- 29.09.09 22:06 Pszemol
- 30.09.09 13:25 Zbych
- 30.09.09 14:20 Pszemol
- 30.09.09 14:45 jotefka
- 30.09.09 15:25 Pszemol
- 30.09.09 18:43 Pszemol
- 30.09.09 20:35 DJ
- 30.09.09 21:09 Pszemol
- 01.10.09 18:10 J.F.
- 02.10.09 06:11 Artur M. Piwko
- 13.10.09 21:06 AK
- 13.10.09 21:34 Jerry1111
- 13.10.09 21:47 Pszemol
Najnowsze wątki z tej grupy
- Popr. 14. Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- Arch. Prog. Nieuprzywilejowanych w pełnej wer. na nowej s. WWW energokod.pl
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
- sprawdzanie słów kluczowych dot. zła
- Re: W czym sie teraz pisze programy??
- Re: (PDF) Surgical Pathology of Non-neoplastic Gastrointestinal Diseases by Lizhi Zhang
Najnowsze wątki
- 2025-01-17 Warszawa => Inżynier oprogramowania .Net <=
- 2025-01-17 Natalia z Andrychowa
- 2025-01-17 Gliwice => Business Development Manager - Dział Sieci i Bezpieczeńst
- 2025-01-17 Warszawa => System Architect (Java background) <=
- 2025-01-17 Warszawa => Full Stack .Net Engineer <=
- 2025-01-17 Gliwice => IT Expert (Network Systems area) <=
- 2025-01-17 Lublin => Programista Delphi <=
- 2025-01-17 Warszawa => Developer .NET (mid) <=
- 2025-01-17 Ostrów Wielkopolski => Konsultant Wdrożeniowy Comarch XL/Optima (Ksi
- 2025-01-17 Katowice => Senior Field Sales (system ERP) <=
- 2025-01-17 Wróblewo => Analityk finansowy <=
- 2025-01-17 Żerniki => Specjalista ds. Employer Brandingu <=
- 2025-01-17 pradnica krokowa
- 2025-01-17 Warszawa => International Freight Forwarder <=
- 2025-01-17 Warszawa => Helpdesk Specialist <=