My forked repository. DISCO_F407VG, DISCO_F303VC, DISCO_F051R8 and DISCO_F100RB maybe added.

Dependents:   FastPWM-DISCO-test

Fork of FastPWM by Erik -

Revision:
24:3467fafa8a21
Parent:
21:aa2884be5496
--- a/Device/FastPWM_STM_TIM_PinOut.cpp	Sun Apr 19 19:35:50 2015 +0000
+++ b/Device/FastPWM_STM_TIM_PinOut.cpp	Thu Feb 11 03:35:05 2016 +0900
@@ -1,6 +1,6 @@
 #include "mbed.h"
 
-#ifdef TARGET_NUCLEO_F030R8
+#if defined (TARGET_NUCLEO_F030R8) || (TARGET_DISCO_F051R8)
 __IO uint32_t* getChannel(TIM_TypeDef* pwm, PinName pin) {
     switch (pin) {
         // Channels 1
@@ -18,6 +18,9 @@
         // Channels 4
         case PC_9:
             return &pwm->CCR4;
+		default:
+			/* NOP */
+			break;
     }        
     return NULL;
 }
@@ -41,13 +44,16 @@
         // Channels 4 : PWMx/4
         case PA_3: case PA_11: case PB_9: case PC_9: 
             return &pwm->CCR4;
+		default:
+			/* NOP */
+			break;
     }
     return NULL;
 }
 #endif
 
-#if defined TARGET_NUCLEO_F103RB
-__IO uint16_t* getChannel(TIM_TypeDef* pwm, PinName pin) {
+#if defined (TARGET_NUCLEO_F103RB) || (TARGET_DISCO_F100RB)
+__IO uint32_t* getChannel(TIM_TypeDef* pwm, PinName pin) {
     switch (pin) {
         // Channels 1 : PWMx/1
         case PA_6: case PA_8: case PA_15: case PB_4: case PC_6: case PB_13:
@@ -64,6 +70,9 @@
         // Channels 4 : PWMx/4
         case PA_3: case PA_11: case PB_1: case PB_11: case PC_9: 
             return &pwm->CCR4;
+		default:
+			/* NOP */
+			break;
     }
     return NULL;
 }
@@ -89,6 +98,9 @@
         // Channels 4
         case PA_11: case PB_1: case PB_7: case PC_3: case PC_9:
             return &pwm->CCR4;
+		default:
+			/* NOP */
+			break;
     }
     return NULL;
 }
@@ -114,7 +126,129 @@
         // Channels 4 : PWMx/4
         case PA_11: case PC_9: 
             return &pwm->CCR4;
+		default:
+			/* NOP */
+			break;
+    }
+    return NULL;
+}
+#endif
+
+#if defined (TARGET_NUCLEO_L152RE)
+__IO uint32_t* getChannel(TIM_TypeDef* pwm, PinName pin) {
+    switch (pin) {
+        // Channels 1 : PWMx/1
+		case PA_6:  case PB_4: case PB_12: case PB_13: case PC_6:
+            return &pwm->CCR1;
+        
+        // Channels 2 : PWMx/2
+		case PA_1: case PA_7: case PB_3: case PB_5: case PB_14: case PB_7: case PC_7:
+            return &pwm->CCR2;
+            
+        // Channels 3 : PWMx/3
+		case PA_2: case PB_0: case PB_8: case PB_10: case PC_8:
+            return &pwm->CCR3;
+ 
+        // Channels 4 : PWMx/4
+		case PA_3: case PB_1:case PB_9: case PB_11: case PC_9: 
+            return &pwm->CCR4;
+		default:
+			/* NOP */
+			break;
     }
     return NULL;
 }
-#endif
\ No newline at end of file
+#endif
+
+#ifdef TARGET_DISCO_F303VC
+__IO uint32_t* getChannel(TIM_TypeDef* pwm, PinName pin) {
+    switch (pin) {
+         // Channels 1
+        case PA_1: case PA_2: case PA_6: case PA_7: case PA_8: case PA_12: case PA_13: 
+		case PB_3: case PB_4: case PB_5: case PB_6: case PB_7:  case PB_8: case PB_9: case PB_13: case PB_14: 
+		case PC_6: case PC_10: 
+		case PD_12:
+		case PE_0:case PE_1:case PE_2:case PE_8:case PE_9:
+            return &pwm->CCR1;
+ 
+        // Channels 2
+        case PA_3: case PA_4: case PA_9: case PA_14:
+		case PB_0:case PB_15:
+		case PC_7:
+		case PD_13:
+		case PE_3: case PE_10: case PE_11:
+            return &pwm->CCR2;
+            
+        // Channels 3
+        case PA_10: 
+		case PB_1: 
+		case PC_8: case PC_12:
+        case PD_14:
+        case PE_4: case PE_12: case PE_13:
+        case PF_0:
+            return &pwm->CCR3;
+ 
+        // Channels 4
+        case PA_11: 
+		case PC_9: case PC_13:
+		case PD_1: case PD_15:
+		case PE_5: case PE_14:
+            return &pwm->CCR4;
+		default:
+			/* NOP */
+			break;
+    }
+    return NULL;
+}
+#endif
+
+#if defined TARGET_DISCO_F407VG
+__IO uint32_t* getChannel(TIM_TypeDef* pwm, PinName pin) {
+    switch (pin) {
+        // Channels 1 : PWMx/1
+        case PA_0: case PA_5: case PA_6: case PA_7: case PA_8: case PA_15:
+		case PB_4: case PB_6: case PB_13:
+		case PC_6: 
+		case PD_12: 
+		case PE_5: case PE_8: case PE_9:
+		case PF_6: case PF_7: case PF_8: case PF_9:
+		case PH_13:
+		case PI_5:
+            return &pwm->CCR1;
+        
+        // Channels 2 : PWMx/2
+        case PA_1: case PA_9: 
+		case PB_0: case PB_3: case PB_5: case PB_7: case PB_14:
+		case PC_7: 
+		case PD_13: 
+		case PE_6: case PE_10: case PE_11:
+		case PH_14:
+		case PI_6:
+            return &pwm->CCR2;
+            
+        // Channels 3 : PWMx/3
+        case PA_2: case PA_10:
+		case PB_1: case PB_8: case PB_10: case PB_15:
+		case PC_8: 
+		case PD_14:            
+		case PE_12: case PE_13:
+		case PH_15:
+		case PI_7:
+			return &pwm->CCR3;
+ 
+        // Channels 4 : PWMx/4
+        case PA_3: case PA_11: 
+		case PB_9: case PB_11:
+		case PC_9: 
+		case PD_15: 
+		case PE_14: 
+		case PI_2: 
+            return &pwm->CCR4;
+		default:
+			/* NOP */
+			break;
+    }
+    return NULL;
+}
+#endif
+