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

ATTINY2313A. Не работают внешние прерывания по входам PCINT(0-7) при включённом UART.


Alex Ferrum

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

Пишу программу для ATTINY2313, заливаю в ATTINY2313A, возникла непонятная проблема: при включённом UART (RXD=PD0, TXD=PD1), не работают внешние прерывания по входам PCINT(0-7) (PB0-PB7), чтобы внешние прерывания начинали работать, необходимо выключать UART, записывая в регистр UCSRB значение 0x00, то есть полностью выключать UART. Возникает вопрос: почему так происходит, если эти 2 функции не имеют общих регистров, векторов прерывания и выводов контроллера??? 

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

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

32 минуты назад, Alex Ferrum сказал:

Возникает вопрос: 

Интересный вопрос. :umnik2:. А даташит что говорит?

Хочешь накормить человека один раз — дай ему рыбу. Хочешь накормить его на всю жизнь — научи его рыбачить.

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

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

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

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

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

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

Навскидку говорит, что просто включенный UART не может влиять на другие прерывания. А вот если имеется некое незавершенное прерывание (например, UART :D) , то...

А чтобы гадать глубже, нужна информация от ТС, которой он с нами еще не поделился. Предполагаю, что разгадка скрыта в регистре UCSRB, там много чего интересного есть.

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

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

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

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

Вот сам проект. Проект сделан в протеусе 7, но испытан в 7 и 8 протеусе, результат один и тот же, если закомментировать строчку

out UCSRB, temp1

перед которой стоит строчка

ldi temp1, 0x00

в одном из файлов (или в обоих файлах) init.inc или vychbutton.inc начинается глюк.

Sensor11032021.rar

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

Более корявого и трудно понимаемого кода на ассемблере трудно представить.

Чей код? Неужели ваш?

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

1) не гоже писать что-то в биты "только для чтения" регистра UCSRA

    ldi temp1, 0xF8
    out UCSRA, temp1


image.png.db938ca1f5c33ace0e985cc76d68c202.png

Из всего этого разнообразия Вас интересует только бит TXC, вот только в него и пишите.

2) Зачем включать прерывания по UART'у если Вы их не используете?
    ldi temp1, 0x68      ; 0x4C, 0x6C
    out UCSRB, temp1     ;
image.png.802607766c809557baa405ebaaaccbcc.png
 

Таким образом Вы включили прерывание по окончанию отправки и пустому буферу. Вектора обработки для них у вас нет, если таблица верна, но это не самая главная проблема, равно как и не является существенной проблемой прерывание по окончанию отправки. Бит автоматически сбросится. А вот прерывание по пустому буферу себя так вести не будет. Судя по всему он у вас пуст большую часть времени, значит и прерывание будет скакать в и из таблицы туда-сюда большую часть времени, не давай выполнить больше никакой полезной работы.

Таково моё предположение. Проверяйте.

 

 

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

5 часов назад, _abk_ сказал:

И что? Вы хотите, чтобы кто-то за вас искал ошибку?

Лично от вас я ничего не хочу, вернее именно от вас хочу одного: чтобы вы не беспокоились по поводу данной темы и занимались своими делами!!! 

2 часа назад, AvrAsm сказал:

Более корявого и трудно понимаемого кода на ассемблере трудно представить.

Чей код? Неужели ваш?

Вас что-то не устраивает? - Проходите мимо, именно с вас я ничего не прошу и не требую, тем более не прошу вас оценивать мой код! 

1 час назад, El-Shang сказал:

1) не гоже писать что-то в биты "только для чтения" регистра UCSRA

    ldi temp1, 0xF8
    out UCSRA, temp1


image.png.db938ca1f5c33ace0e985cc76d68c202.png

Из всего этого разнообразия Вас интересует только бит TXC, вот только в него и пишите.

2) Зачем включать прерывания по UART'у если Вы их не используете?
    ldi temp1, 0x68      ; 0x4C, 0x6C
    out UCSRB, temp1     ;
image.png.802607766c809557baa405ebaaaccbcc.png
 

Таким образом Вы включили прерывание по окончанию отправки и пустому буферу. Вектора обработки для них у вас нет, если таблица верна, но это не самая главная проблема, равно как и не является существенной проблемой прерывание по окончанию отправки. Бит автоматически сбросится. А вот прерывание по пустому буферу себя так вести не будет. Судя по всему он у вас пуст большую часть времени, значит и прерывание будет скакать в и из таблицы туда-сюда большую часть времени, не давай выполнить больше никакой полезной работы.

Таково моё предположение. Проверяйте.

 

 

Спасибо большое, уважаемый товарищ! Ваше предположение оказалось верным! Товарищи с других форумов подтверждают ваши предположения! Спасибо большое уважаемый товарищ!!! 

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

 

1 час назад, Alex Ferrum сказал:

с вас я ничего не прошу и не требую

1 час назад, Alex Ferrum сказал:

Лично от вас я ничего не хочу

Товарищ потреблятель Alex Ferrum, Вы пришли просить , посему имейте мужество выслушать все мнения. :umnik2: А выпендриваться на уровне хамства совсем не гоже. :acute:  А то как бы впредь вам не ответили тем же.

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

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

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

Правильно всё Вам пишут, уважаемый.
Сначала Вы задаёте вопросы, на которые без гадалок не ответить.
Потом, ни слова не говоря, выкладываете какой-то там проект с куском говнокода, и всё. Ни вопросов, ни своих действий, ничего ... Опять к гадалкам обращаться ? Вас и спросили : "Что дальше ?". Ибо действительно, а что дальше то ? Ну выложили что-то там, и что ?

PS: Что-то последнее время на форуме развелось много тех, кому тут обязаны отвечать только так, как они хотят слышать. Напомню им - это публичный форум, а не место собрания проплаченных вами преподавателей. Тут все имеют права писать в темах. И не нужно никому затыкать рот и советовать идти мимо. Не нравится - идите сами мимо форума. Или пишите в личку тому, ответ от которого вас устраивает.

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

14 hours ago, Alex Ferrum said:

Спасибо большое, уважаемый товарищ! Ваше предположение оказалось верным! Товарищи с других форумов подтверждают ваши предположения! Спасибо большое уважаемый товарищ!!! 

Пжлст. Читайте документацию и никому и ничему не верьте. Всегда перепроверяйте. :-)

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

16 hours ago, Alex Ferrum said:

вернее именно от вас хочу одного: чтобы вы не беспокоились

Вот бестолочь. Чукча не читатель? Я тебе сразу сказал, где проблема

On 3/17/2021 at 5:48 PM, _abk_ said:

имеется некое незавершенное прерывание (например, UART

Что и

16 hours ago, Alex Ferrum said:

Товарищи с других форумов подтверждают

А ты вместо того, чтобы там разбираться, свой адский код вывалил и хамить начал. 

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

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

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

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

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

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

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

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

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

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

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

    • Для домашних измерений можно ограничиться определением уровня свечения лампочки  "на глаз" - всё равно это будет точнее амперметров на снимке вверху .  Метод фотоамперметра применяется в метрологических лабораториях  для сложных и ВЧ сигналов . 
    • @korsajЧего то я не совсем понимаю как данную функцию вызывать проверять с конкретными данными. Тем более что у меня в большей части данные которые я буду получать я не знаю полученную информацию там только известны первые символы и последние символы, а в середине хранятся данные которые каждый раз разные. Вот в том то и вся суть приёма данных. Чтобы можно было получить данные и вывести на индикаторы. Так что вариант сравнения строк тут наверное мало поможет. Тут как я понимаю нужно сравнивать конкретные символы и всю информацию между этими символами отдавать уже в обработку программе для вывода на индикацию. Потому как известно что сколько символов занимают данные то есть длинна принятой посылки всегда одинакова для определённого типа информации.
    • И в чем проблема? управлять модулем атмегой16 смог?
    • Наверное существуют, но как реализовать данный алгоритм для самодельной конструкции ? Но постоянный и пульсирующий то же не одно и то же. В том то и проблема . КАК его мерить ?
    • Переменный и пульсирующий постоянный ток- не одно и то же.
    • Я не плавную регулировку тока. Я про увеличить ток заряда с 6 до 10 ампер, и всё. Подобрать ёмкости C14/C15 - по каким параметрам? Поменять ключи на более низкоомные - я хотел поставить например BUV48A или 2SC3320. Пойдут на замену 2SC2335 которые сейчас стоят? А вот этот самый "резистор обмоток связи R19" уже достал! На всех зарядках он набран из 8, бывает из 10 SMD резисторов под которыми выгорает текстолит. Падла греется до 150 градусов. В этом экземпляре, стыдно даже писать его название, Striver PW-150 всё по другому. Зарядка собрана этажеркой, да так криво и нелепо, что выглядит в 100 раз хуже многих самоделок. Так вот этот "резистор обмоток связи R19" тут стоит обычный на 1 или 2 Вт - кетайский, его хрен поймёшь. Я поставил керамический - цементный на 5 Вт - нагрев 75 градусов при 5 амперах. Что ж туда ставить то? 10-20 ваттные проволочные? А вот с делителем R4/R5/R6 я не согласен! Тут за пороги вкл-выкл циклов заряд - пауза отвечает другая часть микросхемы. В этом я уже убедился, регулировку порогов делаю подстроечным резистором на 2 ноге 393. В этих зарядках и схемах часто перепутаны компараторы. Ваше утверждение про 5, а точнее 6 ногу относиться к другим схемам и зарядкам.  Резистором R7 определяется разница между напряжением окончания и начала зарядки. А вот это ценная информация - никак не мог понять как сократить минимальный и максимальный порог заряда.
    • Вообщем буду моделировать цепи включения и авто выключения 
×
×
  • Создать...