diff --git a/examples/stm32/f2/jobygps/miniblink/miniblink.c b/examples/stm32/f2/jobygps/miniblink/miniblink.c index 8db24504..0e9b0173 100644 --- a/examples/stm32/f2/jobygps/miniblink/miniblink.c +++ b/examples/stm32/f2/jobygps/miniblink/miniblink.c @@ -2,6 +2,7 @@ * This file is part of the libopencm3 project. * * Copyright (C) 2009 Uwe Hermann + * Copyright (C) 2011 Fergus Noble * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -17,23 +18,17 @@ * along with this program. If not, see . */ -//#include +#include #include void gpio_setup(void) { /* Enable GPIOC clock. */ - /* Manually: */ - // RCC_APB2ENR |= RCC_APB2ENR_IOPCEN; /* Using API functions: */ - //rcc_peripheral_enable_clock(&RCC_APB2ENR, RCC_APB2ENR_IOPCEN); + rcc_peripheral_enable_clock(&RCC_AHB1ENR, RCC_AHB1ENR_IOPCEN); - /* Set GPIO12 (in GPIO port C) to 'output push-pull'. */ - /* Manually: */ - // GPIOC_CRH = (GPIO_CNF_OUTPUT_PUSHPULL << (((12 - 8) * 4) + 2)); - // GPIOC_CRH |= (GPIO_MODE_OUTPUT_2_MHZ << ((12 - 8) * 4)); + /* Set GPIO3 and GPIO4 (in GPIO port C) to 'output push-pull'. */ /* Using API functions: */ - MMIO32(RCC_BASE + 0x30) |= (1 << 2); gpio_mode_setup(GPIOC, GPIO_MODE_OUTPUT, GPIO_PUPD_NONE, GPIO3 | GPIO4); } @@ -43,32 +38,15 @@ int main(void) gpio_setup(); - /* Blink the LED (PC12) on the board. */ - while (1) { - /* Manually: */ - // GPIOC_BSRR = GPIO12; /* LED off */ - // for (i = 0; i < 800000; i++) /* Wait a bit. */ - // __asm__("nop"); - // GPIOC_BRR = GPIO12; /* LED on */ - // for (i = 0; i < 800000; i++) /* Wait a bit. */ - // __asm__("nop"); - - /* Using API functions gpio_set()/gpio_clear(): */ - // gpio_set(GPIOC, GPIO12); /* LED off */ - // for (i = 0; i < 800000; i++) /* Wait a bit. */ - // __asm__("nop"); - // gpio_clear(GPIOC, GPIO12); /* LED on */ - // for (i = 0; i < 800000; i++) /* Wait a bit. */ - // __asm__("nop"); + gpio_set(GPIOC, GPIO3); + gpio_clear(GPIOC, GPIO4); + /* Blink the LEDs (PC3, PC4) on the board. */ + while (1) + { /* Using API function gpio_toggle(): */ - //gpio_toggle(GPIOC, GPIO3); /* LED on/off */ - gpio_set(GPIOC, GPIO3); - gpio_clear(GPIOC, GPIO4); - for (i = 0; i < 800000; i++) /* Wait a bit. */ - __asm__("nop"); - gpio_clear(GPIOC, GPIO3); - gpio_set(GPIOC, GPIO4); + gpio_toggle(GPIOC, GPIO3); + gpio_toggle(GPIOC, GPIO4); for (i = 0; i < 800000; i++) /* Wait a bit. */ __asm__("nop"); } diff --git a/examples/stm32/f2/jobygps/spi_test/spi_test.c b/examples/stm32/f2/jobygps/spi_test/spi_test.c index 0f3d0eda..e5c9539e 100644 --- a/examples/stm32/f2/jobygps/spi_test/spi_test.c +++ b/examples/stm32/f2/jobygps/spi_test/spi_test.c @@ -28,13 +28,12 @@ void clock_setup(void) { - -#warning "This code has to call some kind of rcc clock setup function!!!" - - RCC_APB1ENR |= RCC_APB1ENR_SPI2EN; - RCC_APB2ENR |= RCC_APB2ENR_USART1EN; - RCC_AHB1ENR |= - RCC_AHB1ENR_IOPCEN | RCC_AHB1ENR_IOPAEN | RCC_AHB1ENR_IOPBEN; + /* Enable clocks on all the peripherals we are going to use. */ + rcc_peripheral_enable_clock(&RCC_APB1ENR, RCC_APB1ENR_SPI2EN); + rcc_peripheral_enable_clock(&RCC_APB2ENR, RCC_APB2ENR_USART1EN); + rcc_peripheral_enable_clock(&RCC_AHB1ENR, RCC_AHB1ENR_IOPCEN | \ + RCC_AHB1ENR_IOPAEN | \ + RCC_AHB1ENR_IOPBEN); } void spi_setup(void) diff --git a/examples/stm32/f2/jobygps/usart_printf/usart_printf.c b/examples/stm32/f2/jobygps/usart_printf/usart_printf.c index eeeb1184..30957a34 100644 --- a/examples/stm32/f2/jobygps/usart_printf/usart_printf.c +++ b/examples/stm32/f2/jobygps/usart_printf/usart_printf.c @@ -28,19 +28,9 @@ void clock_setup(void) { - -#warning "This code has to call some kind of rcc clock setup function!!!" - - //rcc_clock_setup_in_hse_8mhz_out_72mhz(); - - /* Enable GPIOA clock (for LED GPIOs). */ - //rcc_peripheral_enable_clock(&RCC_APB2ENR, RCC_APB2ENR_IOPCEN); - - /* Enable clocks for GPIO port A (for GPIO_USART1_TX) and USART1. */ - // rcc_peripheral_enable_clock(&RCC_APB2ENR, RCC_APB2ENR_IOPAEN | - // RCC_APB2ENR_AFIOEN | RCC_APB2ENR_USART1EN); - RCC_APB2ENR |= RCC_APB2ENR_USART1EN; - RCC_AHB1ENR |= RCC_AHB1ENR_IOPCEN | RCC_AHB1ENR_IOPAEN; + /* Enable clocks on all the peripherals we are going to use. */ + rcc_peripheral_enable_clock(&RCC_APB2ENR, RCC_APB2ENR_USART1EN); + rcc_peripheral_enable_clock(&RCC_AHB1ENR, RCC_AHB1ENR_IOPCEN | RCC_AHB1ENR_IOPAEN); } void usart_setup(void) @@ -62,10 +52,8 @@ void usart_setup(void) void gpio_setup(void) { - gpio_set(GPIOC, GPIO3); - - /* Setup GPIO6 and 7 (in GPIO port A) for LED use. */ gpio_mode_setup(GPIOC, GPIO_MODE_OUTPUT, GPIO_MODE_OUTPUT, GPIO3); + gpio_set(GPIOC, GPIO3); } int _write(int file, char *ptr, int len)