diff options
Diffstat (limited to 'src/cc1111')
| -rw-r--r-- | src/cc1111/ao_arch_funcs.h | 24 | ||||
| -rw-r--r-- | src/cc1111/ao_pins.h | 27 | 
2 files changed, 37 insertions, 14 deletions
| diff --git a/src/cc1111/ao_arch_funcs.h b/src/cc1111/ao_arch_funcs.h index d9f5955a..728f1f76 100644 --- a/src/cc1111/ao_arch_funcs.h +++ b/src/cc1111/ao_arch_funcs.h @@ -31,14 +31,14 @@ extern __xdata uint8_t	ao_spi_mutex;  	ao_mutex_put(&ao_spi_mutex); \  	} while (0) -#define ao_spi_get_bit(bit,bus) do {    \ -	ao_mutex_get(&ao_spi_mutex); \ -	(bit) = 0; \ +#define ao_spi_get_bit(reg,bit,pin,bus) do {	\ +		ao_mutex_get(&ao_spi_mutex);	\ +		pin = 0;			\  	} while (0) -#define ao_spi_put_bit(bit,bus) do {		\ -	(bit) = 1; \ -	ao_mutex_put(&ao_spi_mutex); \ +#define ao_spi_put_bit(reg,bit,pin,bus) do {	\ +		pin = 1;			\ +		ao_mutex_put(&ao_spi_mutex);	\  	} while (0) @@ -65,3 +65,15 @@ ao_spi_init(void);  		SPI_CS_DIR |= mask;		\  		SPI_CS_SEL &= ~mask;		\  	} while (0) + +#define cc1111_enable_output(port,dir,sel,mask,v) do { \ +	port = port & ~(mask) | v; \ +	dir |= mask; \ +	sel &= ~mask; \ +} while (0) + +#define disable_unreachable	_Pragma("disable_warning 126") + +#define token_paster(x,y)	x ## y +#define token_evaluator(x,y)	token_paster(x,y) +#define ao_enable_output(port,pin,v) cc1111_enable_output(port,token_evaluator(port,DIR), token_evaluator(port,SEL), 1 << pin, 1 << v) diff --git a/src/cc1111/ao_pins.h b/src/cc1111/ao_pins.h index 0923e75d..e28a7b65 100644 --- a/src/cc1111/ao_pins.h +++ b/src/cc1111/ao_pins.h @@ -41,8 +41,9 @@  	#define HAS_COMPANION		1  	#define COMPANION_CS_ON_P1	1 -	#define COMPANION_CS_MASK	0x4	/* CS1 is P1_2 */ -	#define COMPANION_CS		P1_2 +	#define AO_COMPANION_CS_PORT	P1 +	#define AO_COMPANION_CS_PIN	2 +	#define AO_COMPANION_CS		P1_2  	#define AO_LED_RED		1  	#define LEDS_AVAILABLE		(AO_LED_RED) @@ -72,9 +73,9 @@  	#define PACKET_HAS_SLAVE	1  	#define HAS_COMPANION		1 -	#define COMPANION_CS_ON_P1	1 -	#define COMPANION_CS_MASK	0x4	/* CS1 is P1_2 */ -	#define COMPANION_CS		P1_2 +	#define AO_COMPANION_CS_PORT	P1 +	#define AO_COMPANION_CS_PIN	2 +	#define AO_COMPANION_CS		P1_2  	#define AO_LED_RED		1  	#define LEDS_AVAILABLE		(AO_LED_RED) @@ -108,9 +109,9 @@  	#define PACKET_HAS_SLAVE	1  	#define HAS_COMPANION		1 -	#define COMPANION_CS_ON_P1	1 -	#define COMPANION_CS_MASK	0x4	/* CS1 is P1_2 */ -	#define COMPANION_CS		P1_2 +	#define AO_COMPANION_CS_PORT	P1 +	#define AO_COMPANION_CS_PIN	2 +	#define AO_COMPANION_CS		P1_2  	#define AO_LED_RED		1  	#define LEDS_AVAILABLE		(AO_LED_RED) @@ -527,21 +528,31 @@  #endif /* HAS_ADC */  #if IGNITE_ON_P2 +#define AO_IGNITER_PORT		P2 +#define AO_IGNITER_DROGUE_PORT	AO_IGNITER_PORT  #define AO_IGNITER_DROGUE	P2_3  #define AO_IGNITER_MAIN		P2_4  #define AO_IGNITER_DIR		P2DIR  #define AO_IGNITER_DROGUE_BIT	(1 << 3)  #define AO_IGNITER_MAIN_BIT	(1 << 4) +#define AO_IGNITER_DROGUE_PIN	3 +#define AO_IGNITER_MAIN_PIN	4  #endif  #if IGNITE_ON_P0 +#define AO_IGNITER_PORT		P0  #define AO_IGNITER_DROGUE	P0_5  #define AO_IGNITER_MAIN		P0_4  #define AO_IGNITER_DIR		P0DIR  #define AO_IGNITER_DROGUE_BIT	(1 << 5)  #define AO_IGNITER_MAIN_BIT	(1 << 4) +#define AO_IGNITER_DROGUE_PIN	5 +#define AO_IGNITER_MAIN_PIN	4  #endif +#define AO_IGNITER_DROGUE_PORT	AO_IGNITER_PORT +#define AO_IGNITER_MAIN_PORT	AO_IGNITER_PORT +  /* test these values with real igniters */  #define AO_IGNITER_OPEN		1000  #define AO_IGNITER_CLOSED	7000 | 
