mirror of https://github.com/ARMmbed/mbed-os.git
Add channel 17 for Vref
parent
bcd8f2431a
commit
354ffe84ab
|
@ -56,6 +56,7 @@ const PinMap PinMap_ADC[] = {
|
||||||
{PC_4, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 14, 0)}, // ADC_IN14
|
{PC_4, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 14, 0)}, // ADC_IN14
|
||||||
{PC_5, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 15, 0)}, // ADC_IN15
|
{PC_5, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 15, 0)}, // ADC_IN15
|
||||||
{ADC_TEMP, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 16, 0)}, // ADC_IN16
|
{ADC_TEMP, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 16, 0)}, // ADC_IN16
|
||||||
|
{ADC_VREF, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 17, 0)}, // ADC_IN17
|
||||||
{NC, NC, 0}
|
{NC, NC, 0}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -46,9 +46,9 @@ extern "C" {
|
||||||
((CHANNEL & 0x1F) << 11) |\
|
((CHANNEL & 0x1F) << 11) |\
|
||||||
((INVERTED & 0x01) << 16)))
|
((INVERTED & 0x01) << 16)))
|
||||||
|
|
||||||
#define STM_PIN_MODE(X) (((X) >> 0) & 0x0F)
|
#define STM_PIN_MODE(X) (((X) >> 0) & 0x0F)
|
||||||
#define STM_PIN_PUPD(X) (((X) >> 4) & 0x07)
|
#define STM_PIN_PUPD(X) (((X) >> 4) & 0x07)
|
||||||
#define STM_PIN_AFNUM(X) (((X) >> 7) & 0x0F)
|
#define STM_PIN_AFNUM(X) (((X) >> 7) & 0x0F)
|
||||||
#define STM_PIN_CHANNEL(X) (((X) >> 11) & 0x1F)
|
#define STM_PIN_CHANNEL(X) (((X) >> 11) & 0x1F)
|
||||||
#define STM_PIN_INVERTED(X) (((X) >> 16) & 0x01)
|
#define STM_PIN_INVERTED(X) (((X) >> 16) & 0x01)
|
||||||
|
|
||||||
|
@ -132,6 +132,7 @@ typedef enum {
|
||||||
|
|
||||||
// ADC internal channels
|
// ADC internal channels
|
||||||
ADC_TEMP = 0xF0,
|
ADC_TEMP = 0xF0,
|
||||||
|
ADC_VREF = 0xF1,
|
||||||
|
|
||||||
// PCB printout
|
// PCB printout
|
||||||
A0 = PA_0,
|
A0 = PA_0,
|
||||||
|
|
|
@ -56,6 +56,7 @@ const PinMap PinMap_ADC[] = {
|
||||||
{PC_4, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 14, 0)}, // ADC_IN14
|
{PC_4, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 14, 0)}, // ADC_IN14
|
||||||
{PC_5, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 15, 0)}, // ADC_IN15
|
{PC_5, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 15, 0)}, // ADC_IN15
|
||||||
{ADC_TEMP, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 16, 0)}, // ADC_IN16
|
{ADC_TEMP, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 16, 0)}, // ADC_IN16
|
||||||
|
{ADC_VREF, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 17, 0)}, // ADC_IN17
|
||||||
{NC, NC, 0}
|
{NC, NC, 0}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -46,9 +46,9 @@ extern "C" {
|
||||||
((CHANNEL & 0x1F) << 11) |\
|
((CHANNEL & 0x1F) << 11) |\
|
||||||
((INVERTED & 0x01) << 16)))
|
((INVERTED & 0x01) << 16)))
|
||||||
|
|
||||||
#define STM_PIN_MODE(X) (((X) >> 0) & 0x0F)
|
#define STM_PIN_MODE(X) (((X) >> 0) & 0x0F)
|
||||||
#define STM_PIN_PUPD(X) (((X) >> 4) & 0x07)
|
#define STM_PIN_PUPD(X) (((X) >> 4) & 0x07)
|
||||||
#define STM_PIN_AFNUM(X) (((X) >> 7) & 0x0F)
|
#define STM_PIN_AFNUM(X) (((X) >> 7) & 0x0F)
|
||||||
#define STM_PIN_CHANNEL(X) (((X) >> 11) & 0x1F)
|
#define STM_PIN_CHANNEL(X) (((X) >> 11) & 0x1F)
|
||||||
#define STM_PIN_INVERTED(X) (((X) >> 16) & 0x01)
|
#define STM_PIN_INVERTED(X) (((X) >> 16) & 0x01)
|
||||||
|
|
||||||
|
@ -134,6 +134,7 @@ typedef enum {
|
||||||
|
|
||||||
// ADC internal channels
|
// ADC internal channels
|
||||||
ADC_TEMP = 0xF0,
|
ADC_TEMP = 0xF0,
|
||||||
|
ADC_VREF = 0xF1,
|
||||||
|
|
||||||
// Arduino connector namings
|
// Arduino connector namings
|
||||||
PA0 = PA_0,
|
PA0 = PA_0,
|
||||||
|
|
|
@ -56,6 +56,7 @@ const PinMap PinMap_ADC[] = {
|
||||||
{PC_4, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 14, 0)}, // ADC_IN14
|
{PC_4, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 14, 0)}, // ADC_IN14
|
||||||
{PC_5, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 15, 0)}, // ADC_IN15
|
{PC_5, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 15, 0)}, // ADC_IN15
|
||||||
{ADC_TEMP, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 16, 0)}, // ADC_IN16
|
{ADC_TEMP, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 16, 0)}, // ADC_IN16
|
||||||
|
{ADC_VREF, ADC_1, STM_PIN_DATA_EXT(STM_MODE_ANALOG, GPIO_NOPULL, 0, 17, 0)}, // ADC_IN17
|
||||||
{NC, NC, 0}
|
{NC, NC, 0}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -46,9 +46,9 @@ extern "C" {
|
||||||
((CHANNEL & 0x1F) << 11) |\
|
((CHANNEL & 0x1F) << 11) |\
|
||||||
((INVERTED & 0x01) << 16)))
|
((INVERTED & 0x01) << 16)))
|
||||||
|
|
||||||
#define STM_PIN_MODE(X) (((X) >> 0) & 0x0F)
|
#define STM_PIN_MODE(X) (((X) >> 0) & 0x0F)
|
||||||
#define STM_PIN_PUPD(X) (((X) >> 4) & 0x07)
|
#define STM_PIN_PUPD(X) (((X) >> 4) & 0x07)
|
||||||
#define STM_PIN_AFNUM(X) (((X) >> 7) & 0x0F)
|
#define STM_PIN_AFNUM(X) (((X) >> 7) & 0x0F)
|
||||||
#define STM_PIN_CHANNEL(X) (((X) >> 11) & 0x1F)
|
#define STM_PIN_CHANNEL(X) (((X) >> 11) & 0x1F)
|
||||||
#define STM_PIN_INVERTED(X) (((X) >> 16) & 0x01)
|
#define STM_PIN_INVERTED(X) (((X) >> 16) & 0x01)
|
||||||
|
|
||||||
|
@ -132,6 +132,7 @@ typedef enum {
|
||||||
|
|
||||||
// ADC internal channels
|
// ADC internal channels
|
||||||
ADC_TEMP = 0xF0,
|
ADC_TEMP = 0xF0,
|
||||||
|
ADC_VREF = 0xF1,
|
||||||
|
|
||||||
// Arduino connector namings
|
// Arduino connector namings
|
||||||
A0 = PA_0,
|
A0 = PA_0,
|
||||||
|
|
|
@ -52,8 +52,8 @@ void analogin_init(analogin_t *obj, PinName pin)
|
||||||
MBED_ASSERT(function != (uint32_t)NC);
|
MBED_ASSERT(function != (uint32_t)NC);
|
||||||
obj->channel = STM_PIN_CHANNEL(function);
|
obj->channel = STM_PIN_CHANNEL(function);
|
||||||
|
|
||||||
// Configure GPIO excepted for internal channels (Temperature)
|
// Configure GPIO excepted for internal channels (Temperature, Vref)
|
||||||
if (obj->channel != 16) {
|
if ((obj->channel != 16) && (obj->channel != 17)) {
|
||||||
pinmap_pinout(pin, PinMap_ADC);
|
pinmap_pinout(pin, PinMap_ADC);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -152,6 +152,9 @@ static inline uint16_t adc_read(analogin_t *obj)
|
||||||
case 16:
|
case 16:
|
||||||
sConfig.Channel = ADC_CHANNEL_16;
|
sConfig.Channel = ADC_CHANNEL_16;
|
||||||
break;
|
break;
|
||||||
|
case 17:
|
||||||
|
sConfig.Channel = ADC_CHANNEL_17;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue