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

 
 
> Битовые поля - есть ли способ поменять Little Endian на Big Endian, расположение битов
sonycman
сообщение May 30 2009, 22:21
Сообщение #1


Любитель
*****

Группа: Свой
Сообщений: 1 864
Регистрация: 20-08-06
Из: Тольятти
Пользователь №: 19 695



Осваиваю тут карты памяти, и возникла нужда поработать со структурами их регистров.
К примеру:
Код
__packed    struct    CID
{
    byte        man_ID:            8;
    byte        oem_ID[2];
    byte        product_name[5];
    byte        revision:        8;
    dword        serial:            32;
    unsigned    :                4;
    word        man_date:        12;
    unsigned    crc:            7;
    unsigned    dummy:            1;
};

Вроде бы всё хорошо, да только данные в такой структуре должны идти линейно сверху вниз - байт 0 - биты 31...24, байт 1 - биты 23...16 и т.д. (big endian).
А компилятор (RealView) считает наоборот - сначала младшие биты (little endian).

То есть читаем слово revision, в регистре должны быть данные вида 0x08070605 [31...0], а на деле имеем 0x05060708...

Есть ли способ побороть такую досадную "однобокость"?
Иначе придётся ручками обрабатывать все битовые сдвиги и маски... crying.gif
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
Rst7
сообщение May 31 2009, 10:26
Сообщение #2


Йа моск ;)
******

Группа: Модераторы
Сообщений: 4 345
Регистрация: 7-07-05
Из: Kharkiv-city
Пользователь №: 6 610



Цитата
ARM в базовой реинкарнации - тоже....


Да там один define в HDL. Кстати, т.к. 68k - суть большой индеец, то в моторолловских телефонах ядро ARM собрано именно в BE smile.gif Так что не такая уж это и редкость smile.gif


--------------------
"Практика выше (теоретического) познания, ибо она имеет не только достоинство всеобщности, но и непосредственной действительности." - В.И. Ленин
Go to the top of the page
 
+Quote Post
zltigo
сообщение May 31 2009, 14:31
Сообщение #3


Гуру
******

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



Цитата(Rst7 @ May 31 2009, 13:26) *
68k - суть большой индеец...

Вот этот мамот и имелся ввиду в первом посте.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
VslavX
сообщение May 31 2009, 20:17
Сообщение #4


embarrassed systems engineer
*****

Группа: Свой
Сообщений: 1 083
Регистрация: 24-10-05
Из: Осокорки
Пользователь №: 10 038



Еще PowerPC очень неплохо себя в BE чувствуют. Коммуникационные XScale тоже в BE часто используются. На самом деле, какое ядро - не особо важно, определяющим является формат периферии. Я пробовал LE на MPC83xx - лучше не надо, перешел в BE - совсем оно не так страшно оказалось. Если данные правильно типизированы - то при портировании проблем минимум.
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- sonycman   Битовые поля - есть ли способ поменять Little Endian на Big Endian   May 30 2009, 22:21
- - sergeeff   Это определяется используемым компилятором и возмо...   May 30 2009, 23:59
- - zltigo   Цитата(sonycman @ May 31 2009, 01:21) А к...   May 31 2009, 06:55
|- - Сергей Борщ   Цитата(zltigo @ May 31 2009, 09:55) (они ...   May 31 2009, 08:25
|- - zltigo   Цитата(Сергей Борщ @ May 31 2009, 11:25) ...   May 31 2009, 08:38
- - sonycman   sergeeff zltigo Понятно, спасибо. Так и думал, что...   May 31 2009, 07:51
|- - zltigo   Цитата(sonycman @ May 31 2009, 10:51) Тут...   May 31 2009, 08:18
|- - sonycman   Цитата(zltigo @ May 31 2009, 12:18) Нафиг...   May 31 2009, 08:23
- - AirDevil   Цитата(sonycman @ May 31 2009, 01:21) ......   May 31 2009, 07:54
|- - sonycman   Цитата(AirDevil @ May 31 2009, 11:54) Исп...   May 31 2009, 07:57
|- - Сергей Борщ   Цитата(sonycman @ May 31 2009, 10:57) Что...   May 31 2009, 08:13
|- - sonycman   Цитата(Сергей Борщ @ May 31 2009, 12:13) ...   May 31 2009, 08:19
||- - zltigo   Цитата(sonycman @ May 31 2009, 11:19) Так...   May 31 2009, 08:29
||- - Сергей Борщ   Цитата(sonycman @ May 31 2009, 11:19) Они...   May 31 2009, 08:31
||- - sonycman   Цитата(zltigo @ May 31 2009, 12:29) Ужас....   May 31 2009, 08:34
|- - zltigo   Цитата(Сергей Борщ @ May 31 2009, 11:13) ...   May 31 2009, 08:20


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

 


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


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