- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试从三个不同的 channel 读取 ADC 值(现在,稍后将是 6 个 channel ,每个 ADC 上 3 个),我想在随机时间后访问我的 ADC 缓冲区并使用UART稍后。现在它们只是连接到 +3.3V,中间有一个三分电位器,导致所有三个引脚上的电压不同,这意味着我应该能够经常读取 ADC?无论如何,为此,我使用的是 STM32f303k8 板,我在其中设置了要使用的 ADC1 channel 2,4 和 11。我使用 STM32CubeMX 生成代码,使用 HAL 库,我将其配置为在循环模式下使用 DMA,扫描转换连续转换和不同等级。启动时(使用断点),我可以看到代码的初始化部分工作正常。 ADC 已初始化且 DMA 已启动,我什至从 ADC1 中获取值到我的缓冲区中,值正确,channel1 != channel2 != channel3。问题是在继续时,进程陷入无限循环处理程序并且永远不会到达我的 while(1) 那里我有一些任意语句。代码如下。
我一直在遵循不同的指南,看看我是否设置有误。其中之一是 https://tunizem.blogspot.com/2014/09/using-adc-with-dma-on-stm32.html?showComment=1562660027777#c1229743050555367742 .我尝试将采样时间从 1.5 一直更改为 601.5 个周期,还尝试将 EOCSelection 从单个更改为顺序。
ADC_HandleTypeDef hadc1;
DMA_HandleTypeDef hdma_adc1;
void MX_DMA_Init(void)
{
/* DMA controller clock enable */
__HAL_RCC_DMA1_CLK_ENABLE();
/* DMA interrupt init */
/* DMA1_Channel1_IRQn interrupt configuration */
HAL_NVIC_SetPriority(DMA1_Channel1_IRQn, 0, 0);
HAL_NVIC_EnableIRQ(DMA1_Channel1_IRQn);
}
/* ADC1 init function */
void MX_ADC1_Init(void)
{
ADC_MultiModeTypeDef multimode = {0};
ADC_ChannelConfTypeDef sConfig = {0};
/** Common config
*/
hadc1.Instance = ADC1;
hadc1.Init.ClockPrescaler = ADC_CLOCK_SYNC_PCLK_DIV4;
hadc1.Init.Resolution = ADC_RESOLUTION_12B;
hadc1.Init.ScanConvMode = ADC_SCAN_ENABLE;
hadc1.Init.ContinuousConvMode = ENABLE;
hadc1.Init.DiscontinuousConvMode = DISABLE;
hadc1.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE;
hadc1.Init.ExternalTrigConv = ADC_SOFTWARE_START;
hadc1.Init.DataAlign = ADC_DATAALIGN_RIGHT;
hadc1.Init.NbrOfConversion = 3;
hadc1.Init.DMAContinuousRequests = ENABLE;//ENABLE;
hadc1.Init.EOCSelection = ADC_EOC_SINGLE_CONV;
hadc1.Init.LowPowerAutoWait = DISABLE;
hadc1.Init.Overrun = ADC_OVR_DATA_PRESERVED;//OVERWRITTEN;
if (HAL_ADC_Init(&hadc1) != HAL_OK)
{
Error_Handler();
}
/** Configure the ADC multi-mode
*/
multimode.Mode = ADC_MODE_INDEPENDENT;
if (HAL_ADCEx_MultiModeConfigChannel(&hadc1, &multimode) != HAL_OK)
{
Error_Handler();
}
/** Configure Regular Channel
*/
sConfig.Channel = ADC_CHANNEL_2;
sConfig.Rank = ADC_REGULAR_RANK_1;
sConfig.SingleDiff = ADC_SINGLE_ENDED;
sConfig.SamplingTime = ADC_SAMPLETIME_61CYCLES_5;
sConfig.OffsetNumber = ADC_OFFSET_NONE;
sConfig.Offset = 0;
if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
{
Error_Handler();
}
/** Configure Regular Channel
*/
sConfig.Channel = ADC_CHANNEL_4;
sConfig.Rank = ADC_REGULAR_RANK_2;
if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
{
Error_Handler();
}
/** Configure Regular Channel
*/
sConfig.Channel = ADC_CHANNEL_11;
sConfig.Rank = ADC_REGULAR_RANK_3;
if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
{
Error_Handler();
}
}
*
*
*
uint32_t adcValue1[60];
int main(void)
{
/* MCU Configuration-----------------------------------------------*/
/* Reset of all peripherals, Initializes the Flash interface and the
Systick. */
HAL_Init();
/* Configure the system clock */
SystemClock_Config();
/* Initialize all configured peripherals */
MX_GPIO_Init();
MX_DMA_Init();
MX_ADC1_Init();
//MX_ADC2_Init();
MX_I2C1_Init();
MX_USART1_UART_Init();
MX_USART2_UART_Init();
//Start ADC writing to DMA on scan complete
if(HAL_ADC_Start_DMA(&hadc1, (uint32_t*)adcValue1, 120) != HAL_OK)
return 0;
uint32_t stopwatch = HAL_GetTick();
/* Infinite loop */
/* USER CODE BEGIN WHILE */
while(1)
{
if(((uint32_t)HAL_GetTick() - stopwatch) > 49)
{
stopwatch = HAL_GetTick();
HAL_GPIO_TogglePin(GPIOB, GPIO_PIN_3);
sprintf((char*)buffer, "(%d)\t ADC1, (%d)\t ADC2, (%d)\t ADC3",
adcValue1[0],
adcValue1[1], adcValue1[2]);
}
}
/* USER CODE END 3 */
}
}
我在“uint32_t stopwatch = HAL_GetTick();”处设置了一个断点我可以看到 adcValue1 正在读取值。这些是正确的,因为所有三个电压都为 3.3V,不同之处在于电位器设置为在 channel 2 处输出 2.2V,即它低于其他两个。但这是我唯一一次可以看到正在阅读,因为在此之后它陷入了无限循环。
enter code here
adcValue1 uint32_t [60] 0x20000220 <adcValue1>
adcValue1[0] uint32_t 2614
adcValue1[1] uint32_t 3638
adcValue1[2] uint32_t 3639
adcValue1[3] uint32_t 2612
adcValue1[4] uint32_t 3639
adcValue1[5] uint32_t 3637
adcValue1[6] uint32_t 2615
adcValue1[7] uint32_t 3642
adcValue1[8] uint32_t 3641
adcValue1[9] uint32_t 2616
adcValue1[10] uint32_t 3642
adcValue1[11] uint32_t 3638
adcValue1[12] uint32_t 2611
adcValue1[13] uint32_t 3637
adcValue1[14] uint32_t 3640
adcValue1[15] uint32_t 2614
adcValue1[16] uint32_t 3639
adcValue1[17] uint32_t 3639
adcValue1[18] uint32_t 2615
adcValue1[19] uint32_t 3643
* @brief This is the code that gets called when the processor receives
an
* unexpected interrupt. This simply enters an infinite loop,
preserving
* the system state for examination by a debugger.
*
* @param None
* @retval : None
*/
Default_Handler:
Infinite_Loop: <--- STUCK HERE
b Infinite_Loop
.size Default_Handler, .-Default_Handler
最佳答案
Default_Handler
在用户代码中没有处理程序的中断时被调用。当您不为该中断提供处理程序时,中断 vector 表中的所有地址都指向此代码。
您可以检查 SCB->ICSR
中的 VECTACTIVE
位(参见 STM32F4 programming manual)以找出缺少哪个中断 vector ,然后在中提供适当的处理程序你的代码。
关于c - STM32F404K8 : HAL, ADC+DMA 第一次读取后卡住,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56948949/
我将 ADC 与 DMA(STM32F4,ide STM32CubeIDE)一起使用,我认为我了解它是如何工作的,但仍然有一个难题。根据我的理解,MCU 仅在 DMA 传输完成时调用,基本上 MCU
我正在开展一个项目,其中涉及 STM32H743 核板和 16 个 ADC 输入的使用。 显然,这些模拟输入一次使用一次;通过轮询机制读取值并配置下一个输入...配置 ADC channel ,启动
1 指令语法 adc <Xd>, <Xn>, <Xm> 2 指令语义 adc就是带「进位」加法,指令中的c就是英文carry。 整个指令等价于: (Xd
ATtiny88初体验(五):ADC ADC模块介绍 ATtiny88单片机包含一个10bit分辨率的ADC模块,拥有8个通道,最大采样率15kSPS,转换时间14us。ATtiny88的
我正在尝试在 STM32L476 Nucleo 板上调出一个 ADC。我想我已经配置好了,但我一定是漏掉了一步。我知道这可以使用 HAL API 和 CubeMX 来完成,但我更喜欢在启动新板时进行寄
mov eax, ptr_to_num1 ; little endian mov ebx, ptr_to_num2 ; little endian xor ecx, ecx xor edx, edx
.MODEL SMALL .STACK 1000 .DATA MSGA DB 13,10,"Input first number: ","$" MSGB DB 13,10,"Input second
我目前正在对 PIC 微 Controller 进行编程。 当按照我的方式创建结构时,每次我尝试访问该结构的变量的地址是否都会更改? 还是像静态变量一样,意味着地址在编译时确定,并且在整个程序中不会更
大家好,我正在开发一个项目,我必须计算 ADC 读数的移动平均值。从 ADC 输出的数据代表正弦波。 这是我用来获取给定信号的移动平均值的代码。 longNew = (8 bit data from
我希望在每次转换结束后调用 ADC 中断服务程序。但是它没有被调用。 这是我的代码: #define RCC_APB2ENR (*((volatile unsigned long*) 0x4002
有人可以看看我的代码吗?当我旋转电位器时,我试图让 8 个 LED 旋转,但四个 LED 一直保持亮着,根本不旋转。 #include /******************************
目的是将最新的 10 个 ADC 读数存储在一个数组中,然后计算它们的平均值以供其他地方使用。每次更新时删除最旧的。 关于 LED 时序,如果 ADC 读数在下面写的边界内,它必须将时序从 1s 切换
我正在尝试将音频ADC(wm8782 / pcm1803a)与Beagle Black连接。我已经对文件 davinci-evm , wm8782.c 和BB-BONE-AUDI-01设备树覆盖文件进
我正在尝试在简单的连续转换模式下通过 STM32F411RE 配置 ADC。我使用 CubeMX 生成基于 HAL 驱动程序的代码,这是生成的代码中初始化 ADC 的部分内容: /* ADC1 ini
我只是对我用 C 编写的反汇编 32 位程序进行一些分析。以下是反汇编程序输出的一部分: 41153c 02 00 add al, [eax] 41153e 00 00 add [eax]
我一直在运行Blarggs CPU tests通过我的 Gameboy 模拟器,op r,r 测试表明我的 ADC 指令工作不正常,但 ADD 是。我的理解是两者之间的唯一区别是在添加之前将现有的进位
我正在使用Renesas RX62N ;我的屏幕使用 ADC 单元 1,我的代码使用单元 0。 难道两个ADC单元不能一起工作吗?当我分别运行“ADC”和“显示代码”时,它工作正常,但一旦我尝试将它们
描述很长,抱歉。我用粗体突出显示了问题。 我目前正在尝试建立一个 driverlib 机制来执行以下操作: 大约每 20 个 RTC 预分频器 1 事件,检查是否应进行 ADC 测量。 如果需要,请设
我正在努力让 ADC 与我的设备配合使用。我正在使用 dsPIC33FJ128GP802,并尝试通过手动采样和转换缓慢启动。 我的代码发布在下面,我已经设置了 ADC 的每个寄存器,然后尝试仅采样一次
我的板上有一个 adc 模块。我在信号发生器上创建了一个正弦波。我将这个发生器的输出提供给一个 adc 引脚。最后我定期读取这个引脚的值。我尝试在我的软件上创建一个正弦波。 x = t, y = As
我是一名优秀的程序员,十分优秀!