Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Проблема запуска Tiny26
Форум разработчиков электроники ELECTRONIX.ru > Сайт и форум > В помощь начинающему > MCS51, AVR, PIC, STM8, 8bit
Roth
В тестовой программе только инициализация порта Б как выхода.
На выводы кроме VCC и GND ничего не повешено (все в воздухе).
Никакие фьюзы не трогал.
Прошивается понипрог-ом нормально.
Вочдог выключен.

При подаче питания перегружается с частотой 2-3 раза в сек (это видно по порту Б и питанию).

Буду признателен, если подскажете в чем дело.
dimka76
Цитата(Roth @ Jun 19 2009, 14:34) *
На выводы кроме VCC и GND ничего не повешено (все в воздухе).

При подаче питания перегружается с частотой 2-3 раза в сек (это видно по порту Б и питанию).



по питанию кондер висит?

рекомендую вывод сброса подтянуть резистором к питанию.

И что значит
Цитата
(это видно по ... и питанию).
я имею ввиду как вы это по питанию определяете?
Roth
Цитата(dimka76 @ Jun 19 2009, 15:00) *
по питанию кондер висит?

рекомендую вывод сброса подтянуть резистором к питанию.

И что значит я имею ввиду как вы это по питанию определяете?


Да конденсатор по питанию есть , правда в 30 см от МК.
Резет подтянул , тот же результат.
По питанию видно , если запитать слабеньким ИП видно горбики на осциллограмме. А с нормальным ИП чисто. Только порт "пляшет".
Sanya_kv
Может в программе проблема? После инициализации цикл стоит?
Код
for(;;); или while(1);
dimka76
Цитата(Sanya_kv @ Jun 19 2009, 15:44) *
Может в программе проблема? После инициализации цикл стоит?
Код
for(;;); или while(1);


кстати, хорошая идея !!! Наверняка именно в этом и причина.

а может человек на asm пишет, тогда
Код
a:    rjmp a
Roth
Цитата(dimka76 @ Jun 19 2009, 15:51) *
кстати, хорошая идея !!! Наверняка именно в этом и причина.

а может человек на asm пишет, тогда
Код
a:    rjmp a


CODE
void main(void)
{
int i;
init_devices(); // app-builder
}


думаю в сторону программатора , потому как производил с ним некоторые действия , хотя как неисправный программатор может корректно прошить , сказать ОК
at90
Цитата(Roth @ Jun 19 2009, 16:26) *
CODE
void main(void)
{
int i;
init_devices(); // app-builder
}


думаю в сторону программатора , потому как производил с ним некоторые действия , хотя как неисправный программатор может корректно прошить , сказать ОК



Попробуй так:
CODE
void main(void)
{
int i;
init_devices(); // app-builder
while(1)
{
}
}
dimka76
Цитата(Roth @ Jun 19 2009, 16:26) *
думаю в сторону программатора


программатор тут не причем

делайте как вам сказал at90 и будет все работать.

в случае отсутствия
Код
while(1);
контроллер продолжает выполнять программу после функции
Код
init_devices(); // app-builder
, а там ничего нету ( 0xFF ). И контроллер не может декодировать код 0xFF идет с следующей ячейке памяти программ, а там опять 0xFF. И так далее пока не дойдет до конца памяти программ и потом перейдет к ячейке памяти с нулевым адресом и начнет все сначала.
А строка
Код
while(1);
заставляет застрять его на этом месте.
Палыч
Цитата(dimka76 @ Jun 19 2009, 16:05) *
в случае отсутствия while(1); контроллер продолжает выполнять программу после функции init_devices(); , а там ничего нету...
Будет очень странно если всё дело - именно в этом. Обычно вызов main производится, примерно, так
Код
    XCALL   main
__exit:
    SLEEP
    RJMP    __exit
поэтому, на непрошитую область памяти выполнение выйти не может. Причины же описанного выше безобразия мне видятся две
1. Запрограммирован fuse WDTON (несмотря на заверения автора вопроса о том, что fuses - не трогал)
2. В программе выполняется еще что-то кроме настройки PORTB на вывод, что приводит к перезагрузке. Например, инициализация таймера и разрешение прерываний, а соответствующего обработчика прерываний - нет. Желательно увидеть всю программу, а не только main.

P.S. Не заметил, что это для t26 в которой fuse WDTON отсутствует. Первую причину можно отмести. Остаётся вторая, ну и ещё, конечно же, - плохое питание МК.
Мусатов Константин
Цитата(Roth @ Jun 19 2009, 15:28) *
Да конденсатор по питанию есть , правда в 30 см от МК.

26-я возбуждается если до конднсатора более 5-10 см проводников. Вынужден был ставить под микросхему smd керамику 0.1 мкф. Все проблмы пропали. А до этого стоял пеночный 0.1мкф в 5 см от микросхемы и ее колбасило.
dimka76
Цитата(Палыч @ Jun 19 2009, 17:56) *
Будет очень странно если всё дело - именно в этом.


Ой, ошибся smile.gif

Никогда не смотрел как это делает компилятор.
Просто всегда использовал while(1)
Roth
Дело не в while(1) - ради интереса попробовал.
Поставил керам конденсатор у самого тини26.

Результат тот же. Порт А , вместо Б.
По осциллограме PORTА относительно +VCC:
60ms - А притянут к земле ,
60ms - А высокоимпендасный ,
итд.

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

Кто это интересно перенес тему в "начинающим"?

CODE
#include <iot26v.h>
#include <macros.h>

void port_init(void)
{
PORTB = 0x00;
DDRB = 0x00;
PORTA = 0x00;
DDRA = 0x40;
}

void init_devices(void)
{
CLI(); //disable all interrupts
port_init();

MCUCR = 0x00;
TIMSK = 0x00; //timer interrupt sources
GIMSK = 0x00; //interrupt sources
PLLCSR = 0x00; //PLL
SEI(); //re-enable interrupts
}

void main(void)
{
int i;

init_devices();

while(1);

return ;
}

dimka76
Цитата(Roth @ Jun 23 2009, 14:05) *
Ошибка ведь гдето рядом, и скорее всего элементарная. Паяю редко, могу ошибится.


Попробуйте проанализировать регистр MCUSR. Выводом его значения в порт. И по состоянию выводом определите причину сброса контроллера.
Roth
Всем спасибо за советы!

Проблема разрешилась программным отключением вочдог таймера.
Почему он включен по умолчанию именно на этом экземпляре attiny26L-8pu не понятно.
На других экземплярах я не отключал вочдог, и все прекрасно работает.
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.