| /**************************************************************************** |
| * arch/arm/src/kinetis/kinetis_pwm.h |
| * |
| * SPDX-License-Identifier: Apache-2.0 |
| * |
| * Licensed to the Apache Software Foundation (ASF) under one or more |
| * contributor license agreements. See the NOTICE file distributed with |
| * this work for additional information regarding copyright ownership. The |
| * ASF licenses this file to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance with the |
| * License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT |
| * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the |
| * License for the specific language governing permissions and limitations |
| * under the License. |
| * |
| ****************************************************************************/ |
| |
| #ifndef __ARCH_ARM_SRC_KINETIS_KINETIS_PWM_H |
| #define __ARCH_ARM_SRC_KINETIS_KINETIS_PWM_H |
| |
| /**************************************************************************** |
| * Included Files |
| ****************************************************************************/ |
| |
| #include <nuttx/config.h> |
| #include <arch/board/board.h> |
| |
| #include "chip.h" |
| #include "hardware/kinetis_pinmux.h" |
| |
| /**************************************************************************** |
| * Pre-processor Definitions |
| ****************************************************************************/ |
| |
| /* Configuration ************************************************************/ |
| |
| /* Timer devices may be used for different purposes. One special purpose is |
| * to generate modulated outputs for such things as motor control. |
| * If CONFIG_KINETIS_FTMn is defined then the CONFIG_KINETIS_FTMn_PWM must |
| * also be defined to indicate that timer "n" is intended to be used for |
| * pulsed output signal generation. |
| */ |
| |
| #ifndef CONFIG_KINETIS_FTM0 |
| # undef CONFIG_KINETIS_FTM0_PWM |
| #endif |
| #ifndef CONFIG_KINETIS_FTM1 |
| # undef CONFIG_KINETIS_FTM1_PWM |
| #endif |
| #ifndef CONFIG_KINETIS_FTM2 |
| # undef CONFIG_KINETIS_FTM2_PWM |
| #endif |
| #ifndef CONFIG_KINETIS_FTM3 |
| # undef CONFIG_KINETIS_FTM3_PWM |
| #endif |
| |
| /* Check if PWM support for any channel is enabled. */ |
| |
| #if defined(CONFIG_KINETIS_FTM0_PWM) || defined(CONFIG_KINETIS_FTM1_PWM) || \ |
| defined(CONFIG_KINETIS_FTM2_PWM) || defined(CONFIG_KINETIS_FTM3_PWM) |
| |
| /* For each timer that is enabled for PWM usage, we need the following |
| * additional configuration settings: |
| * |
| * CONFIG_KINETIS_FTMx_CHANNEL - Specifies the timer output channel {1,..,4} |
| * PWM_FTMx_CHn - One of the values defined in kinetis*_pinmap.h. In the |
| * case where there are multiple pin selections, the correct setting must |
| * be provided in the arch/board/board.h file. |
| */ |
| |
| #ifdef CONFIG_KINETIS_FTM0_PWM |
| # if !defined(CONFIG_KINETIS_FTM0_CHANNEL) |
| # error "CONFIG_KINETIS_FTM0_CHANNEL must be provided" |
| # elif CONFIG_KINETIS_FTM0_CHANNEL == 0 |
| # define PWM_FTM0_PINCFG GPIO_FTM0_CH0OUT |
| # elif CONFIG_KINETIS_FTM0_CHANNEL == 1 |
| # define PWM_FTM0_PINCFG GPIO_FTM0_CH1OUT |
| # elif CONFIG_KINETIS_FTM0_CHANNEL == 2 |
| # define PWM_FTM0_PINCFG GPIO_FTM0_CH2OUT |
| # elif CONFIG_KINETIS_FTM0_CHANNEL == 3 |
| # define PWM_FTM0_PINCFG GPIO_FTM0_CH3OUT |
| # elif CONFIG_KINETIS_FTM0_CHANNEL == 4 |
| # define PWM_FTM0_PINCFG GPIO_FTM0_CH4OUT |
| # elif CONFIG_KINETIS_FTM0_CHANNEL == 5 |
| # define PWM_FTM0_PINCFG GPIO_FTM0_CH5OUT |
| # elif CONFIG_KINETIS_FTM0_CHANNEL == 6 |
| # define PWM_FTM0_PINCFG GPIO_FTM0_CH6OUT |
| # elif CONFIG_KINETIS_FTM0_CHANNEL == 7 |
| # define PWM_FTM0_PINCFG GPIO_FTM0_CH7OUT |
| # else |
| # error "Unsupported value of CONFIG_KINETIS_FTM1_CHANNEL" |
| # endif |
| #endif |
| |
| #ifdef CONFIG_KINETIS_FTM1_PWM |
| # if !defined(CONFIG_KINETIS_FTM1_CHANNEL) |
| # error "CONFIG_KINETIS_FTM1_CHANNEL must be provided" |
| # elif CONFIG_KINETIS_FTM1_CHANNEL == 0 |
| # define PWM_FTM1_PINCFG GPIO_FTM1_CH0OUT |
| # elif CONFIG_KINETIS_FTM1_CHANNEL == 1 |
| # define PWM_FTM1_PINCFG GPIO_FTM1_CH1OUT |
| # elif CONFIG_KINETIS_FTM1_CHANNEL == 2 |
| # define PWM_FTM1_PINCFG GPIO_FTM1_CH2OUT |
| # elif CONFIG_KINETIS_FTM1_CHANNEL == 3 |
| # define PWM_FTM1_PINCFG GPIO_FTM1_CH3OUT |
| # elif CONFIG_KINETIS_FTM1_CHANNEL == 4 |
| # define PWM_FTM1_PINCFG GPIO_FTM1_CH4OUT |
| # elif CONFIG_KINETIS_FTM1_CHANNEL == 5 |
| # define PWM_FTM1_PINCFG GPIO_FTM1_CH5OUT |
| # else |
| # error "Unsupported value of CONFIG_KINETIS_FTM2_CHANNEL" |
| # endif |
| #endif |
| |
| #ifdef CONFIG_KINETIS_FTM2_PWM |
| # if !defined(CONFIG_KINETIS_FTM2_CHANNEL) |
| # error "CONFIG_KINETIS_FTM2_CHANNEL must be provided" |
| # elif CONFIG_KINETIS_FTM2_CHANNEL == 0 |
| # define PWM_FTM2_PINCFG GPIO_FTM2_CH0OUT |
| # elif CONFIG_KINETIS_FTM2_CHANNEL == 1 |
| # define PWM_FTM2_PINCFG GPIO_FTM2_CH1OUT |
| # elif CONFIG_KINETIS_FTM2_CHANNEL == 2 |
| # define PWM_FTM2_PINCFG GPIO_FTM2_CH2OUT |
| # elif CONFIG_KINETIS_FTM2_CHANNEL == 3 |
| # define PWM_FTM2_PINCFG GPIO_FTM2_CH3OUT |
| # elif CONFIG_KINETIS_FTM2_CHANNEL == 4 |
| # define PWM_FTM2_PINCFG GPIO_FTM2_CH4OUT |
| # elif CONFIG_KINETIS_FTM2_CHANNEL == 5 |
| # define PWM_FTM2_PINCFG GPIO_FTM2_CH5OUT |
| # else |
| # error "Unsupported value of CONFIG_KINETIS_FTM3_CHANNEL" |
| # endif |
| #endif |
| |
| #ifdef CONFIG_KINETIS_FTM3_PWM |
| # if !defined(CONFIG_KINETIS_FTM3_CHANNEL) |
| # error "CONFIG_KINETIS_FTM3_CHANNEL must be provided" |
| # elif CONFIG_KINETIS_FTM3_CHANNEL == 0 |
| # define PWM_FTM3_PINCFG GPIO_FTM3_CH0OUT |
| # elif CONFIG_KINETIS_FTM3_CHANNEL == 1 |
| # define PWM_FTM3_PINCFG GPIO_FTM3_CH1OUT |
| # elif CONFIG_KINETIS_FTM3_CHANNEL == 2 |
| # define PWM_FTM3_PINCFG GPIO_FTM3_CH2OUT |
| # elif CONFIG_KINETIS_FTM3_CHANNEL == 3 |
| # define PWM_FTM3_PINCFG GPIO_FTM3_CH3OUT |
| # elif CONFIG_KINETIS_FTM3_CHANNEL == 4 |
| # define PWM_FTM3_PINCFG GPIO_FTM3_CH4OUT |
| # elif CONFIG_KINETIS_FTM3_CHANNEL == 5 |
| # define PWM_FTM3_PINCFG GPIO_FTM3_CH5OUT |
| # elif CONFIG_KINETIS_FTM3_CHANNEL == 6 |
| # define PWM_FTM3_PINCFG GPIO_FTM3_CH6OUT |
| # elif CONFIG_KINETIS_FTM3_CHANNEL == 7 |
| # define PWM_FTM3_PINCFG GPIO_FTM3_CH7OUT |
| # else |
| # error "Unsupported value of CONFIG_KINETIS_FTM3_CHANNEL" |
| # endif |
| #endif |
| |
| /**************************************************************************** |
| * Public Types |
| ****************************************************************************/ |
| |
| /**************************************************************************** |
| * Public Data |
| ****************************************************************************/ |
| |
| #ifndef __ASSEMBLY__ |
| |
| #undef EXTERN |
| #if defined(__cplusplus) |
| #define EXTERN extern "C" |
| extern "C" |
| { |
| #else |
| #define EXTERN extern |
| #endif |
| |
| /**************************************************************************** |
| * Public Functions Prototypes |
| ****************************************************************************/ |
| |
| /**************************************************************************** |
| * Name: kinetis_pwminitialize |
| * |
| * Description: |
| * Initialize one timer for use with the upper_level PWM driver. |
| * |
| * Input Parameters: |
| * timer - A number identifying the timer use. |
| * |
| * Returned Value: |
| * On success, a pointer to the kinetis lower half PWM driver is returned. |
| * NULL is returned on any failure. |
| * |
| ****************************************************************************/ |
| |
| struct pwm_lowerhalf_s *kinetis_pwminitialize(int timer); |
| |
| #undef EXTERN |
| #if defined(__cplusplus) |
| } |
| #endif |
| |
| #endif /* __ASSEMBLY__ */ |
| #endif /* CONFIG_KINETIS_FTMx_PWM */ |
| #endif /* __ARCH_ARM_SRC_KINETIS_KINETIS_PWM_H */ |