DMA : Timer Trigger Memory-to-memory mode,

The DMA channels can also work without being triggered by a request from a peripheral.

This mode is called Memory to Memory mode.

If the MEM2MEM bit in the DMA_CCRx register is set, then the channel initiates transfers

as soon as it is enabled by software by setting the Enable bit (EN) in the DMA_CCRx register."

// STM32 TIM2 DMA Mem-to-Mem pacing VLDiscovery - sourcer32@gmail.com
 
#include "STM32vldiscovery.h"
 
#define OUTLENGTH 5
 
volatile u16 InBuffer[OUTLENGTH], OutBuffer[OUTLENGTH];
 
/**************************************************************************************/
 
void RCC_Configuration(void)
{
    // clock for DMA
    RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);
 
    // clock for TIM2
    RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);
}
 
/**************************************************************************************/
 
void NVIC_Configuration(void)
{
    NVIC_InitTypeDef NVIC_InitStructure;
 
    NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);
 
  NVIC_InitStructure.NVIC_IRQChannel = DMA1_Channel2_IRQn;
  NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;
  NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;
  NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  NVIC_Init(&NVIC_InitStructure);
}
 
/******************************************************************************/
 
void DMA1_Channel2_IRQHandler(void) // Called at 10 Hz
{
  if (DMA_GetITStatus(DMA1_IT_TC2))
  {
    DMA_ClearITPendingBit(DMA1_IT_TC2);
 
    STM32vldiscovery_LEDToggle(LED3); // Toggle 5 Hz
    STM32vldiscovery_LEDToggle(LED4);
 
    // Do something
  }
}
 
/**************************************************************************************/
 
void DMA_Configuration(void)
{
    DMA_InitTypeDef DMA_InitStructure;
 
    DMA_DeInit(DMA1_Channel2);
 
    DMA_InitStructure.DMA_PeripheralBaseAddr = (u32)&InBuffer[0]; // Source
    DMA_InitStructure.DMA_MemoryBaseAddr = (u32)&OutBuffer[0];  // Destination
    DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;
    DMA_InitStructure.DMA_BufferSize = OUTLENGTH;
    DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Enable;
    DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;
    DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord;
    DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord;
    DMA_InitStructure.DMA_Mode = DMA_Mode_Circular; // Repetitive, for my convenience
    DMA_InitStructure.DMA_Priority = DMA_Priority_High;
    DMA_InitStructure.DMA_M2M = DMA_M2M_Disable; // So we can pace via trigger
    DMA_Init(DMA1_Channel2, &DMA_InitStructure);
 
    /* Enable DMA1 Channel2 Transfer Complete interrupt */
    DMA_ITConfig(DMA1_Channel2, DMA_IT_TC, ENABLE);
 
    // turning DMA on (DMA1 Channel2 -> TIM2_UP)
    DMA_Cmd(DMA1_Channel2, ENABLE);
}
 
/**************************************************************************************/
 
void TIM2_Configuration(void)
{
    TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;
 
    TIM_TimeBaseStructure.TIM_Prescaler = (SystemCoreClock / 1000000) - 1;  // 1 MHz
    TIM_TimeBaseStructure.TIM_Period = 20000-1; // 1MHz/20000 = 50 Hz
    TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1;
    TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
    TIM_TimeBaseStructure.TIM_RepetitionCounter = 1;
    TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure);
 
    // "connecting" DMA and TIM2
    TIM_DMACmd(TIM2, TIM_DMA_Update, ENABLE);
 
    // turning on TIM2
    TIM_Cmd(TIM2, ENABLE);
}
 
/**************************************************************************************/
 
int main(void)
{
  /* Initialise LEDs LD3 & LD4 */
  STM32vldiscovery_LEDInit(LED3);
  STM32vldiscovery_LEDInit(LED4);
 
  STM32vldiscovery_LEDOn(LED3);
  STM32vldiscovery_LEDOff(LED4);
 
  RCC_Configuration();
 
  NVIC_Configuration();
 
  DMA_Configuration();
 
  TIM2_Configuration();
 
  while(1);
}

 

### 回答1: 这是一个编译错误,意思是在链接时找不到名为“-lboost::timer”的库。可能是因为您没有正确安装或配置Boost库。您需要检查您的编译环境和库路径,确保Boost库已正确安装并在正确的路径中。 ### 回答2: 这个错误表示链接器无法找到名为"libboost_timer"的库文件。这通常是由于缺少名为"libboost_timer"的库文件而导致的。 解决此问题的方法是安装正确版本的Boost库。Boost库是一个流行的开源C++库,用于增强C++语言功能。Boost库的许多模块(如Timer模块)已成为标准的C++库,并且可以在许多不同的平台上使用。 要解决此问题,请确定您已正确安装了Boost库。如果您没有安装Boost库,请从官方网站下载并安装正确版本的Boost库。一旦安装了Boost库,您需要确保您的编译和链接命令正确地引用库文件。 如果您已经安装了正确版本的Boost库,并且链接器仍然无法找到所需的库文件,请检查库文件的路径是否正确。您可以通过指定"-L"选项来设置库文件的搜索路径。例如,如果您的库文件位于"/usr/local/lib"目录中,您可以这样设置链接器选项: $ g++ main.o -L /usr/local/lib -lboost_timer -o myprogram 这将在"/usr/local/lib"目录中搜索"libboost_timer"库文件,并将其链接到您的程序中。 如果没有找到库文件或者库文件路径不正确,请检查您的库文件是否正确编译。您可以使用命令“nm”来检查库文件中是否存在所需的符号。例如,如果您正在寻找名为"boost::timer"的符号: $ nm -C /usr/local/lib/libboost_timer.so | grep "boost::timer" 这应该输出库文件中所有包含"boost::timer"字符串的符号。如果没有输出,则可能需要重新编译库文件,以确保它包含所需的符号。 综上所述,要解决"/usr/bin/ld:找不到-lboost::timer"错误,您需要确保安装了正确版本的Boost库,并正确设置库文件路径和链接器选项,以便找到所需的库文件。如果出现问题,请检查库文件是否正确编译,并使用命令"nm"来检查库文件中是否存在所需的符号。 ### 回答3: /usr/bin/ld: 找不到 -lboost::timer 是一个编译错误提示。这个错误通常意味着在编译时没有找到所需的库文件 libboost_timer.so 或 libboost_timer.a。因此,解决这个问题的方法就是确保安装了正确的库文件或者手动指定库文件路径。 首先,你需要检查你的系统上是否安装了 Boost 库。如果没有,你需要先安装。Boost 是一个用于 C++ 的开源库,提供了许多有用的功能,包括计时器、日期、时间、文件系统、字符串处理、数值计算等等。 如果你已经安装了 Boost,但仍然遇到这个错误。那么你需要检查是否安装了 boost-timer 包,在 Debian 或 Ubuntu 上,你可以运行以下命令来安装: sudo apt-get install libboost-timer-dev 如果你的系统没有提供 Boost 库的包,你可以从 Boost 官方网站下载并安装。下载地址:https://www.boost.org/,下载完成后解压缩,进入解压后的目录,执行以下命令: ./bootstrap.sh ./b2 这样就会编译并安装 Boost 库。 如果你已经安装了 Boost 库,并且检查过 boost-timer 包已经正确安装,但是仍然遇到找不到库文件的错误,那么可能是你的编译器找不到库文件的位置。在这种情况下,你需要手动指定库文件路径。可以使用以下命令来指定: g++ myapp.cpp -o myapp -L/path/to/lib -lboost_timer 其中 -L 选项用于指定库文件所在的路径,-l 选项表示链接库文件。在指定路径时需要将路径修改为实际路径。这样编译器就可以正确地找到库文件并编译了。 总之,找不到 -lboost::timer 错误通常是导致编译失败的原因之一,解决这个问题的方法就是检查 Boost 库是否安装正确并正确链接库文件。如果还有问题,可以通过查看编译器的输出信息来找到问题所在,并进行修复。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值