altos: Add ADC tests to stm-demo
authorKeith Packard <keithp@keithp.com>
Sun, 8 Apr 2012 01:55:20 +0000 (18:55 -0700)
committerKeith Packard <keithp@keithp.com>
Sun, 8 Apr 2012 01:55:20 +0000 (18:55 -0700)
Signed-off-by: Keith Packard <keithp@keithp.com>
src/stm-demo/Makefile
src/stm-demo/ao_demo.c
src/stm-demo/ao_pins.h

index c1f4937112b8c5edfd32562468b511cefb1f0be0..26c81a822902147d9c3d72f930c60ef6fed9947e 100644 (file)
@@ -29,13 +29,14 @@ ALTOS_SRC = \
        ao_lcd_font.c \
        ao_mutex.c \
        ao_dma_stm.c \
-       ao_spi_stm.c 
+       ao_spi_stm.c \
+       ao_adc_stm.c
 
 PRODUCT=StmDemo-v0.0
 PRODUCT_DEF=-DSTM_DEMO
 IDPRODUCT=0x000a
 
-CFLAGS = $(PRODUCT_DEF) $(STM_CFLAGS) -g -Os
+CFLAGS = $(PRODUCT_DEF) $(STM_CFLAGS) -g -O0
 
 PROG=stm-demo
 
index 5ff2b32a94eeded531e50b6db878e4d4e6034dd0..63647aac912238d461bccea33e7e33f647df082d 100644 (file)
@@ -51,13 +51,15 @@ void _exit () { }
 void _read () { }
 void _fstat() { }
 
+#define AO_DMA_TEST_INDEX      STM_DMA_INDEX(4)
+
 static void
 ao_dma_test(void) {
        static char     src[20] = "hello, world";
        static char     dst[20];
        
        dst[0] = '\0';
-       ao_dma_set_transfer(STM_DMA_INDEX(1), dst, src, 13,
+       ao_dma_set_transfer(AO_DMA_TEST_INDEX, dst, src, 13,
                            (1 << STM_DMA_CCR_MEM2MEM) |
                            (STM_DMA_CCR_PL_LOW << STM_DMA_CCR_PL) |
                            (STM_DMA_CCR_MSIZE_8 << STM_DMA_CCR_MSIZE) |
@@ -66,11 +68,12 @@ ao_dma_test(void) {
                            (1 << STM_DMA_CCR_PINC) |
                            (0 << STM_DMA_CCR_CIRC) |
                            (STM_DMA_CCR_DIR_MEM_TO_PER << STM_DMA_CCR_DIR));
-       ao_dma_start(STM_DMA_INDEX(1));
-       cli();
-       while (!ao_dma_done[STM_DMA_INDEX(1)])
-               ao_sleep(&ao_dma_done[STM_DMA_INDEX(1)]);
-       sei();
+       ao_dma_start(AO_DMA_TEST_INDEX);
+       ao_arch_critical(
+               while (!ao_dma_done[AO_DMA_TEST_INDEX])
+                       ao_sleep(&ao_dma_done[AO_DMA_TEST_INDEX]);
+               );
+       ao_dma_done_transfer(AO_DMA_TEST_INDEX);
        printf ("copied %s\n", dst);
 }
 
@@ -128,13 +131,12 @@ main(void)
 //     ao_lcd_font_init();
        ao_spi_init();
 
+       ao_timer_set_adc_interval(100);
+
+       ao_adc_init();
+
        ao_cmd_register(&ao_demo_cmds[0]);
        
-       stm_rcc.ahbenr |= (1 << STM_RCC_AHBENR_GPIOCEN);
-       stm_gpio_set(&stm_gpioc, 12, 1);
-       stm_moder_set(&stm_gpioc, 12, STM_MODER_OUTPUT);
-       stm_otyper_set(&stm_gpioc, 12, STM_OTYPER_PUSH_PULL);
-
        ao_start_scheduler();
        return 0;
 }
index 09c88f9054aa3a35b6fba672a981a03ad0ae1778..fecd8cdabdf476f251605108904d0c70313571d0 100644 (file)
 
 #define AO_LCD_28_ON_C 1
 
+#define HAS_ADC                        1
+
+#define AO_ADC_RING            32
+
+struct ao_adc {
+       uint16_t                tick;
+       int16_t                 idd;
+       int16_t                 temp;
+};
+
+#define AO_ADC_IDD             4
+#define AO_ADC_PIN0_PORT       stm_gpioa
+#define AO_ADC_PIN0_PIN                4
+
+#define AO_ADC_RCC_AHBENR      ((1 << STM_RCC_AHBENR_GPIOAEN))
+#define AO_ADC_TEMP            16
+
+#define HAS_ADC_TEMP           1
+
+#define AO_NUM_ADC             2
+
+#define AO_ADC_SQ1             AO_ADC_IDD
+#define AO_ADC_SQ2             AO_ADC_TEMP
+       
+
 #endif /* _AO_PINS_H_ */