-
Path: news-archive.icm.edu.pl!news.rmf.pl!agh.edu.pl!news.agh.edu.pl!news.onet.pl!not
-for-mail
From: "Pszemol" <P...@P...com>
Newsgroups: pl.comp.programming
Subject: Re: printf i wielozadaniowosc (MicroC/OS-II)
Date: Tue, 29 Sep 2009 11:47:34 -0500
Organization: http://onet.pl
Lines: 65
Message-ID: <h...@p...onet.pl>
References: <h...@p...onet.pl> <h9tc37$135h$1@news.mm.pl>
Reply-To: "Pszemol" <P...@B...com>
NNTP-Posting-Host: gw.petrovend.com
Mime-Version: 1.0
Content-Type: text/plain; format=flowed; charset="iso-8859-2"; reply-type=response
Content-Transfer-Encoding: 8bit
X-Trace: news.onet.pl 1254242901 11212 204.248.56.195 (29 Sep 2009 16:48:21 GMT)
X-Complaints-To: n...@o...pl
NNTP-Posting-Date: Tue, 29 Sep 2009 16:48:21 +0000 (UTC)
X-Posting-Agent: Hamster/1.3.13.0
In-Reply-To: <h9tc37$135h$1@news.mm.pl>
X-Priority: 3
X-MSMail-Priority: Normal
Importance: Normal
X-Newsreader: Microsoft Windows Live Mail 14.0.8064.206
X-MimeOLE: Produced By Microsoft MimeOLE V14.0.8064.206
Xref: news-archive.icm.edu.pl pl.comp.programming:183675
[ ukryj nagłówki ]"Zbych" <z...@o...pl> wrote in message news:h9tc37$135h$1@news.mm.pl...
> Pszemol pisze:
>
>> gdy wątek o wyższym priorytecie nie ma nic do roboty i czeka na
>> zdarzenie.
> [...]
>> 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
> [...]
>> Czy ktoś mógłby mi to wytłumaczyć?
>
> Żeby to dobrze wytłumaczyć to trzeba zobaczyć jak to jest
> zaimplementowane. Szklana kula mówi tylko, że wątek o wyższym priorytecie
> oddaje czas innym wątkom, bo czeka na zwolnienie miejsca w buforze
> nadawczym RSa. Przy czym nie masz żadnej gwarancji, że po zwolnieniu
> miejsca pierwszy do RSa dobierze się wątek o najwyższym priorytecie. Żeby
> wiedzieć co się dzieje to trzeba by na osobnym kanale wyrzucać kiedy i
> jakie wątki są uruchamiane.
To jest oczywista oczywistość, że wątek o priorytecie 1 czeka na port
RS i oddaje sterowanie :-) Mnie interesuje jak to się dzieje, że w czasie
gdy task 1 oddał sterowanie task 4 lub 7 był wstanie trzy razy wysłać
linię znaków do RS'a trzema osobnymi wywołaniami fprintfa...
Tu masz przykład:
"Barrier 0: s:14 M: c5aa5Barrier 4: handling legacy sensor readings
(time:1607)
Barr 4: Decrement counter (26) for legacy sensor (time:1607)
Barrier task 4, 'unknown' - wait one dev delay increment... (time:1608)
, M: 28521, M: 8b227, M: eddfc, M: 50b03, M: b365c, M: 223b1, M: 66cf0"
To wyżej to był efekt 4 osobnych wywołan funkcji fprintf:
task1 (barrier 0) zrobił najpierw to:
fprn(probe_out, "Barrier %d: s:%02ld M:%6lx, M:%6lx, M:%6lx, M:%6lx,
M:%6lx, M:%6lx, M:%6lx\r\n",
i w trakcie gdy utknął w tej linii czekając na RSa task 5 (barrier 4) zrobił
to:
fprn(barr_out, "Barrier %d: handling legacy sensor readings
(time:%ld)\r\n",
potem to w zupełnie innym miejscu kodu:
fprn(barr_out, "Barr %d: Decrement counter (%ld) for probe #%d
(time:%ld)\r\n",
i za moment to:
fprn(barr_out, "Barrier task %d, '%s' - wait one dev delay
increment... (time:%ld)\r\n",
w czasie gdy task 1 wisiał sobie i czekał na zwolnienie RSa...
Tak czy inaczej muszę przerobić to aby zostało to w kodzie na dłużej.
Chyba zrobię nowy task o najniższym priorytecie który zajmie się
odbiorem tekstów od tasków roboczych o wyższych priorytetach
i wstawianiem tych tekstów do portu szeregowego...
Następne wpisy z tego wątku
- 29.09.09 16:59 A.L.
- 29.09.09 18:08 grg12
- 29.09.09 18:35 Pszemol
- 29.09.09 20:46 Adam Dybkowski
- 29.09.09 21:04 Jerry1111
- 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
Najnowsze wątki z tej grupy
- Perfidne ataki krakerów z KRLD na skrypciarzy JS i Pajton
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- U nas propagują modę na SI, a w Chinach naukowcy SI po kolei umierają w wieku 40-50lat
- C++. Podróż Po Języku - komentarz
- "Wuj dobra rada" z KDAB rozważa: Choosing the Right Programming Language for Your Embedded Linux Device
- Nowa ustawa o ochronie praw autorskich - opis problemu i szkic ustawy
- Alg. kompresji LZW
- 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
Najnowsze wątki
- 2025-04-30 Szczecin => Key Account Manager IT <=
- 2025-04-30 Chiny => Koordynator Produkcji / Przedstawiciel ds. rozwoju produktu <
- 2025-04-30 Wrocław => Konsultant wdrożeniowy Comarch XL (Logistyka, WMS, Produk
- 2025-04-29 Nożownik zaatakował i zabił lekarza
- 2025-04-29 Polecam żarówki Blackout na Blackout z dużym gwintem
- 2025-04-29 Porażka kasty sędziowskiej przed Trybunałem Sprawiedliwości UE
- 2025-04-29 Kombinacja znaków A11 i B33?
- 2025-04-29 Na jakim etapie jest sprawa karna "gaśnicowego" Brauna z grudnia 2023?
- 2025-04-29 TSUE jest "przeciw a nawet za" neosędziami :-)
- 2025-04-29 Wrocław => Konsultant wdrożeniowy (systemy kontrolingowe) <=
- 2025-04-29 China => Production Coordinator / Representant Product Dev <=
- 2025-04-29 Warszawa => Specjalista rekrutacji IT <=
- 2025-04-28 Hiszpania bez pradu
- 2025-04-28 chinska stal
- 2025-04-28 QR kody