mirror of
https://github.com/KostyaSha/arduino-iebus
synced 2025-10-24 15:07:42 +00:00
Adjust timeouts
This commit is contained in:
parent
fde8d708ca
commit
da0f1fd9f3
@ -79,8 +79,8 @@ const AvcOutMessage CmdLanCheckOk PROGMEM = {AVC_MSG_DIRECT, 0x06, {0x00
|
|||||||
|
|
||||||
// AVCLan CDchanger & timer1 init,
|
// AVCLan CDchanger & timer1 init,
|
||||||
void AVCLanCDch::begin(){
|
void AVCLanCDch::begin(){
|
||||||
avclan.deviceAddress = 0x0240;
|
// avclan.deviceAddress = 0x0240;
|
||||||
|
avclan.deviceAddress = 0x0360;
|
||||||
// timer1 setup, prescaler factor - 1024
|
// timer1 setup, prescaler factor - 1024
|
||||||
TCCR1A = 0; // normal mode
|
TCCR1A = 0; // normal mode
|
||||||
TCCR1B = 5; // Prescaler /1024
|
TCCR1B = 5; // Prescaler /1024
|
||||||
|
@ -114,7 +114,8 @@ byte AVCLanDrv::_readMessage (){
|
|||||||
TCCR2B=0x02; // prescaler 8
|
TCCR2B=0x02; // prescaler 8
|
||||||
|
|
||||||
if (t < AVC_START_BIT_HOLD_ON_MIN_LENGTH){
|
if (t < AVC_START_BIT_HOLD_ON_MIN_LENGTH){
|
||||||
//if (t < 0x16){
|
bSerial.print("Error t < AVC_START_BIT_HOLD_ON_MIN_LENGTH: ");
|
||||||
|
bSerial.printHex8(t);
|
||||||
SREG = oldSREG;
|
SREG = oldSREG;
|
||||||
return 2;
|
return 2;
|
||||||
}
|
}
|
||||||
@ -391,6 +392,11 @@ bool AVCLanDrv::handleAcknowledge (void){
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (broadcast == AVC_MSG_DIRECT){
|
||||||
|
// Acknowledge.
|
||||||
|
send1BitWord(1);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
// Return acknowledge bit.
|
// Return acknowledge bit.
|
||||||
return readAcknowledge();
|
return readAcknowledge();
|
||||||
}
|
}
|
||||||
@ -495,15 +501,37 @@ void AVCLanDrv::printMessage(bool incoming){
|
|||||||
}
|
}
|
||||||
bSerial.printHex4(masterAddress >> 8);
|
bSerial.printHex4(masterAddress >> 8);
|
||||||
bSerial.printHex8(masterAddress);
|
bSerial.printHex8(masterAddress);
|
||||||
bSerial.print(" ");
|
bSerial.print("->");
|
||||||
|
|
||||||
bSerial.printHex4(slaveAddress >> 8);
|
bSerial.printHex4(slaveAddress >> 8);
|
||||||
bSerial.printHex8(slaveAddress);
|
bSerial.printHex8(slaveAddress);
|
||||||
bSerial.print(" ");
|
bSerial.print(" ");
|
||||||
bSerial.printHex8(dataSize);
|
bSerial.printHex8(dataSize);
|
||||||
|
if (slaveAddress == 0x0FFF) {
|
||||||
|
bSerial.print(" ");
|
||||||
|
} else {
|
||||||
|
bSerial.print(" ");
|
||||||
|
}
|
||||||
|
|
||||||
for (byte i = 0; i < dataSize; i++) {
|
for (byte i = 0; i < dataSize; i++) {
|
||||||
bSerial.printHex8(message[i]);
|
bSerial.printHex8(message[i]);
|
||||||
|
if (i == 0) {
|
||||||
|
if (slaveAddress == 0x01FF) { // separate logical src and dst addrs
|
||||||
|
bSerial.print(" ");
|
||||||
|
} else if (slaveAddress == 0x0FFF) {
|
||||||
|
|
||||||
|
} else {
|
||||||
|
bSerial.print("->");
|
||||||
|
}
|
||||||
|
} else if (i == 1) {
|
||||||
|
if (slaveAddress == 0x01FF) {
|
||||||
|
// bSerial.print(" ");
|
||||||
|
} else if (slaveAddress == 0x0FFF) {
|
||||||
|
|
||||||
|
} else {
|
||||||
|
bSerial.print(" ");
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
bSerial.println();
|
bSerial.println();
|
||||||
|
|
||||||
|
@ -45,10 +45,11 @@
|
|||||||
#define AVC_BIT_1_HOLD_ON_LENGTH 0x28 // 20 uS * (F_CPU / 1000000L / 8)
|
#define AVC_BIT_1_HOLD_ON_LENGTH 0x28 // 20 uS * (F_CPU / 1000000L / 8)
|
||||||
#define AVC_BIT_0_HOLD_ON_LENGTH 0x40 // 32 uS * (F_CPU / 1000000L / 8)
|
#define AVC_BIT_0_HOLD_ON_LENGTH 0x40 // 32 uS * (F_CPU / 1000000L / 8)
|
||||||
//#define AVC_BIT_0_HOLD_ON_MIN_LENGTH 0x34 // 26 uS * (F_CPU / 1000000L / 8) Compare half way between a '1' (20 us) and a '0' (32 us ): 32 - (32 - 20) /2 = 26 us
|
//#define AVC_BIT_0_HOLD_ON_MIN_LENGTH 0x34 // 26 uS * (F_CPU / 1000000L / 8) Compare half way between a '1' (20 us) and a '0' (32 us ): 32 - (32 - 20) /2 = 26 us
|
||||||
#define AVC_BIT_0_HOLD_ON_MIN_LENGTH 0x3C // 30 uS * (F_CPU / 1000000L / 8) Compare half way between a '1' (20 us) and a '0' (32 us ): 32 - (32 - 20) /2 = 26 us
|
#define AVC_BIT_0_HOLD_ON_MIN_LENGTH 0x32 // from pc car forum
|
||||||
|
//#define AVC_BIT_0_HOLD_ON_MIN_LENGTH 0x3C // 30 uS * (F_CPU / 1000000L / 8) Compare half way between a '1' (20 us) and a '0' (32 us ): 32 - (32 - 20) /2 = 26 us
|
||||||
#define AVC_START_BIT_LENGTH 0x5D // 186 uS * (F_CPU / 1000000L / 32) , prescaler 32
|
#define AVC_START_BIT_LENGTH 0x5D // 186 uS * (F_CPU / 1000000L / 32) , prescaler 32
|
||||||
#define AVC_START_BIT_HOLD_ON_LENGTH 0x54 // 168 uS * (F_CPU / 1000000L / 32) prescaler 32
|
#define AVC_START_BIT_HOLD_ON_LENGTH 0x54 // 168 uS * (F_CPU / 1000000L / 32) prescaler 32
|
||||||
#define AVC_START_BIT_HOLD_ON_MIN_LENGTH 0x16 // 44 uS * (F_CPU / 1000000L / 32) grater that AVC_NORMAL_BIT_LENGTH, prescaler 32
|
#define AVC_START_BIT_HOLD_ON_MIN_LENGTH 0x09 // 44 uS * (F_CPU / 1000000L / 32) grater that AVC_NORMAL_BIT_LENGTH, prescaler 32
|
||||||
#define AVC_1U_LENGTH 0x02 // 1 uS * (F_CPU / 1000000L / 8)
|
#define AVC_1U_LENGTH 0x02 // 1 uS * (F_CPU / 1000000L / 8)
|
||||||
|
|
||||||
#define AVC_MAXMSGLEN 32
|
#define AVC_MAXMSGLEN 32
|
||||||
@ -104,6 +105,7 @@ class AVCLanDrv{
|
|||||||
byte event;
|
byte event;
|
||||||
byte actionID;
|
byte actionID;
|
||||||
bool readonly;
|
bool readonly;
|
||||||
|
bool log;
|
||||||
void begin ();
|
void begin ();
|
||||||
byte readMessage (void);
|
byte readMessage (void);
|
||||||
byte sendMessage (void);
|
byte sendMessage (void);
|
||||||
|
@ -9,7 +9,7 @@
|
|||||||
|
|
||||||
#include <avr/pgmspace.h>
|
#include <avr/pgmspace.h>
|
||||||
#include "AVCLanDrv.h"
|
#include "AVCLanDrv.h"
|
||||||
#include "WProgram.h"
|
#include "Arduino.h"
|
||||||
|
|
||||||
#define AVCLANDEVICE_NAME " Navi"
|
#define AVCLANDEVICE_NAME " Navi"
|
||||||
#define AVCLANDEVICE_VERSION "0.0.1"
|
#define AVCLANDEVICE_VERSION "0.0.1"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user