-
Path: news-archive.icm.edu.pl!newsfeed.gazeta.pl!news.onet.pl!not-for-mail
From: "Pszemol" <P...@P...com>
Newsgroups: pl.comp.programming,pl.misc.elektronika
Subject: Re: printf i wielozadaniowosc (MicroC/OS-II)
Date: Wed, 30 Sep 2009 09:20:18 -0500
Organization: http://onet.pl
Lines: 59
Message-ID: <h...@p...onet.pl>
References: <h...@p...onet.pl> <h9tc37$135h$1@news.mm.pl>
<h...@p...onet.pl> <h9vmcj$4pm$1@atlantis.news.neostrada.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 1254320342 10803 204.248.56.195 (30 Sep 2009 14:19:02 GMT)
X-Complaints-To: n...@o...pl
NNTP-Posting-Date: Wed, 30 Sep 2009 14:19:02 +0000 (UTC)
X-Posting-Agent: Hamster/1.3.13.0
In-Reply-To: <h9vmcj$4pm$1@atlantis.news.neostrada.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:183699 pl.misc.elektronika:572297
[ ukryj nagłówki ]"Zbych" <a...@o...pl> wrote in message
news:h9vmcj$4pm$1@atlantis.news.neostrada.pl...
> Pszemol pisze:
>
>> 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...
>
> Ktoś na pme podpowiedział ci, żebyś sprawdził, czy prawidłowo
> ustawiłeś priorytety wątków.
Nie do końca - on nazwał mnie debilem :-) i zarzucił że task o priorytecie
zero jest najmniej ważnym taskiem w systemie i z tego powodu - to co
obserwuję jest jak najbardziej naturalne. Zdemaskował tym w bardzo
niekulturalny sposób swój brak zaznajomienia z systemem MicroC/OS-II.
W książce autorstwa Jean J. Labrosse "MicroC/OS-II" wydanie
drugie z 2002 roku stoi na stronie 88 jak byk:
"Each task is assigned a unique priority level between 0 and
OS_LOWEST_PRIO, inclusive (see OS_CFG.H). Task priority
OS_LOWEST_PRIO is always assigned to the idle task when
uC/OS-II is initialized."
Mój system jest skonfigurowany w taki sposób, że istnieje w nim
32 poziomy priorytetów bo ustawione jest OS_LOWEST_PRIO=31.
Gdyby wciąż były jakieś wątpliwości co do tego który task wykona
się wcześniej a który później warto zwrócić uwagę na ten fragment:
"To determine which priority (and thus which task) will run next,
the scheduler in uC-OS-II determines the lowest priority number
that has its bit set in OSRdyTbl[]."
> Od siebie dorzucę tylko pytanie: czy ten system gwarantuje ci,
> że jak bufor RSa będzie wolny to w pierwszej kolejności dobierze się do
> niego wątek o najwyższym priorytecie?
> A może kto pierwszy ten lepszy?
Ten RT system miał mi gwarantować, że w danym momencie czasu
wykonuje się ten task spośród tasków gotowych do działania który
ma najwyższy priorytet. Ten warunek dotyczy zarówno typowego
reschedulingu (funkcja OS_Sched()) jak i reschedulingu po
zakończeniu obsługi przerwania. Na stronie 104 tej samej ksiązki:
"The conclusion of the ISR is marked by calling OSIntExit(), which
decrements the interrupt nesting counter. When the nesting counter
reaches 0, all nested interrupts are complete, and uC/OS-II needs
to determine whether a higher priority task has been awakened by
the ISR (or any other nested ISR). If a higher priority task is ready
to run, uC/OS-II returns to the higher priority task rather than to
the interrupted task."
A więc wciąż nie rozumiem dlaczego w momencie gdy przyszło
przerwanie od portu szeregowego (bo tylko w taki sposób mogło
się zwolnić miejsce w buforze portu) funkcja obsługi przerwania
RS232 nie obudziła tasku 0 który czeka na to miejsce i scheduler
zawołał mi do tablicy task 4 lub task 7 zamiast wrócić do tasku 0.
To jest właśnie cała zagadka o której próbuję tu podyskutować :-)
Następne wpisy z tego wątku
- 30.09.09 14:45 jotefka
- 30.09.09 15:25 Pszemol
- 30.09.09 18:10 Jan Kowalski
- 30.09.09 18:43 Pszemol
- 30.09.09 20:28 Jerry1111
- 30.09.09 20:35 DJ
- 30.09.09 21:09 Pszemol
- 30.09.09 21:15 Pszemol
- 30.09.09 21:58 Jerry1111
- 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
- 19.10.09 22:31 Pszemol
- 21.10.09 20:18 Jerry1111
Najnowsze wątki z tej grupy
- Kol. sukces po polsku: firma Szumisie sp. z o.o.
- Chińska Telefonia 6G - Chcą Nas Sterować Elektrycznie - Jak Kukiełki w Teatrze Lalek!!!
- RS-485 ale automatycznie dwukierunkowy
- Leżakujące SSD gubią po roku dane
- kolorowy e-paper
- Sterownik kotła CO praca PWM
- Jakie baterie A23 i LR44?
- OLED SSD1306 - degradacja?
- Który symulator AVR jest ,,prawilny"?
- Disk on Module, czym to odczytać?
- Pasta ochronna? Lutownicza?
- zagadka pneumatyczna
- Klip testowy, jak sie to używa
- Jak sie smazy elektronike z odleglosci kilkuset metrów?
- William Shockley, co-inventor of the transistor
Najnowsze wątki
- 2025-12-05 Warszawa => Architekt rozwiązań (Workday) - Legal Systems <=
- 2025-12-05 Warszawa => Konsultant Microsoft Dynamics AX/365 SCM Consultant - Serv
- 2025-12-05 Warszawa => Microsoft Dynamics AX/365 SCM Consultant - Service & Suppo
- 2025-12-05 Bieruń => Junior Dynamics 365 Finance Consultant <=
- 2025-12-05 Warszawa => Konsultant ERP Microsoft Dynamics 365 Commerce <=
- 2025-12-05 Wrocław => React Developer with knowledge of C++ <=
- 2025-12-05 Dieta dla prątkowców
- 2025-12-05 Wrocław => Programista React ze znajomością C++ <=
- 2025-12-05 Bieruń => Tester Automatyzujący (Junior/Mid) <=
- 2025-12-05 Warszawa => Konsultant Microsoft Dynamics 365 Finance <=
- 2025-12-05 Białystok => Dynamics 365 Commerce/POS Developer <=
- 2025-12-05 Blokada Porsche
- 2025-12-05 Warszawa => Account Manager - Sprzedaż Usług Rekrutacyjnych <=
- 2025-12-05 test
- 2025-12-05 Czyją własnością w RP3 byłby "ruski dron znaleziony na polu"? [Chłop dronowi nie przepuści (Mołdawia)]




Ile kosztują tanie mieszkania w polskich metropoliach?