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

Неправильно Рабоатет Atmega8 ((((


Br.Misha

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

Сдрасте!

Купил вчера atmega8, написал прогу для ШИМ, она нормально загрузилась в МК, но он почему то не работает(((((

потом я написал оч простую программу:

#include <avr/io.h>
#include <avr/interrupt.h>
#define F_CPU 4000000UL
int main(void)
{
DDRB = 0xFF;
PORTB = 0xFF;
DDRC = 0xFF;
PORTC = 0xFF;
}

но даже она не выполнялась, светодиоды прицеплены к этим портам не горели(((

После этого я ещё пробовал заливать прошивку разными программами. но результат тот же. может я фузы как то не нат выставил... но врятле. Ниже я прикрепил скин с фузами:

post-51365-1235482236_thumb.jpg

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

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

Что то непонятно в чём вы пишате, в AIR или CVAVR?

с фузами как у вас настроены всё долно работать...

вот простая прога которая проверит мк

В главном цикле
PORTB=0x00
delay....
PORTB=0xFF
delay....

Вы стирайте кристал перед записью..?

Электроника это целый океан творчества...

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

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

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

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

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

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

Особенности хранения литиевых аккумуляторов и батареек

Потеря емкости аккумулятора напрямую зависит от условий хранения и эксплуатации. При неправильном хранении даже самый лучший литиевый источник тока с превосходными характеристиками может не оправдать ожиданий. Технология, основанная на рекомендациях таких известных производителей литиевых источников тока, как компании FANSO и EVE Energy, поможет организовать правильный процесс хранения батареек и аккумуляторов. Подробнее>>

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

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

На всякий случай, у вас там питание нормальное? Так как, если у вас там 16 светиков, а питание слабое.... то может быть такое что при включении светодиодов напряжение падает в ноль и МК затыкается. И так далее.... в цикле.

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

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

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

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

попробуй вот так

#include <avr/io.h>
#include <avr/interrupt.h>
#define F_CPU 4000000UL
unsigned char a,b,c;
int main(void)               {
  DDRB = 0xFF;
  DDRC = 0xFF;
  a= 0;
  while ( 1 ) {
      c = 1;
      while ( c ) c++;
      a++;
      if ( a == 0 ) b++;
      PORTB = a;
      PORTC = b;
}}

должны светиться твои светодиоды, если соблюдаешь полярность.

Пока ты жив, надежда есть.

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

Только что попробовал чё нить запрограммировать через ICCAVR. Написал програмку загрузил в МК (90S2313) и она заработала!!!! там был припаян сегментный индикатор и на нем появились цифры. После этого решил написать прогу в кодевижине и она тоже заработала в железе! Далее я хотел через кодевижен залить прошивку, написаную в АВРСтудио а после этого ту, что написана в ВинАВР, и ниодна с них не заработала, только в протеусе работала.

Так же писал в ICCV7, программа удачно откомпилировалась и работала в железе. Ещё пробовал заливать через понипрог в МК прошивку, написаную в CVAVR, ICCV7, WinAVR and AVRStudio. Не рабоатали только те, которые написаны на WinAVR and AVRStudio. Вот теперь я понимаю что МК исправный а не рабочий WinAVR.

Если кто нить знает в чем причина, прошу написать.

У меня установлен astudio4b623 совместно с WinAVR-20081205.

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

..Если кто нить знает в чем причина, прошу написать...

Если "кто нить" увидит исходники, то может "че-нить" и напишет...

Любой, заслуживающий внимания, опыт приобретается себе в убыток...

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

вот этот код:

#include <avr/io.h>
#include <avr/interrupt.h>

char n1=0, n2=0, n3=0;
char nam[10] = {0b01111110, 0b00001100, 0b10110110, 0b10011110, 0b11001100, 0b11011010, 0b11111010, 0b00001110, 0b11111110, 0b11011110};
char n = 0;
char sel[3] = {0b0110000, 0b1010000, 0b1100000};   char s = 0;
char tm = 0;
char calc = 250;
char toseg = 0;
char rozr = 0;

ISR(SIG_INTERRUPT1){

calc++;

GIFR = (1<<INTF1);
}

ISR(TIMER0_OVF0_vect)
{
PORTB = 0x00; 
s++; if (s == 4) s = 0;
switch (s)
{
case 0:PORTD = sel[0]; PORTB = n3;   break;
case 1:PORTD = sel[1]; PORTB = n2;   break;
case 2:PORTD = sel[2]; PORTB = n1;   break;
}
TCNT0 = 139;}

ISR(TIMER1_OVF1_vect){
if (rozr == 1)
{
rozr = 0;
toseg = (calc * 10);
}
n1 = nam[toseg/100];
n2 = nam[(toseg%100)/10];
n3 = nam[toseg%10];
calc = 0;
rozr = 1;

TCNT1H = 0xFE; //set count value
TCNT1L = 0x7A;}

int main(void){
cli();
DDRD = 0b11110111; DDRB = 0xFF; PORTD = (1<<PD3);
//--times------------
TCCR0 |= (0<<CS02)|(1<<CS00);
TCNT0 = 139;
TIMSK |= (1<<TOIE0);
//-------------------------
TCCR1B = 0x00; //stop timer
TCNT1H = 0xFE; //set count value
TCNT1L = 0x7A;
TCCR1B = 0x05; //start Timer
TIMSK |= (1<<TOIE1);
//===========================
GIMSK = (1<<INT1);
//===========================
sei();
while(1){

}
}

это частотометр )))))

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

Код, честно говоря, ужасен... Но сейчас не об этом... Слово "volatile" знакомо?

volatile char n1=0, n2=0, n3=0;
volatile char nam[10] = {0b01111110, 0b00001100, 0b10110110, 0b10011110, 0b11001100, 0b11011010, 0b11111010, 0b00001110, 0b11111110, 0b11011110};
volatile char n = 0;
volatile char sel[3] = {0b0110000, 0b1010000, 0b1100000};   char s = 0;
volatile char tm = 0;
volatile char calc = 250;
volatile char toseg = 0;
volatile char rozr = 0;

...

Любой, заслуживающий внимания, опыт приобретается себе в убыток...

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

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

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

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

Make-файл и листинг (*.lst) можно увидеть?

Любой, заслуживающий внимания, опыт приобретается себе в убыток...

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

вот полностью проэкт АВРСтудио и протеуса.

но хочу ещё раз напомнить что раньше он нормально работал и я не вижу в нем критических ошибок

at90s.rar

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

Br.Misha, вы воспользовались советом Goodefine? По листингу не видно;) Не пренебрегайте советами, а то вам перестанут помогать.

Википедия. Переменный типа volatile:

"...Variables declared to be volatile will not be optimized by the compiler because the compiler must assume that their values can change at any time..."

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

Глянул код мельком.

1. Сделай переменные volatile обязательно:

volatile char n1=0, n2=0, n3=0;
volatile char nam[10] = {0b01111110, 0b00001100, 0b10110110, 0b10011110, 0b11001100, 0b11011010, 0b11111010, 0b00001110, 0b11111110, 0b11011110};
volatile char n = 0;
volatile char sel[3] = {0b0111000, 0b1011000, 0b1101000};	// а не так{0b0110000, 0b1010000, 0b1100000}; - объяснение ниже
volatile char s = 0; 
volatile char tm = 0;
volatile char calc = 250;
volatile char toseg = 0;
volatile char rozr = 0;

...и я не вижу в нем критических ошибок...

А я вижу. Причем весьма критическую. Объясняю:

Задействовано внешнее прерывание по входу INT1 (ножка PD3), которое генерируется при НИЗКОМ уровне на этом входе.

В main сконфигурировано почти правильно (PD3 на вход с подтяжкой):

DDRD = 0b11110111;
PORTD|= (1<<PD3); //только так, а не: PORTD= (1<<PD3);

Смотрим что творится в обработчике переполнения T0:

case 0:PORTD = sel[0]; PORTB = n3;   break;
case 1:PORTD = sel[1]; PORTB = n2;   break;
case 2:PORTD = sel[2]; PORTB = n1;   break;

Теперь вопрос, что запишется в PORTD при этих раскладах? Смотрим массив sel[]:

char sel[3] = {0b0110000, 0b1010000, 0b1100000};

Смотрим, что теперь на месте подтяжки на лапе PD3 (INT0)? Правильно, Z-состояние, поскольку только что записали туда 0... А какой уровень будет на пине, зависит от многих факторов, включая фазу луны. Тем более, когда соседние ноги дергают индикатор... Поскольку прерывание генерируется по НИЗКОМУ уровню, то флаг события будет выставлен всегда, когда логический уровень на INT0 равен 0. Поэтому вполне возможна ситуация, когда программа будет постоянно находится в обработчике прерывания, почти не покидая его, поскольку приоритет этого прерывания выше, чем любого из таймеров... Поэтому выше и указан правильный вариант (хотя следовало бы указывать числа в 16-ричной системе счисления, поскольку двоичная запись противоречит стандарту Си). Не помешало бы еще притянуть лапу PD3 к плюсу через 4.7кОм... В протеусе ко входу был присоединен генератор, который и подавал необходимый положительный потенциал. Потому и работало...

И еще, это так задумано?

	//--times------------
TCCR0 |= (0<<CS02)|(1<<CS00); // или так TCCR0 |= (1<<CS02)|(1<<CS00);

Пока не выполнишь эти рекомендации и подробно не опишешь наблюдаемые в реальности признаки работы/(не работы), советовать что-либо дальше просто бессмыслено...

Любой, заслуживающий внимания, опыт приобретается себе в убыток...

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

Вот немного сменил код, но всё равно не рабоатает(((((

#include <avr/io.h>
#include <avr/interrupt.h>

volatile char n1=0, n2=0, n3=0;
volatile char nam[10] = {0b01111110, 0b00001100, 0b10110110, 0b10011110, 0b11001100, 0b11011010, 0b11111010, 0b00001110, 0b11111110, 0b11011110};
volatile char n = 0;
//volatile char sel[3] = {0b0110000, 0b1010000, 0b1100000}; 
//volatile char sel[3] = {0b0111000, 0b1011000, 0b1101000}; 
#define SEL1 (0<<PD4)|(1<<PD5)|(1<<PD6);
#define SEL2 (1<<PD4)|(0<<PD5)|(1<<PD6);
#define SEL3 (1<<PD4)|(1<<PD5)|(0<<PD6);
volatile char s = 0;
volatile char tm = 0;
volatile char calc = 250;
volatile char toseg = 0;
volatile char rozr = 0;

ISR(SIG_INTERRUPT1){

calc++;

GIFR = (1<<INTF1);
}

ISR(TIMER0_OVF0_vect)
{
PORTB = 0x00;
s++; if (s == 4) s = 0;
switch (s)
{
case 0:PORTD = SEL3; PORTB = n3;   break;
case 1:PORTD = SEL2; PORTB = n2;   break;
case 2:PORTD = SEL1; PORTB = n1;   break;
}
TCNT0 = 139;}

ISR(TIMER1_OVF1_vect){
if (rozr == 1)
{
rozr = 0;
toseg = (calc * 10);
}
n1 = nam[toseg/100];
n2 = nam[(toseg%100)/10];
n3 = nam[toseg%10];
calc = 0;
rozr = 1;

TCNT1H = 0xFE; //set count value
TCNT1L = 0x7A;}

int main(void){
cli();
DDRD = 0b11110111; DDRB = 0xFF; PORTD |= (1<<PD3);
//--times------------
TCCR0 |= (0<<CS02)|(1<<CS00);
TCNT0 = 139;
TIMSK |= (1<<TOIE0);
//-------------------------
TCCR1B = 0x00; //stop timer
TCNT1H = 0xFE; //set count value
TCNT1L = 0x7A;
TCCR1B = 0x05; //start Timer
TIMSK |= (1<<TOIE1);
//===========================
GIMSK = (1<<INT1);
//===========================
sei();
while(1){

}
}

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

...
#define SEL1 (0<<PD4)|(1<<PD5)|(1<<PD6);
...
case 2:PORTD = SEL1; PORTB = n1;   break;
...

А не один ли хр... черт, в PORTD.3 записывается 0?

Хотя бы так:

...
case 2:PORTD|= SEL1; PORTB = n1;   break; //во всех case-х, естественно
...

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

Изменено пользователем Goodefine

Любой, заслуживающий внимания, опыт приобретается себе в убыток...

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

Исчерпывающий ответ... А какие неведомые силы мешают написать как раньше но с единицами в PD3??

volatile char sel[3] = {0b0111000, 0b1011000, 0b1101000};

Тихо удаляюсь....

Любой, заслуживающий внимания, опыт приобретается себе в убыток...

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

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

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

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

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

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

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

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

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

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

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

    • Rik_2005, может все же фьюзы не правильно ставите. Генерация зависит только от них и исправных кварца и конденсаторов.
    • Благодарю всех, поделившихся замечаниями и предложениями! Отдельная благодарность z_vip за предложения, которыми я воспользовался и Starichok за принципиальную схему активной нагрузки. Результаты теста на разрушение Активной Нагрузки (далее АН) с транзисторами AP60T03 (30V 45A). В процессе пайки ПП для внесения изменений, закоротил С10. В работе остались два канала - два транзистора. Эти транзисторы и вышли из строя (омметр показывает 120-140 Ом между любыми выводами в любом направлении). Причина выхода из строя - кратковременное превышение предельного напряжения и тока из-за плохого контакта (искрение) при подключении БП при уставке тока больше 0. Два китайских резистора 0,33Ом 1вт, включенные последовательно с этими транзисторами, так же вышли из строя. Но ОЧЕНЬ оригинально - стали показывать изоляцию, НО внешних повреждений не видно. Выводы. Для снижения рисков пробоя силовых транзисторов: 1) (сделано) Максимально уменьшить индуктивность между БП и АН, в том числе убрать дроссель на входе АН (как вариант, можно включить обратный диод параллельно входному дросселю, но токи самоиндукции могут быть большими); 2) (не сделано) Как рекомендовал z_vip, последовательно с конденсаторами Сток-Исток включить резисторы 10-100Ом и входной быстродействующий предохранитель на максимальный ток АН +(3..4А); 3) Установить транзисторы с рабочим напряжением, раз в 5-10 превышающем напряжение нагружаемых БП; 4) Если требуется подключение "на горячую", то в цепь включения установить быстродействующий надёжный выключатель (автомат, реле, тумблер) с запасом по току от 2-3 крат. Восстановление АН. Установил б.у. транзисторы IRFR3411 (100V 32A), устранил короткое C10, установил советские резисторы 0,33Ом 5Вт, удалил дроссель на входе и конденсатор после дросселя, удалил диодный мостик перед стабилизатором, т.к. питание от нестабилизированного БП АС220/DC16В 0,8А. Установил в корпус DC/DC для питания вентилятора. Добавил в схему переключатель на съёмной перемычке, позволяющий подать на вход компаратора 12В служебного - может понадобиться для отладки. Добавил в схему оптопару для вкл/выкл АН внешним ТТЛ сигналом - для исследования переходных процессов испытуемых БП. Тест на разрушение проводить не буду - вроде бы всё понятно. Проверка. Как и говорил z_vip, диод MBR2045 сильно греется. Установленный на медную пластину 30*50*0,8 длительно держит 4А при ~40гр.Ц. При 6А нагревается градусов до ~60. С включенным вентилятором АН длительно держит 60Вт (12В 5А) при температуре радиатора в районе до 40гр.Ц. (приятно тёплый). ZIP-файл - схема и печатка в формате DipTrace, схема в PDF. Фото и осциллограммы.    
    • Я с алика беру сгшки и смд и дип уже давно. Полëт нормальный, но есть нюанс, что у некоторых микрух нет UVLO. Но я нашел способ, как это обходить
    • Поменял в усилителе резисторы на тонкопленочные smd 1206 производства Yageo. Померил их перед установкой - удивительная точность у них оказалась, отклонение от номинала не более 0.1%. Звук на слух не поменялся но фоновый шум усилителя стал практически неслышим даже в очень чувствительных наушниках. Так что есть смысл сразу ставить тонкопленочные резисторы.
    • После делителя поставьте повторитель на ОУ с высоким входным сопротивлением. Тогда и не будет влияния измерителя на делитель. https://forum.cxem.net/index.php?/blogs/entry/317-точный-делитель-из-неточных-резисторов-и-грабли-при-применении-резистивных-делителей/ Читаете вторую часть - "Грабли..."
    • С чего это ему кранты? Правда при первом включении щелчок все же был. Но после включался и выключался вообще тихо. Думаю надо прозванивать дальше плату по питанию, возможно еще что то крякнуло вслед за 4409.
    • Templates это шаблоны.
×
×
  • Создать...