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

 
 
> Ох уж эти ENUM
inventor
сообщение Sep 10 2015, 14:24
Сообщение #1


Знающий
****

Группа: Свой
Сообщений: 524
Регистрация: 25-12-08
Из: Москва
Пользователь №: 42 748



Опять засада, правда почти разобрался

вобщем делаю в IAR определения для АЦП-ешки

CODE

typedef struct {
ADS131_ModeEn mode; /* режим работы */
ADS131_FreqEn sps; /* частота АЦП */
ADS131_PgaEn pga; /* PGA */
ADS131_MuxEn mux; /* Мультиплексор на входе */
ADS131_TestEn test_sign; /* Тестовый сигнал */
ADS131_TestFreqEn test_freq; /* Частота тестового сигнала */
u8 bitmap; /* Включенные каналы: 1 канал включен, 0 - выключен */
u8 file_len; /* Длина файла записи в часах */
} ADS131_Params;

//ADS131_XXX - определены как enum


Для того чтобы посмотреть, что там у меня получается -сделал прогу в С++ Builder
чтобы можно было настройки АЦП передавать своей DSP плате по посл. порту.
посмотрел в билдере sizeof(ADS131_Params)
опа - 28 байт
думаю, ну ладно, у меня объем буфера приема большой - не страшно
На приемной стороне нули, вместо адекватных значений.
Квырялся полдня - потом все же посмотрел, что IAR трактует енумы как байты
поэтому значения попадают на поле с нулем.
Надо исправить, но не знаю как как!
не хочу менять на u8 - так как названия ADS131_XXX более понятны
ищу опции у IAR "treat enum as int" или чего то подобное
не могу найти в опциях.
Как это правильно сделать?
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
SSerge
сообщение Sep 10 2015, 15:46
Сообщение #2


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

Группа: Свой
Сообщений: 1 719
Регистрация: 13-09-05
Из: Novosibirsk
Пользователь №: 8 528



Граждане, храните деньги читайте доки, особенно EWARM_DevelopmentGuide:
Цитата
The enum type
The compiler will use the smallest type required to hold enum constants, preferring
signed rather than unsigned.
When IAR Systems language extensions are enabled, and in C++, the enum constants
and types can also be of the type long, unsigned long, long long, or unsigned
long long.
To make the compiler use a larger type than it would automatically use, define an enum
constant with a large enough value. For example:
/* Disables usage of the char type for enum */
enum Cards{Spade1, Spade2,
DontUseChar=257};
For related information, see --enum_is_int, page 237.

А последняя строка - как раз об опции в командной строке делать все emum не меньше чем int.

ЗЫ. А также поддержу предыдущего оратора в том, что все эти ухищрения с размерами перечислений вряд ли помогут ввиду другой "особенности" языка. Дело в том, что представление структур в памяти (layout) тоже Implementation-defined, т.е. разные компиляторы могут по-разному разложить структуру в памяти.
Единственный надёжный способ общаться с внешним по отношению к программе миром - преобразование из внутреннего представления в четко определённый формат для передачи и обратное преобразование на приёме.
Сейчас это называется сериализация/десериализация.

PPS. Посмотрел что Ваши предыдущие темы были про техасские DSP, у них с пречислениями может быть иначе, в любом случае это должно быть описано в документации на компилятор. И засада со структурами тоже никуда не денется.


--------------------
Russia est omnis divisa in partes octo.
Go to the top of the page
 
+Quote Post
inventor
сообщение Sep 10 2015, 21:06
Сообщение #3


Знающий
****

Группа: Свой
Сообщений: 524
Регистрация: 25-12-08
Из: Москва
Пользователь №: 42 748



Цитата(SSerge @ Sep 10 2015, 18:46) *
Сейчас это называется сериализация/десериализация.

знаем. гугель протобуф
токак оне не поддерживает char

за ответ спасибо, еще один вопрос
где, в какой вкладке можно опцию компилятору задать --enum_is_int?
Go to the top of the page
 
+Quote Post



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

 


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


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