change port manipulation to ardino commands and lets change the pin at runtime possible
This commit is contained in:
parent
1a1aaa883e
commit
f7e987cbeb
4 changed files with 54 additions and 129 deletions
|
@ -45,26 +45,13 @@
|
||||||
const struct sensors_sensor relay_sensor;
|
const struct sensors_sensor relay_sensor;
|
||||||
static int status(int type);
|
static int status(int type);
|
||||||
static int enabled = 0;
|
static int enabled = 0;
|
||||||
static int relay1=0;
|
static int relay[8]={0,0,0,0,0,0,0,0};
|
||||||
static int relay2=0;
|
static int relaypin[8]={RELAY_PIN_1,RELAY_PIN_2,RELAY_PIN_3,RELAY_PIN_4,RELAY_PIN_5,RELAY_PIN_6,RELAY_PIN_7,RELAY_PIN_8};
|
||||||
static int relay3=0;
|
|
||||||
static int relay4=0;
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
static int
|
static int
|
||||||
value(int type)
|
value(int type)
|
||||||
{
|
{
|
||||||
switch(type) {
|
return relay[type];
|
||||||
case RELAY_SENSOR_1:
|
|
||||||
return relay1;
|
|
||||||
case RELAY_SENSOR_2:
|
|
||||||
return relay2;
|
|
||||||
case RELAY_SENSOR_3:
|
|
||||||
return relay2;
|
|
||||||
case RELAY_SENSOR_4:
|
|
||||||
return relay2;
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
static int
|
static int
|
||||||
|
@ -74,6 +61,14 @@ configure(int type, int c)
|
||||||
case SENSORS_ACTIVE:
|
case SENSORS_ACTIVE:
|
||||||
if(c) {
|
if(c) {
|
||||||
if(!status(SENSORS_ACTIVE)) {
|
if(!status(SENSORS_ACTIVE)) {
|
||||||
|
relay_init(relaypin[RELAY_SENSOR_1]);
|
||||||
|
relay_init(relaypin[RELAY_SENSOR_2]);
|
||||||
|
relay_init(relaypin[RELAY_SENSOR_3]);
|
||||||
|
relay_init(relaypin[RELAY_SENSOR_4]);
|
||||||
|
relay_init(relaypin[RELAY_SENSOR_5]);
|
||||||
|
relay_init(relaypin[RELAY_SENSOR_6]);
|
||||||
|
relay_init(relaypin[RELAY_SENSOR_7]);
|
||||||
|
relay_init(relaypin[RELAY_SENSOR_8]);
|
||||||
enabled = 1;
|
enabled = 1;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -81,39 +76,19 @@ configure(int type, int c)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case RELAY_SENSOR_1:
|
case RELAY_SENSOR_1:
|
||||||
if(c==0){
|
|
||||||
relay1_off();
|
|
||||||
relay1=0;
|
|
||||||
}else{
|
|
||||||
relay1_on();
|
|
||||||
relay1=1;
|
|
||||||
};
|
|
||||||
break;
|
|
||||||
case RELAY_SENSOR_2:
|
case RELAY_SENSOR_2:
|
||||||
if(c==0){
|
|
||||||
relay2_off();
|
|
||||||
relay2=0;
|
|
||||||
}else{
|
|
||||||
relay2_on();
|
|
||||||
relay2=1;
|
|
||||||
};
|
|
||||||
break;
|
|
||||||
case RELAY_SENSOR_3:
|
case RELAY_SENSOR_3:
|
||||||
if(c==0){
|
|
||||||
relay3_off();
|
|
||||||
relay3=0;
|
|
||||||
}else{
|
|
||||||
relay3_on();
|
|
||||||
relay3=1;
|
|
||||||
};
|
|
||||||
break;
|
|
||||||
case RELAY_SENSOR_4:
|
case RELAY_SENSOR_4:
|
||||||
|
case RELAY_SENSOR_5:
|
||||||
|
case RELAY_SENSOR_6:
|
||||||
|
case RELAY_SENSOR_7:
|
||||||
|
case RELAY_SENSOR_8:
|
||||||
if(c==0){
|
if(c==0){
|
||||||
relay4_off();
|
relay_off(relaypin[type]);
|
||||||
relay4=0;
|
relay[type]=0;
|
||||||
}else{
|
}else{
|
||||||
relay4_on();
|
relay_on(relaypin[type]);
|
||||||
relay4=1;
|
relay[type]=1;
|
||||||
};
|
};
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -48,5 +48,19 @@ extern const struct sensors_sensor relay_sensor;
|
||||||
#define RELAY_SENSOR_2 1
|
#define RELAY_SENSOR_2 1
|
||||||
#define RELAY_SENSOR_3 2
|
#define RELAY_SENSOR_3 2
|
||||||
#define RELAY_SENSOR_4 3
|
#define RELAY_SENSOR_4 3
|
||||||
|
#define RELAY_SENSOR_5 4
|
||||||
|
#define RELAY_SENSOR_6 5
|
||||||
|
#define RELAY_SENSOR_7 6
|
||||||
|
#define RELAY_SENSOR_8 7
|
||||||
|
|
||||||
|
/* default pins Arduino-Merkurboard */
|
||||||
|
#define RELAY_PIN_1 10
|
||||||
|
#define RELAY_PIN_2 11
|
||||||
|
#define RELAY_PIN_3 12
|
||||||
|
#define RELAY_PIN_4 13
|
||||||
|
#define RELAY_PIN_5 15
|
||||||
|
#define RELAY_PIN_6 16
|
||||||
|
#define RELAY_PIN_7 17
|
||||||
|
#define RELAY_PIN_8 18
|
||||||
|
|
||||||
#endif /* __RELAY_SENSOR_H__ */
|
#endif /* __RELAY_SENSOR_H__ */
|
||||||
|
|
|
@ -37,7 +37,7 @@
|
||||||
* Harald Pichler harald@the-develop.net
|
* Harald Pichler harald@the-develop.net
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
#include "Arduino.h"
|
||||||
#include "relay.h"
|
#include "relay.h"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -45,92 +45,32 @@
|
||||||
* \{
|
* \{
|
||||||
*/
|
*/
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* \brief Turns the RELAY1 on.
|
* \brief init RELAY PINS.
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
relay1_off(void)
|
relay_init(uint8_t pin)
|
||||||
{
|
{
|
||||||
PORTB &= ~(1<<PINB0);
|
pinMode(pin, OUTPUT);
|
||||||
DDRB |= (1<<DDB0);
|
digitalWrite(pin, LOW);
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* \brief Turns the RELAY on.
|
||||||
|
*/
|
||||||
|
|
||||||
|
void
|
||||||
|
relay_on(uint8_t pin)
|
||||||
|
{
|
||||||
|
digitalWrite(pin, HIGH);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* \brief Turns the RELAY1 off
|
* \brief Turns the RELAY off
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
relay1_on(void)
|
relay_off(uint8_t pin)
|
||||||
{
|
{
|
||||||
PORTB |= (1<<PINB0);
|
digitalWrite(pin, LOW);
|
||||||
DDRB |= (1<<DDB0);
|
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
|
||||||
/**
|
|
||||||
* \brief Turns the RELAY2 on.
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
relay2_off(void)
|
|
||||||
{
|
|
||||||
PORTB &= ~(1<<PINB1);
|
|
||||||
DDRB |= (1<<DDB1);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* \brief Turns the RELAY2 off.
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
relay2_on(void)
|
|
||||||
{
|
|
||||||
PORTB |= (1<<PINB1);
|
|
||||||
DDRB |= (1<<DDB1);
|
|
||||||
}
|
|
||||||
/*---------------------------------------------------------------------------*/
|
|
||||||
/**
|
|
||||||
* \brief Turns the RELAY3 on.
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
relay3_off(void)
|
|
||||||
{
|
|
||||||
PORTB &= ~(1<<PINB2);
|
|
||||||
DDRB |= (1<<DDB2);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* \brief Turns the RELAY3 off.
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
relay3_on(void)
|
|
||||||
{
|
|
||||||
PORTB |= (1<<PINB2);
|
|
||||||
DDRB |= (1<<DDB2);
|
|
||||||
}
|
|
||||||
/*---------------------------------------------------------------------------*/
|
|
||||||
/**
|
|
||||||
* \brief Turns the RELAY4 on.
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
relay4_off(void)
|
|
||||||
{
|
|
||||||
PORTB &= ~(1<<PINB3);
|
|
||||||
DDRB |= (1<<DDB3);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* \brief Turns the RELAY4 off.
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
relay4_on(void)
|
|
||||||
{
|
|
||||||
PORTB |= (1<<PINB3);
|
|
||||||
DDRB |= (1<<DDB3);
|
|
||||||
}
|
|
||||||
/*---------------------------------------------------------------------------*/
|
|
||||||
|
|
|
@ -45,14 +45,10 @@
|
||||||
|
|
||||||
/** @name RELAY Functions */
|
/** @name RELAY Functions */
|
||||||
/** @{ */
|
/** @{ */
|
||||||
void relay1_on(void);
|
void relay_init(uint8_t pin);
|
||||||
void relay1_off(void);
|
void relay_on(uint8_t pin);
|
||||||
void relay2_on(void);
|
void relay_off(uint8_t pin);
|
||||||
void relay2_off(void);
|
|
||||||
void relay3_on(void);
|
|
||||||
void relay3_off(void);
|
|
||||||
void relay4_on(void);
|
|
||||||
void relay4_off(void);
|
|
||||||
/** @} */
|
/** @} */
|
||||||
|
|
||||||
#endif /* __RELAY_H__ */
|
#endif /* __RELAY_H__ */
|
||||||
|
|
Loading…
Add table
Reference in a new issue