реклама на сайте
подробности

 
 
 
Reply to this topicStart new topic
> Диагностика в отдельном потоке + printf
FormatCft
сообщение Dec 9 2008, 12:36
Сообщение #1


Местный
***

Группа: Свой
Сообщений: 331
Регистрация: 22-07-08
Из: Р О С С И Я
Пользователь №: 39 145



Решил вынести выдачу диагностических сообщений в отдельный поток.
===
Есть стандартная фукция printf и как организовать передачу этой функции аргументы, не понятно. У принтф может быть их несколько.
===
Не подскажите как решаете эту задачу вы?
Go to the top of the page
 
+Quote Post
aaarrr
сообщение Dec 9 2008, 12:39
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 10 713
Регистрация: 11-12-04
Пользователь №: 1 448



Цитата(FormatCft @ Dec 9 2008, 15:36) *
Есть стандартная фукция printf и как организовать передачу этой функции аргументы, не понятно. У принтф может быть их несколько.

Вопрос-то в чем? Что, как и кому Вы собираетесь передавать?
Go to the top of the page
 
+Quote Post
FormatCft
сообщение Dec 9 2008, 12:46
Сообщение #3


Местный
***

Группа: Свой
Сообщений: 331
Регистрация: 22-07-08
Из: Р О С С И Я
Пользователь №: 39 145



Цитата(aaarrr @ Dec 9 2008, 17:39) *
Вопрос-то в чем? Что, как и кому Вы собираетесь передавать?

Есть много потоков в которых я желаю выводить диагн инф.
Но возникают глюки связанные с разруливанием ресура под названием printf (диагностического порта).
===
Решил используя очереди и сейчас стоит вопрос как передавать через очереди параметры на функцию принтф.
===
пример:
printf("Hello russian vodka v %d gradusov", (unsigned short) 40 );
и хочется передать принтфу: "Hello russian vodka v %d gradusov", (unsigned short) 40
Go to the top of the page
 
+Quote Post
MrYuran
сообщение Dec 9 2008, 13:01
Сообщение #4


Беспросветный оптимист
******

Группа: Свой
Сообщений: 4 640
Регистрация: 26-12-07
Из: Н.Новгород
Пользователь №: 33 646



Цитата(FormatCft @ Dec 9 2008, 15:46) *
и хочется передать принтфу: "Hello russian vodka v %d gradusov", (unsigned short) 40

Так нельзя. задавайте фиксированный формат сообщения, типа printf("%s %d",char comment, int parameter) и передавайте в поток соответствующие переменные


--------------------
Программирование делится на системное и бессистемное. ©Моё :)
— а для кого-то БГ — это Bill Gilbert =)
Go to the top of the page
 
+Quote Post
FormatCft
сообщение Dec 9 2008, 13:12
Сообщение #5


Местный
***

Группа: Свой
Сообщений: 331
Регистрация: 22-07-08
Из: Р О С С И Я
Пользователь №: 39 145



Цитата(MrYuran @ Dec 9 2008, 18:01) *
Так нельзя. задавайте фиксированный формат сообщения, типа printf("%s %d",char comment, int parameter) и передавайте в поток соответствующие переменные

===
Можете поподробнее?
===
Может всё-таки есть выход на любой случай жизни? А то таких конструкций можно до бесконечности писать (с фиксированным форматом).
===
Go to the top of the page
 
+Quote Post
MrYuran
сообщение Dec 9 2008, 13:21
Сообщение #6


Беспросветный оптимист
******

Группа: Свой
Сообщений: 4 640
Регистрация: 26-12-07
Из: Н.Новгород
Пользователь №: 33 646



Цитата(FormatCft @ Dec 9 2008, 16:12) *
Можете поподробнее?

Смысл в том, что строку параметров, которая в кавычках, передать никак нельзя, т.к она const* char и компилятор её подставляет по месту.
А ещё лучше использовать sprintf() и формировать текстовый буфер, а потом отправлять его в любой поток и делать с ним всё что угодно.
Про то, что на слабых контроллерах лучше вообще не использовать printf , я даже не упоминаю.


--------------------
Программирование делится на системное и бессистемное. ©Моё :)
— а для кого-то БГ — это Bill Gilbert =)
Go to the top of the page
 
+Quote Post
FormatCft
сообщение Dec 9 2008, 13:30
Сообщение #7


Местный
***

Группа: Свой
Сообщений: 331
Регистрация: 22-07-08
Из: Р О С С И Я
Пользователь №: 39 145



Цитата(MrYuran @ Dec 9 2008, 18:21) *
Смысл в том, что строку параметров, которая в кавычках, передать никак нельзя, т.к она const* char и компилятор её подставляет по месту.
А ещё лучше использовать sprintf() и формировать текстовый буфер, а потом отправлять его в любой поток и делать с ним всё что угодно.
Про то, что на слабых контроллерах лучше вообще не использовать printf , я даже не упоминаю.

Понял. Спасибо огромное! Проверил всё работает просто замечательно!
А на счет принтфа я не согласен. У меня всё летает на 24МГц с 12ю потоками и задачами не самыми простыми. Главное приоритет сделать поменьше у принтфа. У меня ему приоритет самый низкий дан.
Go to the top of the page
 
+Quote Post
zltigo
сообщение Dec 9 2008, 17:19
Сообщение #8


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(MrYuran @ Dec 9 2008, 16:21) *
А ещё лучше использовать sprintf() и формировать текстовый буфер, а потом отправлять его в любой поток и делать с ним всё что угодно.

Вообще-то vfprintf(),vprintf(),vspritf() для подобного естественнее.
Код
void myprintf( char *arg_list, ...)
{
va_list arg_buffer;
    va_start( arg_buffer, arg_list );
    vsprintf( outbuffer, arg_list, arg_buffer );
..........


Цитата(MrYuran @ Dec 9 2008, 16:21) *
Смысл в том, что строку параметров, которая в кавычках, передать никак нельзя

C чего-бы это вдруг...
Код
printf( format, keyword_full, pvalue, err_cnt ? " <-Error" : "" );


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
FormatCft
сообщение Dec 9 2008, 17:21
Сообщение #9


Местный
***

Группа: Свой
Сообщений: 331
Регистрация: 22-07-08
Из: Р О С С И Я
Пользователь №: 39 145



Цитата(zltigo @ Dec 9 2008, 22:19) *
Вообще-то vfprintf(),vprintf(),vspritf() для подобного естественнее.
Код
void myprintf( char *arg_list, ...)
{
va_list arg_buffer;
    va_start( arg_buffer, arg_list );
    vsprintf( outbuffer, arg_list, arg_buffer );
..........

C чего-бы это вдруг...

Во-о-о-о! То что надо! Спасибо!
Go to the top of the page
 
+Quote Post
FormatCft
сообщение Dec 13 2008, 20:40
Сообщение #10


Местный
***

Группа: Свой
Сообщений: 331
Регистрация: 22-07-08
Из: Р О С С И Я
Пользователь №: 39 145



Цитата(MrYuran @ Dec 9 2008, 18:21) *
...лучше вообще не использовать printf...

===
Я сначала использовал стандартный debug_printf из CW - он оптимизирован и работает шустро. Решил попробовать стандартный принтф и началались тормоза отладки (символы печатаются чуть ли не медленнее чем печатаю сам).
===
Так что Вы правы!
Go to the top of the page
 
+Quote Post
HARMHARM
сообщение Dec 16 2008, 09:42
Сообщение #11


читатель даташитов
****

Группа: Свой
Сообщений: 853
Регистрация: 5-11-06
Из: Днепропетровск
Пользователь №: 21 999



Если на контроллере свободно живет и дышит FreeRTOS, то уж для printf производительности должно хватить. Можно взять упрощенную реализацию без float и пр. Для вывода строки по узказателю из printf можно использовать ( "%*.*s", minlen, maxlen, strptr ).
Go to the top of the page
 
+Quote Post

Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 13th July 2025 - 10:15
Рейтинг@Mail.ru


Страница сгенерированна за 0.01469 секунд с 7
ELECTRONIX ©2004-2016