|
"Правильный" софт ресет, который почти как хард ресет |
|
|
|
Nov 12 2008, 13:57
|
Частый гость
 
Группа: Свой
Сообщений: 148
Регистрация: 26-05-05
Пользователь №: 5 416

|
Добрый день. Подскажите пожалуйста, как правильно сделать софтресет, а то возникла такая проблема:
Есть прибор, который по усарту может получить команду сброса, после которой должен соответсвенно сбросится. Программа написана на асме, и когда я получаю эту команду, то просто jmpом прыгаю в самый первый байт кода. После этого у меня опять происходит инициализация устройства и программа как бы начинается заново. Всё было хорошо года два, пока сегодня не заметили странную штуку - после такого сброса показания прибора зашкаливают, а потом всё опять приходит в норму. Это в принципе недопустимо.
Я так подозреваю, что дело в стеке, т.к. там на этот момент могут храниться несколько точек возврата ну и какие-то левые значения, из-за которых начальные значения являются некорректныи. Посему хочу спросить - как сбросить стек? Как поведёт себя перифирия после повторной инициализации?
|
|
|
|
|
 |
Ответов
(1 - 45)
|
Nov 12 2008, 14:09
|
Частый гость
 
Группа: Свой
Сообщений: 148
Регистрация: 26-05-05
Пользователь №: 5 416

|
Цитата(Igor26 @ Nov 12 2008, 17:02)  А почему бы сделать сброс по WDT? Получив команду на перезапуск уходим в вечный цикл, а через некоторое время произойдет сброс по WDT. Хм... А вот это мысль! Эх, как бы научится мыслить шире?...А после сброса по сторожевому таймеру сбросятся ли его настройки?
|
|
|
|
|
Nov 12 2008, 14:32
|

Гуру
     
Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095

|
Цитата(МП41 @ Nov 12 2008, 17:15)  Или соединить один из выводов через диод с выводом сброса и дёргать этим выводом, когда надо  , И при определенных условиях получить чудеса, ибо вывод по сбросу станет входом и может не выполниться требование на минимальную длительность импульса на входе RESET. Цитата(МП41 @ Nov 12 2008, 17:15)  При старте не мешало бы оперативку чистить, в которой и стек находится. А вот это зачем? Неужели вменяемая программа полагается, что в ОЗУ после старта будут какие-то конкретные значения? Как можно что-то прочитать со стека, предварительно не положив на него это что-то?
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
|
Nov 12 2008, 15:00
|

Участник

Группа: Свой
Сообщений: 63
Регистрация: 13-03-06
Из: Москва
Пользователь №: 15 204

|
Цитата(UniBomb @ Nov 12 2008, 17:57)  jmpом прыгаю в самый первый байт кода. А первый байт - команда cli или ... ? В инициализации что-то не продумано, лично мне так кааацца. Цитата(UniBomb @ Nov 12 2008, 17:57)  хочу спросить - как сбросить стек? "В лоб" - загрузить в sph:spl значение ramend (при запрещенных прерываниях, разумеется).
|
|
|
|
|
Nov 12 2008, 15:37
|

Участник

Группа: Свой
Сообщений: 63
Регистрация: 13-03-06
Из: Москва
Пользователь №: 15 204

|
Цитата(МП41 @ Nov 12 2008, 19:04)  Так обычно в нуле стоит команда, которая прыгает на метку "RESET", которая находится за векторами прерываний, после чего стек первым делом и настраивается, потом порты... и т.д. Первым делом запрещаются прерывания - я как раз об этом. :-)
|
|
|
|
|
Nov 12 2008, 17:34
|

Гуру
     
Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095

|
Цитата(МП41 @ Nov 12 2008, 17:37)  Речь идёт о том, что ресет делается из работающей программы, у которой уже в памяти что-то валяется. Ну и что? И во время первого запуска после аппаратного ресета в памяти что-то валяется. Программа же не использует мусор, она сначала инициализирует переменные, а потом уже ими пользуется. И в стек она сначала кладет, потом вынимает. Зачем делать еще какую-то дополнительную "очистку оперативки"? Цитата(МП41 @ Nov 12 2008, 17:37)  Программа сама фузы не меняет, поэтому вывод сброса входом не станет, Зато станет входом тот вывод, которым вы хотели дергать ногу ресета.
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
|
Nov 12 2008, 19:42
|

Гуру
     
Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095

|
Цитата(zombi @ Nov 12 2008, 20:55)  ну и конечно CLI и инициализация стека в начале обязательно. Снова спрошу - зачем это шаманство с дополнительной инициализацией стека в начале? Программа и так его где надо проинициализирует. Раз она работает после аппаратного ресета, значит стек инициализируется где нужно. Даже(!) если будут разрешены прерывания, то их контекст будет сохраняться в ОЗУ, там, где остался указатель стека от предыдущего запуска программы. Запрещать прерывания перед инициализацией (в случае перезапука методом jmp) конечно нужно. Цитата(zombi @ Nov 12 2008, 20:55)  Должно все работать ведь если он стал входом значит ресет уже сработал У вас есть уверенность, что перевод портов в третье состояние - заключительная стадия процесса ресета?
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
|
Nov 12 2008, 20:46
|
дятел
    
Группа: Свой
Сообщений: 1 681
Регистрация: 13-05-06
Из: Питер
Пользователь №: 17 065

|
Обсуждалось уже очень много раз. ИМХО: - если нужен гарантированный сброс всего и временные рамки не давят, WDT лучший вариант - если нужно быстро и без проблем, запрещаем прерывания и на каждую функцию InitSomeHardware(...) заводим функцию StopSomeHardware(...) которая останавливает ВСЕ что касается этой хардвари, ВСЕ - это значит не только вырубить функцию, но и в некоторых случаях дождаться завершения текущего действия... Очищать стеки это что-то очень веселое...
|
|
|
|
|
Nov 12 2008, 22:20
|
Знающий
   
Группа: Участник
Сообщений: 596
Регистрация: 26-05-06
Из: Москва
Пользователь №: 17 484

|
Цитата(zombi @ Nov 12 2008, 21:55)  Должно все работать ведь если он стал входом значит ресет уже сработал  Вот что Atmel думает об этом: software reset Цитата We are currently updating the AVR FAQ and a software reset is actually one of the entries we've already made. Some people might recognise parts of this answer (and others, when the FAQ is up and running) that is simply because we have been crusing around avrfreaks searching for the most common questions, so many of the answers have been written many times before <START> Question How can I reset my AVR through software? Answer If you want to perform a software reset of your AVR you should use the internal Watchdog. Simply enable it and let it time out. When the Watchdog triggers it resets the program counter back to 0, clears all the registers and performs all the other tasks. This operation gives the same result as pulling the RESET line low. You should not try to: - Use another pin of the AVR to pull the external RESET line. The pins of the AVR are tristated halfway through the minimum reset time, this releases the RESET line and hence nothing happens. - Jump to program location 0. Jumping to program location 0 does not clear all the registers and hence you do not have a "clean" reset. Я думаю также будет полезно прочитать FAQ#30 в avr-libc-user-manual: How do I perform a software reset of the AVR?Анатолий.
|
|
|
|
|
Nov 12 2008, 22:52
|
Местный
  
Группа: Свой
Сообщений: 443
Регистрация: 22-07-06
Из: Украина, г. Харьков
Пользователь №: 19 006

|
Цитата(singlskv @ Nov 13 2008, 01:50)  А Вы дождались остановки UART ? Я специально говорил что нужно дождаться окончания последнего действия: Bit 3 – TXEN: Transmitter Enable Writing this bit to one enables the USART Transmitter. The Transmitter will override normal port operation for the TxD pin when enabled. The disabling of the Transmitter (writing TXEN to zero) will not become effective until ongoing and pending transmissions are completed, i.e., when the transmit Shift Register and transmit Buffer Register do not contain data to be transmitted. When disabled, the transmitter will no longer override the TxD port. Спасибо, на будущее учту.
|
|
|
|
|
Nov 13 2008, 07:52
|

Профессионал
    
Группа: Свой
Сообщений: 1 143
Регистрация: 30-09-08
Из: Новочеркасск
Пользователь №: 40 581

|
Цитата(zombi @ Nov 13 2008, 03:53)  Полной уверенности нет. Но раз процесс ресета пошел разве он может не завершиться??? вполне может. сброс - процесс многоэтапный, для 51-ых я где-то встречал подробное описание всех стадий. так вот, скажем на первом такте при наличии нужного уровня RST происходит сброс регистров pull-up, на втором такте - сброс DDRx, на третьем - остановка таймеров и т.д. (порядок условный - мои предположения). поэтому, если не дождавшись этапа, когда происходит, например, остановка работы ядра контроллера, убрать RST - контроллер вообще может оказаться в неопределенном состоянии (недосброшенным). теоретически может даже зависнуть... но скорее всего процедура сброса просто не будет выполнена до конца: может не произойти переход на адрес 0000, но вся периферия сбросится и т.п. имхо, лучше не экспериментировать. P.S. так же имхо, нет приложений, критичных к скорости программного сброса, так что нечего бояться времени срабатывания WDT.
Сообщение отредактировал ARV - Nov 13 2008, 07:53
--------------------
Я бы взял частями... но мне надо сразу.
|
|
|
|
|
Nov 13 2008, 08:46
|
Местный
  
Группа: Свой
Сообщений: 426
Регистрация: 5-04-07
Из: Санкт-Петербург
Пользователь №: 26 782

|
Цитата(aesok @ Nov 13 2008, 01:20)  Вот что Atmel думает об этом: software reset Я думаю также будет полезно прочитать FAQ#30 в avr-libc-user-manual: How do I perform a software reset of the AVR?Анатолий. +1000. Пора, уже понять и "принять к исполнению", тот факт, что у AVR нет иного "правильного" программного сброса, кроме как с использованием WDT. Все остальное от лукавого.
|
|
|
|
|
Nov 14 2008, 15:56
|

Гуру
     
Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095

|
Цитата(zombi @ Nov 14 2008, 17:23)  А даташите напысано шо внешний резэт срабатывает по фронту ? Или я пэрэвёл нэправылно??? (недосброшенным)  Читать надо весь даташит, а не выборочно: ATmega8, 2486Q–AVR–10/06, Table 15: Цитата tRST Minimum pulse width on RESET Pin 1.5 µs Переводите как хотите. Невнимательным:
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
|
Nov 14 2008, 16:14
|

Гуру
     
Группа: Свой
Сообщений: 2 076
Регистрация: 10-09-08
Пользователь №: 40 106

|
Цитата(Сергей Борщ @ Nov 14 2008, 19:56)  Читать надо весь даташит, а не выборочно: ATmega8, 2486Q–AVR–10/06, Table 15:Переводите как хотите. Невнимательным:  Да действительно надо весь читать! Начал читать. . . . Прочитал. Там написано что при импульсе короче 1.5 мкс не гарантируется сброс. "Shorter pulses are not guaranteed to generate a reset." Т.е. процедура сброса не начнется. Но я ничего не могу найти о зависании мк из за короткого импульса. Или я ищу не там?
|
|
|
|
|
Nov 14 2008, 17:46
|

Профессионал
    
Группа: Свой
Сообщений: 1 143
Регистрация: 30-09-08
Из: Новочеркасск
Пользователь №: 40 581

|
конечно, читая даташит, становится понятно лишь то, что там написано. а что не написано - можно домыслить. я не утверждаю, что сброс у атмела многоэтапный, но если это так, то кто даст гарантию, что сигнал RST не играет роль сигнала CS для микросхем памяти? т.е. наличие должного уровня RST лишь разрешает работу многокаскадной схемы сброса? значит, если его убрать раньше, чем процесс дойдет до финала - разрешение исчезнет, и схема останется в каком-то промежуточном состоянии. простая аналогия: сдвиговый регистр с третьим состоянием выходов: пока есть OE (читай RST), инфа в регистре движется, убрали ОЕ - и на выходах неизвестно что... повторяю: это лишь мои домыслы, но разве они не логичны?
Сообщение отредактировал ARV - Nov 14 2008, 17:48
--------------------
Я бы взял частями... но мне надо сразу.
|
|
|
|
|
Nov 14 2008, 18:49
|

Гуру
     
Группа: Свой
Сообщений: 2 076
Регистрация: 10-09-08
Пользователь №: 40 106

|
Цитата(ARV @ Nov 14 2008, 21:46)  конечно, читая даташит, становится понятно лишь то, что там написано. а что не написано - можно домыслить. я не утверждаю, что сброс у атмела многоэтапный, но если это так, то кто даст гарантию, что сигнал RST не играет роль сигнала CS для микросхем памяти? т.е. наличие должного уровня RST лишь разрешает работу многокаскадной схемы сброса? значит, если его убрать раньше, чем процесс дойдет до финала - разрешение исчезнет, и схема останется в каком-то промежуточном состоянии. простая аналогия: сдвиговый регистр с третьим состоянием выходов: пока есть OE (читай RST), инфа в регистре движется, убрали ОЕ - и на выходах неизвестно что... повторяю: это лишь мои домыслы, но разве они не логичны?  Ваши мысли кажутся мне вполне логичными. Но Цитата конечно, читая даташит, становится понятно лишь то, что там написано. а что не написано - можно домыслить. Полный пипец! И самое главное что проц будет работать именно так как домыслит каждый из читающих? Я всегда предполагал что даташит для того и существует чтобы домысливать ничего не нужно было! Вообщето речь шла о том что если у ATMEGA8 любую ногу порта соединить с ресет и перевести эту ногу в 0. Произойдет ли сброс. Причем тут CS,OE и сдвиговый регистр с третьим состоянием выходов???
|
|
|
|
|
Nov 14 2008, 19:34
|

Профессионал
    
Группа: Свой
Сообщений: 1 143
Регистрация: 30-09-08
Из: Новочеркасск
Пользователь №: 40 581

|
Цитата(zombi @ Nov 14 2008, 21:49)  Полный пипец! И самое главное что проц будет работать именно так как домыслит каждый из читающих? Я всегда предполагал что даташит для того и существует чтобы домысливать ничего не нужно было! конечно нет. но случайно кто-то может своими домыслами попасть в точку. если всюду рекомендуют использовать WDT для софт-сброса и не рекомендуют заводить сигнал с другого пина - этому долно быть какое-то обяснение? вы пытаетесь домыслить, что сброс пройдет (и приводите какие-то домыслы-доказательства этого), я наоборот - и тоже вещаю благую чушь  опыт - критерий истины - заведите порт на RST и попробуйте вообще программу запустить... ну а потом - пересбросить... и тогда, возможно, забрезжит свет истины...
--------------------
Я бы взял частями... но мне надо сразу.
|
|
|
|
|
Nov 14 2008, 19:39
|

Гуру
     
Группа: Свой
Сообщений: 2 076
Регистрация: 10-09-08
Пользователь №: 40 106

|
Цитата(aaarrr @ Nov 14 2008, 23:31)  Поясните свою реплику, будьте любезны. Обсуждалса WDT уже Цитата(ARV @ Nov 14 2008, 23:34)  конечно нет. но случайно кто-то может своими домыслами попасть в точку. если всюду рекомендуют использовать WDT для софт-сброса и не рекомендуют заводить сигнал с другого пина - этому долно быть какое-то обяснение? вы пытаетесь домыслить, что сброс пройдет (и приводите какие-то домыслы-доказательства этого), я наоборот - и тоже вещаю благую чушь  опыт - критерий истины - заведите порт на RST и попробуйте вообще программу запустить... ну а потом - пересбросить... и тогда, возможно, забрезжит свет истины... Честно говоря мне абсолютно по-уй будет оно работать или нет
|
|
|
|
|
Nov 14 2008, 20:06
|
дятел
    
Группа: Свой
Сообщений: 1 681
Регистрация: 13-05-06
Из: Питер
Пользователь №: 17 065

|
Цитата(aaarrr @ Nov 14 2008, 22:23)  Ну, добавьте RC и будет хоть 1.5мкс, хоть 15мс. Только зачем такие извращения, если можно просто задействовать WatchDog? А вот это кстати не факт что RC гарантированно поможет. В отличии от Power-Up Reset для обычного ресета в даташите нет указания про гистерезис, тч Reset все равно может сработать а может и нет. Тем кто расказывает про "неполные" ресеты, немедленно смотреть даташиты и конкретно картинку под названием External Reset During Operation, там ресет заканчивается а внутренний счетчик осуществляющий ресет продолжает работать...
|
|
|
|
|
Nov 14 2008, 20:12
|
Гуру
     
Группа: Участник
Сообщений: 3 928
Регистрация: 28-03-07
Из: РФ
Пользователь №: 26 588

|
Atmel пишет про WDT. Не помню, было ли где про то, что нельзя использовать один из портов, заведенный на ресет. Вроде бы было, что можно. Иначе действительно получается потенциальный баг. Сброс должен быть полный или не быть вообще, скажем в зависимости от длительности импулься, а не какой-то там наполовину. А с jmp 0 давно понятно - jmp - это как бы и не ресет совсем. Вообще, не понятно, почему Atmel не предусмотрели еще один источник сброса - программный. Хотя это не единственное, что не понятно.
|
|
|
|
|
Nov 14 2008, 20:30
|
дятел
    
Группа: Свой
Сообщений: 1 681
Регистрация: 13-05-06
Из: Питер
Пользователь №: 17 065

|
Цитата(Огурцов @ Nov 14 2008, 23:12)  Atmel пишет про WDT. Не помню, было ли где про то, что нельзя использовать один из портов, заведенный на ресет. Atmel как раз четко высказывался на этот счет. Типа не гарантируем... Цитата Иначе действительно получается потенциальный баг. Сброс должен быть полный или не быть вообще, скажем в зависимости от длительности импулься, а не какой-то там наполовину. Нет, сброс или будет или нет, зависит от массы внешних факторов, например емкости на пине сброса, температуре итд Цитата А с jmp 0 давно понятно - jmp - это как бы и не ресет совсем. Вообще, не понятно, почему Atmel не предусмотрели еще один источник сброса - программный. Хотя это не единственное, что не понятно. Ну не ресет, рестарт называется, но кто сказал что с програмной точки зрения будут какие-нить отличия ? Вам когда-нить приходилось стопить переферию для переключения пинов на другие функции ? Если приходилось, то софт рестарт не будет для Вас откровением...
|
|
|
|
|
  |
2 чел. читают эту тему (гостей: 2, скрытых пользователей: 0)
Пользователей: 0
|
|
|