summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/avr/ao_adc_avr.c7
-rw-r--r--src/avr/ao_pins.h2
-rw-r--r--src/telepyro-v0.1/Makefile2
3 files changed, 9 insertions, 2 deletions
diff --git a/src/avr/ao_adc_avr.c b/src/avr/ao_adc_avr.c
index 3a262977..739a6d4a 100644
--- a/src/avr/ao_adc_avr.c
+++ b/src/avr/ao_adc_avr.c
@@ -16,6 +16,7 @@
*/
#include "ao.h"
+#include "ao_pwmin.h"
volatile __xdata struct ao_data ao_data_ring[AO_DATA_RING];
volatile __data uint8_t ao_data_head;
@@ -93,9 +94,13 @@ ISR(ADC_vect)
value = ADCL;
value |= (ADCH << 8);
ao_data_ring[ao_data_head].adc.adc[ao_adc_channel] = value;
- if (++ao_adc_channel < NUM_ADC)
+ if (++ao_adc_channel < NUM_ADC - 1)
ao_adc_start();
else {
+#if HAS_ICP3_COUNT
+ /* steal last adc channel for pwm input */
+ ao_data_ring[ao_data_head].adc.adc[ao_adc_channel] = ao_icp3_count;
+#endif
ADCSRA = ADCSRA_INIT;
ao_data_ring[ao_data_head].tick = ao_time();
ao_data_head = ao_data_ring_next(ao_data_head);
diff --git a/src/avr/ao_pins.h b/src/avr/ao_pins.h
index bc423ff7..0f49db0b 100644
--- a/src/avr/ao_pins.h
+++ b/src/avr/ao_pins.h
@@ -47,6 +47,7 @@
#define AVR_VCC_5V 0
#define AVR_VCC_3V3 1
#define AVR_CLOCK 8000000UL
+ #define HAS_ICP3_COUNT 1
#define SPI_CS_PORT PORTE
#define SPI_CS_DIR DDRE
@@ -81,6 +82,7 @@
#define IS_COMPANION 1
#define HAS_ORIENT 0
#define ao_storage_pos_t uint16_t
+ #define HAS_ICP3_COUNT 0
#define AVR_VCC_5V 0
#define AVR_VCC_3V3 1
diff --git a/src/telepyro-v0.1/Makefile b/src/telepyro-v0.1/Makefile
index 2ccd565f..6743ba66 100644
--- a/src/telepyro-v0.1/Makefile
+++ b/src/telepyro-v0.1/Makefile
@@ -96,7 +96,7 @@ ao_product.o: ao_product.c ao_product.h
distclean: clean
clean:
- rm -f $(OBJ)
+ rm -f $(OBJ) $(PROG) $(PROG).hex
rm -f ao_product.h
install: