Skip to content
GitLab
Projects
Groups
Snippets
Help
Loading...
Help
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
M
micropython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Analytics
Analytics
Repository
Value Stream
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Commits
Open sidebar
xpstem
micropython
Commits
d49a5470
Commit
d49a5470
authored
Mar 22, 2016
by
Tobias Badertscher
Committed by
Damien George
Apr 16, 2016
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
stmhal: L4: Modify adc.c to add support for STM32L4 series.
parent
69f26c68
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
91 additions
and
17 deletions
+91
-17
stmhal/adc.c
stmhal/adc.c
+91
-17
No files found.
stmhal/adc.c
View file @
d49a5470
...
@@ -65,6 +65,8 @@
...
@@ -65,6 +65,8 @@
defined(STM32F437xx) || defined(STM32F439xx) || \
defined(STM32F437xx) || defined(STM32F439xx) || \
defined(STM32F746xx)
defined(STM32F746xx)
#define VBAT_DIV (4)
#define VBAT_DIV (4)
#elif defined(STM32L476xx)
#define VBAT_DIV (3)
#else
#else
#error Unsupported processor
#error Unsupported processor
#endif
#endif
...
@@ -80,8 +82,45 @@ typedef struct _pyb_obj_adc_t {
...
@@ -80,8 +82,45 @@ typedef struct _pyb_obj_adc_t {
ADC_HandleTypeDef
handle
;
ADC_HandleTypeDef
handle
;
}
pyb_obj_adc_t
;
}
pyb_obj_adc_t
;
STATIC
bool
is_adcx_channel
(
int
channel
)
{
#if defined(MCU_SERIES_F4) || defined(MCU_SERIES_F7)
return
IS_ADC_CHANNEL
(
channel
);
#elif defined(MCU_SERIES_L4)
ADC_HandleTypeDef
handle
;
handle
.
Instance
=
ADCx
;
return
IS_ADC_CHANNEL
(
&
handle
,
channel
);
#else
#error Unsupported processor
#endif
}
STATIC
void
adc_wait_for_eoc_or_timeout
(
int32_t
timeout
)
{
uint32_t
tickstart
=
HAL_GetTick
();
#if defined(MCU_SERIES_F4) || defined(MCU_SERIES_F7)
while
((
ADCx
->
SR
&
ADC_FLAG_EOC
)
!=
ADC_FLAG_EOC
)
{
#elif defined(MCU_SERIES_L4)
while
(
READ_BIT
(
ADCx
->
ISR
,
ADC_FLAG_EOC
)
!=
ADC_FLAG_EOC
)
{
#else
#error Unsupported processor
#endif
if
(((
HAL_GetTick
()
-
tickstart
)
>
timeout
))
{
break
;
// timeout
}
}
}
STATIC
void
adcx_clock_enable
(
void
)
{
#if defined(MCU_SERIES_F4) || defined(MCU_SERIES_F7)
ADCx_CLK_ENABLE
();
#elif defined(MCU_SERIES_L4)
__HAL_RCC_ADC_CLK_ENABLE
();
#else
#error Unsupported processor
#endif
}
STATIC
void
adc_init_single
(
pyb_obj_adc_t
*
adc_obj
)
{
STATIC
void
adc_init_single
(
pyb_obj_adc_t
*
adc_obj
)
{
if
(
!
IS_ADC_CHANNEL
(
adc_obj
->
channel
))
{
if
(
!
is_adcx_channel
(
adc_obj
->
channel
))
{
return
;
return
;
}
}
...
@@ -97,22 +136,33 @@ STATIC void adc_init_single(pyb_obj_adc_t *adc_obj) {
...
@@ -97,22 +136,33 @@ STATIC void adc_init_single(pyb_obj_adc_t *adc_obj) {
HAL_GPIO_Init
(
pin
->
gpio
,
&
GPIO_InitStructure
);
HAL_GPIO_Init
(
pin
->
gpio
,
&
GPIO_InitStructure
);
}
}
ADCx_CLK_ENABLE
();
adcx_clock_enable
();
ADC_HandleTypeDef
*
adcHandle
=
&
adc_obj
->
handle
;
ADC_HandleTypeDef
*
adcHandle
=
&
adc_obj
->
handle
;
adcHandle
->
Instance
=
ADCx
;
adcHandle
->
Instance
=
ADCx
;
adcHandle
->
Init
.
ClockPrescaler
=
ADC_CLOCKPRESCALER_PCLK_DIV2
;
adcHandle
->
Init
.
Resolution
=
ADC_RESOLUTION12b
;
adcHandle
->
Init
.
Resolution
=
ADC_RESOLUTION12b
;
adcHandle
->
Init
.
ScanConvMode
=
DISABLE
;
adcHandle
->
Init
.
ContinuousConvMode
=
DISABLE
;
adcHandle
->
Init
.
ContinuousConvMode
=
DISABLE
;
adcHandle
->
Init
.
DiscontinuousConvMode
=
DISABLE
;
adcHandle
->
Init
.
DiscontinuousConvMode
=
DISABLE
;
adcHandle
->
Init
.
NbrOfDiscConversion
=
0
;
adcHandle
->
Init
.
NbrOfDiscConversion
=
0
;
adcHandle
->
Init
.
ExternalTrigConvEdge
=
ADC_EXTERNALTRIGCONVEDGE_NONE
;
adcHandle
->
Init
.
ExternalTrigConvEdge
=
ADC_EXTERNALTRIGCONVEDGE_NONE
;
adcHandle
->
Init
.
ExternalTrigConv
=
ADC_EXTERNALTRIGCONV_T1_CC1
;
adcHandle
->
Init
.
DataAlign
=
ADC_DATAALIGN_RIGHT
;
adcHandle
->
Init
.
DataAlign
=
ADC_DATAALIGN_RIGHT
;
adcHandle
->
Init
.
NbrOfConversion
=
1
;
adcHandle
->
Init
.
NbrOfConversion
=
1
;
adcHandle
->
Init
.
DMAContinuousRequests
=
DISABLE
;
adcHandle
->
Init
.
DMAContinuousRequests
=
DISABLE
;
adcHandle
->
Init
.
EOCSelection
=
DISABLE
;
adcHandle
->
Init
.
EOCSelection
=
DISABLE
;
#if defined(MCU_SERIES_F4) || defined(MCU_SERIES_F7)
adcHandle
->
Init
.
ClockPrescaler
=
ADC_CLOCKPRESCALER_PCLK_DIV2
;
adcHandle
->
Init
.
ScanConvMode
=
DISABLE
;
adcHandle
->
Init
.
ExternalTrigConv
=
ADC_EXTERNALTRIGCONV_T1_CC1
;
#elif defined(MCU_SERIES_L4)
adcHandle
->
Init
.
ClockPrescaler
=
ADC_CLOCK_ASYNC_DIV2
;
adcHandle
->
Init
.
ScanConvMode
=
ADC_SCAN_DISABLE
;
adcHandle
->
Init
.
ExternalTrigConv
=
ADC_EXTERNALTRIG_T1_CC1
;
adcHandle
->
Init
.
LowPowerAutoWait
=
DISABLE
;
adcHandle
->
Init
.
Overrun
=
ADC_OVR_DATA_PRESERVED
;
adcHandle
->
Init
.
OversamplingMode
=
DISABLE
;
#else
#error Unsupported processor
#endif
HAL_ADC_Init
(
adcHandle
);
HAL_ADC_Init
(
adcHandle
);
}
}
...
@@ -122,7 +172,13 @@ STATIC void adc_config_channel(pyb_obj_adc_t *adc_obj) {
...
@@ -122,7 +172,13 @@ STATIC void adc_config_channel(pyb_obj_adc_t *adc_obj) {
sConfig
.
Channel
=
adc_obj
->
channel
;
sConfig
.
Channel
=
adc_obj
->
channel
;
sConfig
.
Rank
=
1
;
sConfig
.
Rank
=
1
;
#if defined(MCU_SERIES_F4) || defined(MCU_SERIES_F7)
sConfig
.
SamplingTime
=
ADC_SAMPLETIME_15CYCLES
;
sConfig
.
SamplingTime
=
ADC_SAMPLETIME_15CYCLES
;
#elif defined(MCU_SERIES_L4)
sConfig
.
SamplingTime
=
ADC_SAMPLETIME_12CYCLES_5
;
#else
#error Unsupported processor
#endif
sConfig
.
Offset
=
0
;
sConfig
.
Offset
=
0
;
HAL_ADC_ConfigChannel
(
&
adc_obj
->
handle
,
&
sConfig
);
HAL_ADC_ConfigChannel
(
&
adc_obj
->
handle
,
&
sConfig
);
...
@@ -173,7 +229,7 @@ STATIC mp_obj_t adc_make_new(const mp_obj_type_t *type, mp_uint_t n_args, mp_uin
...
@@ -173,7 +229,7 @@ STATIC mp_obj_t adc_make_new(const mp_obj_type_t *type, mp_uint_t n_args, mp_uin
channel
=
pin
->
adc_channel
;
channel
=
pin
->
adc_channel
;
}
}
if
(
!
IS_ADC_CHANNEL
(
channel
))
{
if
(
!
is_adcx_channel
(
channel
))
{
nlr_raise
(
mp_obj_new_exception_msg_varg
(
&
mp_type_ValueError
,
"not a valid ADC Channel: %d"
,
channel
));
nlr_raise
(
mp_obj_new_exception_msg_varg
(
&
mp_type_ValueError
,
"not a valid ADC Channel: %d"
,
channel
));
}
}
if
(
pin_adc1
[
channel
]
==
NULL
)
{
if
(
pin_adc1
[
channel
]
==
NULL
)
{
...
@@ -274,17 +330,18 @@ STATIC mp_obj_t adc_read_timed(mp_obj_t self_in, mp_obj_t buf_in, mp_obj_t freq_
...
@@ -274,17 +330,18 @@ STATIC mp_obj_t adc_read_timed(mp_obj_t self_in, mp_obj_t buf_in, mp_obj_t freq_
HAL_ADC_Start
(
&
self
->
handle
);
HAL_ADC_Start
(
&
self
->
handle
);
}
else
{
}
else
{
// for subsequent samples we can just set the "start sample" bit
// for subsequent samples we can just set the "start sample" bit
#if defined(MCU_SERIES_F4) || defined(MCU_SERIES_F7)
ADCx
->
CR2
|=
(
uint32_t
)
ADC_CR2_SWSTART
;
ADCx
->
CR2
|=
(
uint32_t
)
ADC_CR2_SWSTART
;
#elif defined(MCU_SERIES_L4)
SET_BIT
(
ADCx
->
CR
,
ADC_CR_ADSTART
);
#else
#error Unsupported processor
#endif
}
}
// wait for sample to complete
// wait for sample to complete
uint32_t
tickstart
=
HAL_GetTick
();
#define READ_TIMED_TIMEOUT (10) // in ms
while
((
ADCx
->
SR
&
ADC_FLAG_EOC
)
!=
ADC_FLAG_EOC
)
{
adc_wait_for_eoc_or_timeout
(
READ_TIMED_TIMEOUT
);
#define READ_TIMED_TIMEOUT (10) // in ms
if
(((
HAL_GetTick
()
-
tickstart
)
>
READ_TIMED_TIMEOUT
))
{
break
;
// timeout
}
}
// read value
// read value
uint
value
=
ADCx
->
DR
;
uint
value
=
ADCx
->
DR
;
...
@@ -357,22 +414,33 @@ void adc_init_all(pyb_adc_all_obj_t *adc_all, uint32_t resolution) {
...
@@ -357,22 +414,33 @@ void adc_init_all(pyb_adc_all_obj_t *adc_all, uint32_t resolution) {
HAL_GPIO_Init
(
pin
->
gpio
,
&
GPIO_InitStructure
);
HAL_GPIO_Init
(
pin
->
gpio
,
&
GPIO_InitStructure
);
}
}
ADCx_CLK_ENABLE
();
adcx_clock_enable
();
ADC_HandleTypeDef
*
adcHandle
=
&
adc_all
->
handle
;
ADC_HandleTypeDef
*
adcHandle
=
&
adc_all
->
handle
;
adcHandle
->
Instance
=
ADCx
;
adcHandle
->
Instance
=
ADCx
;
adcHandle
->
Init
.
ClockPrescaler
=
ADC_CLOCKPRESCALER_PCLK_DIV2
;
adcHandle
->
Init
.
Resolution
=
resolution
;
adcHandle
->
Init
.
Resolution
=
resolution
;
adcHandle
->
Init
.
ScanConvMode
=
DISABLE
;
adcHandle
->
Init
.
ContinuousConvMode
=
DISABLE
;
adcHandle
->
Init
.
ContinuousConvMode
=
DISABLE
;
adcHandle
->
Init
.
DiscontinuousConvMode
=
DISABLE
;
adcHandle
->
Init
.
DiscontinuousConvMode
=
DISABLE
;
adcHandle
->
Init
.
NbrOfDiscConversion
=
0
;
adcHandle
->
Init
.
NbrOfDiscConversion
=
0
;
adcHandle
->
Init
.
ExternalTrigConvEdge
=
ADC_EXTERNALTRIGCONVEDGE_NONE
;
adcHandle
->
Init
.
ExternalTrigConvEdge
=
ADC_EXTERNALTRIGCONVEDGE_NONE
;
adcHandle
->
Init
.
ExternalTrigConv
=
ADC_EXTERNALTRIGCONV_T1_CC1
;
adcHandle
->
Init
.
DataAlign
=
ADC_DATAALIGN_RIGHT
;
adcHandle
->
Init
.
DataAlign
=
ADC_DATAALIGN_RIGHT
;
adcHandle
->
Init
.
NbrOfConversion
=
1
;
adcHandle
->
Init
.
NbrOfConversion
=
1
;
adcHandle
->
Init
.
DMAContinuousRequests
=
DISABLE
;
adcHandle
->
Init
.
DMAContinuousRequests
=
DISABLE
;
adcHandle
->
Init
.
EOCSelection
=
DISABLE
;
adcHandle
->
Init
.
EOCSelection
=
DISABLE
;
#if defined(MCU_SERIES_F4) || defined(MCU_SERIES_F7)
adcHandle
->
Init
.
ClockPrescaler
=
ADC_CLOCKPRESCALER_PCLK_DIV2
;
adcHandle
->
Init
.
ScanConvMode
=
DISABLE
;
adcHandle
->
Init
.
ExternalTrigConv
=
ADC_EXTERNALTRIGCONV_T1_CC1
;
#elif defined(MCU_SERIES_L4)
adcHandle
->
Init
.
ClockPrescaler
=
ADC_CLOCK_ASYNC_DIV2
;
adcHandle
->
Init
.
ScanConvMode
=
ADC_SCAN_DISABLE
;
adcHandle
->
Init
.
ExternalTrigConv
=
ADC_EXTERNALTRIG_T1_CC1
;
adcHandle
->
Init
.
LowPowerAutoWait
=
DISABLE
;
adcHandle
->
Init
.
Overrun
=
ADC_OVR_DATA_PRESERVED
;
adcHandle
->
Init
.
OversamplingMode
=
DISABLE
;
#else
#error Unsupported processor
#endif
HAL_ADC_Init
(
adcHandle
);
HAL_ADC_Init
(
adcHandle
);
}
}
...
@@ -381,7 +449,13 @@ uint32_t adc_config_and_read_channel(ADC_HandleTypeDef *adcHandle, uint32_t chan
...
@@ -381,7 +449,13 @@ uint32_t adc_config_and_read_channel(ADC_HandleTypeDef *adcHandle, uint32_t chan
ADC_ChannelConfTypeDef
sConfig
;
ADC_ChannelConfTypeDef
sConfig
;
sConfig
.
Channel
=
channel
;
sConfig
.
Channel
=
channel
;
sConfig
.
Rank
=
1
;
sConfig
.
Rank
=
1
;
#if defined(MCU_SERIES_F4) || defined(MCU_SERIES_F7)
sConfig
.
SamplingTime
=
ADC_SAMPLETIME_15CYCLES
;
sConfig
.
SamplingTime
=
ADC_SAMPLETIME_15CYCLES
;
#elif defined(MCU_SERIES_L4)
sConfig
.
SamplingTime
=
ADC_SAMPLETIME_12CYCLES_5
;
#else
#error Unsupported processor
#endif
sConfig
.
Offset
=
0
;
sConfig
.
Offset
=
0
;
HAL_ADC_ConfigChannel
(
adcHandle
,
&
sConfig
);
HAL_ADC_ConfigChannel
(
adcHandle
,
&
sConfig
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment