/*****************************************************
This program was produced by the
CodeWizardAVR V1.25.3 Professional

Project : 2313RC5Decoder
Version : 
Date    : 6.03.2009
Author  : Goodefine. 1995 Kenny.                          



Chip type           : ATtiny2313
Clock frequency     : 8,000000 MHz  RC
Memory model        : Tiny
External SRAM size  : 0
Data Stack size     : 32
*****************************************************/

#include <tiny2313.h>
#include <stdio.h>
#include <delay.h>
//
//Счетчик битов RC5
unsigned char sct_bit = 0;
   //Буффер RC5
unsigned char RC5_buffer [14];
    //Временные пределы
#define Tmin 40 //длинный промежуток
#define Tmax 68
#define TminK 22 //короткий промежуток
#define TmaxK 34

//Флаг центра 
unsigned char centre =  0;
//Флаг попадания в промежутки
unsigned char not_korr = 0;
//число в счетчике таймера
unsigned char Timer = 0;
//переменные кодов
unsigned char startbit2 = 0;
unsigned char trigger = 0;
unsigned int device = 0;
unsigned char command = 0;
//eeprom unsigned char device0 = 0; //сохранялся ли девайс в еепром
//eeprom unsigned char devinit = 0; //сохранение девайса в еепром
bit out1 = 0;
bit out2 = 0;
bit out3 = 0;
bit out4 = 0;
bit out5 = 0;
bit out6 = 0;

// External Interrupt 0 service routine
interrupt [EXT_INT0] void ext_int0_isr(void)
{
PORTD.3 = 1;

Timer = TCNT0; //запоминаем значение счетчика       /////////////////////////////////////
TCNT0 = 0;     //обнуляем счетчик
not_korr = 1;
                    
switch (sct_bit)   {

                  case 0:
                  TCCR0B = 0x04; //запускаем таймер  (31.250 KHz)  //////////////////////////////////////////////
                  RC5_buffer [sct_bit] = !PIND.2;//записываем в эл.массива
                  sct_bit++;
                  centre = 1;
                  break;
                  
                  
                  
                  default:
                 
                  if ((Timer>TminK)&&(Timer<TmaxK))   // проверка короткого промежутка
                                                {
                                                  if (centre) {
                                                              centre = 0;
                                                              not_korr = 0; 
                                                                 }
                                                  else       
                                                              {
                                                              centre = 1;
                                                              RC5_buffer [sct_bit] = !PIND.2;
                                                              sct_bit++;
                                                              not_korr=0;
                                                                };
                  
                  
                                                 };     
                   
                    if ((Timer>Tmin)&&(Timer<Tmax)){ // проверка длинного промежутка
                                                  RC5_buffer [sct_bit] = !PIND.2;
                                                  sct_bit++;
                                                  not_korr = 0;
                                                   };
                                                  
                   if (not_korr == 1) {             // если не попали ни в один из промежутков то 
                                       char i = 0;
                                       GIMSK|=0x00; //запрещаем прерывания по изм. по входу (разрешим в обработчике прерывания по переполнению счетчика)
                                       TCCR0B = 0x00;
                                       TCNT0 = 0;
                                       sct_bit = 0;
                                      //очищаем буффер
                                      for (i=0; i<14; i++){
                                                          RC5_buffer [i] = 0;
                                                           };
                                       //отправляем NO Correct takte (отправлять не обязательно - для себя...)
                                            
                                       // putsf ("T");   //---------->>>>>>>>>>>>>>
                                      
                                                                             
                                       };
                   
                    if (sct_bit == 14){        // если бит последний то 
                  
                   
                    TCCR0B = 0x00; //останавливаем таймер
                    TCNT0=0;
                    sct_bit = 0;
                    //формируем из массива соответствующие коды 
                    startbit2 = RC5_buffer [1];
                    trigger = RC5_buffer [2];
                   
                    device = (RC5_buffer [3] << 4)|(RC5_buffer [4] << 3)|(RC5_buffer [5] << 2)|(RC5_buffer [6] << 1)|RC5_buffer [7];                    
                    command = (RC5_buffer [8] << 5)|(RC5_buffer [9] << 4)|(RC5_buffer [10] << 3 )|(RC5_buffer [11] << 2)|(RC5_buffer [12] << 1)|RC5_buffer [13];
                  
             
                    //отправляем по UART данные 
                    //printf ("StartBit2 %d  Trigger %d  Device %d  Command %d",startbit2, trigger, device, command); //------>>>>>>
                    
                    switch(command){
                                    case 16:    //отключаем паузу для громкости и не только...
                                    break;
                                    
                                    case 17:
                                    break; 
                                    
                                    case 43:
                                    break;
                                    
                                    case 44:
                                    break;
                                    
                                    case 42:
                                    break;
                                    
                                    case 41:
                                    break;
                                    
                                    case 35:
                                    break;
                                    
                                    case 14:
                                    break;
                                                                        
                                    default:
                                    delay_ms (385); //пауза не обязательно - чтобы реакция кнопок была помедленнее...  
                                    };    
                      
                      
                      // сбрасываем флаг прерывания по входу INT0
                    EIFR=0x40;
                       };                                                                
                   
                   };
  
    
}


// Timer 0 overflow interrupt service routine
interrupt [TIM0_OVF] void timer0_ovf_isr(void)
{
// Place your code here
                                             char i = 0;
                                             PORTD.3 = 1;
                                       GIMSK|=0x00;
                                       TCCR0B = 0x00;
                                       TCNT0 = 0;
                                       sct_bit = 0;
                                      //очищаем буффер
                                      for (i=0; i<14; i++){
                                                          RC5_buffer [i] = 0;
                                                           };
                                       //отправляем NO Correct block - для отладки...
                                                  // putsf ("B");  //----------->>>>>>>
                                      // LED_OFF;
                                       GIMSK|=0x40; //разрешаем прерывания по входу
                                       EIFR=0x40;  //сбрасываем флаг прерывания (если произошло)
}

// Declare your global variables here

void main(void)
{
// Declare your local variables here

// Crystal Oscillator division factor: 1
#pragma optsize-
CLKPR=0x80;
CLKPR=0x00;
#ifdef _OPTIMIZE_SIZE_
#pragma optsize+
#endif


// 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=0b11111111;

// Port D initialization
// Func6=In Func5=In Func4=In Func3=In Func2=In Func1=In Func0=In 
// State6=T State5=T State4=T State3=T State2=P State1=T State0=T 
PORTD=0b0001100;
DDRD=0b0001000;
PORTD.3 = 1;

// Timer/Counter 0 initialization
// Clock source: System Clock
// Clock value: Timer 0 Stopped
// Mode: Normal top=FFh
// OC0A output: Disconnected
// OC0B output: Disconnected
TCCR0A=0x00;
TCCR0B=0x00;
TCNT0=0x00;
OCR0A=0x00;
OCR0B=0x00;

// 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;

// External Interrupt(s) initialization
// INT0: On
// INT0 Mode: Any change
// INT1: Off
// Interrupt on any change on pins PCINT0-7: Off
GIMSK=0x40;
MCUCR=0x01;
EIFR=0x40;

// Timer(s)/Counter(s) Interrupt(s) initialization
TIMSK=0x02;

// Universal Serial Interface initialization
// Mode: Disabled
// Clock source: Register & Counter=no clk.
// USI Counter Overflow Interrupt: Off
USICR=0x00;


// Analog Comparator initialization
// Analog Comparator: Off
// Analog Comparator Input Capture by Timer/Counter 1: Off
ACSR=0x80;

// Global enable interrupts
#asm("sei")

while (1)
      {
      // My code here
      DDRB=0b11111111; //настройка портов    
 DDRD=0b0001000;     
 PORTD.3 = 1; 
   //проверка eeprom
   //if (devinit == 0) {
   //device0 = device;
   //devinit = 1;
   //}
   //if (devinit == 1) {
   //if (device == device0) {
    
 
  
 //триггер 1 выхода
 if (out1 == 0) {
 if (command == 000001) {
 
 out1 = 1;
 }
 }
 else {
 if (command == 000001) {
 
 out1 = 0;
 }
 }
 //триггер 2 выхода
 if (out2 == 0) {
 if (command == 000010) {
 
 out2 = 1;
 }
 }
 else {
 if (command == 000010) {
 
 out2 = 0;
 }
 }    
 //триггер 3 выхода
 if (out3 == 0) {
 if (command == 000011) {
 
 out3 = 1;
 }
 }
 else {
 if (command == 000011) {
 
 out3 = 0;
 }
 } 
 //триггер 4 выхода
 if (out4 == 0) {
 if (command == 000100) {
 
 out4 = 1;
 }
 }
 else {
 if (command == 000100) {
 
 out4 = 0;
 }
 }  
 //триггер 5 выхода
 if (out5 == 0) {
 if (command == 000101) {
 
 out1 = 1;
 }
 }
 else {
 if (command == 000101) {
 
 out5 = 0;
 }
 }   
 //триггер 6 выхода
 if (out6 == 0) {
 if (command == 000110) {
 
 out6 = 1;
 }
 }
 else {
 if (command == 000110) {
 
 out6 = 0;
 }
 }
 command = 0;//обнуляем 
     
 //out
 PORTB.7 = out1;
 PORTB.6 = out2; 
 PORTB.5 = out3;
 PORTB.4 = out4;
 PORTB.3 = out5;
 PORTB.2 = out6;
// }
 //}    
     
      };
}