X-Git-Url: https://git.realraum.at/?p=svn42.git;a=blobdiff_plain;f=rf433rcv%2Fteensy%2Fexample.c;h=df393abe7bce9fa37e628c37aad41c98c9765792;hp=282e0bcb0ccec420d86002d65b8264f0b7dd17d9;hb=5b00dab1a7d2ac2d8a593f0bd6e85a7194e2c9bd;hpb=894be2570b2c0198a4c7b87f385957c74b836bb3 diff --git a/rf433rcv/teensy/example.c b/rf433rcv/teensy/example.c index 282e0bc..df393ab 100644 --- a/rf433rcv/teensy/example.c +++ b/rf433rcv/teensy/example.c @@ -28,18 +28,61 @@ #include "usb_rawhid.h" #define CPU_PRESCALE(n) (CLKPR = 0x80, CLKPR = (n)) -#define RF_SEND_BUFFER_LEN_MAX 128 +#define RF_SEND_BUFFER_LEN_MAX 502 + +union multiint { + uint16_t u16; + uint8_t u8[2]; +} __attribute__((packed)); + volatile uint16_t output_count=0; volatile uint8_t active_buffer=0; volatile uint16_t send_buffer=0; volatile uint8_t capture=0; -volatile uint8_t rf_send=0; //count of bits in rf_send_buffer that should be sent -volatile uint8_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; +volatile uint16_t rf_send_buf_pos=0; //count of bits in rf_send_buffer that should be sent +volatile union multiint rf_send_buf_len; //count of bits in rf_send_buffer that should be sent +volatile uint8_t rf_send_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 -uint8_t rf_send_buffer_len=0; +uint16_t rf_send_buf_offset=0; + + +void reset() +{ + cli(); + // disable watchdog, if enabled + // disable all peripherals + UDCON = 1; + USBCON = (1<0) { - if (read_buffer[0]=='b') //begin capture + 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 byte_rem = r-1; - while(byte_rem && rf_send_buffer_len2) - rf_send_reload=rf_send_buffer_len*8-read_buffer[2]; // substract bit offset - else - rf_send_reload=rf_send_buffer_len*8; - rf_send_reload_count=read_buffer[1]; + rf_send_buf_pos=0; + rf_send_count=read_buffer[1]+1; } } if (send_buffer) { send_buffer=0; - usb_rawhid_send(write_buffer[active_buffer?0:1], 45); + usb_rawhid_send(write_buffer[active_buffer?0:1], 23); } } } @@ -108,28 +158,30 @@ int main(void) ISR(TIMER0_COMPA_vect) { PORTF^=2; - if (rf_send) + if (rf_send_count && rf_send_buf_pos=64*8) - { - output_count=0; - active_buffer=active_buffer?0:1; - send_buffer=1; + //rf_send_buffer[rf_send/8]>>=1; + rf_send_buf_pos++; + } else if (rf_send_count) { + rf_send_buf_pos=0; + rf_send_count--; + } else { + PORTF&=~1; + if (capture) { + write_buffer[active_buffer][output_count/8]<<=1; + write_buffer[active_buffer][output_count++/8]|=PIND&1; + if (output_count>=64*8) + { + output_count=0; + active_buffer=active_buffer?0:1; + send_buffer=1; + } } } } - -