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

 
 
> Запись int по указателю на произвольный адрес и выравнивание
0x435641
сообщение Jul 26 2012, 05:19
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 15
Регистрация: 26-07-12
Пользователь №: 72 908



Доброго времени суток.

начну с кода:

char arr[16];

int *pi1 = (int*)arr[0];
int *pi2 = (int*)arr[1];
int *pi3 = (int*)arr[2];
int *pi4 = (int*)arr[3];

*pi1 = 0x11223344;
*pi2 = 0x11223344;
*pi3 = 0x11223344;
*pi4 = 0x11223344;


среда IAR 6.30.1

в результате запись происходит по адресам со сдвигом влево до границы кратной размеру адресуемого типа. это смотрел через J-Link
в листинге каждая запись производится инструкцией STR R0, [Rx]... при чем в Rx лежат правильные значения с шагом в 1 байт.

тот же результат в uVision 4

если же запустить отладку в симуляторе, то при каждой записи по не кратному адресу вылетает сообщение
"STR instruction at addr: 0x40006835 made an illegal unaligned access to 0x40006835"

информации о том, что адрес должен быть выровнен для STR/LDR по 4 байтам для STRH/LDRH по 2 байта я не нашел.
пусть даже должен быть выровнен. почему компилятор не преобразует команду записи по указателю в набор инструкций с побайтовой записью, учитывая специфику адресации?
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
demiurg_spb
сообщение Jul 26 2012, 05:21
Сообщение #2


неотягощённый злом
******

Группа: Свой
Сообщений: 2 746
Регистрация: 31-01-08
Из: Санкт-Петербург
Пользователь №: 34 643



применяйте атрибут __packed к указателю
http://www.keil.com/support/man/docs/armcc...ef_CJAFJHJD.htm


--------------------
“Будьте внимательны к своим мыслям - они начало поступков” (Лао-Цзы)
Go to the top of the page
 
+Quote Post
0x435641
сообщение Jul 26 2012, 05:29
Сообщение #3


Участник
*

Группа: Участник
Сообщений: 15
Регистрация: 26-07-12
Пользователь №: 72 908



я работаю в IAR. кейл только для проверки использовал.

__packed int *pi1 = (int*)&arr[0];
__packed int *pi2 = (int*)&arr[1];
__packed int *pi3 = (int*)&arr[2];
__packed int *pi4 = (int*)&arr[3];

*pi1 = 0x11223344;
*pi2 = 0x11223344;
*pi3 = 0x11223344;
*pi4 = 0x11223344;


в симуляторе с теми же сообщениями, но память заполнилась правильно. через J-Link опять все легло поверх в одно место
кстати в ASM листинге без изменений - те же инструкции

Сообщение отредактировал 0x435641 - Jul 26 2012, 05:32
Go to the top of the page
 
+Quote Post
demiurg_spb
сообщение Jul 26 2012, 05:38
Сообщение #4


неотягощённый злом
******

Группа: Свой
Сообщений: 2 746
Регистрация: 31-01-08
Из: Санкт-Петербург
Пользователь №: 34 643



В IAR тоже должны быть аналогичные средства. Ищите в справке по слову pack или packed.

Цитата(0x435641 @ Jul 26 2012, 09:29) *
опять все легло поверх в одно место
да вроде так и должно быть (с перекрытием инты должны были ложиться):

44 44 44 44 33 22 11 NA NA NA NA NA NA NA NA NA


--------------------
“Будьте внимательны к своим мыслям - они начало поступков” (Лао-Цзы)
Go to the top of the page
 
+Quote Post



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

 


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


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