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

 
 
 
Reply to this topicStart new topic
> LPC2478 + 32бит SDRAM, неправильно читает/пишет невыровненные слова
Nick Nickl's
сообщение Apr 11 2011, 07:28
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 62
Регистрация: 5-05-06
Из: Геленджик
Пользователь №: 16 811



К LPC2478 подключена 32 битная SDRAM, плата самодельная. Выявилась проблемка, если читать слово 4 байта (32бита) из SDRAM по адресу не кратному 4 (не выровненому по слову) то байты переходящие через "границу" грузятся не из следующего слова а из этого же. Любые чтения и записи не нарушающие границу слова работают замечательно.
Документация както умалчивает эту проблему, либо плохо искал. Вопрос ... это я туплю или так и должно быть ?
Детали программирования схему пока не привожу есть ощущение что этот EMC по другому не умеет.

Сообщение отредактировал Nick Nickl's - Apr 11 2011, 07:30
Go to the top of the page
 
+Quote Post
aaarrr
сообщение Apr 11 2011, 07:37
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 10 713
Регистрация: 11-12-04
Пользователь №: 1 448



Цитата(Nick Nickl's @ Apr 11 2011, 11:28) *
Документация както умалчивает эту проблему, либо плохо искал. Вопрос ... это я туплю или так и должно быть ?

Это особенность архитектуры ARM7TDMI. Документация на ядро ничего не умалчивает.
Go to the top of the page
 
+Quote Post
VslavX
сообщение Apr 11 2011, 07:54
Сообщение #3


embarrassed systems engineer
*****

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



Цитата(aaarrr @ Apr 11 2011, 10:37) *
Это особенность архитектуры ARM7TDMI. Документация на ядро ничего не умалчивает.

Если сделали бы в LPC23/24 нормальное исключение "Odd address trap", то таких вопросов было бы на порядок меньше.
Go to the top of the page
 
+Quote Post
Nick Nickl's
сообщение Apr 11 2011, 08:06
Сообщение #4


Участник
*

Группа: Участник
Сообщений: 62
Регистрация: 5-05-06
Из: Геленджик
Пользователь №: 16 811



Спасибо за исчерпывающий ответ ! В документацию к ARM7TDMI заглянуть недодумался.
Go to the top of the page
 
+Quote Post
SII
сообщение Apr 12 2011, 19:17
Сообщение #5


Знающий
****

Группа: Свой
Сообщений: 549
Регистрация: 13-07-10
Из: Солнечногорск-7
Пользователь №: 58 414



Это особенность не конкретного ядра, а вообще архитектуры ARM. В ряде случаев попытка обращения по невыровненному адресу вызывает падение, в других случаях -- загрузку выровненного слова, но с "вращением" содержимого... В общем, там целая куча нюансов, так что лучше взять за правило: никогда не обращаться по невыровненным адресам.
Go to the top of the page
 
+Quote Post
aaarrr
сообщение Apr 12 2011, 19:30
Сообщение #6


Гуру
******

Группа: Свой
Сообщений: 10 713
Регистрация: 11-12-04
Пользователь №: 1 448



Цитата(SII @ Apr 12 2011, 23:17) *
Это особенность не конкретного ядра, а вообще архитектуры ARM.

"Вообще" у ARM не одна архитектура. И некоторые вполне себе позволяют обращения без выравнивания.
Go to the top of the page
 
+Quote Post
SII
сообщение Apr 13 2011, 12:52
Сообщение #7


Знающий
****

Группа: Свой
Сообщений: 549
Регистрация: 13-07-10
Из: Солнечногорск-7
Пользователь №: 58 414



Хорошо, если уж быть точней, -- до ARMv5 включительно. Начиная с ARMv6, появились средства управления невыровненными доступами, и в зависимости от значений соответствующих управляющих битов процессор может вести себя по-разному. Тем не менее, общее правило остаётся в силе: избегать невыровненных доступов.
Go to the top of the page
 
+Quote Post

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

 


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


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