-
Data: 2009-09-29 16:59:54
Temat: Re: printf i wielozadaniowosc (MicroC/OS-II)
Od: A.L. <a...@a...com> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]On Tue, 29 Sep 2009 10:42:52 -0500, "Pszemol" <P...@P...com>
wrote:
>
>Jak wytłumaczyć takie efekty?
>
[...]
>
>Czy ktoś mógłby mi to wytłumaczyć?
JA sie bardzd dawno tym zajmowlem i pod zupelnie inym systeme, a
bardzo dzawno znaczy BARDZO dawno. Ale mialem podobny problem
1. Task o wysokim priorytecie pisze do UART. UART ma wlasny bufor.
Bufor sie przepelnil i taksk dostal notyfikacje. System zawiesil task.
2. Wiec task o niskim priorytecie dostal CPU; w miedzyczasie UART
zaczal oproznaic budor, wiec taks o niskim priorytecie mogl pisac. Po
niedlugim czasie system zauwazyl ze task o wysokim priorytecie czeka
na UART, wiec zasiesil task o niskim priorytecie i ten zaczal pisac do
UART
W efekcie wyszla "sieczka" zlozona z fragmentow informacji z roznych
taskow.
Kluczowe pytanie jes co to znaczy ze printf "zakonczyl" dzialanie.
Powinien raportowac "zakonczenie" dzialania tylko wdedy gdy informacja
zostala rzeczywiscie fizycznie wyslana do klienta.
Nie wiem jak to jest w twoim systemie, ale podejrzewam ze cos takiego
lub podobnego.
Remedium byloby zamkniecie printf w osobnym tasku z wlasnum,
nieograniczonym buforem i potraktowanei calosci jako sekcji krytycznej
A.L.
Następne wpisy z tego wątku
- 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
- 13.10.09 21:06 AK
Najnowsze wątki z tej grupy
- "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
- 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?
Najnowsze wątki
- 2025-04-05 Wyrok dożywocia dla Polki
- 2025-04-04 Prezydium Sejmu Tuskiego orzekło: Poseł KO mecenas Roman Giertych NIE jest mordercą (w żadnym sensie tego słowa?)
- 2025-04-04 Reset komóry
- 2025-04-04 Lublin => JavaScript / Node / Fullstack Developer <=
- 2025-04-04 Zielonka => Key Account Manager IT <=
- 2025-04-04 Warszawa => Ekspert IT (obszar systemów sieciowych) <=
- 2025-04-04 Warszawa => Mid/Senior IT Recruiter <=
- 2025-04-04 Białystok => NMS System Administrator <=
- 2025-04-04 Warszawa => Spedytor Międzynarodowy <=
- 2025-04-04 Warszawa => Generative AI Engineer <=
- 2025-04-04 Warszawa => Gen AI Engineer <=
- 2025-04-04 Warszawa => Senior Programmer C <=
- 2025-04-04 Jak odróżnić myjki wibrujące od ultradźwiękowych.
- 2025-04-03 Ledy na wyłączniku czasowym błyskają
- 2025-04-03 Mapy w android-auto