Merged in raiden00/nuttx_pe (pull request #823)
Improvements in STM32 ADC, PWM and TIM arch/arm/src/stm32/chip/stm32_adc_v2.h: missing T1TRGO2 for JEXTSEL arch/arm/src/stm32/stm32_adc: configure injected channels external trigger when ADC enabled arch/arm/src/stm32/stm32_adc: update injected conversion queue of context after configuration arch/arm/src/stm32/stm32_adc: fix sample time configuration for channels. The array index for channels was missing arch/arm/src/stm32/stm32_adc: support for offset configuration arch/arm/src/stm32/stm32_pwm: fix TRGO/TRGO2 configuration arch/arm/src/stm32/stm32_pwm: support for advanced timers channel 5 and 6 Approved-by: GregoryN <gnutt@nuttx.org>
This commit is contained in:
parent
15db8a21ae
commit
5911478777
@ -3403,6 +3403,54 @@ config STM32_TIM1_CH4OUT
|
|||||||
|
|
||||||
endif # STM32_TIM1_CHANNEL4
|
endif # STM32_TIM1_CHANNEL4
|
||||||
|
|
||||||
|
config STM32_TIM1_CHANNEL5
|
||||||
|
bool "TIM1 Channel 5 (internal)"
|
||||||
|
default n
|
||||||
|
depends on STM32_HAVE_IP_TIMERS_V2
|
||||||
|
---help---
|
||||||
|
Enables channel 5 (no available externaly)
|
||||||
|
|
||||||
|
if STM32_TIM1_CHANNEL5
|
||||||
|
|
||||||
|
config STM32_TIM1_CH5MODE
|
||||||
|
int "TIM1 Channel 5 Mode"
|
||||||
|
default 0
|
||||||
|
range 0 5
|
||||||
|
---help---
|
||||||
|
Specifies the channel mode.
|
||||||
|
|
||||||
|
config STM32_TIM1_CH5OUT
|
||||||
|
bool "TIM1 Channel 5 Output"
|
||||||
|
default n
|
||||||
|
---help---
|
||||||
|
Enables channel 5 output.
|
||||||
|
|
||||||
|
endif # STM32_TIM1_CHANNEL5
|
||||||
|
|
||||||
|
config STM32_TIM1_CHANNEL6
|
||||||
|
bool "TIM1 Channel 6 (internal)"
|
||||||
|
default n
|
||||||
|
depends on STM32_HAVE_IP_TIMERS_V2
|
||||||
|
---help---
|
||||||
|
Enables channel 6 (no available externaly)
|
||||||
|
|
||||||
|
if STM32_TIM1_CHANNEL6
|
||||||
|
|
||||||
|
config STM32_TIM1_CH6MODE
|
||||||
|
int "TIM1 Channel 6 Mode"
|
||||||
|
default 0
|
||||||
|
range 0 5
|
||||||
|
---help---
|
||||||
|
Specifies the channel mode.
|
||||||
|
|
||||||
|
config STM32_TIM1_CH6OUT
|
||||||
|
bool "TIM1 Channel 6 Output"
|
||||||
|
default n
|
||||||
|
---help---
|
||||||
|
Enables channel 6 output.
|
||||||
|
|
||||||
|
endif # STM32_TIM1_CHANNEL6
|
||||||
|
|
||||||
endif # STM32_PWM_MULTICHAN
|
endif # STM32_PWM_MULTICHAN
|
||||||
|
|
||||||
if !STM32_PWM_MULTICHAN
|
if !STM32_PWM_MULTICHAN
|
||||||
@ -4379,6 +4427,54 @@ config STM32_TIM8_CH4OUT
|
|||||||
|
|
||||||
endif # STM32_TIM8_CHANNEL4
|
endif # STM32_TIM8_CHANNEL4
|
||||||
|
|
||||||
|
config STM32_TIM8_CHANNEL5
|
||||||
|
bool "TIM8 Channel 5 (internal)"
|
||||||
|
default n
|
||||||
|
depends on STM32_HAVE_IP_TIMERS_V2
|
||||||
|
---help---
|
||||||
|
Enables channel 5 (no available externaly)
|
||||||
|
|
||||||
|
if STM32_TIM8_CHANNEL5
|
||||||
|
|
||||||
|
config STM32_TIM8_CH5MODE
|
||||||
|
int "TIM8 Channel 5 Mode"
|
||||||
|
default 0
|
||||||
|
range 0 5
|
||||||
|
---help---
|
||||||
|
Specifies the channel mode.
|
||||||
|
|
||||||
|
config STM32_TIM8_CH5OUT
|
||||||
|
bool "TIM8 Channel 5 Output"
|
||||||
|
default n
|
||||||
|
---help---
|
||||||
|
Enables channel 5 output.
|
||||||
|
|
||||||
|
endif # STM32_TIM8_CHANNEL5
|
||||||
|
|
||||||
|
config STM32_TIM8_CHANNEL6
|
||||||
|
bool "TIM8 Channel 6 (internal)"
|
||||||
|
default n
|
||||||
|
depends on STM32_HAVE_IP_TIMERS_V2
|
||||||
|
---help---
|
||||||
|
Enables channel 6 (no available externaly)
|
||||||
|
|
||||||
|
if STM32_TIM8_CHANNEL6
|
||||||
|
|
||||||
|
config STM32_TIM8_CH6MODE
|
||||||
|
int "TIM8 Channel 6 Mode"
|
||||||
|
default 0
|
||||||
|
range 0 5
|
||||||
|
---help---
|
||||||
|
Specifies the channel mode.
|
||||||
|
|
||||||
|
config STM32_TIM8_CH6OUT
|
||||||
|
bool "TIM8 Channel 6 Output"
|
||||||
|
default n
|
||||||
|
---help---
|
||||||
|
Enables channel 6 output.
|
||||||
|
|
||||||
|
endif # STM32_TIM8_CHANNEL6
|
||||||
|
|
||||||
endif # STM32_PWM_MULTICHAN
|
endif # STM32_PWM_MULTICHAN
|
||||||
|
|
||||||
if !STM32_PWM_MULTICHAN
|
if !STM32_PWM_MULTICHAN
|
||||||
@ -5330,10 +5426,10 @@ config STM32_PWM_MULTICHAN
|
|||||||
Specifies that the PWM driver supports multiple output
|
Specifies that the PWM driver supports multiple output
|
||||||
channels per timer.
|
channels per timer.
|
||||||
|
|
||||||
config STM32_TIM_PWM_TRGO
|
config STM32_PWM_TRGO
|
||||||
bool "TIM PWM TRGO"
|
bool "TIM PWM TRGO support"
|
||||||
default n
|
default n
|
||||||
depends on STM32_TIM1
|
depends on STM32_PWM
|
||||||
---help---
|
---help---
|
||||||
Enable TRGO support for PWM driver
|
Enable TRGO support for PWM driver
|
||||||
|
|
||||||
@ -6343,6 +6439,38 @@ config STM32_TIM1_CH4IDLE
|
|||||||
---help---
|
---help---
|
||||||
TIM1 Channel 4 output IDLE
|
TIM1 Channel 4 output IDLE
|
||||||
|
|
||||||
|
config STM32_TIM1_CH5POL
|
||||||
|
int "TIM1 Channel 5 Output polarity"
|
||||||
|
default 0
|
||||||
|
range 0 1
|
||||||
|
depends on STM32_TIM1_CH5OUT
|
||||||
|
---help---
|
||||||
|
TIM1 Channel 5 output polarity
|
||||||
|
|
||||||
|
config STM32_TIM1_CH5IDLE
|
||||||
|
int "TIM1 Channel 5 Output IDLE"
|
||||||
|
default 0
|
||||||
|
range 0 1
|
||||||
|
depends on STM32_TIM1_CH5OUT
|
||||||
|
---help---
|
||||||
|
TIM1 Channel 5 output IDLE
|
||||||
|
|
||||||
|
config STM32_TIM1_CH6POL
|
||||||
|
int "TIM1 Channel 6 Output polarity"
|
||||||
|
default 0
|
||||||
|
range 0 1
|
||||||
|
depends on STM32_TIM1_CH6OUT
|
||||||
|
---help---
|
||||||
|
TIM1 Channel 6 output polarity
|
||||||
|
|
||||||
|
config STM32_TIM1_CH6IDLE
|
||||||
|
int "TIM1 Channel 6 Output IDLE"
|
||||||
|
default 0
|
||||||
|
range 0 1
|
||||||
|
depends on STM32_TIM1_CH6OUT
|
||||||
|
---help---
|
||||||
|
TIM1 Channel 6 output IDLE
|
||||||
|
|
||||||
config STM32_TIM2_CH1POL
|
config STM32_TIM2_CH1POL
|
||||||
int "TIM2 Channel 1 Output polarity"
|
int "TIM2 Channel 1 Output polarity"
|
||||||
default 0
|
default 0
|
||||||
@ -6711,6 +6839,38 @@ config STM32_TIM8_CH4IDLE
|
|||||||
---help---
|
---help---
|
||||||
TIM8 Channel 4 output IDLE
|
TIM8 Channel 4 output IDLE
|
||||||
|
|
||||||
|
config STM32_TIM8_CH5POL
|
||||||
|
int "TIM8 Channel 5 Output polarity"
|
||||||
|
default 0
|
||||||
|
range 0 1
|
||||||
|
depends on STM32_TIM8_CH5OUT
|
||||||
|
---help---
|
||||||
|
TIM8 Channel 5 output polarity
|
||||||
|
|
||||||
|
config STM32_TIM8_CH5IDLE
|
||||||
|
int "TIM8 Channel 5 Output IDLE"
|
||||||
|
default 0
|
||||||
|
range 0 1
|
||||||
|
depends on STM32_TIM8_CH5OUT
|
||||||
|
---help---
|
||||||
|
TIM8 Channel 5 output IDLE
|
||||||
|
|
||||||
|
config STM32_TIM8_CH6POL
|
||||||
|
int "TIM8 Channel 6 Output polarity"
|
||||||
|
default 0
|
||||||
|
range 0 1
|
||||||
|
depends on STM32_TIM8_CH6OUT
|
||||||
|
---help---
|
||||||
|
TIM8 Channel 6 output polarity
|
||||||
|
|
||||||
|
config STM32_TIM8_CH6IDLE
|
||||||
|
int "TIM8 Channel 6 Output IDLE"
|
||||||
|
default 0
|
||||||
|
range 0 1
|
||||||
|
depends on STM32_TIM8_CH6OUT
|
||||||
|
---help---
|
||||||
|
TIM8 Channel 6 output IDLE
|
||||||
|
|
||||||
config STM32_TIM9_CH1POL
|
config STM32_TIM9_CH1POL
|
||||||
int "TIM9 Channel 1 Output polarity"
|
int "TIM9 Channel 1 Output polarity"
|
||||||
default 0
|
default 0
|
||||||
|
@ -574,6 +574,7 @@
|
|||||||
# define ADC12_JSQR_JEXTSEL_T4TRGO (5 << ADC_JSQR_JEXTSEL_SHIFT)
|
# define ADC12_JSQR_JEXTSEL_T4TRGO (5 << ADC_JSQR_JEXTSEL_SHIFT)
|
||||||
# define ADC12_JSQR_JEXTSEL_T20TRGO (6 << ADC_JSQR_JEXTSEL_SHIFT)
|
# define ADC12_JSQR_JEXTSEL_T20TRGO (6 << ADC_JSQR_JEXTSEL_SHIFT)
|
||||||
# define ADC12_JSQR_JEXTSEL_T8CC4 (7 << ADC_JSQR_JEXTSEL_SHIFT)
|
# define ADC12_JSQR_JEXTSEL_T8CC4 (7 << ADC_JSQR_JEXTSEL_SHIFT)
|
||||||
|
# define ADC12_JSQR_JEXTSEL_T1TRGO2 (8 << ADC_JSQR_JEXTSEL_SHIFT)
|
||||||
# define ADC12_JSQR_JEXTSEL_T8TRGO (9 << ADC_JSQR_JEXTSEL_SHIFT)
|
# define ADC12_JSQR_JEXTSEL_T8TRGO (9 << ADC_JSQR_JEXTSEL_SHIFT)
|
||||||
# define ADC12_JSQR_JEXTSEL_T3CC3 (11 << ADC_JSQR_JEXTSEL_SHIFT)
|
# define ADC12_JSQR_JEXTSEL_T3CC3 (11 << ADC_JSQR_JEXTSEL_SHIFT)
|
||||||
# define ADC12_JSQR_JEXTSEL_T3TRGO (12 << ADC_JSQR_JEXTSEL_SHIFT)
|
# define ADC12_JSQR_JEXTSEL_T3TRGO (12 << ADC_JSQR_JEXTSEL_SHIFT)
|
||||||
|
@ -687,6 +687,8 @@ static void adc_intdis(FAR struct stm32_adc_dev_s *dev, uint32_t source);
|
|||||||
static uint32_t adc_intget(FAR struct stm32_adc_dev_s *dev);
|
static uint32_t adc_intget(FAR struct stm32_adc_dev_s *dev);
|
||||||
static uint32_t adc_regget(FAR struct stm32_adc_dev_s *dev);
|
static uint32_t adc_regget(FAR struct stm32_adc_dev_s *dev);
|
||||||
static void adc_llops_reg_startconv(FAR struct stm32_adc_dev_s *dev, bool enable);
|
static void adc_llops_reg_startconv(FAR struct stm32_adc_dev_s *dev, bool enable);
|
||||||
|
static int adc_offset_set(FAR struct stm32_adc_dev_s *dev, uint8_t ch, uint8_t i,
|
||||||
|
uint16_t offset);
|
||||||
# ifdef ADC_HAVE_DMA
|
# ifdef ADC_HAVE_DMA
|
||||||
static int adc_regbufregister(FAR struct stm32_adc_dev_s *dev, uint16_t *buffer,
|
static int adc_regbufregister(FAR struct stm32_adc_dev_s *dev, uint16_t *buffer,
|
||||||
uint8_t len);
|
uint8_t len);
|
||||||
@ -734,6 +736,7 @@ static const struct stm32_adc_ops_s g_adc_llops =
|
|||||||
.int_dis = adc_intdis,
|
.int_dis = adc_intdis,
|
||||||
.val_get = adc_regget,
|
.val_get = adc_regget,
|
||||||
.reg_startconv = adc_llops_reg_startconv,
|
.reg_startconv = adc_llops_reg_startconv,
|
||||||
|
.offset_set = adc_offset_set,
|
||||||
# ifdef ADC_HAVE_DMA
|
# ifdef ADC_HAVE_DMA
|
||||||
.regbuf_reg = adc_regbufregister,
|
.regbuf_reg = adc_regbufregister,
|
||||||
# endif
|
# endif
|
||||||
@ -2783,16 +2786,26 @@ static void adc_configure(FAR struct adc_dev_s *dev)
|
|||||||
adc_extcfg_set(dev, priv->extcfg);
|
adc_extcfg_set(dev, priv->extcfg);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef ADC_HAVE_JEXTCFG
|
|
||||||
/* Configure external event for injected group */
|
|
||||||
|
|
||||||
adc_jextcfg_set(dev, priv->jextcfg);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Enable ADC */
|
/* Enable ADC */
|
||||||
|
|
||||||
adc_enable(priv, true);
|
adc_enable(priv, true);
|
||||||
|
|
||||||
|
#ifdef ADC_HAVE_JEXTCFG
|
||||||
|
/* Configure external event for injected group when ADC enabled */
|
||||||
|
|
||||||
|
adc_jextcfg_set(dev, priv->jextcfg);
|
||||||
|
|
||||||
|
#if defined(HAVE_IP_ADC_V2)
|
||||||
|
/* For ADC IPv2 there is queue of context for injected conversion.
|
||||||
|
* JEXTCFG configuration is the second write to JSQR register which means
|
||||||
|
* configuration is stored on queue.
|
||||||
|
* We trigger single INJ conversion here to update context.
|
||||||
|
*/
|
||||||
|
|
||||||
|
adc_inj_startconv(priv, true);
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Dump regs */
|
/* Dump regs */
|
||||||
|
|
||||||
adc_dumpregs(priv);
|
adc_dumpregs(priv);
|
||||||
@ -3267,8 +3280,9 @@ static void adc_dumpregs(FAR struct stm32_dev_s *priv)
|
|||||||
UNUSED(priv);
|
UNUSED(priv);
|
||||||
|
|
||||||
#if defined(HAVE_IP_ADC_V2)
|
#if defined(HAVE_IP_ADC_V2)
|
||||||
ainfo("ISR: 0x%08x CR: 0x%08x CFGR1: 0x%08x\n",
|
ainfo("ISR: 0x%08x IER: 0x%08x CR: 0x%08x CFGR1: 0x%08x\n",
|
||||||
adc_getreg(priv, STM32_ADC_ISR_OFFSET),
|
adc_getreg(priv, STM32_ADC_ISR_OFFSET),
|
||||||
|
adc_getreg(priv, STM32_ADC_IER_OFFSET),
|
||||||
adc_getreg(priv, STM32_ADC_CR_OFFSET),
|
adc_getreg(priv, STM32_ADC_CR_OFFSET),
|
||||||
adc_getreg(priv, STM32_ADC_CFGR1_OFFSET));
|
adc_getreg(priv, STM32_ADC_CFGR1_OFFSET));
|
||||||
#else
|
#else
|
||||||
@ -3278,17 +3292,19 @@ static void adc_dumpregs(FAR struct stm32_dev_s *priv)
|
|||||||
adc_getreg(priv, STM32_ADC_CR2_OFFSET));
|
adc_getreg(priv, STM32_ADC_CR2_OFFSET));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
ainfo("SQR1: 0x%08x SQR2: 0x%08x SQR3: 0x%08x\n",
|
ainfo("SQR1: 0x%08x SQR2: 0x%08x SQR3: 0x%08x SQR4: 0x%08x\n",
|
||||||
adc_getreg(priv, STM32_ADC_SQR1_OFFSET),
|
adc_getreg(priv, STM32_ADC_SQR1_OFFSET),
|
||||||
adc_getreg(priv, STM32_ADC_SQR2_OFFSET),
|
adc_getreg(priv, STM32_ADC_SQR2_OFFSET),
|
||||||
adc_getreg(priv, STM32_ADC_SQR3_OFFSET));
|
adc_getreg(priv, STM32_ADC_SQR3_OFFSET),
|
||||||
|
adc_getreg(priv, STM32_ADC_SQR4_OFFSET));
|
||||||
|
|
||||||
|
ainfo("SMPR1: 0x%08x SMPR2: 0x%08x\n",
|
||||||
|
adc_getreg(priv, STM32_ADC_SMPR1_OFFSET),
|
||||||
|
adc_getreg(priv, STM32_ADC_SMPR2_OFFSET));
|
||||||
|
|
||||||
#if defined(STM32_ADC_SQR5_OFFSET)
|
#if defined(STM32_ADC_SQR5_OFFSET)
|
||||||
ainfo("SQR4: 0x%08x SQR5: 0x%08x\n",
|
ainfo("SQR5: 0x%08x\n",
|
||||||
adc_getreg(priv, STM32_ADC_SQR4_OFFSET)
|
adc_getreg(priv, STM32_ADC_SQR4_OFFSET));
|
||||||
adc_getreg(priv, STM32_ADC_SQR5_OFFSET));
|
|
||||||
#elif defined(STM32_ADC_SQR4_OFFSET)
|
|
||||||
ainfo("SQR4: 0x%08x\n", adc_getreg(priv, STM32_ADC_SQR4_OFFSET));
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef ADC_HAVE_INJECTED
|
#ifdef ADC_HAVE_INJECTED
|
||||||
@ -3629,6 +3645,67 @@ static uint32_t adc_sqrbits(FAR struct stm32_dev_s *priv, int first, int last,
|
|||||||
return bits;
|
return bits;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: adc_offset_set
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#ifdef HAVE_IP_ADC_V2
|
||||||
|
static int adc_offset_set(FAR struct stm32_adc_dev_s *dev, uint8_t ch,
|
||||||
|
uint8_t i, uint16_t offset)
|
||||||
|
{
|
||||||
|
FAR struct stm32_dev_s *priv = (FAR struct stm32_dev_s *)dev;
|
||||||
|
uint32_t regval = 0;
|
||||||
|
uint32_t reg = 0;
|
||||||
|
int ret = OK;
|
||||||
|
|
||||||
|
if (i >= 4)
|
||||||
|
{
|
||||||
|
/* There are only four offset registers. */
|
||||||
|
|
||||||
|
ret = -E2BIG;
|
||||||
|
goto errout;
|
||||||
|
}
|
||||||
|
|
||||||
|
reg = STM32_ADC_OFR1_OFFSET + i * 4;
|
||||||
|
|
||||||
|
regval = ADC_OFR_OFFSETY_EN;
|
||||||
|
adc_putreg(priv, reg, regval);
|
||||||
|
|
||||||
|
regval |= ADC_OFR_OFFSETY_CH(ch) | ADC_OFR_OFFSETY(offset);
|
||||||
|
adc_putreg(priv, reg, regval);
|
||||||
|
|
||||||
|
errout:
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
#else /* HAVE_IP_ADC_V1 */
|
||||||
|
static int adc_offset_set(FAR struct stm32_adc_dev_s *dev, uint8_t ch,
|
||||||
|
uint8_t i, uint16_t offset)
|
||||||
|
{
|
||||||
|
FAR struct stm32_dev_s *priv = (FAR struct stm32_dev_s *)dev;
|
||||||
|
uint32_t reg = 0;
|
||||||
|
int ret = OK;
|
||||||
|
|
||||||
|
/* WARNING: Offset only for injected channels! */
|
||||||
|
|
||||||
|
UNUSED(ch);
|
||||||
|
|
||||||
|
if (i >= 4)
|
||||||
|
{
|
||||||
|
/* There are only four offset registers. */
|
||||||
|
|
||||||
|
ret = -E2BIG;
|
||||||
|
goto errout;
|
||||||
|
}
|
||||||
|
|
||||||
|
reg = STM32_ADC_JOFR1_OFFSET + i * 4;
|
||||||
|
|
||||||
|
adc_putreg(priv, reg, offset);
|
||||||
|
|
||||||
|
errout:
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: adc_set_ch
|
* Name: adc_set_ch
|
||||||
*
|
*
|
||||||
@ -4381,13 +4458,13 @@ void adc_sampletime_set(FAR struct stm32_adc_dev_s *dev,
|
|||||||
{
|
{
|
||||||
for (i = 0; i < time_samples->channels_nbr; i++)
|
for (i = 0; i < time_samples->channels_nbr; i++)
|
||||||
{
|
{
|
||||||
ch_index = time_samples->channel->channel;
|
ch_index = time_samples->channel[i].channel;
|
||||||
if (ch_index >= ADC_CHANNELS_NUMBER)
|
if (ch_index >= ADC_CHANNELS_NUMBER)
|
||||||
{
|
{
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
priv->sample_rate[ch_index] = time_samples->channel->sample_time;
|
priv->sample_rate[ch_index] = time_samples->channel[i].sample_time;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1921,6 +1921,8 @@
|
|||||||
(adc)->llops->regbuf_reg(adc, buffer, len)
|
(adc)->llops->regbuf_reg(adc, buffer, len)
|
||||||
#define ADC_REG_STARTCONV(adc, state) \
|
#define ADC_REG_STARTCONV(adc, state) \
|
||||||
(adc)->llops->reg_startconv(adc, state)
|
(adc)->llops->reg_startconv(adc, state)
|
||||||
|
#define ADC_OFFSET_SET(adc, ch, i, o) \
|
||||||
|
(adc)->llops->offset_set(adc, ch, i, o)
|
||||||
#define ADC_INJ_STARTCONV(adc, state) \
|
#define ADC_INJ_STARTCONV(adc, state) \
|
||||||
(adc)->llops->inj_startconv(adc, state)
|
(adc)->llops->inj_startconv(adc, state)
|
||||||
#define ADC_INJDATA_GET(adc, chan) \
|
#define ADC_INJDATA_GET(adc, chan) \
|
||||||
@ -2053,6 +2055,11 @@ struct stm32_adc_ops_s
|
|||||||
|
|
||||||
void (*reg_startconv)(FAR struct stm32_adc_dev_s *dev, bool state);
|
void (*reg_startconv)(FAR struct stm32_adc_dev_s *dev, bool state);
|
||||||
|
|
||||||
|
/* Set offset for channel */
|
||||||
|
|
||||||
|
int (*offset_set)(FAR struct stm32_adc_dev_s *dev, uint8_t ch, uint8_t i,
|
||||||
|
uint16_t offset);
|
||||||
|
|
||||||
#ifdef ADC_HAVE_INJECTED
|
#ifdef ADC_HAVE_INJECTED
|
||||||
/* Get current ADC injected data register */
|
/* Get current ADC injected data register */
|
||||||
|
|
||||||
|
@ -652,6 +652,36 @@ static struct stm32_pwmchan_s g_pwm1channels[] =
|
|||||||
.idle = CONFIG_STM32_TIM1_CH4IDLE,
|
.idle = CONFIG_STM32_TIM1_CH4IDLE,
|
||||||
.pincfg = PWM_TIM1_CH4CFG,
|
.pincfg = PWM_TIM1_CH4CFG,
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
},
|
||||||
|
#endif
|
||||||
|
#ifdef CONFIG_STM32_TIM1_CHANNEL5
|
||||||
|
{
|
||||||
|
.channel = 5,
|
||||||
|
.mode = CONFIG_STM32_TIM1_CH5MODE
|
||||||
|
#ifdef CONFIG_STM32_TIM1_CH5OUT
|
||||||
|
.out1 =
|
||||||
|
{
|
||||||
|
.in_use = 1,
|
||||||
|
.pol = CONFIG_STM32_TIM1_CH5POL,
|
||||||
|
.idle = CONFIG_STM32_TIM1_CH5IDLE,
|
||||||
|
.pincfg = 0, /* No available externaly */
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#ifdef CONFIG_STM32_TIM1_CHANNEL6
|
||||||
|
{
|
||||||
|
.channel = 6,
|
||||||
|
.mode = CONFIG_STM32_TIM1_CH6MODE
|
||||||
|
#ifdef CONFIG_STM32_TIM1_CH6OUT
|
||||||
|
.out1 =
|
||||||
|
{
|
||||||
|
.in_use = 1,
|
||||||
|
.pol = CONFIG_STM32_TIM1_CH6POL,
|
||||||
|
.idle = CONFIG_STM32_TIM1_CH6IDLE,
|
||||||
|
.pincfg = 0, /* No available externaly */
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -1185,6 +1215,36 @@ static struct stm32_pwmchan_s g_pwm8channels[] =
|
|||||||
#endif
|
#endif
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef CONFIG_STM32_TIM8_CHANNEL5
|
||||||
|
{
|
||||||
|
.channel = 5,
|
||||||
|
.mode = CONFIG_STM32_TIM8_CH5MODE
|
||||||
|
#ifdef CONFIG_STM32_TIM8_CH5OUT
|
||||||
|
.out1 =
|
||||||
|
{
|
||||||
|
.in_use = 1,
|
||||||
|
.pol = CONFIG_STM32_TIM8_CH5POL,
|
||||||
|
.idle = CONFIG_STM32_TIM8_CH5IDLE,
|
||||||
|
.pincfg = 0, /* No available externaly */
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#ifdef CONFIG_STM32_TIM8_CHANNEL6
|
||||||
|
{
|
||||||
|
.channel = 6,
|
||||||
|
.mode = CONFIG_STM32_TIM8_CH6MODE
|
||||||
|
#ifdef CONFIG_STM32_TIM8_CH6OUT
|
||||||
|
.out1 =
|
||||||
|
{
|
||||||
|
.in_use = 1,
|
||||||
|
.pol = CONFIG_STM32_TIM8_CH6POL,
|
||||||
|
.idle = CONFIG_STM32_TIM8_CH6IDLE,
|
||||||
|
.pincfg = 0, /* No available externaly */
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct stm32_pwmtimer_s g_pwm8dev =
|
static struct stm32_pwmtimer_s g_pwm8dev =
|
||||||
@ -2016,6 +2076,16 @@ static void pwm_dumpregs(struct stm32_pwmtimer_s *priv, FAR const char *msg)
|
|||||||
pwminfo(" DCR: %04x DMAR: %04x\n",
|
pwminfo(" DCR: %04x DMAR: %04x\n",
|
||||||
pwm_getreg(priv, STM32_GTIM_DCR_OFFSET),
|
pwm_getreg(priv, STM32_GTIM_DCR_OFFSET),
|
||||||
pwm_getreg(priv, STM32_GTIM_DMAR_OFFSET));
|
pwm_getreg(priv, STM32_GTIM_DMAR_OFFSET));
|
||||||
|
|
||||||
|
#ifdef HAVE_IP_TIMERS_V2
|
||||||
|
if (priv->timtype == TIMTYPE_ADVANCED)
|
||||||
|
{
|
||||||
|
pwminfo(" CCMR3: %04x CCR5: %04x CCR6: %04x\n",
|
||||||
|
pwm_getreg(priv, STM32_ATIM_CCMR3_OFFSET),
|
||||||
|
pwm_getreg(priv, STM32_ATIM_CCR5_OFFSET),
|
||||||
|
pwm_getreg(priv, STM32_ATIM_CCR6_OFFSET));
|
||||||
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -2468,9 +2538,22 @@ static int pwm_mode_configure(FAR struct stm32_pwmtimer_s *priv,
|
|||||||
uint32_t ccmr2 = 0;
|
uint32_t ccmr2 = 0;
|
||||||
int ret = OK;
|
int ret = OK;
|
||||||
#ifdef HAVE_IP_TIMERS_V2
|
#ifdef HAVE_IP_TIMERS_V2
|
||||||
|
uint32_t ccmr3 = 0;
|
||||||
|
uint32_t ocmode3 = 0;
|
||||||
bool ocmbit = false;
|
bool ocmbit = false;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_IP_TIMERS_V2
|
||||||
|
/* Only advanced timers have channels 5-6 */
|
||||||
|
|
||||||
|
if (channel > 4 && priv->timtype != TIMTYPE_ADVANCED)
|
||||||
|
{
|
||||||
|
pwmerr("ERROR: No such channel: %u\n", channel);
|
||||||
|
ret = -EINVAL;
|
||||||
|
goto errout;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Get channel mode
|
/* Get channel mode
|
||||||
* TODO: configurable preload for CCxR
|
* TODO: configurable preload for CCxR
|
||||||
*/
|
*/
|
||||||
@ -2531,6 +2614,12 @@ static int pwm_mode_configure(FAR struct stm32_pwmtimer_s *priv,
|
|||||||
|
|
||||||
ccmr1 = pwm_getreg(priv, STM32_GTIM_CCMR1_OFFSET);
|
ccmr1 = pwm_getreg(priv, STM32_GTIM_CCMR1_OFFSET);
|
||||||
ccmr2 = pwm_getreg(priv, STM32_GTIM_CCMR2_OFFSET);
|
ccmr2 = pwm_getreg(priv, STM32_GTIM_CCMR2_OFFSET);
|
||||||
|
#ifdef HAVE_IP_TIMERS_V2
|
||||||
|
if (priv->timtype == TIMTYPE_ADVANCED)
|
||||||
|
{
|
||||||
|
ccmr3 = pwm_getreg(priv, STM32_ATIM_CCMR3_OFFSET);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
switch (channel)
|
switch (channel)
|
||||||
{
|
{
|
||||||
@ -2670,6 +2759,62 @@ static int pwm_mode_configure(FAR struct stm32_pwmtimer_s *priv,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef HAVE_IP_TIMERS_V2
|
||||||
|
case 5: /* PWM Mode configuration: Channel 5 */
|
||||||
|
{
|
||||||
|
/* Reset current channel 5 mode configuration */
|
||||||
|
|
||||||
|
ccmr3 &= ~(ATIM_CCMR3_OC5M_MASK | ATIM_CCMR3_OC5PE);
|
||||||
|
|
||||||
|
/* Enable CCR5 preload */
|
||||||
|
|
||||||
|
ocmode3 |= (chanmode << ATIM_CCMR3_OC5M_SHIFT);
|
||||||
|
|
||||||
|
/* Enable CCR5 preload */
|
||||||
|
|
||||||
|
ocmode3 |= ATIM_CCMR3_OC5PE;
|
||||||
|
|
||||||
|
/* Reset current OC bit */
|
||||||
|
|
||||||
|
ccmr3 &= ~(ATIM_CCMR3_OC5M);
|
||||||
|
|
||||||
|
/* Set an additional OC5M bit */
|
||||||
|
|
||||||
|
if (ocmbit)
|
||||||
|
{
|
||||||
|
ocmode3 |= ATIM_CCMR3_OC5M;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case 6: /* PWM Mode configuration: Channel 6 */
|
||||||
|
{
|
||||||
|
/* Reset current channel 6 mode configuration */
|
||||||
|
|
||||||
|
ccmr3 &= ~(ATIM_CCMR3_OC6M_MASK | ATIM_CCMR3_OC6PE);
|
||||||
|
|
||||||
|
/* Enable CCR6 preload */
|
||||||
|
|
||||||
|
ocmode3 |= (chanmode << ATIM_CCMR3_OC6M_SHIFT);
|
||||||
|
|
||||||
|
/* Enable CCR6 preload */
|
||||||
|
|
||||||
|
ocmode3 |= ATIM_CCMR3_OC6PE;
|
||||||
|
|
||||||
|
/* Reset current OC bit */
|
||||||
|
|
||||||
|
ccmr3 &= ~(ATIM_CCMR3_OC6M);
|
||||||
|
|
||||||
|
/* Set an additional OC6M bit */
|
||||||
|
|
||||||
|
if (ocmbit)
|
||||||
|
{
|
||||||
|
ocmode3 |= ATIM_CCMR3_OC6M;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
default:
|
default:
|
||||||
{
|
{
|
||||||
pwmerr("ERROR: No such channel: %u\n", channel);
|
pwmerr("ERROR: No such channel: %u\n", channel);
|
||||||
@ -2683,10 +2828,17 @@ static int pwm_mode_configure(FAR struct stm32_pwmtimer_s *priv,
|
|||||||
ccmr1 |= ocmode1;
|
ccmr1 |= ocmode1;
|
||||||
ccmr2 |= ocmode2;
|
ccmr2 |= ocmode2;
|
||||||
|
|
||||||
/* Write CCMR1 and CCMR2 registers */
|
/* Write CCMRx registers */
|
||||||
|
|
||||||
pwm_putreg(priv, STM32_GTIM_CCMR1_OFFSET, ccmr1);
|
pwm_putreg(priv, STM32_GTIM_CCMR1_OFFSET, ccmr1);
|
||||||
pwm_putreg(priv, STM32_GTIM_CCMR2_OFFSET, ccmr2);
|
pwm_putreg(priv, STM32_GTIM_CCMR2_OFFSET, ccmr2);
|
||||||
|
#ifdef HAVE_IP_TIMERS_V2
|
||||||
|
if (priv->timtype == TIMTYPE_ADVANCED)
|
||||||
|
{
|
||||||
|
ccmr3 |= ocmode3;
|
||||||
|
pwm_putreg(priv, STM32_ATIM_CCMR3_OFFSET, ccmr3);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
errout:
|
errout:
|
||||||
return ret;
|
return ret;
|
||||||
@ -2919,12 +3071,12 @@ static int pwm_sync_configure(FAR struct stm32_pwmtimer_s *priv, uint8_t trgo)
|
|||||||
|
|
||||||
/* Configure TRGO (4 LSB in trgo) */
|
/* Configure TRGO (4 LSB in trgo) */
|
||||||
|
|
||||||
cr2 |= (trgo & ATIM_CR2_MMS_MASK) << ATIM_CR2_MMS_SHIFT;
|
cr2 |= (((trgo>>0) & 0x0F) << ATIM_CR2_MMS_SHIFT) & ATIM_CR2_MMS_MASK;
|
||||||
|
|
||||||
#ifdef HAVE_IP_TIMERS_V2
|
#ifdef HAVE_IP_TIMERS_V2
|
||||||
/* Configure TRGO2 (4 MSB in trgo)*/
|
/* Configure TRGO2 (4 MSB in trgo)*/
|
||||||
|
|
||||||
cr2 |= ((trgo>>4) & ATIM_CR2_MMS2_MASK) << ATIM_CR2_MMS2_SHIFT;
|
cr2 |= (((trgo>>4) & 0x0F) << ATIM_CR2_MMS2_SHIFT) & ATIM_CR2_MMS2_MASK;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Write register */
|
/* Write register */
|
||||||
@ -3178,7 +3330,7 @@ static int pwm_pulsecount_configure(FAR struct pwm_lowerhalf_s *dev)
|
|||||||
|
|
||||||
/* Configure TRGO/TRGO2 */
|
/* Configure TRGO/TRGO2 */
|
||||||
#ifdef HAVE_TRGO
|
#ifdef HAVE_TRGO
|
||||||
ret = pwm_sync_configure(priv, trgo);
|
ret = pwm_sync_configure(priv, priv->trgo);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
{
|
{
|
||||||
goto errout;
|
goto errout;
|
||||||
@ -3420,7 +3572,7 @@ static int pwm_configure(FAR struct pwm_lowerhalf_s *dev)
|
|||||||
|
|
||||||
/* Configure TRGO/TRGO2 */
|
/* Configure TRGO/TRGO2 */
|
||||||
#ifdef HAVE_TRGO
|
#ifdef HAVE_TRGO
|
||||||
ret = pwm_sync_configure(priv, trgo);
|
ret = pwm_sync_configure(priv, priv->trgo);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
{
|
{
|
||||||
goto errout;
|
goto errout;
|
||||||
@ -3437,7 +3589,6 @@ static int pwm_configure(FAR struct pwm_lowerhalf_s *dev)
|
|||||||
|
|
||||||
if (priv->channels[j].channel != 0)
|
if (priv->channels[j].channel != 0)
|
||||||
{
|
{
|
||||||
|
|
||||||
/* Update PWM mode */
|
/* Update PWM mode */
|
||||||
|
|
||||||
ret = pwm_mode_configure(priv, priv->channels[j].channel,
|
ret = pwm_mode_configure(priv, priv->channels[j].channel,
|
||||||
|
@ -774,87 +774,87 @@ static int stm32_tim_setclock(FAR struct stm32_tim_dev_s *dev, uint32_t freq)
|
|||||||
{
|
{
|
||||||
#ifdef CONFIG_STM32_TIM1
|
#ifdef CONFIG_STM32_TIM1
|
||||||
case STM32_TIM1_BASE:
|
case STM32_TIM1_BASE:
|
||||||
freqin = BOARD_TIM1_FREQUENCY;
|
freqin = STM32_APB2_TIM1_CLKIN;
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_STM32_TIM2
|
#ifdef CONFIG_STM32_TIM2
|
||||||
case STM32_TIM2_BASE:
|
case STM32_TIM2_BASE:
|
||||||
freqin = BOARD_TIM2_FREQUENCY;
|
freqin = STM32_APB1_TIM2_CLKIN;
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_STM32_TIM3
|
#ifdef CONFIG_STM32_TIM3
|
||||||
case STM32_TIM3_BASE:
|
case STM32_TIM3_BASE:
|
||||||
freqin = BOARD_TIM3_FREQUENCY;
|
freqin = STM32_APB1_TIM3_CLKIN;
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_STM32_TIM4
|
#ifdef CONFIG_STM32_TIM4
|
||||||
case STM32_TIM4_BASE:
|
case STM32_TIM4_BASE:
|
||||||
freqin = BOARD_TIM4_FREQUENCY;
|
freqin = STM32_APB1_TIM4_CLKIN;
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_STM32_TIM5
|
#ifdef CONFIG_STM32_TIM5
|
||||||
case STM32_TIM5_BASE:
|
case STM32_TIM5_BASE:
|
||||||
freqin = BOARD_TIM5_FREQUENCY;
|
freqin = STM32_APB1_TIM5_CLKIN;
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_STM32_TIM6
|
#ifdef CONFIG_STM32_TIM6
|
||||||
case STM32_TIM6_BASE:
|
case STM32_TIM6_BASE:
|
||||||
freqin = BOARD_TIM6_FREQUENCY;
|
freqin = STM32_APB1_TIM6_CLKIN;
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_STM32_TIM7
|
#ifdef CONFIG_STM32_TIM7
|
||||||
case STM32_TIM7_BASE:
|
case STM32_TIM7_BASE:
|
||||||
freqin = BOARD_TIM7_FREQUENCY;
|
freqin = STM32_APB1_TIM7_CLKIN;
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_STM32_TIM8
|
#ifdef CONFIG_STM32_TIM8
|
||||||
case STM32_TIM8_BASE:
|
case STM32_TIM8_BASE:
|
||||||
freqin = BOARD_TIM8_FREQUENCY;
|
freqin = STM32_APB2_TIM8_CLKIN;
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_STM32_TIM9
|
#ifdef CONFIG_STM32_TIM9
|
||||||
case STM32_TIM9_BASE:
|
case STM32_TIM9_BASE:
|
||||||
freqin = BOARD_TIM9_FREQUENCY;
|
freqin = STM32_APB2_TIM9_CLKIN;
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_STM32_TIM10
|
#ifdef CONFIG_STM32_TIM10
|
||||||
case STM32_TIM10_BASE:
|
case STM32_TIM10_BASE:
|
||||||
freqin = BOARD_TIM10_FREQUENCY;
|
freqin = STM32_APB2_TIM10_CLKIN;
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_STM32_TIM11
|
#ifdef CONFIG_STM32_TIM11
|
||||||
case STM32_TIM11_BASE:
|
case STM32_TIM11_BASE:
|
||||||
freqin = BOARD_TIM11_FREQUENCY;
|
freqin = STM32_APB2_TIM11_CLKIN;
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_STM32_TIM12
|
#ifdef CONFIG_STM32_TIM12
|
||||||
case STM32_TIM12_BASE:
|
case STM32_TIM12_BASE:
|
||||||
freqin = BOARD_TIM12_FREQUENCY;
|
freqin = STM32_APB1_TIM12_CLKIN;
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_STM32_TIM13
|
#ifdef CONFIG_STM32_TIM13
|
||||||
case STM32_TIM13_BASE:
|
case STM32_TIM13_BASE:
|
||||||
freqin = BOARD_TIM13_FREQUENCY;
|
freqin = STM32_APB1_TIM13_CLKIN;
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_STM32_TIM14
|
#ifdef CONFIG_STM32_TIM14
|
||||||
case STM32_TIM14_BASE:
|
case STM32_TIM14_BASE:
|
||||||
freqin = BOARD_TIM14_FREQUENCY;
|
freqin = STM32_APB1_TIM14_CLKIN;
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_STM32_TIM15
|
#ifdef CONFIG_STM32_TIM15
|
||||||
case STM32_TIM15_BASE:
|
case STM32_TIM15_BASE:
|
||||||
freqin = BOARD_TIM15_FREQUENCY;
|
freqin = STM32_APB2_TIM15_CLKIN;
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_STM32_TIM16
|
#ifdef CONFIG_STM32_TIM16
|
||||||
case STM32_TIM16_BASE:
|
case STM32_TIM16_BASE:
|
||||||
freqin = BOARD_TIM16_FREQUENCY;
|
freqin = STM32_APB2_TIM16_CLKIN;
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_STM32_TIM17
|
#ifdef CONFIG_STM32_TIM17
|
||||||
case STM32_TIM17_BASE:
|
case STM32_TIM17_BASE:
|
||||||
freqin = BOARD_TIM17_FREQUENCY;
|
freqin = STM32_APB2_TIM17_CLKIN;
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user