Change SPWM example to enable timer after configure timer clock.
This commit is contained in:
parent
d1057403c6
commit
3f6157001a
@ -254,7 +254,8 @@ static inline void stm32l4_putreg32(FAR struct stm32l4_tim_dev_s *dev,
|
|||||||
/* Timer helpers */
|
/* Timer helpers */
|
||||||
|
|
||||||
static void stm32l4_tim_reload_counter(FAR struct stm32l4_tim_dev_s *dev);
|
static void stm32l4_tim_reload_counter(FAR struct stm32l4_tim_dev_s *dev);
|
||||||
static void stm32l4_tim_enable(FAR struct stm32l4_tim_dev_s *dev, bool state);
|
static void stm32l4_tim_enable(FAR struct stm32l4_tim_dev_s *dev);
|
||||||
|
static void stm32l4_tim_disable(FAR struct stm32l4_tim_dev_s *dev);
|
||||||
static void stm32l4_tim_reset(FAR struct stm32l4_tim_dev_s *dev);
|
static void stm32l4_tim_reset(FAR struct stm32l4_tim_dev_s *dev);
|
||||||
#if defined(HAVE_TIM1_GPIOCONFIG) || defined(HAVE_TIM2_GPIOCONFIG) || \
|
#if defined(HAVE_TIM1_GPIOCONFIG) || defined(HAVE_TIM2_GPIOCONFIG) || \
|
||||||
defined(HAVE_TIM3_GPIOCONFIG) || defined(HAVE_TIM4_GPIOCONFIG) || \
|
defined(HAVE_TIM3_GPIOCONFIG) || defined(HAVE_TIM4_GPIOCONFIG) || \
|
||||||
@ -312,6 +313,7 @@ static const struct stm32l4_tim_ops_s stm32l4_tim_ops =
|
|||||||
.ackint = stm32l4_tim_ackint,
|
.ackint = stm32l4_tim_ackint,
|
||||||
.checkint = stm32l4_tim_checkint,
|
.checkint = stm32l4_tim_checkint,
|
||||||
.enable = stm32l4_tim_enable,
|
.enable = stm32l4_tim_enable,
|
||||||
|
.disable = stm32l4_tim_disable,
|
||||||
.dump_regs = stm32l4_tim_dumpregs,
|
.dump_regs = stm32l4_tim_dumpregs,
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -506,19 +508,23 @@ static void stm32l4_tim_reload_counter(FAR struct stm32l4_tim_dev_s *dev)
|
|||||||
* Name: stm32l4_tim_enable
|
* Name: stm32l4_tim_enable
|
||||||
************************************************************************************/
|
************************************************************************************/
|
||||||
|
|
||||||
static void stm32l4_tim_enable(FAR struct stm32l4_tim_dev_s *dev, bool state)
|
static void stm32l4_tim_enable(FAR struct stm32l4_tim_dev_s *dev)
|
||||||
{
|
{
|
||||||
uint16_t val = stm32l4_getreg16(dev, STM32L4_BTIM_CR1_OFFSET);
|
uint16_t val = stm32l4_getreg16(dev, STM32L4_BTIM_CR1_OFFSET);
|
||||||
|
|
||||||
if(state)
|
|
||||||
{
|
|
||||||
val |= ATIM_CR1_CEN;
|
val |= ATIM_CR1_CEN;
|
||||||
stm32l4_tim_reload_counter(dev);
|
stm32l4_tim_reload_counter(dev);
|
||||||
}
|
stm32l4_putreg16(dev, STM32L4_BTIM_CR1_OFFSET, val);
|
||||||
else
|
}
|
||||||
{
|
|
||||||
|
/************************************************************************************
|
||||||
|
* Name: stm32l4_tim_disable
|
||||||
|
************************************************************************************/
|
||||||
|
|
||||||
|
static void stm32l4_tim_disable(FAR struct stm32l4_tim_dev_s *dev)
|
||||||
|
{
|
||||||
|
uint16_t val = stm32l4_getreg16(dev, STM32L4_BTIM_CR1_OFFSET);
|
||||||
val &= ~ATIM_CR1_CEN;
|
val &= ~ATIM_CR1_CEN;
|
||||||
}
|
|
||||||
stm32l4_putreg16(dev, STM32L4_BTIM_CR1_OFFSET, val);
|
stm32l4_putreg16(dev, STM32L4_BTIM_CR1_OFFSET, val);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -533,7 +539,7 @@ static void stm32l4_tim_enable(FAR struct stm32l4_tim_dev_s *dev, bool state)
|
|||||||
static void stm32l4_tim_reset(FAR struct stm32l4_tim_dev_s *dev)
|
static void stm32l4_tim_reset(FAR struct stm32l4_tim_dev_s *dev)
|
||||||
{
|
{
|
||||||
((struct stm32l4_tim_priv_s *)dev)->mode = STM32L4_TIM_MODE_DISABLED;
|
((struct stm32l4_tim_priv_s *)dev)->mode = STM32L4_TIM_MODE_DISABLED;
|
||||||
stm32l4_tim_enable(dev, false);
|
stm32l4_tim_disable(dev);
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************************************************
|
/************************************************************************************
|
||||||
@ -567,29 +573,30 @@ static void stm32l4_tim_gpioconfig(uint32_t cfg, enum stm32l4_tim_channel_e mode
|
|||||||
static void stm32l4_tim_dumpregs(FAR struct stm32l4_tim_dev_s *dev)
|
static void stm32l4_tim_dumpregs(FAR struct stm32l4_tim_dev_s *dev)
|
||||||
{
|
{
|
||||||
struct stm32l4_tim_priv_s *priv = (struct stm32l4_tim_priv_s *)dev;
|
struct stm32l4_tim_priv_s *priv = (struct stm32l4_tim_priv_s *)dev;
|
||||||
{
|
|
||||||
/* data */
|
|
||||||
};
|
|
||||||
|
|
||||||
ainfo(" CR1: %04x CR2: %04x SMCR: %04x DIER: %04x\n",
|
ainfo(" CR1: %04x CR2: %04x SMCR: %04x DIER: %04x\n",
|
||||||
stm32l4_getreg16(dev, STM32L4_GTIM_CR1_OFFSET),
|
stm32l4_getreg16(dev, STM32L4_GTIM_CR1_OFFSET),
|
||||||
stm32l4_getreg16(dev, STM32L4_GTIM_CR2_OFFSET),
|
stm32l4_getreg16(dev, STM32L4_GTIM_CR2_OFFSET),
|
||||||
stm32l4_getreg16(dev, STM32L4_GTIM_SMCR_OFFSET),
|
stm32l4_getreg16(dev, STM32L4_GTIM_SMCR_OFFSET),
|
||||||
stm32l4_getreg16(dev, STM32L4_GTIM_DIER_OFFSET));
|
stm32l4_getreg16(dev, STM32L4_GTIM_DIER_OFFSET)
|
||||||
|
);
|
||||||
ainfo(" SR: %04x EGR: 0000 CCMR1: %04x CCMR2: %04x\n",
|
ainfo(" SR: %04x EGR: 0000 CCMR1: %04x CCMR2: %04x\n",
|
||||||
stm32l4_getreg16(dev, STM32L4_GTIM_SR_OFFSET),
|
stm32l4_getreg16(dev, STM32L4_GTIM_SR_OFFSET),
|
||||||
stm32l4_getreg16(dev, STM32L4_GTIM_CCMR1_OFFSET),
|
stm32l4_getreg16(dev, STM32L4_GTIM_CCMR1_OFFSET),
|
||||||
stm32l4_getreg16(dev, STM32L4_GTIM_CCMR2_OFFSET));
|
stm32l4_getreg16(dev, STM32L4_GTIM_CCMR2_OFFSET)
|
||||||
|
);
|
||||||
ainfo(" CCER: %04x CNT: %04x PSC: %04x ARR: %04x\n",
|
ainfo(" CCER: %04x CNT: %04x PSC: %04x ARR: %04x\n",
|
||||||
stm32l4_getreg16(dev, STM32L4_GTIM_CCER_OFFSET),
|
stm32l4_getreg16(dev, STM32L4_GTIM_CCER_OFFSET),
|
||||||
stm32l4_getreg16(dev, STM32L4_GTIM_CNT_OFFSET),
|
stm32l4_getreg16(dev, STM32L4_GTIM_CNT_OFFSET),
|
||||||
stm32l4_getreg16(dev, STM32L4_GTIM_PSC_OFFSET),
|
stm32l4_getreg16(dev, STM32L4_GTIM_PSC_OFFSET),
|
||||||
stm32l4_getreg16(dev, STM32L4_GTIM_ARR_OFFSET));
|
stm32l4_getreg16(dev, STM32L4_GTIM_ARR_OFFSET)
|
||||||
|
);
|
||||||
ainfo(" CCR1: %04x CCR2: %04x CCR3: %04x CCR4: %04x\n",
|
ainfo(" CCR1: %04x CCR2: %04x CCR3: %04x CCR4: %04x\n",
|
||||||
stm32l4_getreg16(dev, STM32L4_GTIM_CCR1_OFFSET),
|
stm32l4_getreg16(dev, STM32L4_GTIM_CCR1_OFFSET),
|
||||||
stm32l4_getreg16(dev, STM32L4_GTIM_CCR2_OFFSET),
|
stm32l4_getreg16(dev, STM32L4_GTIM_CCR2_OFFSET),
|
||||||
stm32l4_getreg16(dev, STM32L4_GTIM_CCR3_OFFSET),
|
stm32l4_getreg16(dev, STM32L4_GTIM_CCR3_OFFSET),
|
||||||
stm32l4_getreg16(dev, STM32L4_GTIM_CCR4_OFFSET));
|
stm32l4_getreg16(dev, STM32L4_GTIM_CCR4_OFFSET)
|
||||||
|
);
|
||||||
|
|
||||||
if (priv->base == STM32L4_TIM1_BASE || priv->base == STM32L4_TIM8_BASE)
|
if (priv->base == STM32L4_TIM1_BASE || priv->base == STM32L4_TIM8_BASE)
|
||||||
{
|
{
|
||||||
@ -698,7 +705,7 @@ static int stm32l4_tim_setclock(FAR struct stm32l4_tim_dev_s *dev,
|
|||||||
|
|
||||||
if (freq == 0)
|
if (freq == 0)
|
||||||
{
|
{
|
||||||
stm32l4_tim_enable(dev, false);
|
stm32l4_tim_disable(dev);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/************************************************************************************
|
/*****************************************************************************
|
||||||
* arch/arm/src/stm32l4/stm32l4_tim.h
|
* arch/arm/src/stm32l4/stm32l4_tim.h
|
||||||
*
|
*
|
||||||
* Copyright (C) 2011 Uros Platise. All rights reserved.
|
* Copyright (C) 2011 Uros Platise. All rights reserved.
|
||||||
@ -37,25 +37,25 @@
|
|||||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
* POSSIBILITY OF SUCH DAMAGE.
|
||||||
*
|
*
|
||||||
************************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
#ifndef __ARCH_ARM_SRC_STM32L4_STM32L4_TIM_H
|
#ifndef __ARCH_ARM_SRC_STM32L4_STM32L4_TIM_H
|
||||||
#define __ARCH_ARM_SRC_STM32L4_STM32L4_TIM_H
|
#define __ARCH_ARM_SRC_STM32L4_STM32L4_TIM_H
|
||||||
|
|
||||||
/************************************************************************************
|
/*****************************************************************************
|
||||||
* Included Files
|
* Included Files
|
||||||
************************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
#include <nuttx/config.h>
|
#include <nuttx/config.h>
|
||||||
|
|
||||||
#include "chip.h"
|
#include "chip.h"
|
||||||
#include "hardware/stm32l4_tim.h"
|
#include "hardware/stm32l4_tim.h"
|
||||||
|
|
||||||
/************************************************************************************
|
/*****************************************************************************
|
||||||
* Pre-processor Definitions
|
* Pre-processor Definitions
|
||||||
************************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/* Helpers **************************************************************************/
|
/* Helpers *******************************************************************/
|
||||||
|
|
||||||
#define STM32L4_TIM_SETMODE(d,mode) ((d)->ops->setmode(d,mode))
|
#define STM32L4_TIM_SETMODE(d,mode) ((d)->ops->setmode(d,mode))
|
||||||
#define STM32L4_TIM_SETCLOCK(d,freq) ((d)->ops->setclock(d,freq))
|
#define STM32L4_TIM_SETCLOCK(d,freq) ((d)->ops->setclock(d,freq))
|
||||||
@ -71,12 +71,13 @@
|
|||||||
#define STM32L4_TIM_DISABLEINT(d,s) ((d)->ops->disableint(d,s))
|
#define STM32L4_TIM_DISABLEINT(d,s) ((d)->ops->disableint(d,s))
|
||||||
#define STM32L4_TIM_ACKINT(d,s) ((d)->ops->ackint(d,s))
|
#define STM32L4_TIM_ACKINT(d,s) ((d)->ops->ackint(d,s))
|
||||||
#define STM32L4_TIM_CHECKINT(d,s) ((d)->ops->checkint(d,s))
|
#define STM32L4_TIM_CHECKINT(d,s) ((d)->ops->checkint(d,s))
|
||||||
#define STM32L4_TIM_ENABLE(d,s) ((d)->ops->enable(d,s))
|
#define STM32L4_TIM_ENABLE(d) ((d)->ops->enable(d))
|
||||||
|
#define STM32L4_TIM_DISABLE(d) ((d)->ops->disable(d))
|
||||||
#define STM32L4_TIM_DUMPREGS(d) ((d)->ops->dump_regs(d))
|
#define STM32L4_TIM_DUMPREGS(d) ((d)->ops->dump_regs(d))
|
||||||
|
|
||||||
/************************************************************************************
|
/*****************************************************************************
|
||||||
* Public Types
|
* Public Types
|
||||||
************************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
#ifndef __ASSEMBLY__
|
#ifndef __ASSEMBLY__
|
||||||
|
|
||||||
@ -117,7 +118,7 @@ enum stm32l4_tim_mode_e
|
|||||||
#if 0
|
#if 0
|
||||||
STM32L4_TIM_MODE_CK_INT_TRIG = 0x0400,
|
STM32L4_TIM_MODE_CK_INT_TRIG = 0x0400,
|
||||||
STM32L4_TIM_MODE_CK_EXT = 0x0800,
|
STM32L4_TIM_MODE_CK_EXT = 0x0800,
|
||||||
STM32L4_TIM_MODE_CK_EXT_TRIG = 0x0C00,
|
STM32L4_TIM_MODE_CK_EXT_TRIG = 0x0c00,
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Clock sources, OR'ed with CK_EXT */
|
/* Clock sources, OR'ed with CK_EXT */
|
||||||
@ -150,7 +151,9 @@ enum stm32l4_tim_channel_e
|
|||||||
|
|
||||||
/* Output Compare Modes */
|
/* Output Compare Modes */
|
||||||
|
|
||||||
STM32L4_TIM_CH_OUTPWM = 0x04, /* Enable standard PWM mode, active high when counter < compare */
|
STM32L4_TIM_CH_OUTPWM = 0x04, /* Enable standard PWM mode, active
|
||||||
|
* high when counter < compare
|
||||||
|
*/
|
||||||
#if 0
|
#if 0
|
||||||
STM32L4_TIM_CH_OUTCOMPARE = 0x06,
|
STM32L4_TIM_CH_OUTCOMPARE = 0x06,
|
||||||
#endif
|
#endif
|
||||||
@ -194,13 +197,14 @@ struct stm32l4_tim_ops_s
|
|||||||
void (*disableint)(FAR struct stm32l4_tim_dev_s *dev, int source);
|
void (*disableint)(FAR struct stm32l4_tim_dev_s *dev, int source);
|
||||||
void (*ackint)(FAR struct stm32l4_tim_dev_s *dev, int source);
|
void (*ackint)(FAR struct stm32l4_tim_dev_s *dev, int source);
|
||||||
int (*checkint)(FAR struct stm32l4_tim_dev_s *dev, int source);
|
int (*checkint)(FAR struct stm32l4_tim_dev_s *dev, int source);
|
||||||
void (*enable)(FAR struct stm32l4_tim_dev_s *dev, bool state);
|
void (*enable)(FAR struct stm32l4_tim_dev_s *dev);
|
||||||
|
void (*disable)(FAR struct stm32l4_tim_dev_s *dev);
|
||||||
void (*dump_regs)(FAR struct stm32l4_tim_dev_s *dev);
|
void (*dump_regs)(FAR struct stm32l4_tim_dev_s *dev);
|
||||||
};
|
};
|
||||||
|
|
||||||
/************************************************************************************
|
/*****************************************************************************
|
||||||
* Public Functions
|
* Public functions
|
||||||
************************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
/* Power-up timer and get its structure */
|
/* Power-up timer and get its structure */
|
||||||
|
|
||||||
@ -210,7 +214,7 @@ FAR struct stm32l4_tim_dev_s *stm32l4_tim_init(int timer);
|
|||||||
|
|
||||||
int stm32l4_tim_deinit(FAR struct stm32l4_tim_dev_s *dev);
|
int stm32l4_tim_deinit(FAR struct stm32l4_tim_dev_s *dev);
|
||||||
|
|
||||||
/****************************************************************************
|
/*****************************************************************************
|
||||||
* Name: stm32l4_timer_initialize
|
* Name: stm32l4_timer_initialize
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
@ -218,14 +222,15 @@ int stm32l4_tim_deinit(FAR struct stm32l4_tim_dev_s *dev);
|
|||||||
* register the timer drivers at 'devpath'
|
* register the timer drivers at 'devpath'
|
||||||
*
|
*
|
||||||
* Input Parameters:
|
* Input Parameters:
|
||||||
* devpath - The full path to the timer device. This should be of the form /dev/timer0
|
* devpath - The full path to the timer device. This should be of the form
|
||||||
|
* /dev/timer0
|
||||||
* timer - the timer number.
|
* timer - the timer number.
|
||||||
*
|
*
|
||||||
* Returned Value:
|
* Returned Value:
|
||||||
* Zero (OK) is returned on success; A negated errno value is returned
|
* Zero (OK) is returned on success; A negated errno value is returned
|
||||||
* to indicate the nature of any failure.
|
* to indicate the nature of any failure.
|
||||||
*
|
*
|
||||||
****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
#ifdef CONFIG_TIMER
|
#ifdef CONFIG_TIMER
|
||||||
int stm32l4_timer_initialize(FAR const char *devpath, int timer);
|
int stm32l4_timer_initialize(FAR const char *devpath, int timer);
|
||||||
|
@ -392,6 +392,7 @@ static int spwm_tim6_setup(FAR struct spwm_s *spwm)
|
|||||||
|
|
||||||
STM32L4_TIM_SETCLOCK(tim, BOARD_TIM6_FREQUENCY);
|
STM32L4_TIM_SETCLOCK(tim, BOARD_TIM6_FREQUENCY);
|
||||||
STM32L4_TIM_SETPERIOD(tim, per);
|
STM32L4_TIM_SETPERIOD(tim, per);
|
||||||
|
STM32L4_TIM_ENABLE(tim);
|
||||||
|
|
||||||
/* Attach TIM6 ram vector */
|
/* Attach TIM6 ram vector */
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user