1,7 → 1,6 |
//---------------------------------------------------------------------------------- |
// Prevodnik RS232 <--> RS485 s prodlevou pri prevodu smerem do RS485 |
// pri startbitu na RS232 zapne okamzite vysilac. ceka nez prestanou prichazet data a vysilac vypne. |
// je implementovany jednoduchy algoritmus na rozpoznani rychlosti, ktery vsak nefunkuje na veskery mozny obsah bajtu. |
// pri startbitu na RS232 zapne okamzite vysilac pokud nejsou detekovana data z RS485. |
//---------------------------------------------------------------------------------- |
|
#include <avr/io.h> |
31,8 → 30,8 |
int main(void) |
{ |
int delay; |
int bit; |
int spozdeni; |
int last; |
|
DDRD |= (1<<DDD5); |
// DDRB |= (1<<DDB3); |
45,26 → 44,21 |
{ |
if(!(PIND & (1<<PD1))) // kdyz je 0 na datech |
{ |
PORTD &= ~(1<<PD5); // zapni vysilani |
TCNT1 = 0; // zacni merit cas |
|
while (!(PIND & (1<<PD1))); // cekej na 1 |
|
delay = TCNT1; // hned jak narazis na 1, poznamenej si jak dlouho to trvalo |
TCNT1 = 0; // zacni znova merit cas |
bit = (delay >> 3); // cas ktery jsme pred tim zmerili videl 8mi aby jsme se dostali maximalne na delku bitu |
|
|
while (TCNT1 <= delay); // pockej zmerenou dobu |
if((PIND & (1<<PD1))) // kdyz je 1 na datech, pockej jeste |
{ |
for (spozdeni=0;spozdeni<=16;spozdeni ++) |
{ |
TCNT1 = 0; // zacni znova merit cas |
if((PIND & (1<<PD1))) while (TCNT1 <= bit); // kdyz je porad 1 tak pockej jeste delku bitu |
else break; |
PORTD &= ~(1<<PD5); // zapni vysilani |
for (spozdeni=0;spozdeni<=8;spozdeni ++) |
{ |
last = (PIND & (1<<PD1)); |
TCNT1 = 0; // zacni znova merit cas |
while (TCNT1 <= delay) |
{ |
if((PIND & (1<<PD1)) != last) |
{ |
if (TCNT1 < delay) delay = TCNT1; |
break; |
} |
} |
} |
while (!(PIND & (1<<PD1))); |
} |
else PORTD |= (1<<PD5); // kdyz je 1 prepni na prijem |
} |