neerly working version of rf433rcv
[svn42.git] / rf433rcv / teensy / example.c
index ab7026c..649f6de 100644 (file)
 #include "usb_rawhid.h"
 
 #define CPU_PRESCALE(n)        (CLKPR = 0x80, CLKPR = (n))
-
+#define RF_SEND_BUFFER_LEN_MAX 128
 volatile uint16_t output_count=0;
 volatile uint8_t active_buffer=0;
-volatile uint8_t send_buffer=0;
-uint8_t read_buffer[64];
-uint8_t write_buffer[2][64];
+volatile uint16_t send_buffer=0;
+volatile uint8_t capture=0;
+volatile uint16_t rf_send=0; //count of bits in rf_send_buffer that should be sent
+volatile uint16_t rf_send_reload=0; //count of bits in rf_send_buffer that should be sent
+volatile uint8_t rf_send_reload_count=0; // number of repetitions (times rf_send gets reloaded;
+uint8_t read_buffer[64]; // buffer for reading usb signals
+uint8_t write_buffer[2][64]; // buffer for writing usb signals
+uint8_t rf_send_buffer[RF_SEND_BUFFER_LEN_MAX]; // buffer for sending rf433 signals
+volatile uint16_t rf_send_buffer_len=0;
+
+
+void reset()
+{
+  cli();
+  // disable watchdog, if enabled
+  // disable all peripherals
+  UDCON = 1;
+  USBCON = (1<<FRZCLK);  // disable USB
+  UCSR1B = 0;
+  _delay_ms(5);
+  #if defined(__AVR_AT90USB162__)                // Teensy 1.0
+      EIMSK = 0; PCICR = 0; SPCR = 0; ACSR = 0; EECR = 0;
+      TIMSK0 = 0; TIMSK1 = 0; UCSR1B = 0;
+      DDRB = 0; DDRC = 0; DDRD = 0;
+      PORTB = 0; PORTC = 0; PORTD = 0;
+      asm volatile("jmp 0x3E00");
+  #elif defined(__AVR_ATmega32U4__)              // Teensy 2.0
+      EIMSK = 0; PCICR = 0; SPCR = 0; ACSR = 0; EECR = 0; ADCSRA = 0;
+      TIMSK0 = 0; TIMSK1 = 0; TIMSK3 = 0; TIMSK4 = 0; UCSR1B = 0; TWCR = 0;
+      DDRB = 0; DDRC = 0; DDRD = 0; DDRE = 0; DDRF = 0; TWCR = 0;
+      PORTB = 0; PORTC = 0; PORTD = 0; PORTE = 0; PORTF = 0;
+      asm volatile("jmp 0x7E00");
+  #elif defined(__AVR_AT90USB646__)              // Teensy++ 1.0
+      EIMSK = 0; PCICR = 0; SPCR = 0; ACSR = 0; EECR = 0; ADCSRA = 0;
+      TIMSK0 = 0; TIMSK1 = 0; TIMSK2 = 0; TIMSK3 = 0; UCSR1B = 0; TWCR = 0;
+      DDRA = 0; DDRB = 0; DDRC = 0; DDRD = 0; DDRE = 0; DDRF = 0;
+      PORTA = 0; PORTB = 0; PORTC = 0; PORTD = 0; PORTE = 0; PORTF = 0;
+      asm volatile("jmp 0xFC00");
+  #elif defined(__AVR_AT90USB1286__)             // Teensy++ 2.0
+      EIMSK = 0; PCICR = 0; SPCR = 0; ACSR = 0; EECR = 0; ADCSRA = 0;
+      TIMSK0 = 0; TIMSK1 = 0; TIMSK2 = 0; TIMSK3 = 0; UCSR1B = 0; TWCR = 0;
+      DDRA = 0; DDRB = 0; DDRC = 0; DDRD = 0; DDRE = 0; DDRF = 0;
+      PORTA = 0; PORTB = 0; PORTC = 0; PORTD = 0; PORTE = 0; PORTF = 0;
+      asm volatile("jmp 0x1FC00");
+  #endif 
+}
 
 int main(void)
 {
@@ -45,7 +88,7 @@ int main(void)
   // 200*8 clock cycles, 100us
   TCCR0A = 1<<WGM01;
   TCCR0B = 1<<CS01;
-  OCR0A = 199;
+  OCR0A = 249;
   TCNT0 = 0;
   TIMSK0 = (1<<OCIE0A);
 
@@ -59,8 +102,44 @@ int main(void)
   _delay_ms(1000);
   while (1) {
     // if received data, do something with it
-    //r = usb_rawhid_recv(read_buffer, 0);
-    //if (r>0)
+    int8_t r = usb_rawhid_recv(read_buffer, 0);
+    if (r>0)
+    {
+      if (read_buffer[0]=='r') //reset
+        reset();
+      else if (read_buffer[0]=='b') //begin capture
+        capture=1;
+      else if (read_buffer[0]=='e') //end capture
+        capture=0;
+      else if (read_buffer[0]=='f') //fill send buffer
+      {
+        int8_t buffer_pos = 1;
+        while(buffer_pos < r && rf_send_buffer_len<RF_SEND_BUFFER_LEN_MAX)
+        {
+          rf_send_buffer[rf_send_buffer_len]=read_buffer[buffer_pos];
+          rf_send_buffer_len++;
+          buffer_pos++;
+        }
+      }
+      else if (read_buffer[0]=='c') // clear send buffer
+      {
+        rf_send_buffer_len=0;
+      }
+      else if (read_buffer[0]=='s') //send
+      {
+        capture=0;
+        //if (r>2)
+        //  rf_send_reload=rf_send_buffer_len*8-read_buffer[2]; // substract bit offset
+        //else
+        usb_rawhid_send(rf_send_buffer, 145);
+        rf_send=0;
+        rf_send_reload=rf_send_buffer_len*8;
+        rf_send_reload_count=read_buffer[1];  
+        //read_buffer[0]=rf_send_reload;
+        //read_buffer[1]=rf_send_reload>>8;
+        //read_buffer[2]=0;
+      }
+    }
     if (send_buffer)
     {
       send_buffer=0;
@@ -73,14 +152,30 @@ int main(void)
 ISR(TIMER0_COMPA_vect)
 {
   PORTF^=2;
-  write_buffer[active_buffer][output_count/8]<<=1;
-  write_buffer[active_buffer][output_count++/8]|=PINB&1;
-  if (output_count>=64*8)
+  if (rf_send)
   {
-    output_count=0;
-    active_buffer=active_buffer?0:1;
-    send_buffer=1;
+    if ( ( rf_send_buffer[rf_send/8] >> ( (rf_send%8)?8-(rf_send%8):0 ) ) & 1)
+    {
+     PORTF&=~1;
+    } else {
+     PORTF|=1;
+    }
+    //rf_send_buffer[rf_send/8]>>=1;
+    rf_send--;
+  } else if (rf_send_reload_count) {
+    rf_send=rf_send_reload;
+    rf_send_reload_count--;
+  } else {
+    PORTF&=~1;
+    if (capture) {
+      write_buffer[active_buffer][output_count/8]<<=1;
+      write_buffer[active_buffer][output_count++/8]|=PINB&1;
+      if (output_count>=64*8)
+      {
+        output_count=0;
+        active_buffer=active_buffer?0:1;
+        send_buffer=1;
+      }
+    }
   }
 }
-
-