2014-02-03 19:35:37 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2014 Freie Universität Berlin
|
|
|
|
*
|
2014-02-27 18:22:31 +01:00
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser General
|
|
|
|
* Public License v2.1. See the file LICENSE in the top level directory for more
|
|
|
|
* details.
|
2014-02-03 19:35:37 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2015-11-19 15:54:52 +01:00
|
|
|
* @defgroup drivers_periph_pwm PWM
|
|
|
|
* @ingroup drivers_periph
|
2014-02-04 18:52:53 +01:00
|
|
|
* @brief Low-level PWM peripheral driver
|
2014-02-03 19:35:37 +01:00
|
|
|
*
|
2014-12-04 10:03:15 +01:00
|
|
|
* @{
|
2014-10-25 15:37:04 +02:00
|
|
|
* @file
|
2014-02-04 18:52:53 +01:00
|
|
|
* @brief Low-level PWM peripheral driver interface definitions
|
2014-02-03 19:35:37 +01:00
|
|
|
*
|
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
|
|
*/
|
|
|
|
|
2015-03-23 21:07:50 +01:00
|
|
|
#ifndef PWM_H
|
|
|
|
#define PWM_H
|
2014-02-03 19:35:37 +01:00
|
|
|
|
|
|
|
#include "periph_conf.h"
|
|
|
|
|
2014-10-13 15:49:17 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2014-07-16 22:57:38 +02:00
|
|
|
/* ignore file in case no PWM devices are defined */
|
|
|
|
#if PWM_NUMOF
|
2014-02-03 19:35:37 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Definition of available PWM devices
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-03-26 17:11:24 +01:00
|
|
|
* To this point a maximum of four PWM device is available.
|
2014-02-03 19:35:37 +01:00
|
|
|
*/
|
|
|
|
typedef enum {
|
2014-03-26 17:11:24 +01:00
|
|
|
#if PWM_0_EN
|
|
|
|
PWM_0, /*< 1st PWM device */
|
2014-02-03 19:35:37 +01:00
|
|
|
#endif
|
2014-03-26 17:11:24 +01:00
|
|
|
#if PWM_1_EN
|
|
|
|
PWM_1, /*< 2nd PWM device */
|
2014-02-03 19:35:37 +01:00
|
|
|
#endif
|
2014-03-26 17:11:24 +01:00
|
|
|
#if PWM_2_EN
|
|
|
|
PWM_2, /*< 3rd PWM device */
|
2014-02-03 19:35:37 +01:00
|
|
|
#endif
|
2014-03-26 17:11:24 +01:00
|
|
|
#if PWM_3_EN
|
|
|
|
PWM_3, /*< 4th PWM device */
|
|
|
|
#endif
|
|
|
|
} pwm_t;
|
2014-02-03 19:35:37 +01:00
|
|
|
|
|
|
|
/**
|
2014-02-04 18:52:53 +01:00
|
|
|
* @brief Definition of available PWM modes
|
2014-02-03 19:35:37 +01:00
|
|
|
*/
|
|
|
|
typedef enum {
|
2014-03-26 17:11:24 +01:00
|
|
|
PWM_LEFT, /*< use left aligned PWM */
|
|
|
|
PWM_RIGHT, /*< use right aligned PWM */
|
|
|
|
PWM_CENTER /*< use center aligned PWM */
|
2014-02-03 19:35:37 +01:00
|
|
|
} pwm_mode_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Initialize a PWM device
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-02-03 19:35:37 +01:00
|
|
|
* The PWM module is based on virtual PWM devices, which can have one or more channels.
|
|
|
|
* The PWM devices can be configured to run with a given frequency and resolution, which
|
|
|
|
* are always identical for the complete device, hence for every channel on a device.
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-02-03 19:35:37 +01:00
|
|
|
* The desired frequency and resolution may not be possible on a given device when chosen
|
2014-03-26 17:11:24 +01:00
|
|
|
* too large. In this case the PWM driver will always keep the resolution and decrease the
|
2014-02-04 18:52:53 +01:00
|
|
|
* frequency if needed. To verify the correct settings compare the returned value which
|
2014-02-03 19:35:37 +01:00
|
|
|
* is the actually set frequency.
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-02-27 18:22:31 +01:00
|
|
|
* @param[in] dev PWM channel to initialize
|
|
|
|
* @param[in] mode PWM mode, left, right or center aligned
|
|
|
|
* @param[in] frequency the PWM frequency in Hz
|
|
|
|
* @param[in] resolution the PWM resolution
|
|
|
|
*
|
2015-05-16 09:59:10 +02:00
|
|
|
* @return Actual PWM frequency on success
|
2014-07-16 22:57:38 +02:00
|
|
|
* @return -1 on mode not applicable
|
|
|
|
* @return -2 on frequency and resolution not applicable
|
2014-02-03 19:35:37 +01:00
|
|
|
*/
|
|
|
|
int pwm_init(pwm_t dev, pwm_mode_t mode, unsigned int frequency, unsigned int resolution);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the duty-cycle for a given channel of the given PWM device
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-02-03 19:35:37 +01:00
|
|
|
* The duty-cycle is set in relation to the chosen resolution of the given device. If
|
|
|
|
* value > resolution, value is set to resolution.
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-02-27 18:22:31 +01:00
|
|
|
* @param[in] dev the PWM device to set
|
|
|
|
* @param[in] channel the channel of the given device to set
|
|
|
|
* @param[in] value the desired duty-cycle to set
|
|
|
|
*
|
|
|
|
* @return 0 on success
|
2014-07-16 22:57:38 +02:00
|
|
|
* @return -1 on invalid channel
|
2014-02-03 19:35:37 +01:00
|
|
|
*/
|
|
|
|
int pwm_set(pwm_t dev, int channel, unsigned int value);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Start PWM generation on the given device
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-02-27 18:22:31 +01:00
|
|
|
* @param[in] dev device to start
|
2014-02-03 19:35:37 +01:00
|
|
|
*/
|
2014-07-16 22:57:38 +02:00
|
|
|
void pwm_start(pwm_t dev);
|
2014-02-03 19:35:37 +01:00
|
|
|
|
|
|
|
/**
|
2014-02-04 18:52:53 +01:00
|
|
|
* @brief Stop PWM generation on the given device
|
2014-05-14 10:46:15 +02:00
|
|
|
*
|
2014-02-27 18:22:31 +01:00
|
|
|
* @param[in] dev device to stop
|
2014-07-16 22:57:38 +02:00
|
|
|
*/
|
|
|
|
void pwm_stop(pwm_t dev);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Power on the PWM device
|
2014-02-27 18:22:31 +01:00
|
|
|
*
|
2014-07-16 22:57:38 +02:00
|
|
|
* The PWM deice is powered on. It is dependent on the implementing platform,
|
|
|
|
* if the previously set configuration is still available after power on.
|
|
|
|
*
|
|
|
|
* @param[in] dev device to power on
|
2014-02-03 19:35:37 +01:00
|
|
|
*/
|
2014-07-16 22:57:38 +02:00
|
|
|
void pwm_poweron(pwm_t dev);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Power off the given PWM device
|
|
|
|
*
|
|
|
|
* The given PWM is completely powered off. On most platform this means, that
|
|
|
|
* the clock for the PWM device is disabled.
|
|
|
|
*
|
|
|
|
* @param[in] dev device to power off
|
|
|
|
*/
|
|
|
|
void pwm_poweroff(pwm_t dev);
|
|
|
|
|
|
|
|
#endif /* PWM_NUMOF */
|
2014-02-03 19:35:37 +01:00
|
|
|
|
2014-10-13 15:49:17 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2015-03-23 21:07:50 +01:00
|
|
|
#endif /* PWM_H */
|
2014-02-03 19:35:37 +01:00
|
|
|
/** @} */
|