用Proteus8.9自带STM32F401VE的Controller仿真STM32F407ZGT6,F429IGT6

描述

 

一,目前得到的 Proteus8.9版本软件能够支持的Cortex-M4固件库项目,只能到达STM32F401VE (如下图1所示)。
C/C++ 

(图1)
作为ST公司Cortex-M4更为广泛应用的F407,F429系列芯片;现在的Proteus8.9版本软件还没有固件库支持,不能对F407,F429系列芯片进行仿真实验。
但STM32F401VE的固件库基于Cortex-M4,笔者就想利用Proteus8.9版本软件现有的STM32F401VE的固件库,对F407,F429系列芯片通过Proteus VSM Studio进行仿真实验应用。
首先生成STM32F401VE的固件库项目,选取STM32F401VE的芯片和其他组件(如下图2所示)。
 C/C++

(图2)
  接着搭建一个Timer—>PWM项目,即通过首先生成STM32F401VE的通用定时器Timer1生成三组不同频率的和不同占空比的方波实验(如下图3所示)。
C/C++ 
(图3)
用Proteus VSM Studio编写代码,编译,仿真。Main.c代码(如下图4,5所示)。
C/C++ 

(图4)
 C/C++

(图5)
其他led.c代码:
#include "led.h"
void LED_Init(void)
{        
       GPIO_InitTypeDef  GPIO_InitStructure;
       RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOB,ENABLE);//使能GPIOF时钟
       //GPIOF9,F10初始化设置
       GPIO_InitStructure.GPIO_Pin= GPIO_Pin_6| GPIO_Pin_12| GPIO_Pin_13;//LED对应引脚
       GPIO_InitStructure.GPIO_Mode= GPIO_Mode_OUT;//普通输出模式
       GPIO_InitStructure.GPIO_OType= GPIO_OType_PP;//推挽输出
       GPIO_InitStructure.GPIO_Speed= GPIO_Speed_100MHz;//100MHz
       GPIO_InitStructure.GPIO_PuPd= GPIO_PuPd_UP;//上拉
       GPIO_Init(GPIOA,&GPIO_InitStructure);//初始化
        LED0=1;
       GPIO_ResetBits(GPIOA,GPIO_Pin_12);
       GPIO_ResetBits(GPIOA,GPIO_Pin_13);
}
Led.h代码:
#ifndef __LED_H
#define __LED_H
#include "sys.h"
//LED端口定义
#define LED0 PAout(6) // DS0
//#define LED1 PBout(8)      //DS1
void LED_Init(void);//初始化                                           
#endif
Key.c代码:
#include "key.h"
#include "delay.h"
void KEY_Init(void)
{
       GPIO_InitTypeDef  GPIO_InitStructure;
       RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOB,ENABLE);//使能GPIOA,GPIOE时钟
       GPIO_InitStructure.GPIO_Pin= GPIO_Pin_14| GPIO_Pin_15; //KEY0 对应引脚
       GPIO_InitStructure.GPIO_Mode= GPIO_Mode_IN;//普通输入模式
       GPIO_InitStructure.GPIO_Speed= GPIO_Speed_100MHz;//100M
       GPIO_InitStructure.GPIO_PuPd= GPIO_PuPd_DOWN ;//下拉
       GPIO_Init(GPIOA,&GPIO_InitStructure);//初始化GPIOE4
}
key.h代码:
#ifndef __KEY_H
#define __KEY_H  
#include "sys.h"
#define KEY0              PAin(14)      //PA14
#define KEY1              PAin(15)      //PA15
void KEY_Init(void);    //IO初始化
#endif
timer.c代码:
#include "timer.h"
#include "led.h"
#include "usart.h"
extern u8 ov_frame;
extern volatile u16 jpeg_data_len;
void TIM1_Mode_Config(void)
{     
     TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;
     TIM_OCInitTypeDef TIM_OCInitStructure; 
     u16 CCR1_Val =700;
     
    TIM_TimeBaseStructure.TIM_Period = 2800;
    TIM_TimeBaseStructure.TIM_Prescaler = 0;
    TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1 ;
    TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
    TIM_TimeBaseInit(TIM1, &TIM_TimeBaseStructure); 
     
    TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1;
    TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
     
    TIM_OCInitStructure.TIM_OutputNState = TIM_OutputNState_Enable;
        //TIM_OCInitStructure.TIM_Pulse = CCR1_Val;
    //TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;
    //TIM_OC1Init(TIM1, &TIM_OCInitStructure);
    //TIM_OC1PreloadConfig(TIM1, TIM_OCPreload_Enable);
     
    TIM_OCInitStructure.TIM_Pulse = CCR1_Val;
    TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;
    TIM_OC1Init(TIM1, &TIM_OCInitStructure);
    TIM_OC1PreloadConfig(TIM1, TIM_OCPreload_Enable);
        TIM_OCInitStructure.TIM_Pulse = CCR1_Val*2;
    TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;
    TIM_OC2Init(TIM1, &TIM_OCInitStructure);
    TIM_OC2PreloadConfig(TIM1, TIM_OCPreload_Enable);
       
    TIM_OCInitStructure.TIM_Pulse = CCR1_Val;
    TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;
    TIM_OC3Init(TIM1, &TIM_OCInitStructure);
    TIM_OC3PreloadConfig(TIM1, TIM_OCPreload_Enable);
        TIM_OCInitStructure.TIM_Pulse = CCR1_Val*3;
    TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;
    TIM_OC4Init(TIM1, &TIM_OCInitStructure);
    TIM_OC4PreloadConfig(TIM1, TIM_OCPreload_Enable);
              TIM_ARRPreloadConfig(TIM1,ENABLE);
              TIM_CtrlPWMOutputs(TIM1,ENABLE);
              TIM_Cmd(TIM1,ENABLE);
}
void TIM1_GPIO_Config(void)

     GPIO_InitTypeDef GPIO_InitStructure;
     RCC_APB2PeriphClockCmd(RCC_APB2Periph_TIM1, ENABLE);
     RCC_APB2PeriphClockCmd(RCC_AHB1Periph_GPIOA, ENABLE);
     GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8| GPIO_Pin_9| GPIO_Pin_10| GPIO_Pin_11;
                     GPIO_InitStructure.GPIO_Mode= GPIO_Mode_AF;
                     GPIO_InitStructure.GPIO_OType= GPIO_OType_PP;//推挽输出
      GPIO_InitStructure.GPIO_Speed =GPIO_Speed_50MHz;
     GPIO_Init(GPIOA, &GPIO_InitStructure);
     
                     GPIO_PinAFConfig(GPIOA,GPIO_PinSource8,GPIO_AF_TIM1);
                     GPIO_PinAFConfig(GPIOA,GPIO_PinSource9,GPIO_AF_TIM1);
                     GPIO_PinAFConfig(GPIOA,GPIO_PinSource10,GPIO_AF_TIM1);
                     GPIO_PinAFConfig(GPIOA,GPIO_PinSource11,GPIO_AF_TIM1);
}
void TIM1_GPIO_ReSetConfig(void)

     GPIO_InitTypeDef GPIO_InitStructure;
     RCC_APB2PeriphClockCmd(RCC_AHB1Periph_GPIOA, ENABLE);
     GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;
                     GPIO_InitStructure.GPIO_Mode= GPIO_Mode_AF;
                     GPIO_InitStructure.GPIO_OType= GPIO_OType_PP;//推挽输出
     GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
     GPIO_Init(GPIOA, &GPIO_InitStructure);
     
                     GPIO_PinAFConfig(GPIOA,GPIO_PinSource8,GPIO_AF_TIM1);
}
void TIM1_GPIO_UnSetConfig(void)

     GPIO_InitTypeDef GPIO_InitStructure;
     RCC_APB2PeriphClockCmd(RCC_AHB1Periph_GPIOA, ENABLE);
     GPIO_InitStructure.GPIO_Pin =  GPIO_Pin_8| GPIO_Pin_11;
                     GPIO_InitStructure.GPIO_Mode= GPIO_Mode_OUT;
                     GPIO_InitStructure.GPIO_OType= GPIO_OType_PP;//推挽输出
     GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
     GPIO_Init(GPIOA, &GPIO_InitStructure);
     
                     GPIO_ResetBits(GPIOA,GPIO_Pin_8);
                     GPIO_ResetBits(GPIOA,GPIO_Pin_11);
}
void TIM1_PWM_Init(void)
{     
    TIM1_GPIO_Config();  
    TIM1_Mode_Config();
}
timer.h代码:
#ifndef _TIMER_H
#define _TIMER_H
#include "sys.h"
void TIM1_PWM_Init(void);
void TIM1_Mode_Config(void);
void TIM1_GPIO_Config(void);
void TIM1_GPIO_ReSetConfig(void);
void TIM1_GPIO_UnSetConfig(void);
//void TIM3_Int_Init(u16 arr,u16 psc);
#endif
用Proteus VSM Studio编译已完成的代码(如下图6所示)。
 C/C++

(图6)
用Proteus仿真STM32F401VE的TimeràPWM项目(如下图7,8所示)。
 C/C++

(图7)
C/C++ 
(图8)
按下Key0按钮LED0红灯亮灯(如下图9所示)。
 C/C++

(图9)


二,根据原理图制作STM32F407ZGT6的Proteus仿真元件(如下图10,11所示)。
 C/C++

(图10)
 C/C++

(图11)
由于是在使用STM32F401VE的固件库与STM32F407ZGT6的引脚数和标号不同,需要进行调整(如下图12所示)。
 C/C++

(图12)
为了避免与Proteus以后推出STM32F407ZGT6的固件库冲突,将制作的元件命名为STM32MF407ZGT6。由于是基于STM32F401VE的固件库以及MDF,只支持100Pins。与真的STM32F407ZGT6 相对照,还少了些引脚,和一些功能。,但基础功能仿真是可以满足的(如下图13所示)。
C/C++ 
(图13)
用Proteus仿真STM32MF407ZGT6的TimeràPWM项目的编程,编译,仿真操作以及显示结果一致。(如下图14所示)。
 C/C++

(图14)
三,
根据原理图制作STM32F429IGT6的Proteus仿真元件(如下图15,16所示)。
 C/C++

(图15)
 C/C++

(图16)
由于是在使用STM32F401VE的固件库与STM32F429IGT6的引脚数和标号不同,需要进行调整(如下图17所示)。
 C/C++

(图17)
为了避免与Proteus以后推出STM32F29IGT6的固件库冲突,将制作的元件命名为STM32MF29IGT6。由于是基于STM32F401VE的固件库以及MDF,只支持100Pins。与真的STM32F29IGT6 相对照,还少了些引脚,和一些功能。,但基础功能仿真是可以满足的(如下图18所示)。
 C/C++

(图18)
用Proteus仿真STM32MF429IGT6的TimeràPWM项目的编程,编译,仿真操作以及显示结果一致。(如下图19所示)。
 C/C++

(图19)
需要进一步了解,请加入QQ群:976235464

 

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
评论(0)
发评论
jf_69711125 2022-04-02
0 回复 举报
谢谢!!! 收起回复

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分