Добрый вечер господа!
Сегодня чуть крыша не сьехала...
Захотел реализовать декодер Sony sirc
Начал с самого простого, с захвата стартового бита. И на этом закончил...
Запутался основательно....
Пример брал с проекта по декодированию НЕК протокола.
Алгоритм для sony sirc представляю такой:
тактовая у нас 8000000
мы ее делим на 256
имеем 31250Гц таймер счетчик
Приемник ИК подключаю к прерыванию ИНТ 0 настраиваю прерывание по спаду
как только срабатывает прерывание запускаю таймер и отбиваю интервалы, но в прерывании половина работает не так как я хочу!!!
Например эта строчка не работает.. :
if (tmr_code‹13){ tmr_code++; } else { tmr_code=0; }
эта строка была помещена в прерывание и она ну никак не срабатывает....
вот ввесь код:[HTML]/************************************************** ***
This program was produced by the
CodeWizardAVR V1.25.9 Standard
Automatic Program Generator
© Copyright 1998-2008 Pavel Haiduc, HP InfoTech s.r.l.
http://www.hpinfotech.com
Project :
Version :
Date : 09.07.2011
Author : F4CG
Company : F4CG
Comments:
Chip type : ATmega8
Program type : Application
Clock frequency : 8,000000 MHz
Memory model : Small
External SRAM size : 0
Data Stack size : 256
************************************************** ***/
#include ‹mega8.h›
#include ‹delay.h›
unsigned char comand, data_code, adress, start=0;
//unsigned char comand_1 = 0b1000000;
//unsigned char comand_2 = 0;
//unsigned char comand_3 = 0b0001000;
//unsigned char adress_devices = 0b10000;
void tmr_reset()
{
TCCR0=0;
TCNT0=0;
//data_code=0;
comand=adress=0;
//GIMSK|=0x40; //разрешаем прерывания по входу
//EIFR=0x40; //сбрасываем флаг прерывания (если произошло)
}
/*
почему это не правильно работает? я хочу для начала захватить старт бит , код работает только не така как надо, декодер фиксирует стартовый бит и мигает светиком когда принял старт бит но только я отправлю не правильный стартовый бит тоесть с другого протокола так пульт сразу виснет и уже не принимает стартовый бит который принимал в этом коде только прерывания
*/
// External Interrupt 0 service routine
interrupt [EXT_INT0] void ext_int0_isr(void)
{
// Place your code here
if (data_code==0) { TCCR0=0x04; } // 37,500 kHz start /256
if (data_code‹2)PORTB.5=1;else PORTB.5=0;
if (data_code==1) {
PORTB.2=0;
TCCR0=0;
if (TCNT0›65 && TCNT0‹100)
{
start=1;
TCCR0=0x04;
tmr_reset();
} else { PORTB.1=0; data_code=0; tmr_reset(); }
} else { PORTB.2=1;}
data_code++;
}
// Timer 0 overflow interrupt service routine
interrupt [TIM0_OVF] void timer0_ovf_isr(void)
{
// Reinitialize Timer 0 value
//TCNT0=0xFF;
// Place your code here
tmr_reset();
}
// Declare your global variables here
void main(void)
{
// Declare your local variables here
// Input/Output Ports initialization
// Port B initialization
// Func7=In Func6=In Func5=In Func4=In Func3=In Func2=In Func1=In Func0=In
// State7=T State6=T State5=T State4=T State3=T State2=T State1=T State0=T
PORTB=0x00;
DDRB=0xFF;
// Port C initialization
// Func6=In Func5=In Func4=In Func3=In Func2=In Func1=In Func0=In
// State6=T State5=T State4=T State3=T State2=T State1=T State0=T
PORTC=0x00;
DDRC=0x00;
// Port D initialization
// Func7=In Func6=In Func5=In Func4=In Func3=In Func2=In Func1=In Func0=In
// State7=T State6=T State5=T State4=T State3=T State2=T State1=T State0=T
PORTD=0x00;
DDRD=0x00;
// Timer/Counter 0 initialization
// Clock source: System Clock
// Clock value: 37,500 kHz for 9,6 mHz
// Clock value: 31,250 kHz for 8,0 mHz
// system clock/256
//TCNT0=0xFF;
// Timer/Counter 1 initialization
// Clock source: System Clock
// Clock value: Timer 1 Stopped
// Mode: Normal top=FFFFh
// OC1A output: Discon.
// OC1B output: Discon.
// Noise Canceler: Off
// Input Capture on Falling Edge
// Timer 1 Overflow Interrupt: Off
// Input Capture Interrupt: Off
// Compare A Match Interrupt: Off
// Compare B Match Interrupt: Off
TCCR1A=0x00;
TCCR1B=0x00;
TCNT1H=0x00;
TCNT1L=0x00;
ICR1H=0x00;
ICR1L=0x00;
OCR1AH=0x00;
OCR1AL=0x00;
OCR1BH=0x00;
OCR1BL=0x00;
// Timer/Counter 2 initialization
// Clock source: System Clock
// Clock value: Timer 2 Stopped
// Mode: Normal top=FFh
// OC2 output: Disconnected
ASSR=0x00;
TCCR2=0x00;
TCNT2=0x00;
OCR2=0x00;
// External Interrupt(s) initialization
// INT0: On
// INT0 Mode: Any change
// INT1: Off
GICR|=0x40;
MCUCR=0x01;
GIFR=0x40;
// Timer(s)/Counter(s) Interrupt(s) initialization
TIMSK=0x01;
// Analog Comparator initialization
// Analog Comparator: Off
// Analog Comparator Input Capture by Timer/Counter 1: Off
ACSR=0x80;
SFIOR=0x00;
tmr_reset();
// Global enable interrupts
#asm("sei")
while (1)
{
// Place your code here
//if (data_code›26) { data_code=0; }
if (start==1)
{
PORTB = PORTB | (1‹‹4);
delay_ms(250);
PORTB = PORTB &~ (1‹‹4);
data_code=0;
start=0;
}
};
}
[/HTML]
Хочу понять как работать с таймером на самом деле...
например єто
if (TCNT0›40 && TCNT0‹80) { PORTB.0 = ~PORTB.0;}
тут мы читаем значение счетчика
а как тогда быть с этим?
прерывание таймера
{
TCNT0=0x10;
}
это получается прерывание при переполнении этого значения.. так получается что мы присваиваем таймеру/счетчику значение 0х10;
Запутался.... Пожалуйста не отправляйте в "гогль" я его очень долго курил
и поиск на этом форуме курил. как мне подсчитать импульсы в прерывании , сравнить их и выполнить необходимые действия? Например мне надо определить импульс лог. Нуля равен интервалу 2400мкс или нет если да , зажечь светодиод если нет не зажигать, при чем остальные импульсы вплоть до 13 надо игнорировать...
С ув. Артем