|
stm32 NVIC: сброс маскировки прерываний внутри обработчика |
|
|
|
 |
Ответов
|
Jul 14 2017, 15:37
|
Administrator
  
Группа: Свой
Сообщений: 400
Регистрация: 10-05-04
Пользователь №: 1

|
Цитата(AVI-crak @ Jul 14 2017, 02:05)  Править уровни прерываний и их очереди в теле пользовательских прерываний - это есть громадный костыль, означающий что программист накосячил в нескольких местах и не смог исправить. Никто уровни и очереди не правит. Еще раз - задача выполнить reset, но не всего и сразу, а выборочный. Включая сброс NVIC. Чтобы часть периферии и данных в RAM остались нетронутыми. Цитата Чтобы не ресетить девайс - нужно изначально закладывать архитектуру здоровой OS Вы эту ОС будете переустанавливать/обновлять без ресета? Действия при аварии электропитания тоже предполагаются без ресета?
|
|
|
|
|
Jul 24 2017, 09:50
|
Частый гость
 
Группа: Участник
Сообщений: 180
Регистрация: 5-04-09
Пользователь №: 47 205

|
QUOTE (jeka @ Jul 14 2017, 18:37)  Чтобы часть периферии и данных в RAM остались нетронутыми. Дык не трогайте данные в RAM - они и останутся нетронутыми. Ресет содержимое SRAM не затрагивает. Для пущей безопасности нужный кусок SRAM защитите CRC или еще каким образом.
|
|
|
|
|
Jul 25 2017, 12:30
|

Профессионал
    
Группа: Свой
Сообщений: 1 215
Регистрация: 22-02-05
Пользователь №: 2 831

|
Цитата(jcxz @ Jul 25 2017, 15:02)  Да ладно?!! Они умудрились написать код чисто на регистрах и без использования стека??? Прямо чудеса чудесатые какие-то рассказываете.....  Вы ничего не путаете?  В STM32 есть два спец пина BOOT0 и BOOT1, оменно они определяют кто будет запускаться при старте проца: user-код (User Flash memory), boot-загручик (System memory), ОЗУ или еще что-то (например, в "толстых" камнях). Опрос этих пинов производится ядром (или узлом, который отвечает за выбор области загрузки) в течение нескольких тактов после сброса. Но даже в случае безусловного использования бут-загручика можно выяснить области ОЗУ, которые он использует. А используют они совсем небольшую часть ОЗУ. Это не секретная информация  Все есть в соотв. мануалах )) Еще раз: BOOT-загрузчик в STM32 НЕ стартует безусловно. Более того, в тотально залоченном состоянии бут вообще невозможно запустить (разве что прочитать его версию): When readout protection Level2 is activated, STM32 does not boot on system memory in any case and Bootloader can't be executed (unless jumping to it from Flash user code, all commands are not accessible except Get, GetID, and GetVersion).Может, вы путаете STM32 с другими камнями (которые без своей FLASH), где BOOT стартует ВСЕГДА после сброса?
--------------------
Кругозор некоторых людей - круг с нулевым радиусом. Они называют его "точкой зрения".
|
|
|
|
|
Jul 25 2017, 13:29
|

Профессионал
    
Группа: Свой
Сообщений: 1 215
Регистрация: 22-02-05
Пользователь №: 2 831

|
Цитата(jcxz @ Jul 25 2017, 16:25)  boot / не-boot - вопрос не в том, Вопрос был как раз именно "в том": Цитата(jcxz) Да ладно?!! Они умудрились написать код чисто на регистрах и без использования стека??? Прямо чудеса чудесатые какие-то рассказываете..... Чудес не бывает, но бывает недостаточно внимательное чтение мануалов Цитата ...а в том - какая ОЗУ портится при старте. Дык, если сам user-код гадит под себя портит ОЗУ, то все вопросы к этому самому коду! Но это РЕШАЕМО (способов несколько).
--------------------
Кругозор некоторых людей - круг с нулевым радиусом. Они называют его "точкой зрения".
|
|
|
|
|
Jul 25 2017, 13:33
|
Гуру
     
Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713

|
Цитата(Forger @ Jul 25 2017, 16:29)  Дык, если сам user-код гадит под себя портит ОЗУ, то все вопросы к этому самому коду! Вопрос не про пользовательский код. А именно про boot-ROM. И в каких случаях и где он портит. Цитата(Forger @ Jul 25 2017, 16:31)  Вы не со мной спорите, а с мануалом от ST. Имхо, это бессмысленно  Я не спорю с мануалом. Выдержку из него я привёл выше. В которой указывается, что "8 Kbyte starting from address 0x20000000 are used by the bootloader firmware". Как там написано, так и читаю. К тому же там сказано про бутлоадер версии v7, а какой у меня - не знаю.
|
|
|
|
|
Aug 3 2017, 09:28
|
Частый гость
 
Группа: Участник
Сообщений: 180
Регистрация: 5-04-09
Пользователь №: 47 205

|
QUOTE (jcxz @ Jul 25 2017, 16:33)  Вопрос не про пользовательский код. А именно про boot-ROM. И в каких случаях и где он портит. Предположим, что бут-код стартует всегда и выбор режима дальнейшей работы осуществляется программно (тем более что у STM32F042 это именно так). что мешает осуществить эту проверку без стека и переменных? Это же буквально десяток асмовых команд (кстати, латч ножек Boot на 4 такт sysclk какбэ намекает). В общем не буду толочь воду в ступе - на всех виденных мной STM32 содержимое SRAM полностью сохраняется при сбросе, если ножками/фьюзами выбрана загрузка из флеша. QUOTE Т. е. этот тот самый случай, когда бутзагрузчик запускается безусловно не взирая на состояние BOOT0. Но все же одно условие для этого нужно выполнить - флэш должна быть полностью стерта  Достаточно стертого вектора reset
Сообщение отредактировал LightElf - Aug 3 2017, 09:31
|
|
|
|
|
Aug 3 2017, 09:47
|

Профессионал
    
Группа: Свой
Сообщений: 1 215
Регистрация: 22-02-05
Пользователь №: 2 831

|
Цитата(LightElf @ Aug 3 2017, 12:28)  Предположим, что бут-код стартует всегда и выбор режима дальнейшей работы осуществляется программно (тем более что у STM32F042 это именно так). Предполагать бессмысленно, все факты описаны в даташитах - выбор места старта выбирается неким аппаратным узлом, который НЕ является частью заводского бутзагрузчика. Это по сути простейший автомат состояний, который размещен прямо на кристалле, он совсем крохотный, поэтому встроен в каждый STM, отключить его нельзя (а смысл?). Он лишь, так сказать, "корректирует" вектор сброса перед запуском ядра. Цитата В общем не буду толочь воду в ступе - на всех виденных мной STM32 содержимое SRAM полностью сохраняется при сбросе, если ножками/фьюзами выбрана загрузка из флеша. Именно! Более того, в SRAM судя по всему нет аппаратного сброса, поскольку, судя по даташитам, после подачи питания там "мусор". Цитата Достаточно стертого вектора reset Есть такое, вот тут нашел подтверждение: Цитата Empty check (category 1 devices only) On category 1 devices, an internal empty check flag is implemented to allow easy programming of virgin devices by the bootloader. This flag is used when BOOT0 pin is configured to select Flash program memory as target boot area. When this flag is set, the device is considered as unprogrammed and the system memory (bootloader) is selected as boot area instead of the Flash program memory to allow the application to program the Flash memory. The empty check flag is updated only when the option bytes are loaded: it is set when the content of address 0x8000 0000 is read as 0x0000 0000 and cleared otherwise. As a result, only a power-on reset or setting OBL_LAUNCH bit in FLASH_CR register can clear this flag after programming a virgin device to execute user code after system reset. Но этот флажок реализован не во всех STM32, в "старых" семействах, увы, он не реализован ((
--------------------
Кругозор некоторых людей - круг с нулевым радиусом. Они называют его "точкой зрения".
|
|
|
|
|
Aug 3 2017, 14:06
|
Частый гость
 
Группа: Участник
Сообщений: 180
Регистрация: 5-04-09
Пользователь №: 47 205

|
QUOTE (Forger @ Aug 3 2017, 12:47)  Предполагать бессмысленно, все факты описаны в даташитах - выбор места старта выбирается неким аппаратным узлом, который НЕ является частью заводского бутзагрузчика. Действительно, бессмысленно предполагать. Надо тупо залезть дизасмом в бут и посмотреть
|
|
|
|
|
Aug 3 2017, 16:16
|
Частый гость
 
Группа: Участник
Сообщений: 182
Регистрация: 16-10-15
Пользователь №: 88 894

|
Цитата(LightElf @ Aug 3 2017, 20:06)  Действительно, бессмысленно предполагать. Надо тупо залезть дизасмом в бут и посмотреть  КАК? Каким образом смотреть содержимое ядра и адресного пространства мк в режиме явного срабатывания загрузчика по usart??? Вопрос на миллион баксов!!!
|
|
|
|
|
Aug 4 2017, 10:23
|
Частый гость
 
Группа: Участник
Сообщений: 180
Регистрация: 5-04-09
Пользователь №: 47 205

|
QUOTE (AVI-crak @ Aug 3 2017, 19:16)  Каким образом смотреть содержимое ядра и адресного пространства мк в режиме явного срабатывания загрузчика по usart??? Вопрос на миллион баксов!!! Не понял вопроса. Код бутлодера доступен для чтения всегда (если камень не залочен). QUOTE (Forger @ Aug 3 2017, 17:21)  Если уже и даташитам веры нет (тотальный атеист), то придется назначение регистров также "проверять дизасмом" ....  В даташите нигде не сказано, что выбор режима загрузки осуществляется строго аппаратно. На мой взгляд - это нелогично.
|
|
|
|
|
Aug 4 2017, 10:33
|

Профессионал
    
Группа: Свой
Сообщений: 1 215
Регистрация: 22-02-05
Пользователь №: 2 831

|
Цитата(LightElf @ Aug 4 2017, 13:23)  В даташите нигде не сказано, что выбор режима загрузки осуществляется строго аппаратно. Явно слова hardware там не указано, но вы внимательнее почитайте про принцип выбора вектора сброса. Более того, в даташитах явно указано, после выхода из standby режима повторно производится опрос пинов boot (это указано в даташитах), а уж это явно сделано аппаратно. Ну, и как минимум то, что управление передается заводскому загрузчику по точно такому же принципу, как и юзер-коду, наводит на мысль, что выбор вектора сброса производится где-то в недрах камня, про детальную работу которого нигде нет информации. Если вам удастся найти эту информацию, поделитесь с нами  Цитата На мой взгляд - это нелогично. Это еще почему? По-мне - как раз существующее исполнение вполне логично.
--------------------
Кругозор некоторых людей - круг с нулевым радиусом. Они называют его "точкой зрения".
|
|
|
|
|
Aug 5 2017, 10:06
|
Частый гость
 
Группа: Участник
Сообщений: 180
Регистрация: 5-04-09
Пользователь №: 47 205

|
QUOTE (Forger @ Aug 4 2017, 13:33)  Это еще почему? По-мне - как раз существующее исполнение вполне логично. Городить аппаратный блок, уникальный для каждого кристалла и для дальнейшей работы совершенно не нужный, вместо того чтобы добавить пяток команд - это логично?
|
|
|
|
|
Aug 5 2017, 10:49
|

Профессионал
    
Группа: Свой
Сообщений: 1 215
Регистрация: 22-02-05
Пользователь №: 2 831

|
Цитата(jcxz @ Aug 5 2017, 13:37)  Вот именно! Я об этом же и писал - совершенно нелогично. Когда под боком такое мощное ядро. Этот аппаратный узел позволяет вообще не трогать ядро, ничего не трогать. Т.е. ядро, периферия, тактовые генераторы и т.п. изначально вообще остановлены. Причины могут быть разные - борьба за потребление, за надежность да и мало еще за что?! Короче, не нравится решение ST? Нет проблем - рисуйте свой проц и делайте так, как душе угодно  Цитата Скорее всего ST хитрит - скрыли этот код инициализации в недокументированную область. Уфология прям - зеленых человечков никто не видел, но они есть!
--------------------
Кругозор некоторых людей - круг с нулевым радиусом. Они называют его "точкой зрения".
|
|
|
|
Сообщений в этой теме
jeka stm32 NVIC: сброс маскировки прерываний внутри обработчика Jul 12 2017, 16:58 Forger Цитата(jeka @ Jul 12 2017, 19:58) Назрела... Jul 12 2017, 17:29 jeka Собственно в мягком ресете есть необходимость имен... Jul 12 2017, 17:55 Forger Цитата(jeka @ Jul 12 2017, 20:55) Единств... Jul 12 2017, 18:02  jeka Цитата(Forger @ Jul 12 2017, 21:02) Я бы ... Jul 12 2017, 18:14   Forger Цитата(jeka @ Jul 12 2017, 21:14) как вар... Jul 12 2017, 18:18 jeka п.с. irq вызывается, поскольку авария может прилет... Jul 12 2017, 18:06 Forger Цитата(jeka @ Jul 12 2017, 21:06) п.с. ir... Jul 12 2017, 18:14  jeka Цитата(Forger @ Jul 12 2017, 21:14) Так в... Jul 12 2017, 18:25   Forger Цитата(jeka @ Jul 12 2017, 21:25) Ей нужн... Jul 12 2017, 18:32    jeka Цитата(Forger @ Jul 12 2017, 21:32) Я сов... Jul 12 2017, 18:45     Forger Цитата(jeka @ Jul 12 2017, 21:45) После п... Jul 12 2017, 18:56 jeka Сейчас я в одном из девайсов делаю примерно так. Т... Jul 12 2017, 18:34 Forger Цитата(jeka @ Jul 12 2017, 21:34) Вполне ... Jul 12 2017, 18:36 jeka Специфика такая. Не хочется протокол обмена обрыва... Jul 12 2017, 19:17 Forger Цитата(jeka @ Jul 12 2017, 22:17) Специфи... Jul 12 2017, 19:19 jeka годится, но больно сложно получается. Плюс дополни... Jul 12 2017, 19:29 Forger Цитата(jeka @ Jul 12 2017, 22:29) годится... Jul 12 2017, 19:36 jeka Ну не хочется городить огород с записью во флеш, п... Jul 12 2017, 20:01 Forger Цитата(jeka @ Jul 12 2017, 23:01) ... ког... Jul 12 2017, 20:08 jeka Цель - понять, можно ли на arm сбросить маскировку... Jul 12 2017, 23:47 KSN По поводу непрерывного протокола обмена.
Делаю та... Jul 13 2017, 02:24 Forger Цитата(KSN @ Jul 13 2017, 05:24) По повод... Jul 13 2017, 06:04  KSN Цитата(Forger @ Jul 13 2017, 13:04) Скаже... Jul 13 2017, 07:18 jcxz Цитата(jeka @ Jul 12 2017, 19:58) Назрела... Jul 13 2017, 06:03 jcxz Цитата(jeka @ Jul 12 2017, 19:58) в докум... Jul 13 2017, 06:20 Obam ЦитатаНазрела необходимость (уже давно), разрешить... Jul 13 2017, 07:58 jeka Прошу прощения, не указал один важный момент, из-з... Jul 13 2017, 09:59 Obam Тогда вообще ни о чём: сброс и всё. Jul 13 2017, 10:58 jeka Сброс не желателен, т.к. состояние части периферии... Jul 13 2017, 12:27 Forger Цитата(jeka @ Jul 13 2017, 15:27) сброс н... Jul 13 2017, 12:34 jeka Мешает то что если из обработчика прерывания прост... Jul 13 2017, 12:48 Forger Цитата(jeka @ Jul 13 2017, 15:48) Мешает ... Jul 13 2017, 12:54 jcxz Цитата(jeka @ Jul 13 2017, 15:48) Мешает ... Jul 13 2017, 15:02 Obam "сброс текущего приоритета прерываний без шам... Jul 13 2017, 13:09 AVI-crak Цитата(jeka @ Jul 12 2017, 22:58) Собстве... Jul 13 2017, 15:12 jeka jcxz, спасибо за ответ. В целом как и предполагал.... Jul 13 2017, 16:11 jcxz Цитата(jeka @ Jul 13 2017, 19:11) jcxz, с... Jul 13 2017, 16:30  Forger Вот читаю, вижу интересные мудрёные решения, но во... Jul 13 2017, 17:14   AVI-crak Цитата(Forger @ Jul 13 2017, 23:14) Имхо,... Jul 13 2017, 23:05    Forger Цитата(AVI-crak @ Jul 14 2017, 02:05... Jul 14 2017, 08:16 Forger Цитата(jeka @ Jul 14 2017, 18:37) Включая... Jul 14 2017, 16:15  Forger Цитата(LightElf @ Jul 24 2017, 12:50) Дык... Jul 24 2017, 10:10      jcxz Цитата(Forger @ Jul 25 2017, 15:30) Вы ни... Jul 25 2017, 13:15       Forger Цитата(jcxz @ Jul 25 2017, 16:15) В AN260... Jul 25 2017, 13:20        jcxz Цитата(Forger @ Jul 25 2017, 16:20) Это у... Jul 25 2017, 13:30         Forger Цитата(jcxz @ Jul 25 2017, 16:30) Содержи... Jul 25 2017, 13:31         Forger Цитата(jcxz @ Jul 25 2017, 16:32) Вопрос ... Jul 25 2017, 13:48           AVI-crak Режим отладки в памяти.
Программа в флеш выполняет... Aug 3 2017, 13:25            Forger Цитата(LightElf @ Aug 3 2017, 17:06) Надо... Aug 3 2017, 14:21             Forger Цитата(AVI-crak @ Aug 3 2017, 19:16)... Aug 4 2017, 06:56             jcxz Цитата(AVI-crak @ Aug 3 2017, 19:16)... Aug 4 2017, 06:59              AVI-crak Цитата(jcxz @ Aug 4 2017, 12:59) Или что ... Aug 4 2017, 08:29               jcxz Цитата(AVI-crak @ Aug 4 2017, 11:29)... Aug 4 2017, 10:43                Forger Цитата(jcxz @ Aug 4 2017, 13:43) Может бы... Aug 4 2017, 11:04                 jcxz Цитата(Forger @ Aug 4 2017, 14:04) Встрое... Aug 4 2017, 12:19                 AVI-crak Цитата(Forger @ Aug 4 2017, 17:04) зы Рад... Aug 4 2017, 12:38                  Forger Цитата(AVI-crak @ Aug 4 2017, 15:38)... Aug 4 2017, 13:12              LightElf QUOTE (jcxz @ Aug 4 2017, 09:59) Очевидно... Aug 5 2017, 13:26               Forger Цитата(LightElf @ Aug 5 2017, 16:26) Дабы... Aug 5 2017, 16:10                LightElf QUOTE (Forger @ Aug 5 2017, 19:10) Встрое... Aug 8 2017, 17:04                 Forger Цитата(LightElf @ Aug 8 2017, 20:04) Знае... Aug 8 2017, 17:48                  LightElf QUOTE (Forger @ Aug 8 2017, 20:48) Не виж... Aug 15 2017, 14:53                   Forger Цитата(LightElf)А что, возможен вариант И/И?
В фан... Aug 16 2017, 06:50                    LightElf QUOTE (Forger @ Aug 16 2017, 09:50) Если ... Aug 22 2017, 17:54                     Forger Цитата(LightElf @ Aug 22 2017, 20:54) И г... Aug 22 2017, 18:22                      LightElf QUOTE (Forger @ Aug 22 2017, 21:22) Мля, ... Aug 24 2017, 09:20                       Forger Цитата(LightElf @ Aug 24 2017, 12:20) что... Aug 24 2017, 10:54                        LightElf QUOTE (Forger @ Aug 24 2017, 13:54) Камен... Aug 30 2017, 08:38                         Forger Цитата(LightElf @ Aug 30 2017, 11:38) Вы ... Aug 30 2017, 09:07                          LightElf QUOTE (Forger @ Aug 30 2017, 12:07) Поско... Aug 30 2017, 15:50                           Forger Цитата(LightElf @ Aug 30 2017, 18:50) И в... Aug 30 2017, 16:17                Forger Цитата(LightElf @ Aug 5 2017, 13:06) Горо... Aug 5 2017, 10:29                  jcxz Цитата(Forger @ Aug 5 2017, 13:49) Т.е. я... Aug 5 2017, 11:03                   Forger Цитата(jcxz @ Aug 5 2017, 14:03) Ядро/так... Aug 5 2017, 12:10
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|