cc2531 Button 2 driver

This commit is contained in:
George Oikonomou 2011-12-22 21:37:42 +00:00 committed by George Oikonomou
parent 5662b1f37d
commit 6a808053ce
3 changed files with 139 additions and 42 deletions

View file

@ -35,76 +35,155 @@
#include "dev/port.h" #include "dev/port.h"
#include "dev/button-sensor.h" #include "dev/button-sensor.h"
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
#if BUTTON_SENSOR_ON
static __data struct timer debouncetimer; static __data struct timer debouncetimer;
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
/* Button 1 - SmartRT and cc2531 USb Dongle */
/*---------------------------------------------------------------------------*/
static static
int value(int type) int value_b1(int type)
{ {
return BUTTON_READ() || !timer_expired(&debouncetimer); type;
return BUTTON_READ(1) || !timer_expired(&debouncetimer);
} }
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
static static
int status(int type) int status_b1(int type)
{ {
switch (type) { switch (type) {
case SENSORS_ACTIVE: case SENSORS_ACTIVE:
case SENSORS_READY: case SENSORS_READY:
return BUTTON_IRQ_ENABLED(); return BUTTON_IRQ_ENABLED(1);
} }
return 0; return 0;
} }
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
static static
int configure(int type, int value) int configure_b1(int type, int value)
{ {
switch(type) { switch(type) {
case SENSORS_HW_INIT: case SENSORS_HW_INIT:
#if !MODEL_CC2531
P0INP |= 2; /* Tri-state */ P0INP |= 2; /* Tri-state */
BUTTON_IRQ_ON_PRESS(); #endif
BUTTON_FUNC_GPIO(); BUTTON_IRQ_ON_PRESS(1);
BUTTON_DIR_INPUT(); BUTTON_FUNC_GPIO(1);
BUTTON_DIR_INPUT(1);
return 1; return 1;
case SENSORS_ACTIVE: case SENSORS_ACTIVE:
if(value) { if(value) {
if(!BUTTON_IRQ_ENABLED()) { if(!BUTTON_IRQ_ENABLED(1)) {
timer_set(&debouncetimer, 0); timer_set(&debouncetimer, 0);
BUTTON_IRQ_FLAG_OFF(); BUTTON_IRQ_FLAG_OFF(1);
BUTTON_IRQ_ENABLE(); BUTTON_IRQ_ENABLE(1);
} }
} else { } else {
BUTTON_IRQ_DISABLE(); BUTTON_IRQ_DISABLE(1);
} }
return 1; return 1;
} }
return 0; return 0;
} }
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
/* Button 2 - cc2531 USb Dongle only */
/*---------------------------------------------------------------------------*/
#if MODEL_CC2531
static
int value_b2(int type)
{
type;
return BUTTON_READ(2) || !timer_expired(&debouncetimer);
}
/*---------------------------------------------------------------------------*/
static
int status_b2(int type)
{
switch (type) {
case SENSORS_ACTIVE:
case SENSORS_READY:
return BUTTON_IRQ_ENABLED(2);
}
return 0;
}
/*---------------------------------------------------------------------------*/
static
int configure_b2(int type, int value)
{
switch(type) {
case SENSORS_HW_INIT:
BUTTON_IRQ_ON_PRESS(2);
BUTTON_FUNC_GPIO(2);
BUTTON_DIR_INPUT(2);
return 1;
case SENSORS_ACTIVE:
if(value) {
if(!BUTTON_IRQ_ENABLED(2)) {
timer_set(&debouncetimer, 0);
BUTTON_IRQ_FLAG_OFF(2);
BUTTON_IRQ_ENABLE(2);
}
} else {
BUTTON_IRQ_DISABLE(2);
}
return 1;
}
return 0;
}
#endif
/*---------------------------------------------------------------------------*/
/* ISRs */
/*---------------------------------------------------------------------------*/
#if MODEL_CC2531 #if MODEL_CC2531
void void
port_1_isr(void) __interrupt(P1INT_VECTOR) port_1_isr(void) __interrupt(P1INT_VECTOR)
#else
void
port_0_isr(void) __interrupt(P0INT_VECTOR)
#endif
{ {
EA = 0; EA = 0;
ENERGEST_ON(ENERGEST_TYPE_IRQ); ENERGEST_ON(ENERGEST_TYPE_IRQ);
/* This ISR is for the entire port. Check if the interrupt was caused by our /* This ISR is for the entire port. Check if the interrupt was caused by our
* button's pin. */ * button's pin. */
if(BUTTON_IRQ_CHECK()) { if(BUTTON_IRQ_CHECK(1)) {
if(timer_expired(&debouncetimer)) {
timer_set(&debouncetimer, CLOCK_SECOND / 8);
sensors_changed(&button_1_sensor);
}
}
if(BUTTON_IRQ_CHECK(2)) {
if(timer_expired(&debouncetimer)) {
timer_set(&debouncetimer, CLOCK_SECOND / 8);
sensors_changed(&button_2_sensor);
}
}
BUTTON_IRQ_FLAG_OFF(1);
BUTTON_IRQ_FLAG_OFF(2);
ENERGEST_OFF(ENERGEST_TYPE_IRQ);
EA = 1;
}
#else
void
port_0_isr(void) __interrupt(P0INT_VECTOR)
{
EA = 0;
ENERGEST_ON(ENERGEST_TYPE_IRQ);
/* This ISR is for the entire port. Check if the interrupt was caused by our
* button's pin. */
if(BUTTON_IRQ_CHECK(1)) {
if(timer_expired(&debouncetimer)) { if(timer_expired(&debouncetimer)) {
timer_set(&debouncetimer, CLOCK_SECOND / 8); timer_set(&debouncetimer, CLOCK_SECOND / 8);
sensors_changed(&button_sensor); sensors_changed(&button_sensor);
} }
} }
BUTTON_IRQ_FLAG_OFF(); BUTTON_IRQ_FLAG_OFF(1);
ENERGEST_OFF(ENERGEST_TYPE_IRQ); ENERGEST_OFF(ENERGEST_TYPE_IRQ);
EA = 1; EA = 1;
} }
#endif
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
SENSORS_SENSOR(button_sensor, BUTTON_SENSOR, value, configure, status); SENSORS_SENSOR(button_1_sensor, BUTTON_SENSOR, value_b1, configure_b1, status_b1);
#endif /* BUTTON_SENSOR_ON */ #if MODEL_CC2531
SENSORS_SENSOR(button_2_sensor, BUTTON_SENSOR, value_b2, configure_b2, status_b2);
#endif

View file

@ -55,41 +55,56 @@
* *
*/ */
#if MODEL_CC2531 #if MODEL_CC2531
#define BUTTON_PORT 1 #define BUTTON1_PORT 1
#define BUTTON_PIN 2 #define BUTTON1_PIN 2
#define BUTTON2_PORT 1
#define BUTTON2_PIN 3
#else #else
#define BUTTON_PORT 0 #define BUTTON1_PORT 0
#define BUTTON_PIN 1 #define BUTTON1_PIN 1
#endif #endif
#ifdef BUTTON_SENSOR_CONF_ON #ifdef BUTTON_SENSOR_CONF_ON
#define BUTTON_SENSOR_ON BUTTON_SENSOR_CONF_ON #define BUTTON_SENSOR_ON BUTTON_SENSOR_CONF_ON
#endif /* BUTTON_SENSOR_CONF_ON */ #endif /* BUTTON_SENSOR_CONF_ON */
#define button_sensor button_1_sensor
#if BUTTON_SENSOR_ON #if BUTTON_SENSOR_ON
extern const struct sensors_sensor button_sensor; /* Common */
extern const struct sensors_sensor button_1_sensor;
#if MODEL_CC2531 #if MODEL_CC2531
/* Button 1: P1_2 - Port 1 ISR needed */ /* USB Dongle */
extern const struct sensors_sensor button_2_sensor;
/* Buttons: P1_2 & P1_3 - Port 1 ISR needed */
void port_1_isr(void) __interrupt(P1INT_VECTOR); void port_1_isr(void) __interrupt(P1INT_VECTOR);
#else #define BUTTON_SENSOR_ACTIVATE() do { \
button_1_sensor.configure(SENSORS_ACTIVE, 1); \
button_2_sensor.configure(SENSORS_ACTIVE, 1); \
} while(0)
#else /* MODEL_CC2531 */
/* SmartRF */
/* Button 1: P0_1 - Port 0 ISR needed */ /* Button 1: P0_1 - Port 0 ISR needed */
void port_0_isr(void) __interrupt(P0INT_VECTOR); void port_0_isr(void) __interrupt(P0INT_VECTOR);
#endif
#define BUTTON_SENSOR_ACTIVATE() button_sensor.configure(SENSORS_ACTIVE, 1) #define BUTTON_SENSOR_ACTIVATE() button_sensor.configure(SENSORS_ACTIVE, 1)
#else #endif /* MODEL_CC2531 */
#else /* BUTTON_SENSOR_ON */
#define BUTTON_SENSOR_ACTIVATE() #define BUTTON_SENSOR_ACTIVATE()
#endif /* BUTTON_SENSOR_ON */ #endif /* BUTTON_SENSOR_ON */
/* Define macros for button 1 */ /* Define macros for buttons */
#define BUTTON_READ() PORT_READ(BUTTON_PORT, BUTTON_PIN) #define BUTTON_READ(b) PORT_READ(BUTTON##b##_PORT, BUTTON##b##_PIN)
#define BUTTON_FUNC_GPIO() PORT_FUNC_GPIO(BUTTON_PORT, BUTTON_PIN) #define BUTTON_FUNC_GPIO(b) PORT_FUNC_GPIO(BUTTON##b##_PORT, BUTTON##b##_PIN)
#define BUTTON_DIR_INPUT() PORT_DIR_INPUT(BUTTON_PORT, BUTTON_PIN) #define BUTTON_DIR_INPUT(b) PORT_DIR_INPUT(BUTTON##b##_PORT, BUTTON##b##_PIN)
#define BUTTON_IRQ_ENABLED() PORT_IRQ_ENABLED(BUTTON_PORT, BUTTON_PIN) #define BUTTON_IRQ_ENABLED(b) PORT_IRQ_ENABLED(BUTTON##b##_PORT, BUTTON##b##_PIN)
#define BUTTON_IRQ_CHECK() PORT_IRQ_CHECK(BUTTON_PORT, BUTTON_PIN) #define BUTTON_IRQ_CHECK(b) PORT_IRQ_CHECK(BUTTON##b##_PORT, BUTTON##b##_PIN)
#define BUTTON_IRQ_ENABLE() PORT_IRQ_ENABLE(BUTTON_PORT, BUTTON_PIN) #define BUTTON_IRQ_ENABLE(b) PORT_IRQ_ENABLE(BUTTON##b##_PORT, BUTTON##b##_PIN)
#define BUTTON_IRQ_DISABLE() PORT_IRQ_DISABLE(BUTTON_PORT, BUTTON_PIN) #define BUTTON_IRQ_DISABLE(b) PORT_IRQ_DISABLE(BUTTON##b##_PORT, BUTTON##b##_PIN)
#define BUTTON_IRQ_FLAG_OFF() PORT_IRQ_FLAG_OFF(BUTTON_PORT, BUTTON_PIN) #define BUTTON_IRQ_FLAG_OFF(b) PORT_IRQ_FLAG_OFF(BUTTON##b##_PORT, BUTTON##b##_PIN)
#define BUTTON_IRQ_ON_PRESS() PORT_IRQ_EDGE_RISE(BUTTON_PORT, BUTTON_PIN) #define BUTTON_IRQ_ON_PRESS(b) PORT_IRQ_EDGE_RISE(BUTTON##b##_PORT, BUTTON##b##_PIN)
#define BUTTON_IRQ_ON_RELEASE() PORT_IRQ_EDGE_FALL(BUTTON_PORT, BUTTON_PIN) #define BUTTON_IRQ_ON_RELEASE(b) PORT_IRQ_EDGE_FALL(BUTTON##b##_PORT, BUTTON##b##_PIN)
#endif /* __BUTTON_SENSOR_H__ */ #endif /* __BUTTON_SENSOR_H__ */

View file

@ -46,7 +46,10 @@ const struct sensors_sensor *sensors[] = {
&adc_sensor, &adc_sensor,
#endif #endif
#if BUTTON_SENSOR_ON #if BUTTON_SENSOR_ON
&button_sensor, &button_1_sensor,
#if MODEL_CC2531
&button_2_sensor,
#endif
#endif #endif
0 0
}; };