航顺HK32F030MF4P6开发脱坑小记

8 篇文章 7 订阅
1 篇文章 0 订阅

航顺HK32F030MF4P6开发脱坑记

1.SWCLK和SDWIO复用

1.1复用成IO,需要使用IOMUX寄存器

如将PB5(SDWIO)复用成输入IO口

GPIO_InitTypeDef m_gpio;
RCC_APB1PeriphClockCmd(RCC_APB1Periph_IOMUX,ENABLE); //复用io口的时钟使能
RCC_AHBPeriphClockCmd(RCC_AHBPeriph_GPIOB, ENABLE);

m_gpio.GPIO_Mode = GPIO_Mode_IN;
m_gpio.GPIO_Pin = GPIO_Pin_5;
m_gpio.GPIO_PuPd = GPIO_PuPd_UP;
m_gpio.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_IOMUX_ChangePin(IOMUX_PIN11,IOMUX_PB5_SEL_PB5); 					
GPIO_Init(GPIOB, &m_gpio);

如果将PB5(SDWIO)复用成输出IO

GPIO_InitTypeDef m_gpio;
RCC_APB1PeriphClockCmd(RCC_APB1Periph_IOMUX,ENABLE); //复用io口的时钟使能
RCC_AHBPeriphClockCmd(RCC_AHBPeriph_GPIOB, ENABLE);

m_gpio.GPIO_Mode = GPIO_Mode_OUT;
m_gpio.GPIO_OType = GPIO_OType_PP;
m_gpio.GPIO_Pin = GPIO_Pin_5;
m_gpio.GPIO_PuPd = GPIO_PuPd_UP;
m_gpio.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_IOMUX_ChangePin(IOMUX_PIN11,IOMUX_PB5_SEL_PB5); 
GPIO_Init(GPIOB, &m_gpio);

注意1:不同pin数的芯片的其复用开关有差别,这里20脚的用IOMUX_PIN11,一定要查手册,另外宏定义一定要用选用的芯片,例程中的和选用的可能不一样。
在这里插入图片描述
注意2:作为输入IO,不要使用库里的uint8_t GPIO_ReadOutputDataBit(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin)函数,而要使用uint8_t GPIO_ReadInputDataBit(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin),两者有差别。英文含义也能判断。

1.2 复用成AD

如将SWDIO复用成AD0,要是用AF,作为多功能选择。不需要配置IOMUX寄存器, 代码如下

static void ADC0_PortInit(void)
{
  GPIO_InitTypeDef GPIO_InitStructure;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AN;
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5;
  GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
  GPIO_Init(GPIOD, &GPIO_InitStructure);
  GPIO_PinAFConfig(GPIOD,GPIO_PinSource5,GPIO_AF_7);
}

2.定时器

定时器选用TIM1和TIM2,使用基本定时器功能时,方法和stm32的类似。TIM_Period为计数周期(次数),TIM_Prescaler为时钟源的分频数。如果时钟源为32M,分频数为32000-1,那么给定时器提供的时钟为:32M/32000=1000Hz(1ms)。 如果计数100次,也就是100ms。

void Timer1_Init(void)
{
	TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;
	NVIC_InitTypeDef NVIC_InitStructure;
	uint16_t PrescalerValue = 0;
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_TIM1, ENABLE);
  /* Compute the prescaler value */
  PrescalerValue = (uint16_t) ((SystemCoreClock ) / 32000000) - 1;//配置频率为32M

  /* Time base configuration */
  TIM_TimeBaseStructure.TIM_Period = 100-1; //对于1kHZ(32M/32000)的时钟源,计数100次,则为100毫秒中断一次
  TIM_TimeBaseStructure.TIM_Prescaler = 32000-1;    //100ms中断一次
  TIM_TimeBaseStructure.TIM_ClockDivision = 0;
  TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;

  TIM_TimeBaseInit(TIM1, &TIM_TimeBaseStructure);

  /* TIM Interrupts enable */
  TIM_ITConfig(TIM1, TIM_IT_Update, ENABLE);

  /* TIM3 enable counter */
  TIM_Cmd(TIM1, ENABLE);

  /* Enable the TIM2 gloabal Interrupt */
  NVIC_InitStructure.NVIC_IRQChannel = TIM1_UP_TRG_COM_IRQn;
  NVIC_InitStructure.NVIC_IRQChannelPriority = 1;
  NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  NVIC_Init(&NVIC_InitStructure);
    
}

另外要注意:中断服务函数是void TIM2_IRQHandler(void),不是随便小写的,这里直接拷贝别处的,导致没反应。

  • 0
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
HK32F030MF4P6是一款STM32系列的微控制器,您可以按照以下步骤来使用它: 1. 硬件连接:将HK32F030MF4P6与其他外围设备(例如传感器、显示屏等)进行连接。请参考HK32F030MF4P6的硬件手册或者开发板的原理图来了解正确的连接方式。 2. 开发环境搭建:安装ST公司提供的开发环境,例如STM32CubeIDE或者Keil MDK。这些开发环境可以帮助您编写、编译和调试代码。 3. 编写代码:使用C语言或者汇编语言编写代码来控制HK32F030MF4P6的功能。您可以使用ST提供的库函数来简化开发过程,例如GPIO库、UART库等。 4. 编译和烧录:使用开发环境将代码编译成可执行文件,并将该文件烧录到HK32F030MF4P6的闪存中。确保使用正确的编译选项和连接器脚本。 5. 调试和测试:使用开发环境提供的调试工具,例如调试器和仿真器,来调试和测试您的代码。您可以设置断点、单步执行代码,并观察变量的值来检查代码的正确性。 6. 部署和运行:将烧录好的代码通过USB或者其他接口连接到目标设备上,并进行测试和运行。确保您的代码可以正确地控制外围设备,并满足您的需求。 请注意,以上是一个基本的使用流程,具体的步骤和细节可能会因您的具体需求和应用场景而有所不同。建议您参考HK32F030MF4P6的技术文档和示例代码,以及ST的官方支持论坛,获取更多的帮助和资源。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值