aboutsummaryrefslogtreecommitdiffstats
path: root/testhal
diff options
context:
space:
mode:
authorgdisirio <gdisirio@35acf78f-673a-0410-8e92-d51de3d6d3f4>2012-06-23 15:21:44 +0000
committergdisirio <gdisirio@35acf78f-673a-0410-8e92-d51de3d6d3f4>2012-06-23 15:21:44 +0000
commitfdc0555892c21c6aa6b582c468dfa31d05005273 (patch)
tree4d36ca147f5ffa270a601270a22706b18d8d90b8 /testhal
parent2abe2c479f15f9b4c66af007461c1ab2e2626ee0 (diff)
downloadChibiOS-fdc0555892c21c6aa6b582c468dfa31d05005273.tar.gz
ChibiOS-fdc0555892c21c6aa6b582c468dfa31d05005273.tar.bz2
ChibiOS-fdc0555892c21c6aa6b582c468dfa31d05005273.zip
PWM and ICU working on the STM32F0.
git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@4329 35acf78f-673a-0410-8e92-d51de3d6d3f4
Diffstat (limited to 'testhal')
-rw-r--r--testhal/STM32F0xx/PWM-ICU/main.c15
1 files changed, 10 insertions, 5 deletions
diff --git a/testhal/STM32F0xx/PWM-ICU/main.c b/testhal/STM32F0xx/PWM-ICU/main.c
index 8d771299a..2cabd2844 100644
--- a/testhal/STM32F0xx/PWM-ICU/main.c
+++ b/testhal/STM32F0xx/PWM-ICU/main.c
@@ -60,12 +60,17 @@ static void icuperiodcb(ICUDriver *icup) {
last_period = icuGetPeriod(icup);
}
+static void icuoverflowcb(ICUDriver *icup) {
+
+ (void)icup;
+}
+
static ICUConfig icucfg = {
ICU_INPUT_ACTIVE_HIGH,
10000, /* 10kHz ICU clock frequency. */
icuwidthcb,
icuperiodcb,
- NULL,
+ icuoverflowcb,
ICU_CHANNEL_1
};
@@ -86,14 +91,14 @@ int main(void) {
/*
* Initializes the PWM driver 2 and ICU driver 3.
- * GPIOA15 is the PWM output.
- * GPIOC6 is the ICU input.
+ * GPIOA6 is the ICU input (CH1).
+ * GPIOA15 is the PWM output (CH1).
* The two pins have to be externally connected together.
*/
pwmStart(&PWMD2, &pwmcfg);
- palSetPadMode(GPIOA, 15, PAL_MODE_ALTERNATE(1));
+ palSetPadMode(GPIOA, 15, PAL_MODE_ALTERNATE(2));
icuStart(&ICUD3, &icucfg);
- palSetPadMode(GPIOC, 6, PAL_MODE_ALTERNATE(2));
+ palSetPadMode(GPIOA, 6, PAL_MODE_ALTERNATE(1));
icuEnable(&ICUD3);
chThdSleepMilliseconds(2000);