Skip to content

Commit e3f457b

Browse files
authored
Merge pull request #4154 from jeromecoutant/PR_F7_LEVEL0
STM32F7 Internal ADC channels rework
2 parents f1576bf + d1fa951 commit e3f457b

File tree

6 files changed

+41
-12
lines changed

6 files changed

+41
-12
lines changed

targets/TARGET_STM/TARGET_STM32F7/TARGET_STM32F746xG/TARGET_DISCO_F746NG/PeripheralPins.c

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -47,6 +47,10 @@ const PinMap PinMap_ADC[] = {
4747
{PF_8, ADC_3, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 6, 0)}, // ADC3_IN6 - ARDUINO A3
4848
{PF_9, ADC_3, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 7, 0)}, // ADC3_IN7 - ARDUINO A2
4949
{PF_10, ADC_3, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 8, 0)}, // ADC3_IN8 - ARDUINO A1
50+
{NC, NC, 0}
51+
};
52+
53+
const PinMap PinMap_ADC_Internal[] = {
5054
{ADC_TEMP, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 16, 0)}, // See in analogin_api.c the correct ADC channel used
5155
{ADC_VREF, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 17, 0)}, // See in analogin_api.c the correct ADC channel used
5256
{ADC_VBAT, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 18, 0)}, // See in analogin_api.c the correct ADC channel used

targets/TARGET_STM/TARGET_STM32F7/TARGET_STM32F746xG/TARGET_NUCLEO_F746ZG/PeripheralPins.c

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -65,6 +65,10 @@ const PinMap PinMap_ADC[] = {
6565
{PF_8, ADC_3, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 6, 0)}, // ADC3_IN6
6666
{PF_9, ADC_3, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 7, 0)}, // ADC3_IN7
6767
{PF_10, ADC_3, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 8, 0)}, // ADC3_IN8 - ARDUINO A5
68+
{NC, NC, 0}
69+
};
70+
71+
const PinMap PinMap_ADC_Internal[] = {
6872
{ADC_TEMP, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 16, 0)}, // See in analogin_api.c the correct ADC channel used
6973
{ADC_VREF, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 17, 0)}, // See in analogin_api.c the correct ADC channel used
7074
{ADC_VBAT, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 18, 0)}, // See in analogin_api.c the correct ADC channel used

targets/TARGET_STM/TARGET_STM32F7/TARGET_STM32F756xG/TARGET_NUCLEO_F756ZG/PeripheralPins.c

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -65,6 +65,10 @@ const PinMap PinMap_ADC[] = {
6565
{PF_8, ADC_3, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 6, 0)}, // ADC3_IN6
6666
{PF_9, ADC_3, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 7, 0)}, // ADC3_IN7
6767
{PF_10, ADC_3, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 8, 0)}, // ADC3_IN8 - ARDUINO A5
68+
{NC, NC, 0}
69+
};
70+
71+
const PinMap PinMap_ADC_Internal[] = {
6872
{ADC_TEMP, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 16, 0)}, // See in analogin_api.c the correct ADC channel used
6973
{ADC_VREF, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 17, 0)}, // See in analogin_api.c the correct ADC channel used
7074
{ADC_VBAT, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 18, 0)}, // See in analogin_api.c the correct ADC channel used

targets/TARGET_STM/TARGET_STM32F7/TARGET_STM32F767xI/TARGET_NUCLEO_F767ZI/PeripheralPins.c

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -65,6 +65,10 @@ const PinMap PinMap_ADC[] = {
6565
{PF_8, ADC_3, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 6, 0)}, // ADC3_IN6
6666
{PF_9, ADC_3, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 7, 0)}, // ADC3_IN7
6767
{PF_10, ADC_3, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 8, 0)}, // ADC3_IN8 - ARDUINO A5
68+
{NC, NC, 0}
69+
};
70+
71+
const PinMap PinMap_ADC_Internal[] = {
6872
{ADC_TEMP, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 16, 0)}, // See in analogin_api.c the correct ADC channel used
6973
{ADC_VREF, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 17, 0)}, // See in analogin_api.c the correct ADC channel used
7074
{ADC_VBAT, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 18, 0)}, // See in analogin_api.c the correct ADC channel used

targets/TARGET_STM/TARGET_STM32F7/TARGET_STM32F769xI/TARGET_DISCO_F769NI/PeripheralPins.c

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -52,6 +52,10 @@ const PinMap PinMap_ADC[] = {
5252
{PF_8, ADC_3, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 6, 0)}, // ADC3_IN6 - ARDUINO A4
5353
{PF_9, ADC_3, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 7, 0)}, // ADC3_IN7 - ARDUINO A5
5454
{PF_10, ADC_3, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 8, 0)}, // ADC3_IN8 - ARDUINO A3
55+
{NC, NC, 0}
56+
};
57+
58+
const PinMap PinMap_ADC_Internal[] = {
5559
{ADC_TEMP, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 16, 0)}, // See in analogin_api.c the correct ADC channel used
5660
{ADC_VREF, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 17, 0)}, // See in analogin_api.c the correct ADC channel used
5761
{ADC_VBAT, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 18, 0)}, // See in analogin_api.c the correct ADC channel used

targets/TARGET_STM/TARGET_STM32F7/analogin_api.c

Lines changed: 21 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -40,6 +40,9 @@ ADC_HandleTypeDef AdcHandle;
4040

4141
void analogin_init(analogin_t *obj, PinName pin)
4242
{
43+
uint32_t function = (uint32_t)NC;
44+
obj->adc = (ADCName)NC;
45+
4346
#if defined(ADC1)
4447
static int adc1_inited = 0;
4548
#endif
@@ -49,21 +52,27 @@ void analogin_init(analogin_t *obj, PinName pin)
4952
#if defined(ADC3)
5053
static int adc3_inited = 0;
5154
#endif
52-
53-
// Get the peripheral name from the pin and assign it to the object
54-
obj->adc = (ADCName)pinmap_peripheral(pin, PinMap_ADC);
55-
MBED_ASSERT(obj->adc != (ADCName)NC);
56-
57-
// Get the functions (adc channel) from the pin and assign it to the object
58-
uint32_t function = pinmap_function(pin, PinMap_ADC);
59-
MBED_ASSERT(function != (uint32_t)NC);
60-
obj->channel = STM_PIN_CHANNEL(function);
61-
62-
// Configure GPIO excepted for internal channels (Temperature, Vref, Vbat, ...)
63-
// ADC Internal Channels "pins" are described in PinNames.h and must have a value >= 0xF0
55+
// ADC Internal Channels "pins" (Temperature, Vref, Vbat, ...)
56+
// are described in PinNames.h and PeripheralPins.c
57+
// Pin value must be >= 0xF0
6458
if (pin < 0xF0) {
59+
// Normal channels
60+
// Get the peripheral name from the pin and assign it to the object
61+
obj->adc = (ADCName)pinmap_peripheral(pin, PinMap_ADC);
62+
// Get the functions (adc channel) from the pin and assign it to the object
63+
function = pinmap_function(pin, PinMap_ADC);
64+
// Configure GPIO
6565
pinmap_pinout(pin, PinMap_ADC);
66+
} else {
67+
// Internal channels
68+
obj->adc = (ADCName)pinmap_peripheral(pin, PinMap_ADC_Internal);
69+
function = pinmap_function(pin, PinMap_ADC_Internal);
70+
// No GPIO configuration for internal channels
6671
}
72+
MBED_ASSERT(obj->adc != (ADCName)NC);
73+
MBED_ASSERT(function != (uint32_t)NC);
74+
75+
obj->channel = STM_PIN_CHANNEL(function);
6776

6877
// Save pin number for the read function
6978
obj->pin = pin;

0 commit comments

Comments
 (0)