|
Как записать/считать float в/из EEPROM, ATmega8 |
|
|
|
Oct 27 2010, 08:08
|

Гуру
     
Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095

|
Цитата(sergeeff @ Oct 27 2010, 09:12)  А для чего явное задание адреса цифрами, да еще и без приведения к указателю? Код s s1, s2; s EEMEM s1_ee, s2_ee; eeprom_write_block(&s1, &s1_ee, sizeof(s1)); eeprom_read_block(&s2, &s2_ee, sizeof(s2));
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
|
Oct 27 2010, 08:53
|
Профессионал
    
Группа: Свой
Сообщений: 1 481
Регистрация: 10-04-05
Пользователь №: 4 007

|
Я просто хотел показать, как писать/читать структуру в/из eeprom. Ясно, что указатель "куда" в eeprom надо как-то по-приличнее определить, но и Код s EEMEM s1_ee, s2_ee; что-то напутанное собой представляет.
|
|
|
|
|
Oct 27 2010, 09:03
|

Гуру
     
Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095

|
Цитата(sergeeff @ Oct 27 2010, 11:53)  но и Код s EEMEM s1_ee, s2_ee; что-то напутанное собой представляет. Это с непривычки. ведь Код s const s1_const, s2_const; читается вполне ясно.
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
|
Oct 27 2010, 17:24
|
Участник

Группа: Участник
Сообщений: 50
Регистрация: 3-09-10
Пользователь №: 59 263

|
Цитата(sergeeff @ Oct 27 2010, 17:01)  Нет там никакого оверхеда Конечно нет. И про ОЗУ тут напрасно беспокоятся. Совершенно нормально, что я переношу из ЕЕПРОМ в ОЗУ все оперативные данные, работаю с ними - а при необходимости прячу снова в ЕЕПРОМ. Вытаскивать 1 байт из ЕЕПРОМ во время обработки данны - это чуднО  Цитата(sergeeff @ Oct 27 2010, 17:01)  Беда в том, что это непереносимая конструкция. Почему? Куда непереносимая? Или просто Вы ее не переносите  Цитата(sergeeff @ Oct 27 2010, 17:01)  Вопрос в том, на кой это надо, если безо всяких union работает. Ну, я это использую потому, что при чтении из ЕЕПРОМ и записи туда подсчитываю контрольную сумму. И мне удобно обращаться поэлементно к массиву. Если и при Вашем подходе можно подсчитывать побайтно сумму - то признаю с готовностью, что много лет у меня болталась напрасно усложненная конструкция  Спасибо за подсказку!
|
|
|
|
|
Oct 27 2010, 20:38
|
Профессионал
    
Группа: Свой
Сообщений: 1 481
Регистрация: 10-04-05
Пользователь №: 4 007

|
Цитата(drvlas @ Oct 27 2010, 20:24)  Почему? Куда непереносимая? Или просто Вы ее не переносите  Например, тут : http://www.cplusplus.com/doc/tutorial/other_data_types/написано: "The exact alignment and order of the members of a union in memory is platform dependant." Или здесь: http://www.drdobbs.com/184403890Цитата Ну, я это использую потому, что при чтении из ЕЕПРОМ и записи туда подсчитываю контрольную сумму. И мне удобно обращаться поэлементно к массиву. Если и при Вашем подходе можно подсчитывать побайтно сумму - то признаю с готовностью, что много лет у меня болталась напрасно усложненная конструкция  Спасибо за подсказку! Вас же, наверное, интересует crc всей структуры? Кто тогда мешает сделать: Код s s1; uint crc_val = crc(&s1, sizeof(s1));
|
|
|
|
|
Oct 27 2010, 21:43
|

I WANT TO BELIEVE
     
Группа: Свой
Сообщений: 2 617
Регистрация: 9-03-08
Пользователь №: 35 751

|
Цитата И про ОЗУ тут напрасно беспокоятся. Совершенно нормально, что я переношу из ЕЕПРОМ в ОЗУ все оперативные данные, работаю с ними Ну я немного погодя додумал, что погорячился. Кстати говоря, никто не мешает натравить на начало структуры поинтер char *ptr и прогнать его по всем байтам. Зачем там массив явно объявлять? Более того, к этому поинтеру можно скобочки нарисовать ptr[] и синтаксически будет выглядеть как массив  Правда, засада может быть если там в структуре для выравнивания дырки имеются. Но, как уже говорилось, нас то интересует crc всей структуры и ничего не мешает посчитать его в месте с теми дырками и с ними же и хранить в EEPROM. Ну а вообще структуру сделать packed чтоб без дырок была.... В общем я тоже не вижу смысла в юнионе. Одни минусы от его использования получаются.
--------------------
The truth is out there...
|
|
|
|
|
Oct 28 2010, 12:05
|
Участник

Группа: Участник
Сообщений: 50
Регистрация: 3-09-10
Пользователь №: 59 263

|
Убедили меня  По второму пункту. Ибо, что касается приведенных ссылок Цитата(sergeeff @ Oct 27 2010, 23:38)  Например, тут... написано: "The exact alignment and order of the members of a union in memory is platform dependant." ...то здесь я же говорил: использую массив только при записи-чтении всей структуры в ЕЕПРОМ. И мне в это время до лампочки, какое там выравнивание и размещение. Согласны? Цитата(sergeeff @ Oct 27 2010, 23:38)  Вас же, наверное, интересует crc всей структуры? Кто тогда мешает сделать: Код s s1; uint crc_val = crc(&s1, sizeof(s1)); Ну, так кто ж знал Спасибо, буду знать. Если crc() есть во всех компиляторах, то даже переносимость не ухудшится. Но все же не могу не отметить, что в моем случае (с учетом вышеобозначенного способа использования союза) удобство предложенного уважаемым товарищем ergeeff способа - только в обращении к элементам структуры без лишнего .u
|
|
|
|
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|