void main() { DDRC = 0xff;//0xff = 0b11111111 все выводы порта A сконфигурировать как выходы DDRD=0x00; PORTD=0xff; TCCR0=0x05; TCNT0=(0); TIFR=0; TIMSK=0x02; GIMSK=0x80; MCUCR=0x09;
#asm sei #endasm
while(1) { }
// 1000 rpm eto 17 rpsec } //в оригинале замыкающей скобки не было
сравните, какой вариант удобнее читать тем, кому Вы задаете вопрос, на который они отвечают совершенно на добровольных условиях, так зачем же им усложнять задачу?
ну, надо поставить breakpoint в timer0_overflow на TCNT0=(0);, посмотреть, попадает ли туда вообще, и сколько раз, то есть, изменяется ли pr, и отключен ли watchdog?
Качественное и безопасное устройство, работающее от аккумулятора, должно учитывать его физические и химические свойства, профили заряда и разряда, их изменение во времени и под влиянием различных условий, таких как температура и ток нагрузки. Мы расскажем о литий-ионных аккумуляторных батареях EVE и нескольких решениях от различных китайских компаний, рекомендуемых для разработок приложений с использованием этих АКБ. Представленные в статье китайские аналоги помогут заменить продукцию западных брендов с оптимизацией цены без потери качества.
ну, надо поставить breakpoint в timer0_overflow на TCNT0=(0);, посмотреть, попадает ли туда вообще, и сколько раз, то есть, изменяется ли pr, и отключен ли watchdog?
Компания EVE выпустила новый аккумулятор серии PLM, сочетающий в себе высокую безопасность, длительный срок службы, широкий температурный диапазон и высокую токоотдачу даже при отрицательной температуре.
Эти аккумуляторы поддерживают заряд при температуре от -40/-20°С (сниженным значением тока), безопасны (не воспламеняются и не взрываются) при механическом повреждении (протыкание и сдавливание), устойчивы к вибрации. Они могут применяться как для автотранспорта (трекеры, маячки, сигнализация), так и для промышленных устройств мониторинга, IoT-устройств.
За магические числа надо расстреливать. Ну блин, вот ненаглядно ведь нифига. Какие биты выставлены? На какой частоте работает мега? Частота прерывания таймера? Ну ок, предделитель стоит 1024 (надо не магические числа писать, а биты и комментарии! чтобы сразу было видно), значит прерывание будет в четверть частоты МК.
Добавлено after 43 seconds: Что подключено на PORTC.2?
Добавлено after 1 minute 32 seconds: Какой частоты входной сигнал на INT1?
странно, но многие не хотят и увиливают от дебага, и я тоже ведь был когда-то в их числе... а сейчас не представляю, как без него. На своём любимом ST7FOX запустил ШИМ методом тыка меняя значения регистров в отладочном режиме (по документации ШИМ работать почему-то не хотел). Без отладочного режима был бы полный пипец: поменял, скомпилил,прошил (симулятоа на него нет), запустил, поменял, скомпилил,прошил, запустил...
странно, но многие не хотят и увиливают от дебага, и я тоже ведь был когда-то в их числе... а сейчас не представляю, как без него. На своём любимом ST7FOX запустил ШИМ методом тыка меняя значения регистров в отладочном режиме (по документации ШИМ работать почему-то не хотел). Без отладочного режима был бы полный пипец: поменял, скомпилил,прошил (симулятоа на него нет), запустил, поменял, скомпилил,прошил, запустил...
Да очень странно что я раньше не пользовался дебаггером, очень простая и интуитивная вещь. код исправил и запустил. все работает отлично )
Решил усложнить задачу и сделать в том же коде генератор синуса на прерываниях соответственно.
Продолжая тему: Счетчик работает правильно, синус на шиме генерирует, а вот все вместе не получается - на OCR выходе вместо ШИМа выходят хаотично импульсы. На ПРОТЕУСе все отлично, а вот на железе - ерунду генерирует. Гдето наткнулся на информацию, что АТмега либо чтото делает, либо генерит ШИМ, изза того что нет DMA. То есть если строим синус, то только на отдельной МК. Может кто сталкивался с этим? Кстати делаю тахометр, который берет сигнал с ДПКВ и на табло двигает стрелку, генерируя синус и косинус.
Гдето наткнулся на информацию, что АТмега либо чтото делает, либо генерит ШИМ, изза того что нет DMA. То есть если строим синус, то только на отдельной МК.
Бред какой-то. Что-то наверное вы не так поняли. ДМА нужен совсем не для того. ШИМ мега генерит аппаратно таймеров, вне зависимости от того, чем занят проц. Только менять его надо для записи в регистр проц задействовать. Раз в протеусе работает, а в железе нет - скорее всего помехи по входу, которые не фильтруются и дают левые значения.
Смотрим момент перезаписи нового значения из времянок в защелки. Второе - не забываем, что запись в 16-битовые регистры не мгновенна (одной командой) - необходима защита от наложения прерываний "в разрыв" операции загрузки значения в таймер/OCRn.
Насчет дебаггера... Ядро всегда проверить можно, а вот аппаратные модули - смотреть "ограничения" - там самостоятельно пишем дополнительные отладочные модули с выводом данных на заведомо рабочую систему индикации. (У адуриньи к примеру - печать сообщений в терминал ПК.)
b526, а с одного аккаунта писать слабо? А код приложить не надо думаете? Что вы там за биты пишете, когда в регистре TIMSK только 1 бит от таймера 0? Еще обратите внимание на то, что предделитель для таймеров 0 и 1 - общий, и есть нюансы при работе с обоими таймерами на меге8.
...Вопрос: как влияет тимск на ШИМ на таймере 1 в меге8 ???
TIMSK mega8 работает для Т0 только с 0 битом прерывания по переполнению (кстати, вы оперируете с 1, а это необъявленный бит). Попробуйте управлять битом TOIE0 по или.
...Вопрос: как влияет тимск на ШИМ на таймере 1 в меге8 ???
TIMSK mega8 работает для Т0 только с 0 битом прерывания по переполнению (кстати, вы оперируете с 1, а это необъявленный бит). Попробуйте управлять битом TOIE0 по или.
OCR2 генериурет ШИМ, однако не меняет скважность по заданному массиву:
Код:
ISR(TIMER1_COMPA_vect) { OCR2=aSin[i]; i++; if (i>127) i=0;
где aSin[i] это массив. Чтобы заработало все, необходимо отключить INT1. Как это связано не понял, установил опытным путем 2. При таком подходе, когда генерируется ШИМ как показано выше, OCR1a почему-то не хочет генерировать:
Код:
ISR(TIMER1_COMPA_vect) { OCR2=aSin[i]; OCR1A=254; i++; if (i>127) i=0;
А регистр MCUCR в каком состоянии? Если в исходном, то низкий уровень на лапе(ах)INT0,1 будет держать камень в прерывании, не давая работать остальному, т.к. у остальных приоритет слабее.
Сейчас этот форум просматривают: нет зарегистрированных пользователей и гости: 26
Вы не можете начинать темы Вы не можете отвечать на сообщения Вы не можете редактировать свои сообщения Вы не можете удалять свои сообщения Вы не можете добавлять вложения