Перейти к содержанию

Векторы прерывания AVR


Рекомендуемые сообщения

Помогите разобраться!

Как обрабатывать прерывания по внешнему сбросу RESET?

if ((Program < 3) && (MCUSR & (1<<1))) 
    {
        Program++;
        MCUSR &= ~(1<<1);
    }

При отладке в AVR studio программа выполняется, когда флаг вручную выставляешь!

В протеусе моделирование не выполняется, флаг MCUSR 0b00000010  не устанавливается при нажатии на кнопку ресет?

 

image.png.6536e1bde389823102cf623776854938.png

Изменено пользователем Владимир34
Ссылка на комментарий
Поделиться на другие сайты

Реклама: ООО ТД Промэлектроника, ИНН: 6659197470, Тел: 8 (800) 1000-321

20% скидка на весь каталог электронных компонентов в ТМ Электроникс!

Акция "Лето ближе - цены ниже", успей сделать выгодные покупки!

Плюс весь апрель действует скидка 10% по промокоду APREL24 + 15% кэшбэк и бесплатная доставка!

Перейти на страницу акции

Реклама: ООО ТМ ЭЛЕКТРОНИКС, ИНН: 7806548420, info@tmelectronics.ru, +7(812)4094849

В железе, пока не пробовал, руки не дошли... Вот и решил спросить, может кто сталкивался!

При первой же возможности попробую и отпишусь! 

Но хотелось бы продвинутых пользователей послушать!

Ссылка на комментарий
Поделиться на другие сайты

Выбираем схему BMS для корректной работы литий-железофосфатных (LiFePO4) аккумуляторов

 Обязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ, также как и для других, очень важен контроль процесса заряда и разряда, а специализированных микросхем для этого вида аккумуляторов не так много. Инженеры КОМПЭЛ подготовили список имеющихся микросхем и возможных решений от разных производителей. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

В 21.01.2022 в 18:33, Alex сказал:

Пробовал на микросхеме, в железе тоже не работает, в регистрах после сброса не сохраняются данные...

 

Изменено пользователем Владимир34
Ссылка на комментарий
Поделиться на другие сайты

@Владимир34 , зачем ты в цитату с ником Алекса, вписал слова, которые он не говорил?

если ты сделал цитату, то пиши ниже цитаты, а не внутри нее.

Мудрость приходит вместе с импотенцией...

Когда на русском форуме переходят на Вы, в реальной жизни начинают бить морду.

Ссылка на комментарий
Поделиться на другие сайты

Кто-нибудь поможет? После перезагрузки контроллера, все данные стираются, а как же оперативка (RAM), питание то включено! И как записать и прочитать данные в ОЗУ? Кучу страниц уже пролистал, может я не правильно вопрос ставлю?

Ссылка на комментарий
Поделиться на другие сайты

не пишу на Си и Ассме, проблем сохранить всё ОЗУ (и регистры) нет.
Сохраняю регистр MCUSR (или как он в этом МК называется) в самом начале кода, анализирую состояние до очистки ОЗУ и установки стека.
Помню, в каких-то проектах МК работает на 128 кГц и спит почти всегда, перезапуск по Сбросу и дальше попёр работать...

 

ps
Никогда не использую Симуляторы: хватило пары недель опыта в самом начале пути освоения МК...

Изменено пользователем Александр Д.

Авторы ТЗ, с которыми я работаю, не имеют права жаловаться на дороги, ЖКХ, бюрократию и правительство.

Ссылка на комментарий
Поделиться на другие сайты

3 минуты назад, Александр Д. сказал:

не пишу на Си и Ассме, проблем сохранить всё ОЗУ (и регистры) нет.
Сохраняю регистр MCUSR (или как он в этом МК называется) самым верхним, анализирую его до очистки ОЗУ и установки стека.
Помню, в каких-то проектах МК работает на 128 кГц и спит почти всегда, перезапуск по Сбросу и дальше попёр работать...

Спасибо, если можно простым языком, что значит (Сохраняю регистр MCUSR, анализирую его до очистки ОЗУ и установки стека)? А когда ОЗУ очищается?

Вообще вся идея взята отсюда https://habr.com/ru/post/110894/, использование внешнего сброса для переключения режимов, статья старая и пример кода в ней не открывается((

Ссылка на комментарий
Поделиться на другие сайты

Разобрался!

image.png.1a34d8634f0da3179b99cb3d0b0fa240.png

Команду проверки поставил в нулевой адрес и всё заработало! Спасибо!

Теперь другой вопрос!

image.png.aa9bf54aaa5d4e0bbf81adda7c7d2e6f.png

Если инкрементировать регистр ААА++, то не работает! Т.е. если три раза нажать reset данные в регистре ААА не увеличатся. Вопрос с ОЗУ открытый, получается что данные стираются после перезагрузки или есть другие варианты?! 

Изменено пользователем Владимир34
Ссылка на комментарий
Поделиться на другие сайты

38 минут назад, Владимир34 сказал:

получается что данные стираются после перезагрузки или есть другие варианты?!

Какие могут быть варианты, если Вы сами же, своим кодом, говорите компилятору : "Обнули переменную AAA при инициализации !" ? :wacko:
Шутники, блин ....

Переменная AAA, по приходу на проверку

if(AAA == 3)

, будет иметь одно из двух значений : 0 или 1. Всё.

Ссылка на комментарий
Поделиться на другие сайты

14 минут назад, Alex сказал:

Какие могут быть варианты, если Вы сами же, своим кодом, говорите компилятору : "Обнули переменную AAA при инициализации !" ? :wacko:
Шутники, блин ....

Переменная AAA, по приходу на проверку

if(AAA == 3)

, будет иметь одно из двух значений : 0 или 1. Всё.

А как по другому?

image.png.85b3e1331bf6bfdf29dbd8372fcb31fe.png

И таким образом делал, всё равно не получается...

Ссылка на комментарий
Поделиться на другие сайты

2 минуты назад, _abk_ сказал:

В eeprom сохраняй.

Спасибо, это понятно. 

Мне бы хотелось разобраться с оперативной памятью, раз написано что ОЗУ энергозависимая, почему тогда данные не сохраняются? Питание я то не отключаю! Где-то мне попадалось, что к оперативной памяти нужно как-то обращаться но я так и не разобрался. Конкретных примеров на си не нашел!

Ссылка на комментарий
Поделиться на другие сайты

1 час назад, Владимир34 сказал:

Спасибо, это понятно. 

Мне бы хотелось разобраться с оперативной памятью, раз написано что ОЗУ энергозависимая, почему тогда данные не сохраняются?

Потому, что энергонезависимая - только EEPROM.

Ссылка на комментарий
Поделиться на другие сайты

12 минут назад, Геннадий сказал:

Потому, что энергонезависимая - только EEPROM.

ЭнергоЗАвисимая ОЗУ, я питание не отключаю, тогда почему в регистрах данные не сохраняются, я это имел в виду. И как к ОЗУ обратиться на СИ, чтобы записать или вытащить из неё данные (кроме EEPROM)?

Ссылка на комментарий
Поделиться на другие сайты

Компилятор обнуляет только глобальные переменные. Объявите ААА локально.

int main(void)
{
  unsigned char AAA;
  ...

Это не правильно, но в этом случае должно сработать.

Ссылка на комментарий
Поделиться на другие сайты

5 часов назад, Владимир34 сказал:

И таким образом делал, всё равно не получается...

Это глобальная переменная. В неё компилятор сам запишет ноль, если программист явно не указал значение. Так же, как и статические переменные.
И со стороны стандарта и логики это правильно. Время жизни у глобальных переменных - время работы самой программы. Программа закончила работу ? - да. Что Вы хотите ?

Первая ссылка в поисковике по переменным - http://ermak.cs.nstu.ru/cprog/HTML/057.htm. Надеюсь, Вас не затруднит почитать, коли трудно было поискать.

На вопрос "как быть ?", уже выше ответили. Самый правильный способ - запись в энергонезависимую память. Либо линкером отводить секцию для своих нужд, для которой у компилятора будут связаны шаловливые ручки.

Ссылка на комментарий
Поделиться на другие сайты

4 часа назад, Владимир34 сказал:

ЭнергоЗАвисимая ОЗУ, я питание не отключаю, тогда почему в регистрах данные не сохраняются, я это имел в виду.

Почитайте даташит. После сброса регистры принимают значения по-умолчанию, а содержимое RAM не гарантируется даже производителем. Поэтому, при включении, область RAM принято инициализировать требуемыми значениями.

Ссылка на комментарий
Поделиться на другие сайты

9 минут назад, Владимир34 сказал:

Буду работать с EEPROM

Это верное решение.

Всяческие нештатные манипуляции с RAM чреваты последствиями. Особенно, когда не понимаешь, что делаешь.

Ссылка на комментарий
Поделиться на другие сайты

  • 2 недели спустя...
В 26.01.2022 в 15:44, Владимир34 сказал:

ЭнергоЗАвисимая ОЗУ, я питание не отключаю, тогда почему в регистрах данные не сохраняются, я это имел в виду. И как к ОЗУ обратиться на СИ, чтобы записать или вытащить из неё данные (кроме EEPROM)?

А где вы в СИ обращаетесь к регистрам? А к ячейкам памяти? Компилятор, паразит такой, кроме вашего кода ещё целую кучу манипуляций делает скрытно, в том числе инициализацию переменных иногда даже если его не просить. В этом языке ни с чем нельзя быть уверенным, разве что работать ассемблерными вставками и как-то сообщить компилятору чтобы ни при каких обстоятельствах не трогал какой-то регистр/ячейку памяти. Тогда может и заработает.
Когда-то эксперименты ставил, SRAM держит состояние даже без питания - секунд 20-30 при комнатной температуре. Основные проблемы с повреждением содержимого - переходные процессы в логике управления памятью, поэтому 100% гарантии неповреждения содержимого при дёргании питания быть не может. Вторая причина - скрытые от пользователя процедуры инициализации ЯВУ. Хотите полного контроля над происходящим - есть ассемблер. попробуйте открыть декомпилированный бинарник в ассемблере, скомпилированный по вашей программе и посмотреть что за чертовщина происходит до первой ВАШЕЙ строчки кода.

 

Учение - изучение правил. Опыт - изучение исключений.

Ссылка на комментарий
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы публикуете как гость. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.
Примечание: Ваш пост будет проверен модератором, прежде чем станет видимым.

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить в этой теме...

×   Вставлено с форматированием.   Восстановить форматирование

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

Загрузка...
  • Последние посетители   0 пользователей онлайн

    • Ни одного зарегистрированного пользователя не просматривает данную страницу
  • Сообщения

    • @nekrylov Кулер на малых оборотах по центру радиатора решит все проблемы, при толщине основания 10 мм такое расположение выходников ничем плохим не грозит, при условии обдува. Радиатор выше 50-60 градусов вряд-ли нагреется когда-нибудь, его температура, скорее всего, будет от силы градусов на 10-15 выше температуры окружающего воздуха... Но схемка термоконтроля все же не повредит, на всякий пожарный.
    • двухтактный полумостовой импульсный преобразователь.   Качество монтажа ужасное, половина элементов, как этот конденсатор. Про сами детали сказать ничего не могу.   Пиковый ток из розетки? У меня есть осциллограф, если нужно могу провести замеры.    
    • Попробуйте скачать ГОСТ 16745-83 про конденсаторную бумагу. Там понятные слова, русские... :-)
    • Так ладно в общем нужно до конца разобраться с UART. Сейчас я выкладываю весь код и всю информацию что у меня есть. Сначала поясню что по схеме. Микроконтроллер у меня ATMEGA16. На PD2 и PD3 установлены светодиоды, На PC0 и PC1 установлены кнопки. Также установлен внешний кварц на частоту 7.3728 MHz. Теперь собственно сам код по UART. Код был взят из одного примера в просторах инета. Первоначально он был под ATMEGA8, но он вполне подошёл и на ATMEGA16. #define F_CPU 7372800UL #define BAUND 9600L #define UBRRL_value (F_CPU/(BAUND*16))-1 #include <avr/io.h> #include <util/delay.h> #include <avr/interrupt.h> void init_pin(void); #define C_PC0 (~PINC&(1<<PC0)) #define C_PC1 (~PINC&(1<<PC1)) #define LED_1_ON() PORTD|=(1<<PD2) #define LED_1_OFF() PORTD&=~(1<<PD2) #define LED_2_ON() PORTD|=(1<<PD3) #define LED_2_OFF() PORTD&=~(1<<PD3) volatile start=1; char b; ISR(USART_RXC_vect) { b=UDR; } void init_UART() { UBRRL = UBRRL_value; UBRRH = UBRRL_value>>8; UCSRB|=(1<<TXEN); UCSRB|=(1<<RXEN); UCSRC|=((1<<URSEL)|(1<<UCSZ0)|(1<<UCSZ1)); UCSRB|=(1<<RXCIE); sei(); } void send_UART(char value) { while(!(UCSRA&(1<<UDRE))); UDR=value; } int main(void) { init_pin(); init_UART(); while(1) { if (start==1) { _delay_ms(500); send_UART('O'); send_UART('K'); send_UART('!'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); start=0; } if (b == '0') { LED_1_ON(); LED_2_OFF(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (b == '1') { LED_1_OFF(); LED_2_ON(); send_UART('N'); send_UART('+'); send_UART('1'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (b == '2') { LED_1_ON(); LED_2_ON(); send_UART('N'); send_UART('+'); send_UART('2'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (b == '3') { LED_1_OFF(); LED_2_OFF(); send_UART('N'); send_UART('+'); send_UART('3'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (C_PC0) { send_UART('P'); send_UART('C'); send_UART('0'); send_UART(0x0D); send_UART(0x0A); _delay_ms(250); } if (C_PC1) { send_UART('P'); send_UART('C'); send_UART('1'); send_UART(0x0D); send_UART(0x0A); _delay_ms(250); } } } void init_pin(void) { DDRC = 0b00000000; PORTC = 0b11111111; DDRD |= ((1<<2)|(1<<3)); PORTD &=~ ((1<<2)|(1<<3)); } Здесь я пробовал этот код UART конечно в таком виде работает, но здесь есть некоторая непонятная ситуация. На микроконтроллер почему то принимаются значения только в цифровом виде. По другому он отказывается работать. Возможно нужно как то перенастроить что то не совсем это понимаю. А UART эта вещь такая очень нужна без него не сделать управление плеером.
    • Заходишь в даташит усилителя, ищешь вход, обычно конденсаторы, туда и подпаиваешь. Выводишь 5 проводов: входы 4 каналов, и земля входа. Потом: провод левого переднего входа (in1) соединяешь с левым задним (in3), по аналогии с правой стороной делай так же. Получается 2 контакта и земля. Ищешь распиновку своего разъёма и паяешь. Распиновку могу объяснить, если фото будет. Что бы включить, Подключи разъём в телефон и вставь, например, диск с записанной тишиной. Именно с записанной тишиной. То есть со звуком. Например, скачиваешь аудиосигнал 100 гц, и в аудиоредакторе делаешь громкость этого звука на минимум и сохраняешь на диск. Тогда вроде песня будет, но не будет её слышно. И когда этот звук с диска будет воспроизводиться, включи музыку с аукса. 
    • @Гость Михаил, что мешает поставить и послушать? Что мешает потестить операционник из магазина на предмет подлинности, хотя бы замерить скорость нарастания выходного сигнала и сравнить с даташит? Из магазина с большой вероятностью может быть перемаркированный LM358, его сразу видно то характерной ступеньке на синусоиде и по частоте он просто "тормоз" по сравнению с ne. Ваш LG медленнее в три раза от исходного. Ваш lg со своими 3 МГц должен быть однозначно лучше, чем перемаркированный ne из 358. Например, разницы между оригинальным LM833 и с хорошей  8 мегагерцовой  подделкой ne с Али не слышно.
×
×
  • Создать...