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

 
 
 
Reply to this topicStart new topic
> обращение по нулевому адресу..., ексепшен не генерится
klen
сообщение Mar 14 2012, 10:34
Сообщение #1


бессмертным стать можно тремя способами
*****

Группа: Свой
Сообщений: 1 405
Регистрация: 9-05-06
Из: Москва
Пользователь №: 16 912



вот код
Код
typedef struct
{
    int z;
    int d;
} EE;
EE* sw;
volatile int z;
//-----------------------------------------------------------
int main(void)
{
    sw->d = 12;
    z = sw->d;
}


делается на stm32f417zgt
эксешнен не генерится, такое ощущение что просто команды игнорируются.
чего я не правильно понимаю?
Go to the top of the page
 
+Quote Post
shmur
сообщение Mar 14 2012, 10:40
Сообщение #2


Участник
*

Группа: Участник
Сообщений: 55
Регистрация: 28-11-11
Пользователь №: 68 553



А с чего вы взяли, что адрес нулевой?
Go to the top of the page
 
+Quote Post
scifi
сообщение Mar 14 2012, 10:50
Сообщение #3


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



Цитата(klen @ Mar 14 2012, 14:34) *
эксешнен не генерится, такое ощущение что просто команды игнорируются.

А где написано, что должен быть эксепшн? По мне так наоборот: запись в область флэш используется в процессе IAP.
Go to the top of the page
 
+Quote Post
klen
сообщение Mar 14 2012, 13:57
Сообщение #4


бессмертным стать можно тремя способами
*****

Группа: Свой
Сообщений: 1 405
Регистрация: 9-05-06
Из: Москва
Пользователь №: 16 912



Цитата(scifi @ Mar 14 2012, 14:50) *
А где написано, что должен быть эксепшн? По мне так наоборот: запись в область флэш используется в процессе IAP.

1. адрес нулевой, потому что переменная неинициализирована, значит отправляется линкером в секциюю bss, кусок памяти для секции bss в crt коде забиваются нулями - это поведение определенноне ANSI C стандартом.
2. запись в область флеша здесь не выполняется, во первых флеш начинается со смешением 0x800000, во вторых в нее нелзя писать иначе это называлосьбы озу , можно только попросит флеш контроллер это сделать, это и назывется IAP.

Go to the top of the page
 
+Quote Post
scifi
сообщение Mar 14 2012, 14:18
Сообщение #5


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



Цитата(klen @ Mar 14 2012, 17:57) *
2. запись в область флеша здесь не выполняется, во первых флеш начинается со смешением 0x800000, во вторых в нее нелзя писать иначе это называлосьбы озу , можно только попросит флеш контроллер это сделать, это и назывется IAP.

Спасибо, кэп!
Советую почитать тут:
STM32F40xxx and STM32F41xxx Flash programming manual
конкретно вот этот кусок:
Цитата
The Flash memory programming sequence is as follows:
1. Check that no main Flash memory operation is ongoing by checking the BSY bit in the FLASH_SR register.
2. Set the PG bit in the FLASH_CR register
3. Perform the data write operation(s) to the desired memory address (inside main memory block or OTP area):
– Byte access in case of x8 parallelism
– Half-word access in case of x16 parallelism
– Word access in case of x32 parallelism
– Double word access in case of x64 parallelism
4. Wait for the BSY bit to be cleared

Вот что я имел в виду, когда говорил, что запись в область флэш используется в процесса IAP.
Кстати, если я правильно помню, я проверял процедуру программирования флэш без использования смещения 0x08000000 (то есть с нулевым базовым адресом) и она таки работает.
В свете сказанного выше совсем не удивительно, что никакого эксепшена не происходит.
Go to the top of the page
 
+Quote Post
jcxz
сообщение Mar 14 2012, 15:28
Сообщение #6


Гуру
******

Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713



Цитата(klen @ Mar 14 2012, 19:57) *
1. адрес нулевой, потому что переменная неинициализирована, значит отправляется линкером в секциюю bss, кусок памяти для секции bss в crt коде забиваются нулями - это поведение определенноне ANSI C стандартом.

Даже если принять это, где у вас запись в нулевой адрес? Скорее в адрес == 4.
Go to the top of the page
 
+Quote Post
klen
сообщение Mar 15 2012, 07:30
Сообщение #7


бессмертным стать можно тремя способами
*****

Группа: Свой
Сообщений: 1 405
Регистрация: 9-05-06
Из: Москва
Пользователь №: 16 912



Цитата(jcxz @ Mar 14 2012, 19:28) *
Даже если принять это, где у вас запись в нулевой адрес? Скорее в адрес == 4.

это уже буквоедство. конечно 0 + sizeof(uint32_t) = 4, это сути не меняет.
я чето не понимаю, видимо того что понимают все...
адреса 0x00000000...... согласно выставленым пинам BOOT является алиасоми лоя адресов 0x08000000 - тоесть
адреса ячеек флеш накопитяля. если делаю STR r0 , [r1] , где r1 содержит в указанном выше диапазоне то это соответствует попытке записать слово в ячейку по указанному адресу, декодер адреса контроллера шины должен на это отреагировать как недопустимый адрес для операции записи - ведь туда ничего записать принципиально нельзя.
Go to the top of the page
 
+Quote Post
scifi
сообщение Mar 15 2012, 07:55
Сообщение #8


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



Цитата(klen @ Mar 15 2012, 11:30) *
декодер адреса контроллера шины должен на это отреагировать как недопустимый адрес для операции записи - ведь туда ничего записать принципиально нельзя.

Вот никак не пойму, на каком основании сделан этот вывод. "Какие ваши доказательства?"
Go to the top of the page
 
+Quote Post
jcxz
сообщение Mar 15 2012, 14:47
Сообщение #9


Гуру
******

Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713



Цитата(klen @ Mar 15 2012, 13:30) *
адреса 0x00000000...... согласно выставленым пинам BOOT является алиасоми лоя адресов 0x08000000 - тоесть
адреса ячеек флеш накопитяля. если делаю STR r0 , [r1] , где r1 содержит в указанном выше диапазоне то это соответствует попытке записать слово в ячейку по указанному адресу, декодер адреса контроллера шины должен на это отреагировать как недопустимый адрес для операции записи - ведь туда ничего записать принципиально нельзя.

Насколько я понимаю у вас Cortex-M4? С ним дела не имел, но например в M3, многие исключения могут разрешаться/запрещаться через System control block. Возможно у вас генерация данного исключения просто выключена.
Может в M4 есть что-то типа memory manager-a и его можно использовать для этого?
Go to the top of the page
 
+Quote Post
scifi
сообщение Mar 15 2012, 15:02
Сообщение #10


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



Цитата(jcxz @ Mar 15 2012, 18:47) *
Насколько я понимаю у вас Cortex-M4?

Что интересно, STM32F4 очень похож на STM32F2. Мне даже кажется, что код для STM32F2 без изменений запустится на STM32F4 (включая конфигурацию PLL и т.д.) Cortex-M4 проявляется только в том, что там есть дополнительные инструкции.
Go to the top of the page
 
+Quote Post

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

 


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


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