summaryrefslogtreecommitdiff
path: root/src/avr
diff options
context:
space:
mode:
authorKeith Packard <keithp@keithp.com>2012-07-14 02:44:17 -0700
committerKeith Packard <keithp@keithp.com>2012-07-14 02:44:17 -0700
commit0cfd22baa6af44e053428c30c1a95cf5551b68af (patch)
treea347ac877f882bb6eaef11f0a88d46fe89915514 /src/avr
parent37032e4b0cbac4c823e3dd18e60ad8900e9ceff1 (diff)
src: Add explicit 'pin' argument to ao_enable_output
This lets the cc1111 use the atomic bit operation instead of a mask, which is immune to interrupt issues as well as being a shorter code sequence. Signed-off-by: Keith Packard <keithp@keithp.com>
Diffstat (limited to 'src/avr')
-rw-r--r--src/avr/ao_arch_funcs.h17
1 files changed, 17 insertions, 0 deletions
diff --git a/src/avr/ao_arch_funcs.h b/src/avr/ao_arch_funcs.h
index e400c98b..792ff744 100644
--- a/src/avr/ao_arch_funcs.h
+++ b/src/avr/ao_arch_funcs.h
@@ -41,12 +41,29 @@ extern __xdata uint8_t ao_spi_mutex;
ao_mutex_put(&ao_spi_mutex); \
} while (0)
+
+#define ao_gpio_token_paster(x,y) x ## y
+#define ao_gpio_token_evaluator(x,y) ao_gpio_token_paster(x,y)
+
+#define ao_gpio_set(port, bit, pin, v) do { \
+ if (v) \
+ (ao_gpio_token_evaluator(PORT,port)) |= (1 << bit); \
+ else \
+ (ao_gpio_token_evaluator(PORT,port)) &= ~(1 << bit); \
+ } while (0)
+
/*
* The SPI mutex must be held to call either of these
* functions -- this mutex covers the entire SPI operation,
* from chip select low to chip select high
*/
+#define ao_enable_output(port, bit, pin, v) do { \
+ ao_gpio_set(port, bit, pin, v); \
+ ao_gpio_token_evaluator(DDR,port) |= (1 << bit); \
+ } while (0)
+
+
void
ao_spi_send_bus(void __xdata *block, uint16_t len) __reentrant;