Add support for STM32 Potentiometer via ADC3
git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@4252 42af7a65-404d-4744-a932-0658087f49c3
This commit is contained in:
parent
f5dee16d90
commit
96d2702826
@ -2,7 +2,7 @@
|
|||||||
* configs/stm3210e-eval/src/up_adc.c
|
* configs/stm3210e-eval/src/up_adc.c
|
||||||
* arch/arm/src/board/up_adc.c
|
* arch/arm/src/board/up_adc.c
|
||||||
*
|
*
|
||||||
* Copyright (C) 2011 Gregory Nutt. All rights reserved.
|
* Copyright (C) 2011-2012 Gregory Nutt. All rights reserved.
|
||||||
* Author: Gregory Nutt <gnutt@nuttx.org>
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
@ -73,10 +73,13 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_STM32_ADC1) || defined(CONFIG_STM32_ADC2) || defined(CONFIG_STM32_ADC3)
|
#if defined(CONFIG_STM32_ADC1) || defined(CONFIG_STM32_ADC2) || defined(CONFIG_STM32_ADC3)
|
||||||
|
#ifndef CONFIG_STM32_ADC1
|
||||||
|
# warning "Channel information only available for ADC1"
|
||||||
|
#endif
|
||||||
|
|
||||||
/* The number of ADC channels in the conversion list */
|
/* The number of ADC channels in the conversion list */
|
||||||
|
|
||||||
#define ADC_NCHANNELS 1
|
#define ADC1_NCHANNELS 1
|
||||||
|
|
||||||
/************************************************************************************
|
/************************************************************************************
|
||||||
* Private Data
|
* Private Data
|
||||||
@ -84,11 +87,13 @@
|
|||||||
|
|
||||||
/* Identifying number of each ADC channel: Variable Resistor */
|
/* Identifying number of each ADC channel: Variable Resistor */
|
||||||
|
|
||||||
static const uint8_t g_chanlist[ADC_NCHANNELS] = {14};
|
#ifdef CONFIG_STM32_ADC1
|
||||||
|
static const uint8_t g_chanlist[ADC1_NCHANNELS] = {14};
|
||||||
|
|
||||||
/* Configurations of pins used byte each ADC channels */
|
/* Configurations of pins used byte each ADC channels */
|
||||||
|
|
||||||
static const uint32_t g_pinlist[ADC_NCHANNELS] = {GPIO_ADC1_IN14};
|
static const uint32_t g_pinlist[ADC1_NCHANNELS] = {GPIO_ADC1_IN14};
|
||||||
|
#endif
|
||||||
|
|
||||||
/************************************************************************************
|
/************************************************************************************
|
||||||
* Private Functions
|
* Private Functions
|
||||||
@ -99,31 +104,36 @@ static const uint32_t g_pinlist[ADC_NCHANNELS] = {GPIO_ADC1_IN14};
|
|||||||
************************************************************************************/
|
************************************************************************************/
|
||||||
|
|
||||||
/************************************************************************************
|
/************************************************************************************
|
||||||
* Name: stm32_boardinitialize
|
* Name: adc_devinit
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
* All STM32 architectures must provide the following entry point. This entry point
|
* All STM32 architectures must provide the following interface to work with
|
||||||
* is called early in the intitialization -- after all memory has been configured
|
* examples/adc.
|
||||||
* and mapped but before any devices have been initialized.
|
|
||||||
*
|
*
|
||||||
************************************************************************************/
|
************************************************************************************/
|
||||||
|
|
||||||
int adc_devinit(void)
|
int adc_devinit(void)
|
||||||
{
|
{
|
||||||
|
#ifdef CONFIG_STM32_ADC1
|
||||||
|
static bool initialized = false;
|
||||||
struct adc_dev_s *adc;
|
struct adc_dev_s *adc;
|
||||||
int ret;
|
int ret;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
/* Check if we have already initialized */
|
||||||
|
|
||||||
|
if (!initialized)
|
||||||
|
{
|
||||||
/* Configure the pins as analog inputs for the selected channels */
|
/* Configure the pins as analog inputs for the selected channels */
|
||||||
|
|
||||||
for(i = 0; i < ADC_NCHANNELS; i++)
|
for (i = 0; i < ADC1_NCHANNELS; i++)
|
||||||
{
|
{
|
||||||
stm32_configgpio(g_pinlist[i]);
|
stm32_configgpio(g_pinlist[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Call stm32_adcinitialize() to get an instance of the ADC interface */
|
/* Call stm32_adcinitialize() to get an instance of the ADC interface */
|
||||||
|
|
||||||
adc = stm32_adcinitialize(1, g_chanlist, ADC_NCHANNELS);
|
adc = stm32_adcinitialize(1, g_chanlist, ADC1_NCHANNELS);
|
||||||
if (adc == NULL)
|
if (adc == NULL)
|
||||||
{
|
{
|
||||||
adbg("ERROR: Failed to get ADC interface\n");
|
adbg("ERROR: Failed to get ADC interface\n");
|
||||||
@ -136,10 +146,19 @@ int adc_devinit(void)
|
|||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
{
|
{
|
||||||
adbg("adc_register failed: %d\n", ret);
|
adbg("adc_register failed: %d\n", ret);
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
/* Now we are initialized */
|
||||||
|
|
||||||
|
initialized = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return OK;
|
||||||
|
#else
|
||||||
|
return -ENOSYS;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* CONFIG_STM32_ADC || CONFIG_STM32_ADC2 || CONFIG_STM32_ADC3 */
|
#endif /* CONFIG_STM32_ADC1 || CONFIG_STM32_ADC2 || CONFIG_STM32_ADC3 */
|
||||||
#endif /* CONFIG_ADC */
|
#endif /* CONFIG_ADC */
|
@ -590,9 +590,49 @@ Where <subdir> is one of the following:
|
|||||||
CONFIG_NSH_IPADDR=(10<<24|0<<16|0<<8|2) : Target IP address 10.0.0.2
|
CONFIG_NSH_IPADDR=(10<<24|0<<16|0<<8|2) : Target IP address 10.0.0.2
|
||||||
CONFIG_NSH_DRIPADDR=(10<<24|0<<16|0<<8|1) : Host IP address 10.0.0.1
|
CONFIG_NSH_DRIPADDR=(10<<24|0<<16|0<<8|1) : Host IP address 10.0.0.1
|
||||||
|
|
||||||
NOTE: This example assumes that a network is connected. During its
|
NOTES:
|
||||||
|
1. This example assumes that a network is connected. During its
|
||||||
initialization, it will try to negotiate the link speed. If you have
|
initialization, it will try to negotiate the link speed. If you have
|
||||||
no network connected when you reset the board, there will be a long
|
no network connected when you reset the board, there will be a long
|
||||||
delay (maybe 30 seconds?) before anything happens. That is the timeout
|
delay (maybe 30 seconds?) before anything happens. That is the timeout
|
||||||
before the networking finally gives up and decides that no network is
|
before the networking finally gives up and decides that no network is
|
||||||
available.
|
available.
|
||||||
|
|
||||||
|
2. This example supports the ADC test (apps/examples/adc) but this must
|
||||||
|
be manually enabled by selecting:
|
||||||
|
|
||||||
|
CONFIG_ADC=y : Enable the generic ADC infrastructure
|
||||||
|
CONFIG_STM32_ADC3=y : Enable ADC3
|
||||||
|
CONFIG_STM32_TIM1_ADC3=y : Assign timer 1 to driver ADC3 sampling
|
||||||
|
|
||||||
|
See also apps/examples/README.txt
|
||||||
|
|
||||||
|
General debug for analog devices (ADC/DAC):
|
||||||
|
|
||||||
|
CONFIG_DEBUG_ANALOG
|
||||||
|
|
||||||
|
3. This example supports the PWM test (apps/examples/pwm) but this must
|
||||||
|
be manually enabled by selecting:
|
||||||
|
|
||||||
|
CONFIG_PWM=y : Enable the generic PWM infrastructure
|
||||||
|
CONFIG_STM32_TIM4_PWM=y : Use TIM4 to generate PWM output
|
||||||
|
|
||||||
|
See also apps/examples/README.txt
|
||||||
|
|
||||||
|
Special PWM-only debug options:
|
||||||
|
|
||||||
|
CONFIG_DEBUG_PWM
|
||||||
|
|
||||||
|
4. This example supports the CAN loopback test (apps/examples/can) but this
|
||||||
|
must be manually enabled by selecting:
|
||||||
|
|
||||||
|
CONFIG_CAN=y : Enable the generic CAN infrastructure
|
||||||
|
CONFIG_STM32_CAN1=y : Enable CAN1
|
||||||
|
CONFIG_CAN_LOOPBACK=y : Enable CAN loopback mode
|
||||||
|
|
||||||
|
See also apps/examples/README.txt
|
||||||
|
|
||||||
|
Special CAN-only debug options:
|
||||||
|
|
||||||
|
CONFIG_DEBUG_CAN
|
||||||
|
CONFIG_CAN_REGDEBUG
|
||||||
|
@ -50,6 +50,10 @@ CONFIGURED_APPS += netutils/webclient
|
|||||||
CONFIGURED_APPS += netutils/tftpc
|
CONFIGURED_APPS += netutils/tftpc
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifeq ($(CONFIG_ADC),y)
|
||||||
|
CONFIGURED_APPS += examples/adc
|
||||||
|
endif
|
||||||
|
|
||||||
ifeq ($(CONFIG_PWM),y)
|
ifeq ($(CONFIG_PWM),y)
|
||||||
CONFIGURED_APPS += examples/pwm
|
CONFIGURED_APPS += examples/pwm
|
||||||
endif
|
endif
|
||||||
|
@ -323,6 +323,15 @@ CONFIG_STM32_PHYSR_FULLDUPLEX=0x0004
|
|||||||
CONFIG_STM32_ETH_PTP=n
|
CONFIG_STM32_ETH_PTP=n
|
||||||
CONFIG_STM32_ETHMAC_REGDEBUG=n
|
CONFIG_STM32_ETHMAC_REGDEBUG=n
|
||||||
|
|
||||||
|
#
|
||||||
|
# ADC configuration
|
||||||
|
#
|
||||||
|
# Enable ADC driver support. The STM3240G-EVAL has a 10 Kohm potentiometer
|
||||||
|
# RV1 connected to PF9 of STM32F407IGH6 on the board: TIM14_CH1/ SMC_CD/ADC3_IN7
|
||||||
|
#
|
||||||
|
CONFIG_ADC=n
|
||||||
|
CONFIG_STM32_TIM1_ADC3=y
|
||||||
|
|
||||||
#
|
#
|
||||||
# PWM configuration
|
# PWM configuration
|
||||||
#
|
#
|
||||||
@ -459,6 +468,9 @@ CONFIG_DEBUG_LCD=n
|
|||||||
CONFIG_DEBUG_USB=n
|
CONFIG_DEBUG_USB=n
|
||||||
CONFIG_DEBUG_NET=n
|
CONFIG_DEBUG_NET=n
|
||||||
CONFIG_DEBUG_RTC=n
|
CONFIG_DEBUG_RTC=n
|
||||||
|
CONFIG_DEBUG_ANALOG=n
|
||||||
|
CONFIG_DEBUG_PWM=n
|
||||||
|
CONFIG_DEBUG_CAN=n
|
||||||
CONFIG_HAVE_CXX=y
|
CONFIG_HAVE_CXX=y
|
||||||
CONFIG_MM_REGIONS=2
|
CONFIG_MM_REGIONS=2
|
||||||
CONFIG_ARCH_LOWPUTC=y
|
CONFIG_ARCH_LOWPUTC=y
|
||||||
@ -1203,6 +1215,53 @@ CONFIG_EXAMPLES_USBSERIAL_TRACETRANSFERS=n
|
|||||||
CONFIG_EXAMPLES_USBSERIAL_TRACECONTROLLER=n
|
CONFIG_EXAMPLES_USBSERIAL_TRACECONTROLLER=n
|
||||||
CONFIG_EXAMPLES_USBSERIAL_TRACEINTERRUPTS=n
|
CONFIG_EXAMPLES_USBSERIAL_TRACEINTERRUPTS=n
|
||||||
|
|
||||||
|
#
|
||||||
|
# Settings for examples/adc
|
||||||
|
#
|
||||||
|
# CONFIG_ADC - Enabled ADC support
|
||||||
|
# CONFIG_NSH_BUILTIN_APPS - Build the ADC test as an NSH built-in function.
|
||||||
|
# Default: Built as a standalone problem
|
||||||
|
#
|
||||||
|
# CONFIG_EXAMPLES_ADC_DEVPATH - The path to the ADC device. Default: /dev/adc0
|
||||||
|
# CONFIG_EXAMPLES_ADC_NSAMPLES - If CONFIG_NSH_BUILTIN_APPS
|
||||||
|
# is defined, then the number of samples is provided on the command line
|
||||||
|
# and this value is ignored. Otherwise, this number of samples is
|
||||||
|
# collected and the program terminates. Default: Samples are collected
|
||||||
|
# indefinitely.
|
||||||
|
# CONFIG_EXAMPLES_ADC_GROUPSIZE - The number of samples to read at once.
|
||||||
|
# Default: 4
|
||||||
|
|
||||||
|
#
|
||||||
|
# Settings for examples/can
|
||||||
|
#
|
||||||
|
# CONFIG_CAN - Enables CAN support.
|
||||||
|
# CONFIG_CAN_LOOPBACK - A CAN driver may or may not support a loopback
|
||||||
|
# mode for testing. The STM32 CAN driver does support loopback mode.
|
||||||
|
# CONFIG_NSH_BUILTIN_APPS - Build the CAN test as an NSH built-in function.
|
||||||
|
# Default: Built as a standalone problem
|
||||||
|
#
|
||||||
|
# CONFIG_EXAMPLES_CAN_DEVPATH - The path to the CAN device. Default: /dev/can0
|
||||||
|
# CONFIG_EXAMPLES_CAN_NMSGS - If CONFIG_NSH_BUILTIN_APPS
|
||||||
|
# is defined, then the number of loops is provided on the command line
|
||||||
|
# and this value is ignored. Otherwise, this number of CAN message is
|
||||||
|
# collected and the program terminates. Default: If built as an NSH
|
||||||
|
# built-in, the default is 32. Otherwise messages are sent and received
|
||||||
|
# indefinitely.
|
||||||
|
|
||||||
|
#
|
||||||
|
# Settings for examples/pwm
|
||||||
|
#
|
||||||
|
# CONFIG_PWM - Enables PWM support.
|
||||||
|
# CONFIG_NSH_BUILTIN_APPS - Build the PWM test as an NSH built-in function.
|
||||||
|
# Default: Not built! The example can only be used as an NSH built-in
|
||||||
|
# application
|
||||||
|
#
|
||||||
|
# CONFIG_EXAMPLES_PWM_DEVPATH - The path to the PWM device. Default: /dev/pwm0
|
||||||
|
# CONFIG_EXAMPLES_PWM_FREQUENCY - The initial PWM frequency. Default: 100 Hz
|
||||||
|
# CONFIG_EXAMPLES_PWM_DUTYPCT - The initial PWM duty as a percentage. Default: 50%
|
||||||
|
# CONFIG_EXAMPLES_PWM_DURATION - The initial PWM pulse train duration in sectonds.
|
||||||
|
# as a percentage. Default: 5 seconds
|
||||||
|
|
||||||
#
|
#
|
||||||
# Stack and heap information
|
# Stack and heap information
|
||||||
#
|
#
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* configs/stm3240g-eval/src/up_adc.c
|
* configs/stm3240g-eval/src/up_adc.c
|
||||||
* arch/arm/src/board/up_adc.c
|
* arch/arm/src/board/up_adc.c
|
||||||
*
|
*
|
||||||
* Copyright (C) 2011 Gregory Nutt. All rights reserved.
|
* Copyright (C) 2011-2012 Gregory Nutt. All rights reserved.
|
||||||
* Author: Gregory Nutt <gnutt@nuttx.org>
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
@ -73,6 +73,30 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_STM32_ADC1) || defined(CONFIG_STM32_ADC2) || defined(CONFIG_STM32_ADC3)
|
#if defined(CONFIG_STM32_ADC1) || defined(CONFIG_STM32_ADC2) || defined(CONFIG_STM32_ADC3)
|
||||||
|
#ifndef CONFIG_STM32_ADC3
|
||||||
|
# warning "Channel information only available for ADC3"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* The number of ADC channels in the conversion list */
|
||||||
|
|
||||||
|
#define ADC3_NCHANNELS 1
|
||||||
|
|
||||||
|
/************************************************************************************
|
||||||
|
* Private Data
|
||||||
|
************************************************************************************/
|
||||||
|
/* The STM3240G-EVAL has a 10 Kohm potentiometer RV1 connected to PF9 of
|
||||||
|
* STM32F407IGH6 on the board: TIM14_CH1/FSMC_CD/ADC3_IN7
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Identifying number of each ADC channel: Variable Resistor. */
|
||||||
|
|
||||||
|
#ifdef CONFIG_STM32_ADC3
|
||||||
|
static const uint8_t g_chanlist[ADC3_NCHANNELS] = {7};
|
||||||
|
|
||||||
|
/* Configurations of pins used byte each ADC channels */
|
||||||
|
|
||||||
|
static const uint32_t g_pinlist[ADC3_NCHANNELS] = {GPIO_ADC3_IN7};
|
||||||
|
#endif
|
||||||
|
|
||||||
/************************************************************************************
|
/************************************************************************************
|
||||||
* Private Functions
|
* Private Functions
|
||||||
@ -93,19 +117,31 @@
|
|||||||
|
|
||||||
int adc_devinit(void)
|
int adc_devinit(void)
|
||||||
{
|
{
|
||||||
|
#ifdef CONFIG_STM32_ADC3
|
||||||
static bool initialized = false;
|
static bool initialized = false;
|
||||||
struct adc_dev_s *adc;
|
struct adc_dev_s *adc;
|
||||||
int ret;
|
int ret;
|
||||||
|
int i;
|
||||||
|
|
||||||
/* Check if we have already initialized */
|
/* Check if we have already initialized */
|
||||||
|
|
||||||
if (!initialized)
|
if (!initialized)
|
||||||
{
|
{
|
||||||
/* Configure the pins as analog inputs for the selected channels */
|
/* Configure the pins as analog inputs for the selected channels */
|
||||||
#warning "Missing Logic"
|
|
||||||
|
for (i = 0; i < ADC3_NCHANNELS; i++)
|
||||||
|
{
|
||||||
|
stm32_configgpio(g_pinlist[i]);
|
||||||
|
}
|
||||||
|
|
||||||
/* Call stm32_adcinitialize() to get an instance of the ADC interface */
|
/* Call stm32_adcinitialize() to get an instance of the ADC interface */
|
||||||
#warning "Missing Logic"
|
|
||||||
|
adc = stm32_adcinitialize(1, g_chanlist, ADC3_NCHANNELS);
|
||||||
|
if (adc == NULL)
|
||||||
|
{
|
||||||
|
adbg("ERROR: Failed to get ADC interface\n");
|
||||||
|
return -ENODEV;
|
||||||
|
}
|
||||||
|
|
||||||
/* Register the ADC driver at "/dev/adc0" */
|
/* Register the ADC driver at "/dev/adc0" */
|
||||||
|
|
||||||
@ -122,7 +158,10 @@ int adc_devinit(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
return OK;
|
return OK;
|
||||||
|
#else
|
||||||
|
return -ENOSYS;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* CONFIG_STM32_ADC || CONFIG_STM32_ADC2 || CONFIG_STM32_ADC3 */
|
#endif /* CONFIG_STM32_ADC1 || CONFIG_STM32_ADC2 || CONFIG_STM32_ADC3 */
|
||||||
#endif /* CONFIG_ADC */
|
#endif /* CONFIG_ADC */
|
Loading…
Reference in New Issue
Block a user