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

 
 
3 страниц V   1 2 3 >  
Reply to this topicStart new topic
> Применение буферов больше 256 байт глючит sprintf, Камень stm32L476
Димон Безпарольн...
сообщение Aug 22 2017, 19:19
Сообщение #1


Знающий
****

Группа: Участник
Сообщений: 734
Регистрация: 29-11-10
Пользователь №: 61 247



Почему при использовании буферов (у меня их 4) в разных местах размером больше 256 (ставил 400) начинает рассыпаться sprintf - выводит глюки.

В чем может быть проблема?
Go to the top of the page
 
+Quote Post
x893
сообщение Aug 22 2017, 19:23
Сообщение #2


Профессионал
*****

Группа: Свой
Сообщений: 1 333
Регистрация: 27-10-08
Из: Планета Земля
Пользователь №: 41 226



Это ЧУДО !
Go to the top of the page
 
+Quote Post
Димон Безпарольн...
сообщение Aug 22 2017, 19:59
Сообщение #3


Знающий
****

Группа: Участник
Сообщений: 734
Регистрация: 29-11-10
Пользователь №: 61 247



Чисто поржать - мне не до смеха. Есть какая специфика использования таких буферов?
Go to the top of the page
 
+Quote Post
Lagman
сообщение Aug 22 2017, 20:01
Сообщение #4


Знающий
****

Группа: Свой
Сообщений: 875
Регистрация: 28-10-05
Пользователь №: 10 245



а буфер наверно объявлен как char с размером [0xff] и подаете вы туда utf8 sm.gif
Go to the top of the page
 
+Quote Post
Димон Безпарольн...
сообщение Aug 22 2017, 20:03
Сообщение #5


Знающий
****

Группа: Участник
Сообщений: 734
Регистрация: 29-11-10
Пользователь №: 61 247



Цитата(Lagman @ Aug 23 2017, 00:01) *
а буфер наверно объявлен как char с размером [0xff] и подаете вы туда utf8 sm.gif

Вовсе нет.

Буфер char buf[400]; и подаю я туда байты.
Go to the top of the page
 
+Quote Post
aaarrr
сообщение Aug 22 2017, 20:09
Сообщение #6


Гуру
******

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



Цитата(Димон Безпарольный @ Aug 22 2017, 22:59) *
Есть какая специфика использования таких буферов?

Никакой. Накладываются, наверно, буферы на стек - и привет.
Go to the top of the page
 
+Quote Post
jcxz
сообщение Aug 22 2017, 20:42
Сообщение #7


Гуру
******

Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713



Цитата(Димон Безпарольный @ Aug 22 2017, 22:59) *
Чисто поржать - мне не до смеха. Есть какая специфика использования таких буферов?

Вероятных причин может быть целая туча. А реальная вряд-ли связана со sprintf. Скорее баг у вас в другом месте.
Например: каков размера стека задачи, вызывающей sprintf?

PS: Не использую sprintf ни в одном из последних проектов....
Go to the top of the page
 
+Quote Post
Димон Безпарольн...
сообщение Aug 22 2017, 20:44
Сообщение #8


Знающий
****

Группа: Участник
Сообщений: 734
Регистрация: 29-11-10
Пользователь №: 61 247



Цитата(jcxz @ Aug 23 2017, 00:42) *
Например: каков размера стека задачи, вызывающей sprintf?

Как это узнать?
Go to the top of the page
 
+Quote Post
aaarrr
сообщение Aug 22 2017, 21:06
Сообщение #9


Гуру
******

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



Цитата(Димон Безпарольный @ Aug 22 2017, 23:44) *
Как это узнать?

Традиционный способ такой:
1. Заполняем выделенную под стек память каким-нибудь паттерном (хоть бы и однобайтовым)
2. Вызываем интересующую процедуру
3. Смотрим, сколько памяти было "затерто"
Go to the top of the page
 
+Quote Post
jcxz
сообщение Aug 22 2017, 21:18
Сообщение #10


Гуру
******

Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713



Цитата(Димон Безпарольный @ Aug 22 2017, 23:44) *
Как это узнать?

Это надо не узнавать. А задавать. У себя в исходниках. Если конечно писали их Вы....

Цитата(aaarrr @ Aug 23 2017, 00:06) *
3. Смотрим, сколько памяти было "затерто"

В некоторых случаях наблюдал как ..printf из IAR-овской библиотеки использовал до немного больше 256 байт стека.
Но это не при каждом вызове. Обычно - намного меньше. Так что "просто вызвать и посмотреть сколько потрёт" - тут не всегда сработает как надо.
Go to the top of the page
 
+Quote Post
Димон Безпарольн...
сообщение Aug 22 2017, 21:20
Сообщение #11


Знающий
****

Группа: Участник
Сообщений: 734
Регистрация: 29-11-10
Пользователь №: 61 247



Цитата(aaarrr @ Aug 23 2017, 01:06) *
Традиционный способ такой:
1. Заполняем выделенную под стек память каким-нибудь паттерном (хоть бы и однобайтовым)
2. Вызываем интересующую процедуру
3. Смотрим, сколько памяти было "затерто"

Слишком сложно.

Даже если смогу, как изменить размер?
Go to the top of the page
 
+Quote Post
aaarrr
сообщение Aug 22 2017, 21:29
Сообщение #12


Гуру
******

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



Цитата(jcxz @ Aug 23 2017, 00:18) *
В некоторых случаях наблюдал как ..printf из IAR-овской библиотеки использовал до немного больше 256 байт стека.
Но это не при каждом вызове. Обычно - намного меньше. Так что "просто вызвать и посмотреть сколько потрёт" - тут не всегда сработает как надо.

Да форматированный ввод-вывод очень прожорлив. Смотреть, естественно, наиболее навороченные вызовы.

Цитата(Димон Безпарольный @ Aug 23 2017, 00:20) *
Слишком сложно.

Несколько строк кода.

Цитата(Димон Безпарольный @ Aug 23 2017, 00:20) *
Даже если смогу, как изменить размер?

Этот момент лучше выяснять задолго до введения нескольких буферов по 400 байт.

Кстати,
Цитата(Димон Безпарольный @ Aug 22 2017, 23:03) *
Буфер char buf[400]; и подаю я туда байты.

buf - не локальный часом?
Go to the top of the page
 
+Quote Post
Димон Безпарольн...
сообщение Aug 22 2017, 21:30
Сообщение #13


Знающий
****

Группа: Участник
Сообщений: 734
Регистрация: 29-11-10
Пользователь №: 61 247



Цитата(aaarrr @ Aug 23 2017, 01:29) *
buf - не локальный часом?

Локальный. А что?
Go to the top of the page
 
+Quote Post
jcxz
сообщение Aug 22 2017, 21:33
Сообщение #14


Гуру
******

Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713



Цитата(aaarrr @ Aug 23 2017, 00:29) *
Цитата(Димон Безпарольный @ Aug 22 2017, 23:03) *

Буфер char buf[400]; и подаю я туда байты.

buf - не локальный часом?

biggrin.gif

Это надо уже заносить в faq для чайников.
Go to the top of the page
 
+Quote Post
Димон Безпарольн...
сообщение Aug 22 2017, 21:36
Сообщение #15


Знающий
****

Группа: Участник
Сообщений: 734
Регистрация: 29-11-10
Пользователь №: 61 247



Полагаю есть ограничение? Уж не 255 ли?
Go to the top of the page
 
+Quote Post

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

 


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


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