Skip to content

Commit 864ff77

Browse files
authored
Merge pull request #2924 from bcostm/adcintch_F2
STM32F2xx - Add support of ADC internal channels (temperature, VRef, VBat)
2 parents 478c732 + dfc2a2d commit 864ff77

File tree

3 files changed

+26
-7
lines changed

3 files changed

+26
-7
lines changed

targets/TARGET_STM/TARGET_STM32F2/TARGET_NUCLEO_F207ZG/PeripheralPins.c

Lines changed: 4 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -86,7 +86,10 @@ const PinMap PinMap_ADC[] = {
8686
{PF_7, ADC_3, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 5, 0)}, // ADC3_IN5
8787
{PF_8, ADC_3, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 6, 0)}, // ADC3_IN6
8888
{PF_9, ADC_3, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 7, 0)}, // ADC3_IN7
89-
{PF_10, ADC_3, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 8, 0)}, // ADC3_IN8
89+
{PF_10, ADC_3, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 8, 0)}, // ADC3_IN8
90+
{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
91+
{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
92+
{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
9093
{NC, NC, 0}
9194
};
9295

targets/TARGET_STM/TARGET_STM32F2/TARGET_NUCLEO_F207ZG/PinNames.h

Lines changed: 9 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -43,14 +43,14 @@ extern "C" {
4343
#define STM_PIN_DATA_EXT(MODE, PUPD, AFNUM, CHANNEL, INVERTED) ((int)(((MODE & 0x0F) << 0) |\
4444
((PUPD & 0x07) << 4) |\
4545
((AFNUM & 0x0F) << 7) |\
46-
((CHANNEL & 0x0F) << 11) |\
47-
((INVERTED & 0x01) << 15)))
46+
((CHANNEL & 0x1F) << 11) |\
47+
((INVERTED & 0x01) << 16)))
4848

4949
#define STM_PIN_MODE(X) (((X) >> 0) & 0x0F)
5050
#define STM_PIN_PUPD(X) (((X) >> 4) & 0x07)
5151
#define STM_PIN_AFNUM(X) (((X) >> 7) & 0x0F)
52-
#define STM_PIN_CHANNEL(X) (((X) >> 11) & 0x0F)
53-
#define STM_PIN_INVERTED(X) (((X) >> 15) & 0x01)
52+
#define STM_PIN_CHANNEL(X) (((X) >> 11) & 0x1F)
53+
#define STM_PIN_INVERTED(X) (((X) >> 16) & 0x01)
5454

5555
#define STM_MODE_INPUT (0)
5656
#define STM_MODE_OUTPUT_PP (1)
@@ -199,6 +199,11 @@ typedef enum {
199199
PH_0 = 0x70,
200200
PH_1 = 0x71,
201201

202+
// ADC internal channels
203+
ADC_TEMP = 0xF0,
204+
ADC_VREF = 0xF1,
205+
ADC_VBAT = 0xF2,
206+
202207
// Arduino connector namings
203208
A0 = PA_3,
204209
A1 = PC_0,

targets/TARGET_STM/TARGET_STM32F2/analogin_api.c

Lines changed: 13 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -58,8 +58,10 @@ void analogin_init(analogin_t *obj, PinName pin)
5858
MBED_ASSERT(function != (uint32_t)NC);
5959
obj->channel = STM_PIN_CHANNEL(function);
6060

61-
// Configure GPIO
62-
pinmap_pinout(pin, PinMap_ADC);
61+
// Configure GPIO excepted for internal channels (Temperature, Vref, Vbat)
62+
if ((obj->channel != 16) && (obj->channel != 17) && (obj->channel != 18)) {
63+
pinmap_pinout(pin, PinMap_ADC);
64+
}
6365

6466
// Save pin number for the read function
6567
obj->pin = pin;
@@ -166,6 +168,15 @@ static inline uint16_t adc_read(analogin_t *obj)
166168
case 15:
167169
sConfig.Channel = ADC_CHANNEL_15;
168170
break;
171+
case 16:
172+
sConfig.Channel = ADC_CHANNEL_TEMPSENSOR;
173+
break;
174+
case 17:
175+
sConfig.Channel = ADC_CHANNEL_VREFINT;
176+
break;
177+
case 18:
178+
sConfig.Channel = ADC_CHANNEL_VBAT;
179+
break;
169180
default:
170181
return 0;
171182
}

0 commit comments

Comments
 (0)