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

 
 
> Функция sprintf
aBoomest
сообщение Jul 4 2018, 09:41
Сообщение #1


Частый гость
**

Группа: Участник
Сообщений: 167
Регистрация: 24-12-08
Из: Россия
Пользователь №: 42 714



Добрый день.
Работаю на NXP MK66FN2M0xxx18.
При этом при использовании функции sprintf для вывода чисел с плавающей запятой, программа на этой функции вылетает. Убираешь %f (т.е. выводишь все кроме float'ов) - все работает.
Кто сталкивался с подобным?

На сайте IAR нашел следующее https://www.iar.com/support/tech-notes/gene...point-f-on-arm/
Правда думается, что не о том.


--------------------
C уважением!
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
Jenya7
сообщение Jul 7 2018, 06:05
Сообщение #2


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

Группа: Участник
Сообщений: 1 778
Регистрация: 29-03-12
Пользователь №: 71 075



уверен там хардварный FPU. включите его
Код
#define CORTEX_M4_BLOCK  0xe000e000
#define CPACR *(unsigned long *)(CORTEX_M4_BLOCK + 0xd88)  // Co-processor Access Control

//__enable_FPU();  
CPACR |= (0xf << 20);   // enable access to FPU
а вообще sprintf монструозная функция для эмбедед. никогда не использовал ее.
Go to the top of the page
 
+Quote Post
jcxz
сообщение Jul 24 2018, 11:09
Сообщение #3


Гуру
******

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



Цитата(Jenya7 @ Jul 7 2018, 09:05) *
а вообще sprintf монструозная функция для эмбедед. никогда не использовал ее.

Поразительно - человек беспокоится о расходе стека printf()-ом, но при этом даже не задумываясь лепит кучу константных данных в ОЗУ (строки, массивы указателей на строки и т.п. - как видно из разных его сообщений на форуме). В местах где это ну совершенно не нужно. wacko.gif
Go to the top of the page
 
+Quote Post
Jenya7
сообщение Jul 24 2018, 11:23
Сообщение #4


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

Группа: Участник
Сообщений: 1 778
Регистрация: 29-03-12
Пользователь №: 71 075



Цитата(jcxz @ Jul 24 2018, 16:09) *
Поразительно - человек беспокоится о расходе стека printf()-ом, но при этом даже не задумываясь лепит кучу константных данных в ОЗУ (строки, массивы указателей на строки и т.п. - как видно из разных его сообщений на форуме). В местах где это ну совершенно не нужно. wacko.gif


а что плохого если строки лежат во txt секции?
Go to the top of the page
 
+Quote Post
jcxz
сообщение Jul 24 2018, 11:46
Сообщение #5


Гуру
******

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



Цитата(Jenya7 @ Jul 24 2018, 14:23) *
а что плохого если строки лежат во txt секции?

В какой txt-секции? Так как Вы пишете, все Ваши строки и указатели на них лежат в ОЗУ + инициализирующие значения лежат во флешь.
А если передаёте в некую функцию строку типа: Func("си_не_знаю_пишу_как_попало") и эта Func объявлена как Func(char *), то такой вызов говорит компилятору до вызова функции создать переменную char t[] = "си_не_знаю_пишу_как_попало"; где-то в ОЗУ - или на стеке или в static памяти, проинициализировав её в runtime из константы char const ti[] = "си_не_знаю_пишу_как_попало"; во флешь.
Go to the top of the page
 
+Quote Post
scifi
сообщение Jul 24 2018, 11:52
Сообщение #6


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



Цитата(jcxz @ Jul 24 2018, 14:46) *
А если передаёте в некую функцию строку типа: Func("си_не_знаю_пишу_как_попало") и эта Func объявлена как Func(char *), то такой вызов говорит компилятору до вызова функции создать переменную char t[] = "си_не_знаю_пишу_как_попало"; где-то в ОЗУ - или на стеке или в static памяти, проинициализировав её в runtime из константы char const ti[] = "си_не_знаю_пишу_как_попало"; во флешь.

Ну это уже совсем трэш, угар и содомия. Вот не при помню ни одного повода, по которому неявно создавалась бы строка в ОЗУ. И в данном случае точно нет.
Поправка: если возвращать из функции по значению структуру, содержащую строку, эта структура будет временно создана на стеке. Но это совсем другой случай, конечно.
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- aBoomest   Функция sprintf   Jul 4 2018, 09:41
- - jcxz   Цитата(aBoomest @ Jul 4 2018, 12:41) При ...   Jul 4 2018, 09:55
|- - megajohn   Цитата(jcxz @ Jul 4 2018, 13:55) Вангую и...   Jul 4 2018, 10:34
|- - scifi   Цитата(megajohn @ Jul 4 2018, 13:34) либо...   Jul 4 2018, 10:42
- - aBoomest   1. Операционок нет, для прерываний контекст сохран...   Jul 4 2018, 10:49
|- - scifi   Цитата(aBoomest @ Jul 4 2018, 13:49) Стэк...   Jul 4 2018, 11:13
|- - jcxz   Цитата(scifi @ Jul 4 2018, 14:13) Кстати,...   Jul 4 2018, 11:28
|- - demiurg_spb   Может банальное переполнение буфера? HINT: Попробу...   Jul 4 2018, 12:36
|- - scifi   Цитата(demiurg_spb @ Jul 4 2018, 15:36) М...   Jul 4 2018, 12:56
- - aBoomest   Цитата(scifi @ Jul 4 2018, 14:13) Именно....   Jul 5 2018, 19:29
|- - jcxz   Цитата(aBoomest @ Jul 5 2018, 22:29) Уваж...   Jul 6 2018, 08:50
|- - Arlleex   Цитата(Jenya7 @ Jul 24 2018, 15:23) а что...   Jul 24 2018, 11:40
|- - jcxz   Цитата(scifi @ Jul 24 2018, 14:52) Ну это...   Jul 24 2018, 12:03
|- - scifi   Цитата(jcxz @ Jul 24 2018, 15:03) попробу...   Jul 24 2018, 12:06
|- - jcxz   Цитата(scifi @ Jul 24 2018, 15:06) Это яв...   Jul 24 2018, 12:21
|- - scifi   Цитата(jcxz @ Jul 24 2018, 15:21) Ну так ...   Jul 24 2018, 12:26
|- - Сергей Борщ   QUOTE (scifi @ Jul 24 2018, 15:26) Нет, н...   Jul 24 2018, 12:54
|- - jcxz   Цитата(scifi @ Jul 24 2018, 15:26) Нет, н...   Jul 24 2018, 13:49
|- - scifi   Цитата(jcxz @ Jul 24 2018, 16:49) Значит ...   Jul 24 2018, 14:23
||- - jcxz   Цитата(scifi @ Jul 24 2018, 17:23) Вообще...   Jul 25 2018, 06:03
||- - scifi   Цитата(jcxz @ Jul 25 2018, 09:03) Хотя-бы...   Jul 25 2018, 07:05
||- - jcxz   Цитата(scifi @ Jul 25 2018, 10:05) Я дово...   Jul 25 2018, 07:38
||- - scifi   Цитата(jcxz @ Jul 25 2018, 10:38) Но при ...   Jul 25 2018, 08:25
||- - jcxz   Цитата(scifi @ Jul 25 2018, 11:25) Компил...   Jul 25 2018, 10:18
|- - VladislavS   Цитата(jcxz @ Jul 24 2018, 16:49) Значит ...   Jul 25 2018, 11:13
|- - Arlleex   Цитата(VladislavS @ Jul 25 2018, 15:13) В...   Jul 25 2018, 11:41
|- - jcxz   Цитата(VladislavS @ Jul 25 2018, 14:13) О...   Jul 25 2018, 11:46
- - aBoomest   Цитата(Jenya7 @ Jul 7 2018, 09:05) а вооб...   Jul 21 2018, 09:57
|- - Arlleex   Цитата(aBoomest @ Jul 21 2018, 12:57) Как...   Jul 21 2018, 11:10
|- - thermit   Цитата(aBoomest @ Jul 21 2018, 12:57) Как...   Jul 21 2018, 11:57
|- - Jenya7   Цитата(aBoomest @ Jul 21 2018, 14:57) Как...   Jul 24 2018, 09:14
- - Jenya7   я создам отдельную тему в В помощь начинающему ...   Jul 24 2018, 12:14
- - scifi   Цитата(Сергей Борщ @ Jul 24 2018, 15:54) ...   Jul 24 2018, 13:04
|- - VladislavS   Цитата(scifi @ Jul 24 2018, 16:04) Это оч...   Jul 24 2018, 13:11
- - VladislavS   Ещё как ругается. Если в Print(char *s); передать ...   Jul 25 2018, 11:51
|- - jcxz   Цитата(VladislavS @ Jul 25 2018, 14:51) Е...   Jul 25 2018, 12:16
|- - VladislavS   Цитата(jcxz @ Jul 25 2018, 15:16) Как Вы ...   Jul 25 2018, 12:24
- - scifi   Цитата(scifi @ Jul 25 2018, 11:25) Компил...   Jul 25 2018, 12:27
- - VladislavS   Цитата(scifi @ Jul 25 2018, 15:27) Очевид...   Jul 25 2018, 12:30
- - jcxz   Цитата(scifi @ Jul 25 2018, 15:27) Очевид...   Jul 25 2018, 15:42


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

 


RSS Текстовая версия Сейчас: 20th June 2025 - 17:28
Рейтинг@Mail.ru


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