Чт сен 21, 2017 14:16:10
#define F_CPU 1000000
#include <util/delay.h>
#include <avr/io.h>
#include <avr/interrupt.h>
unsigned char i=0;
//----------
void segchar (unsigned char seg)
{
switch (seg)
{
case 1: PORTB = 0b00000010; break;
case 2: PORTB = 0b00000110; break;
case 3: PORTB = 0b00001110; break;
case 4: PORTB = 0b00011110; break;
}
}
//----------
void timer_ini (void){
TCCR0A |= (1<<WGM01); //Устанавливаем режим СТС сброс по совпадению
TCCR0B |= (1<<CS02)|(0<<CS01)|(1<<CS00); //Делитель 1024
TIMSK |=(1<<OCIE0A); //бит разрешения прерываний
OCR0A = 0b11111111; //до чего считать
}
//----------
//обработка прерывания таймера0
ISR (TIMER0_COMPA_vect)
{
if (i>=5){i=1;}
segchar(i);
i++;
}
void timer1_ini (void){
TCCR1 |= (1 << CTC1) //режим CTC
|(0<<COM1A1)|(0<<COM1A0) //отключаем OC1A
|(1 << CS10)|(1 << CS11)|(1 << CS12)|(0 << CS13); //Делитель 8192
TCNT1 = 0x00; //сброс счетчика
OCR1A = 0xFA; //регистр сравнения
TIMSK =(1<<OCIE1A); //включаем прерывания по переполнению
}
//обработка прерывания таймера1
ISR(TIMER1_COMPA_vect){
PORTB = 0b00000000;
}
//----------
int main(void)
{
sei();
timer_ini();
timer1_ini();
DDRB = 0xfe;
PORTB = 0b00000000;
//----------
while(1){
}
}
Чт сен 21, 2017 14:19:14
Чт сен 21, 2017 14:28:14
Чт сен 21, 2017 14:41:40
щаззз что еще сделать?fulky писал(а):В протеусе добавьте аттини 85 и закоментите timer1_ini() в коде;
Чт сен 21, 2017 15:11:47
Чт сен 21, 2017 16:28:54
Это делитель на 64.fulky писал(а):|(1 << CS10)|(1 << CS11)|(1 << CS12)|(0 << CS13); //Делитель 8192
и вЫключаем прерываний от таймера0.TIMSK =(1<<OCIE1A); //включаем прерывания по переполнению
Чт сен 21, 2017 16:38:37
Наверное потому что ATtiny85 не поддерживает аппаратную отладку с пошаговым режимом.Z_h_e писал(а):Пошаговая отладка решает много проблем, что же ей мало так кто пользуется.
Чт сен 21, 2017 16:42:10
Чт сен 21, 2017 17:25:09
Это делитель на 64.fulky писал(а):|(1 << CS10)|(1 << CS11)|(1 << CS12)|(0 << CS13); //Делитель 8192
и вЫключаем прерываний от таймера0.TIMSK =(1<<OCIE1A); //включаем прерывания по переполнению
TCCR1 |= (1 << CTC1) //режим CTC
|(0<<COM1A1)|(0<<COM1A0) //отключаем OC1A
|(1 << CS13)|(0 << CS12)|(1 << CS11)|(0 << CS10); //Делитель 512
TCNT1 = 0x00; //сброс счетчика
OCR1A = 0xFF; //регистр сравнения
TIMSK =(1<<TOIE1); //включаем прерывания по переполнению
Чт сен 21, 2017 17:26:38
Чт сен 21, 2017 18:01:55
Пт сен 22, 2017 10:19:00
Пт сен 22, 2017 10:25:22
ух, рубанул!!!COKPOWEHEU писал(а):я даже больше скажу
Пт сен 22, 2017 16:25:32
Сб сен 23, 2017 06:51:57
Сб сен 23, 2017 07:03:00
Z_h_e писал(а):Пошаговая отладка решает много проблем,
Пн сен 25, 2017 22:42:24
Пн сен 25, 2017 22:51:18
Вт сен 26, 2017 06:43:13
Вт сен 26, 2017 07:58:48