这些小活动你都参加了吗?快来围观一下吧!>>
电子产品世界 » 论坛首页 » 高校专区 » 漓东e学堂 » 【1.18更新】11号~STM32学习进程

共9条 1/1 1 跳转至

【1.18更新】11号~STM32学习进程

菜鸟
2015-11-15 15:53:39     打赏

作业一:Keil的安装:http://forum.eepw.com.cn/thread/277756/1#2

作业二:流水灯效果:http://forum.eepw.com.cn/thread/277756/1#3

作业三:0~99按键计数:http://forum.eepw.com.cn/thread/277756/1#4

作业四:单号亮度控制:http://forum.eepw.com.cn/thread/277756/1#5

作业五:S3、S4按键控制亮灭:http://forum.eepw.com.cn/thread/277756/1#6

作业六:uart控制LED流水灯转速:http://forum.eepw.com.cn/thread/277756/1#7

作业七:计算开机次数:http://forum.eepw.com.cn/thread/277756/1#8

作业八:DS18B20温度使灯的颜色变化http://forum.eepw.com.cn/thread/277756/1#9



菜鸟
2015-11-15 15:56:28     打赏
2楼

嵌入式系统:

作业一:Keil的安装

步骤一:找到安装文件点击进入安装界面

步骤二:安装页面的操作

继续下一步操作:

下一步操作不勾选两个空格:

步骤四:完成安装后点开该软件

点击File/License Management就出现下面这个界面

然后复制其中的CID!

步骤五:点开破解软件把CID粘贴进去点击最下边箭头的按钮获取激活码!

多点几次如下:

步骤六:返回软件复制CID的位置

把上步骤复制的激活码复制进该见面然后ADD

完成激活后如下:



菜鸟
2015-11-15 15:57:49     打赏
3楼

作业二:流水灯

编写程序如下:

/**
  ******************************************************************************
  * @file    GPIO/IOToggle/main.c 
  * @author  MCD Application Team
  * @version V3.5.0
  * @date    08-April-2011
  * @brief   Main program body.
  ******************************************************************************
  * @attention
  *
  * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
  * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
  * TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
  * DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
  * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
  * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
  *
  * <h2><center>&copy; COPYRIGHT 2011 STMicroelectronics</center></h2>
  ******************************************************************************
  */

/* Includes ------------------------------------------------------------------*/
#include "stm32f10x.h"
#include "stm32_eval.h"

GPIO_InitTypeDef GPIO_InitStructure;

void RCC_Configuration(void)
{
  RCC_DeInit();
    
  RCC_HSICmd(ENABLE);
  while(RCC_GetFlagStatus(RCC_FLAG_HSIRDY) == RESET);
  
  RCC_SYSCLKConfig(RCC_SYSCLKSource_HSI);
  
  RCC_HSEConfig(RCC_HSE_OFF);
  RCC_LSEConfig(RCC_LSE_OFF);
  RCC_PLLConfig(RCC_PLLSource_HSI_Div2,RCC_PLLMul_9); //  72HMz
  RCC_PLLCmd(ENABLE);
  while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET);
  RCC_ADCCLKConfig(RCC_PCLK2_Div4);
  RCC_PCLK2Config(RCC_HCLK_Div1);
  RCC_PCLK1Config(RCC_HCLK_Div2);
  RCC_HCLKConfig(RCC_SYSCLK_Div1);
  RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);
  while(RCC_GetSYSCLKSource() != 0x08);
 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD|RCC_APB2Periph_AFIO, ENABLE);
 GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable,ENABLE);//disable JTAG
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  GPIO_Init(GPIOD, &GPIO_InitStructure);
 GPIO_ResetBits(GPIOD,GPIO_Pin_2);
}

void delay_us(u32 n)
{
 u8 j;
 while(n--)
 for(j=0;j<10;j++);
}
void delay_ms(u32 n)
{
 while(n--)
 delay_us(1000);
}

/**
  * @brief  Main program.
  * @param  None
  * @retval None
  */
int main(void)
{  unsigned char flag=0;
 
 RCC_Configuration();
 
 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE);
 
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE);
 
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
   GPIO_Init(GPIOC, &GPIO_InitStructure);
 
 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3|GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  GPIO_Init(GPIOC, &GPIO_InitStructure);
 
 
 
 while(1)
 {
   GPIO_SetBits(GPIOC,GPIO_Pin_0);
   GPIO_SetBits(GPIOC,GPIO_Pin_1);
   GPIO_SetBits(GPIOC,GPIO_Pin_2);
   GPIO_SetBits(GPIOC,GPIO_Pin_3);
   GPIO_SetBits(GPIOC,GPIO_Pin_4);
   GPIO_SetBits(GPIOC,GPIO_Pin_5);
   GPIO_SetBits(GPIOC,GPIO_Pin_6);
   GPIO_SetBits(GPIOC,GPIO_Pin_7);

  
   
   delay_ms(100);
    GPIO_ResetBits(GPIOC,GPIO_Pin_0);
  delay_ms(100);
  GPIO_SetBits(GPIOC,GPIO_Pin_0);
  delay_ms(100);
  GPIO_ResetBits(GPIOC,GPIO_Pin_1);
  delay_ms(100);
    GPIO_SetBits(GPIOC,GPIO_Pin_1);
  delay_ms(100);
  GPIO_ResetBits(GPIOC,GPIO_Pin_2);
  delay_ms(100);
   GPIO_SetBits(GPIOC,GPIO_Pin_2);
  delay_ms(100);
  GPIO_ResetBits(GPIOC,GPIO_Pin_3);
  delay_ms(100);
   GPIO_SetBits(GPIOC,GPIO_Pin_3);
  delay_ms(100);
  GPIO_ResetBits(GPIOC,GPIO_Pin_4);
  delay_ms(100);
   GPIO_SetBits(GPIOC,GPIO_Pin_4);
  delay_ms(100);
  GPIO_ResetBits(GPIOC,GPIO_Pin_5);
  delay_ms(100);
   GPIO_SetBits(GPIOC,GPIO_Pin_5);
   delay_ms(100);
  GPIO_ResetBits(GPIOC,GPIO_Pin_6);
  delay_ms(100);
   GPIO_SetBits(GPIOC,GPIO_Pin_6);
   delay_ms(100);
  GPIO_ResetBits(GPIOC,GPIO_Pin_7);
  delay_ms(100);
   GPIO_SetBits(GPIOC,GPIO_Pin_7);
   delay_ms(100);

 }
}



菜鸟
2015-11-15 15:59:54     打赏
4楼

作业三:0~99按键计数:

GPIO_InitTypeDef GPIO_InitStructure; // 声明一个结构体  

  
void RCC_Configuration(void);   
void GPIO_INIT(void) ;  
void Function(void) ;  
  
int main(void)     
{      
    RCC_Configuration();     
    GPIO_INIT();  
    Function();     
}      
        
void RCC_Configuration(void)    //复位所有的RCC外围设备寄存器  
{     
    ErrorStatus HSEStartUpStatus;   //  设置错误标志量  
  RCC_DeInit();                 //复位RCC模块的寄存器,复位成缺省值  
 RCC_HSEConfig(RCC_HSE_ON);      //开启HSE时钟  
  HSEStartUpStatus = RCC_WaitForHSEStartUp();  //获取HSE启动状态:   
  if(HSEStartUpStatus==SUCCESS) //如果HSE启动成功 
    {  
        FLASH_PrefetchBufferCmd(ENABLE);          //开启FLASH的预取功能
        FLASH_SetLatency(FLASH_Latency_2);      //FLASH延迟2个周期
        RCC_HCLKConfig(RCC_SYSCLK_Div1); //配置HCLK,PCLK2,PCLK1,PLL   
        RCC_PCLK2Config(RCC_HCLK_Div1);
        RCC_PCLK1Config(RCC_HCLK_Div2);  
        RCC_PLLConfig(RCC_PLLSource_HSI_Div2,RCC_PLLMul_9); //  72HMz 
        RCC_PLLCmd(ENABLE); //启动PLL            
        while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY)==RESET);  
        {}   //等待PLL启动完成
        RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);//配置系统时钟  
        while(RCC_GetSYSCLKSource() != 0x08); //检查是否将HSE 9倍频后作为系统时钟      
    }  
      
    GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable,ENABLE);//改变管脚的映射SWJ使能选择用于事件输出的GPIO端口  
      
    /*蜂鸣器*/  
    RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD|RCC_APB2Periph_AFIO, ENABLE); //使能所有要用APB2的外设时钟
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2;       //选中2引脚 
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;        // 引脚频率50M 
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;     //引脚设置推拉输出    
  GPIO_Init(GPIOD, &GPIO_InitStructure);    //初始化GPIOD   
    GPIO_ResetBits(GPIOD,GPIO_Pin_2);  
}   
  
void delay_us(u32 n)        //延时函数     
{     
    u8 j;     
    while(n--)     
            for(j=0;j<10;j++);     
}      
void  delay_ms(u32 n)       //延时函数     
{     
   while(n--)     
   delay_us(1000);     
}  
   
void GPIO_INIT(void)     
{       
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC|RCC_APB2Periph_GPIOB, ENABLE);   //使能所有要用APB2的外设时钟 
      
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_10|GPIO_Pin_11;  //选中8,9,10,11引脚 
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;   // 引脚频率50M     
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;   //引脚设置推拉输出   
        GPIO_Init(GPIOC, &GPIO_InitStructure);  //初始化     
       
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5|GPIO_Pin_1|GPIO_Pin_15|GPIO_Pin_6|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14;//数码管  
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;       // 引脚频率50M 
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;  
        GPIO_Init(GPIOB, &GPIO_InitStructure);    //初始化 
}     
    
  
void Number(int a)  //数码管显示数字  
{  
    switch(a)    
            {    
        case 0 : GPIO_ResetBits(GPIOB,GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14);break;    
        case 1 : GPIO_ResetBits(GPIOB,GPIO_Pin_9|GPIO_Pin_12);break;    
        case 2 : GPIO_ResetBits(GPIOB,GPIO_Pin_5|GPIO_Pin_7|GPIO_Pin_9|GPIO_Pin_13|GPIO_Pin_14);break;    
        case 3 : GPIO_ResetBits(GPIOB,GPIO_Pin_5|GPIO_Pin_7|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_14);break;    
        case 4 : GPIO_ResetBits(GPIOB,GPIO_Pin_5|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_12);break;    
        case 5 : GPIO_ResetBits(GPIOB,GPIO_Pin_5|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_12|GPIO_Pin_14);break;    
        case 6 : GPIO_ResetBits(GPIOB,GPIO_Pin_5|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14);break;    
        case 7 : GPIO_ResetBits(GPIOB,GPIO_Pin_7|GPIO_Pin_9|GPIO_Pin_12);break;    
        case 8 : GPIO_ResetBits(GPIOB,GPIO_Pin_5|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14);break;    
        case 9 : GPIO_ResetBits(GPIOB,GPIO_Pin_5|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_14); break;    
            }    
}    
    
     
void Function(void)   
{       
        int i=0,j=0;          //i被按下的次数,n延时变量    
  
        GPIO_SetBits(GPIOB,GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14);       
        delay_ms(50); //关闭数码管      
  
        while(1)    
        {                   
                GPIO_SetBits(GPIOB,GPIO_Pin_1);         //打开个位数码管    
                Number(i);                                //用switch函数显示00    
                delay_ms(50);                              
                GPIO_ResetBits(GPIOB,GPIO_Pin_1);        //关闭个位         
                GPIO_SetBits(GPIOB,GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14);    
  
                GPIO_SetBits(GPIOB,GPIO_Pin_15);           //打开十位    
                Number(j);      
                delay_ms(50);    
                GPIO_ResetBits(GPIOB,GPIO_Pin_15);      //关掉十位数码管       
                GPIO_SetBits(GPIOB,GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14);    
  
                if(!GPIO_ReadInputDataBit(GPIOC,GPIO_Pin_8))   //判断按键是s1否被按下    
                {       
                    delay_ms(50);            //延时消抖    
                    if(!GPIO_ReadInputDataBit(GPIOC,GPIO_Pin_8))  //再次判断按键是s1否被按下      
                    {     
                        i++;                     //按键被按下,个位+1    
                        if(i==10)       
                        {    
                            j++;                 
                            i=0;                   
                        }  
                        if(j==10)  
                        {  
                             j=0;  
                                                 i=0;  
                        }  
                    }  
                }     
  

菜鸟
2015-11-15 16:06:26     打赏
5楼

作业四:

#include "stm32f10x.h"  

#include "stm32_eval.h"  
#include "stdbool.h"  
GPIO_InitTypeDef GPIO_InitStructure;  
 void RCC_Configuration(void);   
void GPIO_INIT(void) ;  
void Function(void) ;  
  
int main(void)     
{      
    RCC_Configuration();     
    GPIO_INIT();  
    Function();     
}      
     
void RCC_Configuration(void)  
{  
  RCC_DeInit();  
  RCC_HSICmd(ENABLE);  
  while(RCC_GetFlagStatus(RCC_FLAG_HSIRDY) == RESET);  
  RCC_SYSCLKConfig(RCC_SYSCLKSource_HSI);  
  RCC_HSEConfig(RCC_HSE_OFF);  
  RCC_LSEConfig(RCC_LSE_OFF);  
  RCC_PLLConfig(RCC_PLLSource_HSI_Div2,RCC_PLLMul_9); //  72HMz  
  RCC_PLLCmd(ENABLE);  
  while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET);  
  RCC_ADCCLKConfig(RCC_PCLK2_Div4);  
  RCC_PCLK2Config(RCC_HCLK_Div1);  
  RCC_PCLK1Config(RCC_HCLK_Div2);  
  RCC_HCLKConfig(RCC_SYSCLK_Div1);  
  RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);  
  while(RCC_GetSYSCLKSource() != 0x08);
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD|RCC_APB2Periph_AFIO, ENABLE);  
  GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable,ENABLE); 
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2;  
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;  
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;  
  GPIO_Init(GPIOD, &GPIO_InitStructure);  
  GPIO_ResetBits(GPIOD,GPIO_Pin_2);  
}  
  
void GPIO_INIT()     
{     
   //GPIO数码管初始化  
   RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);     
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1|GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7|GPIO_Pin_8
|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14|GPIO_Pin_15;     
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;     
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;     
  GPIO_Init(GPIOB, &GPIO_InitStructure);     
         
  //按键初始化 
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE);     
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_10|GPIO_Pin_11;     
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;     
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;     
  GPIO_Init(GPIOC, &GPIO_InitStructure);     
}     
  
void delay_us(u32 n)  
{  
    u8 j;  
    while(n--)  
    for(j=0;j<10;j++);  
}  
  
void  delay_ms(u32 n)  
{  
    while(n--)  
    delay_us(1000);  
}  
  void Function(void)   
{       
        int i=0,j=0;          //i被按下的次数,n延时变量    
  
        GPIO_SetBits(GPIOB,GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14);       
        delay_ms(50); //关闭数码管      
  
        while(1)    
        {                   
                GPIO_SetBits(GPIOB,GPIO_Pin_1);         //打开个位数码管    
                Number(i);                                //用switch函数显示00    
                delay_ms(50);                              
                GPIO_ResetBits(GPIOB,GPIO_Pin_1);        //关闭个位         
                GPIO_SetBits(GPIOB,GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14);    
  
                GPIO_SetBits(GPIOB,GPIO_Pin_15);           //打开十位    
                Number(j);      
                delay_ms(50);    
                GPIO_ResetBits(GPIOB,GPIO_Pin_15);      //关掉十位数码管       
                GPIO_SetBits(GPIOB,GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14);    
  
                if(!GPIO_ReadInputDataBit(GPIOC,GPIO_Pin_8))   //判断按键是s1否被按下    
                {       
                    delay_ms(50);            //延时消抖    
                    if(!GPIO_ReadInputDataBit(GPIOC,GPIO_Pin_8))  //再次判断按键是s1否被按下      
                    {     
                        i++;                     //按键被按下,个位+1    
                        if(i==10)       
                        {    
                            j++;                 
                            i=0;                   
                        }  
                        if(j==10)  
                        {  
                             j=0;  
                                                 i=0;  
                        }  
                    }  
                }     
              }
}
/**
  * @brief  Main program.
  * @param  None
  * @retval None
  */
 

菜鸟
2015-11-15 16:06:56     打赏
6楼

作业五:S3、S4按键控制亮灭:

/**

  ******************************************************************************
  * @file    EXTI/EXTI_Config/main.c 
  * @author  MCD Application Team
  * @version V3.5.0
  * @date    08-April-2011
  * @brief   Main program body
  ******************************************************************************
  * @attention
  *
  * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
  * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
  * TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
  * DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
  * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
  * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
  *
  * <h2><center>&copy; COPYRIGHT 2011 STMicroelectronics</center></h2>
  ******************************************************************************
  */ 

/* Includes ------------------------------------------------------------------*/
#include "stm32f10x.h"
#include "stm32_eval.h"
#include <stdio.h>
/** @addtogroup STM32F10x_StdPeriph_Examples
  * @{
  */

/** @addtogroup EXTI_Config
  * @{
  */ 

/* Private typedef -----------------------------------------------------------*/
/* Private define ------------------------------------------------------------*/
/* Private macro -------------------------------------------------------------*/
/* Private variables ---------------------------------------------------------*/
EXTI_InitTypeDef   EXTI_InitStructure;
GPIO_InitTypeDef   GPIO_InitStructure;
NVIC_InitTypeDef   NVIC_InitStructure;
USART_InitTypeDef USART_InitStructure;
USART_ClockInitTypeDef USART_ClockInitStructure;
/* Private function prototypes -----------------------------------------------*/
void EXTIkeyS3_Config(void);
void EXTIkeyS4_Config(void);
void RCC_Configuration(void)
{
  RCC_DeInit();
    
  RCC_HSICmd(ENABLE);
  while(RCC_GetFlagStatus(RCC_FLAG_HSIRDY) == RESET);
  
  RCC_SYSCLKConfig(RCC_SYSCLKSource_HSI);
  
  RCC_HSEConfig(RCC_HSE_OFF);
  RCC_LSEConfig(RCC_LSE_OFF);
  RCC_PLLConfig(RCC_PLLSource_HSI_Div2,RCC_PLLMul_9); //  72HMz
  RCC_PLLCmd(ENABLE);
  while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET);
  RCC_ADCCLKConfig(RCC_PCLK2_Div4);
  RCC_PCLK2Config(RCC_HCLK_Div1);
  RCC_PCLK1Config(RCC_HCLK_Div2);
  RCC_HCLKConfig(RCC_SYSCLK_Div1);
  RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);
  while(RCC_GetSYSCLKSource() != 0x08);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD|RCC_APB2Periph_AFIO, ENABLE);
 GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable,ENABLE);//disable JTAG
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD|RCC_APB2Periph_AFIO, ENABLE);
 GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable,ENABLE);//disable JTAG
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  GPIO_Init(GPIOD, &GPIO_InitStructure);
GPIO_ResetBits(GPIOD,GPIO_Pin_2);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC|RCC_APB2Periph_AFIO, ENABLE);
 GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable,ENABLE);//disable JTAG
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3|GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  GPIO_Init(GPIOC, &GPIO_InitStructure);
GPIO_ResetBits(GPIOC,GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3|GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7);
}

void USART_int(long BaudRate)
{
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_USART1,ENABLE);
       GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
    GPIO_InitStructure.GPIO_Speed = GPIO_Speed_10MHz;
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; 
    GPIO_Init(GPIOA, &GPIO_InitStructure);
    /* PA10 USART1_Rx  */
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
    GPIO_Init(GPIOA, &GPIO_InitStructure);
  /* USARTx configured as follow:
        - BaudRate = 115200 baud  
        - Word Length = 8 Bits
        - One Stop Bit
        - No parity
        - Hardware flow control disabled (RTS and CTS signals)
        - Receive and transmit enabled
  */
  USART_InitStructure.USART_BaudRate = BaudRate;//??????
  USART_InitStructure.USART_WordLength = USART_WordLength_8b;//???????8bit
  USART_InitStructure.USART_StopBits = USART_StopBits_1;//????1
  USART_InitStructure.USART_Parity = USART_Parity_No;//????
  USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;//??????none
  USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;//??????????
USART_ClockInitStructure.USART_Clock = USART_Clock_Disable;     
    USART_ClockInitStructure.USART_CPOL = USART_CPOL_Low;      
    USART_ClockInitStructure.USART_CPHA = USART_CPHA_2Edge;      
    USART_ClockInitStructure.USART_LastBit = USART_LastBit_Disable;
    USART_ClockInit(USART1, &USART_ClockInitStructure);
  USART_Init(USART1, &USART_InitStructure);
  USART_Cmd(USART1, ENABLE);
USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);
 USART_Cmd(USART1, ENABLE);
 
  /* Configure four bit for preemption priority */
  NVIC_PriorityGroupConfig(NVIC_PriorityGroup_4);
  /* Enable the USART1 Interrupt */
  NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn; //
  NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 15;
  NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  NVIC_Init(&NVIC_InitStructure);
}

/* Private functions ---------------------------------------------------------*/

/**
  * @brief  Main program.
  * @param  None
  * @retval None
  */
int main(void)
{RCC_Configuration();
  
  /* Configure PA.00 in interrupt mode */
  EXTIkeyS3_Config();

  /* Configure PB.09 or PG.08 in interrupt mode */
  EXTIkeyS4_Config();
USART_int(115200);
printf("Config done,waiting for interrupt......\r\n");
          
  while (1)
  {
  }
}

/**
  * @brief  Configure PA.00 in interrupt mode
  * @param  None
  * @retval None
  */
void EXTIkeyS3_Config(void)
{
  /* Enable GPIOA clock */
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE);
  
  /* Configure PA.00 pin as input floating */
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
  GPIO_Init(GPIOA, &GPIO_InitStructure);

  /* Enable AFIO clock */
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO, ENABLE);

  /* Connect EXTI0 Line to PA.00 pin */
  GPIO_EXTILineConfig(GPIO_PortSourceGPIOC, GPIO_PinSource10);

  /* Configure EXTI0 line */
  EXTI_InitStructure.EXTI_Line = EXTI_Line10;
  EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;
  EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Falling;  
  EXTI_InitStructure.EXTI_LineCmd = ENABLE;
  EXTI_Init(&EXTI_InitStructure);

  /* Enable and set EXTI0 Interrupt to the lowest priority */
  NVIC_InitStructure.NVIC_IRQChannel = EXTI15_10_IRQn;
  NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0x0F;
  NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0x0F;
  NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  NVIC_Init(&NVIC_InitStructure);
}

/**
  * @brief  Configure PB.09 or PG.08 in interrupt mode
  * @param  None
  * @retval None
  */
void EXTIkeyS4_Config(void)
{
  /* Enable GPIOB clock */
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE);

  /* Configure PB.09 pin as input floating */
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
  GPIO_Init(GPIOC, &GPIO_InitStructure);

  /* Enable AFIO clock */
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO, ENABLE);
  /* Connect EXTI9 Line to PB.09 pin */
  GPIO_EXTILineConfig(GPIO_PortSourceGPIOC, GPIO_PinSource11);

  /* Configure EXTI9 line */
  EXTI_InitStructure.EXTI_Line = EXTI_Line11;
  EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;
  EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Falling;
  EXTI_InitStructure.EXTI_LineCmd = ENABLE;
  EXTI_Init(&EXTI_InitStructure);

  /* Enable and set EXTI9_5 Interrupt to the lowest priority */
  NVIC_InitStructure.NVIC_IRQChannel = EXTI15_10_IRQn;
  NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0x0F;
  NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0x0F;
  NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;

  NVIC_Init(&NVIC_InitStructure);
}

/******************************************************************************/
/*            STM32F10x Peripherals Interrupt Handlers                        */
/******************************************************************************/

/**
  * @brief  This function handles External lines 9 to 5 interrupt request.
  * @param  None
  * @retval None
  */
void EXTI15_10_IRQHandler(void)
{
  if(EXTI_GetITStatus(EXTI_Line10) != RESET)
  {
    /* Toggle LED2 */
     GPIO_SetBits(GPIOC,GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7);
printf("S4 interrupt ......\r\n");
    /* Clear the  EXTI line 9 pending bit */
    EXTI_ClearITPendingBit(EXTI_Line10);
  }
if(EXTI_GetITStatus(EXTI_Line11) != RESET)
  {
    /* Toggle LED1 */
     GPIO_SetBits(GPIOC,GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3);
printf("S3 interrupt ......\r\n");
    /* Clear the  EXTI line 0 pending bit */
    EXTI_ClearITPendingBit(EXTI_Line11);
  }
}


#ifdef  USE_FULL_ASSERT

/**
  * @brief  Reports the name of the source file and the source line number
  *         where the assert_param error has occurred.
  * @param  file: pointer to the source file name
  * @param  line: assert_param error line source number
  * @retval None
  */
void assert_failed(uint8_t* file, uint32_t line)

  /* User can add his own implementation to report the file name and line number,
     ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */

  /* Infinite loop */
  while (1)
  {
  }
}

#endif

/**
  * @}
  */ 

/**
  * @}
  */ 

#ifdef __GNUC__
  /* With GCC/RAISONANCE, small printf (option LD Linker->Libraries->Small printf
     set to 'Yes') calls __io_putchar() */
  #define PUTCHAR_PROTOTYPE int __io_putchar(int ch)
#else
  #define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)
#endif /* __GNUC__ */
  


/**
  * @brief  Retargets the C library printf function to the USART.
  * @param  None
  * @retval None
  */
PUTCHAR_PROTOTYPE
{
  /* Place your implementation of fputc here */
  /* e.g. write a character to the USART */
  USART_SendData(EVAL_COM1, (uint8_t) ch);

  /* Loop until the end of transmission */
  while (USART_GetFlagStatus(EVAL_COM1, USART_FLAG_TC) == RESET)
  {}

  return ch;
}

#ifdef  USE_FULL_ASSERT

/**
  * @brief  Reports the name of the source file and the source line number
  *         where the assert_param error has occurred.
  * @param  file: pointer to the source file name
  * @param  line: assert_param error line source number
  * @retval None
  */
void assert_failed(uint8_t* file, uint32_t line)

  /* User can add his own implementation to report the file name and line number,
     ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */

  /* Infinite loop */
  while (1)
  {
  }
}

#endif

/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/


菜鸟
2015-12-13 23:45:13     打赏
7楼

作业六:uart控制LED流水灯转速


  1. #include "stm32f10x.h"
  2. #include    "stdio.h"
  3. GPIO_InitTypeDef GPIO_InitStructure; // 声明结构体
  4. NVIC_InitTypeDef  NVIC_InitStructure;
  5. USART_InitTypeDef  USART_InitStructure;
  6. USART_ClockInitTypeDef  USART_ClockInitStructure;
  7. #define buff_size  16;
  8. char rx_buff[],rx_buff_count=0;
  9. void RCC_Configuration(void) ;
  10. void GPIO_INIT(void)  ;
  11. void USART_int(long BaudRate);
  12. void USART_SendStr(char *str);
  13. void delay_ms(u32 n)  ;
  14. void delay_us(u32 n);
  15. /****主函数 ****/
  16. int main()
  17. {
  18. RCC_Configuration();
  19. GPIO_INIT();
  20. USART_int(9600);
  21. GPIO_ResetBits(GPIOC,0xffff);//led全亮,提示程序开始
  22. delay_ms(200);
  23. GPIO_SetBits(GPIOC,0xffff);//led全灭
  24. USART_SendStr("USART Led Speed\r\n");//
  25. USART_SendStr("\n>");//
  26. while(1);
  27. }
  28. /****   配置RCC ****/
  29. void RCC_Configuration(void)
  30. {
  31. ErrorStatus HSEStartUpStatus; //  设置错误标志量
  32. RCC_DeInit(); //*将外设寄存器RCC重设为初始值
  33. RCC_HSEConfig(RCC_HSE_ON);//*打开外部高速时钟晶振HSE:
  34. HSEStartUpStatus = RCC_WaitForHSEStartUp(); //*等待外部高速时钟晶振工作:
  35. if(HSEStartUpStatus==SUCCESS)
  36. {
  37. RCC_HCLKConfig(RCC_SYSCLK_Div1);//*AHB使用系统时钟,负责外部存储器的时钟
  38. RCC_PCLK1Config(RCC_HCLK_Div2);//*APB1 负责DA,USB,SPI,I2C,CAN,串口2345,普通TIM
  39. RCC_PCLK2Config(RCC_HCLK_Div1);//*APB2负责AD,I/O,高级TIM,串口1
  40. RCC_PLLConfig(RCC_PLLSource_HSE_Div1,RCC_PLLMul_9);//*设置PLL输入时钟源72M
  41. RCC_PLLCmd(ENABLE);//*打开PLL:
  42. while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY)==RESET);//*等待PLL工作:
  43. RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);//*设置系统时钟
  44. while(RCC_GetSYSCLKSource() != 0x08);//* 判断PLL是否是系统时钟:
  45. }
  46. GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable,ENABLE);
  47. /*蜂鸣器*/
  48. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD|RCC_APB2Periph_AFIO, ENABLE);
  49. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2;
  50. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  51. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  52. GPIO_Init(GPIOD, &GPIO_InitStructure);
  53. GPIO_ResetBits(GPIOD,GPIO_Pin_2);
  54. }
  55. /****延时 ****/
  56. void delay_us(u32 n)
  57. {
  58. u8 j;
  59. while(n--)
  60. for(j=0;j<10;j++);
  61. }
  62. void delay_ms(u32 n)
  63. {
  64. while(n--)
  65. delay_us(1000);
  66. }
  67. /**** 初始化GPIO ****/
  68. void GPIO_INIT(void)
  69. {
  70. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE);
  71. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3|GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7;
  72. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  73. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  74. GPIO_Init(GPIOC, &GPIO_InitStructure);
  75. }
  76. /**** USART传输的波特率 ****/
  77. void USART_int(long BaudRate)
  78. {
  79. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_USART1,ENABLE);//使能PA和 usart1
  80. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
  81. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_10MHz;
  82. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; //复用推挽输出 PA9作为US1的TX端,打开复用,负责发送数据
  83. GPIO_Init(GPIOA, &GPIO_InitStructure);
  84. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10; //RX位于PA10
  85. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; //浮空输入,PA10作为US1的RX端,负责接收数据
  86. //RX初始化PA10
  87. USART_InitStructure.USART_BaudRate = BaudRate;//波特率
  88. USART_InitStructure.USART_WordLength = USART_WordLength_8b;//USART_WordLength 在一个帧中传输8位数据(字节)
  89. USART_InitStructure.USART_StopBits = USART_StopBits_1;//停止位为一个字节
  90. USART_InitStructure.USART_Parity = USART_Parity_No;//无奇偶校验
  91. USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;//无流控制
  92. USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;//收发模式
  93. USART_ClockInitStructure.USART_Clock = USART_Clock_Disable;//时钟低电平活动,开启发送接受数据功能(usart 使能)
  94. USART_ClockInitStructure.USART_CPOL = USART_CPOL_Low; //SCLK输出时钟低电平
  95. USART_ClockInitStructure.USART_CPHA = USART_CPHA_2Edge;//时钟第二个边沿开始数据捕获
  96. USART_ClockInitStructure.USART_LastBit = USART_LastBit_Disable;//最后一位数据不从SCLK发出
  97. USART_ClockInit(USART1, &USART_ClockInitStructure);//初始化USART1时钟
  98. USART_Init(USART1, &USART_InitStructure);//初始化USART1
  99. USART_Cmd(USART1, ENABLE);//USART1使能
  100. USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);//使能接收中断,在接受移位寄存器中有数据时产生
  101. USART_Cmd(USART1, ENABLE);
  102. //配置NVIC ,设置优先级分组,使用NVIC_Init对NVIC进行初始化
  103. NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0);//选择中断分组4(先占优先级四位,从优先级0)
  104. NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn; //选择中断通道
  105. NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;//抢占优先级1-15
  106. NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;//响应优先级1-15
  107. NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;//使能中断
  108. NVIC_Init(&NVIC_InitStructure); //初始化中断
  109. }
  110. /**** usart发送数据 ****/
  111. void USART_SendStr(char *str) //USART发送数据
  112. {
  113. while((*str)!='\0')
  114. {
  115. USART_SendData(USART1,*str++); //通过外设 USARTx 发送单个数据
  116. while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET); //检查指定的 USART 标志位设置与否
  117. }
  118. }
  119. /**** 取字符串中的数字 ****/
  120. unsigned int translate(char* pstr)
  121. {
  122. int s = 0;
  123. while(*pstr != '\0') //如果没扫到字符串的最后不停止
  124. {
  125. if(*pstr >= '0' && *pstr <= '9') //如果字符串中存在0-9的数字
  126. {
  127. s = s * 10 + *pstr - '0';
  128. }
  129. pstr++;
  130. }
  131. return s;
  132. }
  133. /****  点亮led****/
  134. void LED(char *S,char LEN) //(字符串,字符串长度)
  135. {
  136. int m,i;
  137. int a[8]={GPIO_Pin_0,GPIO_Pin_1,GPIO_Pin_2,GPIO_Pin_3,GPIO_Pin_4,GPIO_Pin_5,GPIO_Pin_6,GPIO_Pin_7};
  138. m=translate(S);
  139. GPIO_SetBits(GPIOC,GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3|GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7);
  140. delay_ms(100);
  141. for(i=0;i<8;i++)
  142. {
  143. GPIO_ResetBits(GPIOC,a[i]); // 点亮LED
  144. delay_ms(m);
  145. GPIO_SetBits(GPIOC,a[i]); //熄灭LED
  146. delay_ms(m);
  147. }
  148. }
  149. void input_ASK()
  150. {
  151. char j;
  152. LED(rx_buff,rx_buff_count);
  153. rx_buff_count=0;
  154. for (j=0;j
  155. {
  156. rx_buff[j]='\0';
  157. }//判断读入信息是否结束,如果结束则准备下一次读入
  158. USART_SendStr("\n>");
  159. }
  160. /****接收中断****/
  161. void USART1_IRQHandler(void)
  162. {
  163. while(USART_GetFlagStatus(USART1, USART_FLAG_RXNE) == RESET)  { } //判断接收中断是否打开
  164. if(USART_ReceiveData(USART1)==0x0d)
  165. {
  166. input_ASK();
  167. }
  168. else
  169. {
  170. USART_SendData(USART1,USART_ReceiveData(USART1)); //将数据传回给电脑
  171. rx_buff[rx_buff_count]= USART_ReceiveData(USART1);
  172. rx_buff_count++;
  173. }
  174. USART_ClearFlag(USART1, USART_FLAG_RXNE); //清除中断接受完成标志位
  175. }

菜鸟
2016-01-19 01:38:03     打赏
8楼
作业七:计算开机次数:

sfr IAP_DATA     = 0xE2;

sfr IAP_ADDRH     = 0xE3;
sfr IAP_ADDRL     = 0xE4;
sfr IAP_CMD      = 0xE5;
sfr IAP_TRIG     = 0xE6;
sfr IAP_CONTR     = 0xE7;

#define           CMD_IDLE  0
#define           CMD_READ   1
#define           CMD_PROGRAM   2
#define           CMD_ERASE   3 

#define     ENABLE_IAP0x80 
#define     ENABLE_IAP0x81 
#define     ENABLE_IAP0x82
#define     ENABLE_IAP0x83 

IAP_ADDRESS    0x2000    //STC90C52ϵÁÐEEPROM²âÊÔÆðʼµØÖ·

void IapIdle(void)
{
IAP_CONTR=0;
IAP_CMD =0;
IAP_TRIG =0;
IAP_ADDRH=0x80;
IAP_ADDRL =0;

}

unsigned char IapReadByte(unsigned int addt) 
{
unsigned char dat;
IAP_CONTR=ENABLE_IAP;
IAP_CMD =CMD_READ;
IAP_ADDRL=addr;
IAP_ADDRL=addr>>8
IAP_TRIG =0x46;
IAP_TRIG =0xb9;
dat = IAP_DATA;
IapIdle();


return dat;

}

void Iap ProgramByte(unsigned int addr,unsigned char dat )
{
IAP_CONTR=ENABLE_IAP;
IAP_CMD =CMD_REOGRAM;
IAP_ADDRL=addr;
IAP_ADDRH=addr>>8
IAP_DATA=date;
IAP_TRIG =0x46;
IAP_TRIG =0xb9;

IapIdle();
}

void Iap EraseSector(unsigned int addr )
{
IAP_CONTR=ENABLE_IAP;
IAP_CMD =CMD_ERASE;
IAP_ADDRL=addr;
IAP_ADDRH=addr>>8
IAP_TRIG =0x46;
IAP_TRIG =0xb9;

IapIdle();
}
unsigned char Num=0;
void main(void)
{
unsigned long i=0;
Num = Iap ReadByte(IAP_ADDRESS+20);
Num++;
Iap EraseSector(IAP_ADDRESS);
Iap ProgramByte(IAP_ADDRESS+20,Num);
for(i=0;i
{
LED0=0;
DelayMs(100);
LED0=1;
DelayMs(100);
}
while(1);
}

菜鸟
2016-01-19 01:51:28     打赏
9楼
  1. //ADC改变灯的颜色:
  2. #include "stm32f10x.h"    
  3. #include "stm32_eval.h"    
  4. #include <stdio.h>    
  5. #define VREF 3.3    
  6. GPIO_InitTypeDef   GPIO_InitStructure;    
  7. USART_InitTypeDef USART_InitStructure;    
  8. USART_ClockInitTypeDef USART_ClockInitStructure;    
  9. int volt;    
  10. unsigned int temp0,temp1,temp2;    
  11. void RCC_Configuration(void)    
  12. {/*  
  13.   RCC_DeInit();  
  14.       
  15.   RCC_HSICmd(ENABLE);  
  16.   while(RCC_GetFlagStatus(RCC_FLAG_HSIRDY) == RESET);  
  17.     
  18.   RCC_SYSCLKConfig(RCC_SYSCLKSource_HSI);  
  19.     
  20.   RCC_HSEConfig(RCC_HSE_OFF);  
  21.   RCC_LSEConfig(RCC_LSE_OFF);  
  22.   RCC_PLLConfig(RCC_PLLSource_HSI_Div2,RCC_PLLMul_9); //  72HMz  
  23.   RCC_PLLCmd(ENABLE);  
  24.   while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET);  
  25.   RCC_ADCCLKConfig(RCC_PCLK2_Div4);  
  26.   RCC_PCLK2Config(RCC_HCLK_Div1);  
  27.   RCC_PCLK1Config(RCC_HCLK_Div2);  
  28.   RCC_HCLKConfig(RCC_SYSCLK_Div1);  
  29.   RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);  
  30.   while(RCC_GetSYSCLKSource() != 0x08);  
  31. */    
  32.     SystemInit();    
  33.     RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD|RCC_APB2Periph_AFIO, ENABLE);    
  34.  GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable,ENABLE);//disable JTAG    
  35. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD|RCC_APB2Periph_AFIO, ENABLE);    
  36.  GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable,ENABLE);//disable JTAG    
  37.   GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2;    
  38.   GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;    
  39.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;    
  40.   GPIO_Init(GPIOD, &GPIO_InitStructure);    
  41.     GPIO_ResetBits(GPIOD,GPIO_Pin_2);    
  42.     RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC|RCC_APB2Periph_AFIO, ENABLE);    
  43.  GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable,ENABLE);//disable JTAG    
  44.   GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3|GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7;    
  45.   GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;    
  46.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;    
  47.   GPIO_Init(GPIOC, &GPIO_InitStructure);    
  48.     GPIO_SetBits(GPIOC,GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3|GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7);    
  49.       RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);    
  50. }     
  51.     
  52. void USART_int(long BaudRate)    
  53. {    
  54.     RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_USART1,ENABLE);    
  55.        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;    
  56.     GPIO_InitStructure.GPIO_Speed = GPIO_Speed_10MHz;    
  57.     GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;     
  58.     GPIO_Init(GPIOA, &GPIO_InitStructure);    
  59.     /* PA10 USART1_Rx  */    
  60.     GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;    
  61.     GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;    
  62.     GPIO_Init(GPIOA, &GPIO_InitStructure);    
  63.   /* USARTx configured as follow:  
  64.         - BaudRate = 115200 baud    
  65.         - Word Length = 8 Bits  
  66.         - One Stop Bit  
  67.         - No parity  
  68.         - Hardware flow control disabled (RTS and CTS signals)  
  69.         - Receive and transmit enabled  
  70.   */    
  71.   USART_InitStructure.USART_BaudRate = BaudRate;   
  72.   USART_InitStructure.USART_WordLength = USART_WordLength_8b;   
  73.   USART_InitStructure.USART_StopBits = USART_StopBits_1;    
  74.   USART_InitStructure.USART_Parity = USART_Parity_No;    
  75.   USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None; USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;    
  76.     USART_ClockInitStructure.USART_Clock = USART_Clock_Disable;         
  77.     USART_ClockInitStructure.USART_CPOL = USART_CPOL_Low;          
  78.     USART_ClockInitStructure.USART_CPHA = USART_CPHA_2Edge;          
  79.     USART_ClockInitStructure.USART_LastBit = USART_LastBit_Disable;    
  80.     USART_ClockInit(USART1, &USART_ClockInitStructure);    
  81.   USART_Init(USART1, &USART_InitStructure);    
  82.   USART_Cmd(USART1, ENABLE);    
  83.     USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);    
  84.  USART_Cmd(USART1, ENABLE);    
  85. }    
  86. void delay_us(u32 n)    
  87. {    
  88.     u8 j;    
  89.     while(n--)    
  90.     for(j=0;j<10;j++);    
  91. }    
  92. void  delay_ms(u32 n)    
  93. {    
  94.     while(n--)    
  95.     delay_us(1000);    
  96. }    
  97. void PWM_Config()    
  98. {    
  99.     uint16_t PrescalerValue = 0;    
  100.     TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;    
  101.   TIM_OCInitTypeDef  TIM_OCInitStructure;    
  102.     /* TIM2 clock enable */    
  103.   RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);    
  104.   /* GPIOA  enable */    
  105.   RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO, ENABLE);    
  106.     GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3;//PWM&RGB- PA1 PA2 PA3    
  107.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;    
  108.   GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;    
  109.   GPIO_Init(GPIOA, &GPIO_InitStructure);    
  110.         TIM_Cmd(TIM2, ENABLE);    
  111.       /* Compute the prescaler value */    
  112.   PrescalerValue = (uint16_t) (SystemCoreClock / 24000000) - 1;    
  113.   /* Time base configuration */    
  114.   TIM_TimeBaseStructure.TIM_Period = 0x07FF;    
  115.   TIM_TimeBaseStructure.TIM_Prescaler = PrescalerValue;    
  116.   TIM_TimeBaseStructure.TIM_ClockDivision = 0;    
  117.   TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;    
  118.   TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure);    
  119.   TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1;    
  120.   TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;    
  121.   /* PWM1 Mode configuration: Channel2 ,PA1在通道2*/    
  122.   TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;    
  123.   TIM_OCInitStructure.TIM_Pulse = 0xFFFF;    
  124.   TIM_OC2Init(TIM2, &TIM_OCInitStructure);    
  125.     /* PWM1 Mode configuration: Channel3 PA2在通道3*/    
  126.   TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;    
  127.   TIM_OCInitStructure.TIM_Pulse = 0xFFFF;    
  128.   TIM_OC3Init(TIM2, &TIM_OCInitStructure);    
  129.     /* PWM1 Mode configuration: Channel4 PA3在通道4*/    
  130.   TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;    
  131.   TIM_OCInitStructure.TIM_Pulse = 0xFFFF;    
  132.   TIM_OC4Init(TIM2, &TIM_OCInitStructure);    
  133.   TIM_ARRPreloadConfig(TIM2, ENABLE);    
  134. }    
  135. void ADC_CONFIG(){    
  136.     ADC_InitTypeDef ADC_InitStructure;    
  137.     #if defined (STM32F10X_LD_VL) || defined (STM32F10X_MD_VL) || defined (STM32F10X_HD_VL)    
  138.   /* ADCCLK = PCLK2/2 */    
  139.   RCC_ADCCLKConfig(RCC_PCLK2_Div2);     
  140. #else    
  141.   /* ADCCLK = PCLK2/4 */    
  142.   RCC_ADCCLKConfig(RCC_PCLK2_Div4);     
  143. #endif    
  144. ADC_DeInit(ADC1);    
  145.   /* Enable ADC1 and GPIOC clock */    
  146.   RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1 | RCC_APB2Periph_GPIOB, ENABLE);    
  147.     /* Configure PB0 (ADC Channel14) as analog input -------------------------*/    
  148.   GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;//ADC所在端口PB0    
  149.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;//模拟输入模式    
  150.   GPIO_Init(GPIOB, &GPIO_InitStructure);    
  151.   /* ADC1 configuration ------------------------------------------------------*/    
  152.   ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;    
  153.   ADC_InitStructure.ADC_ScanConvMode = ENABLE;    
  154.   ADC_InitStructure.ADC_ContinuousConvMode = ENABLE;    
  155.   ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;    
  156.   ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;//ADC数据右对齐    
  157.   ADC_InitStructure.ADC_NbrOfChannel = 1;//ADC通道数为1    
  158.   ADC_Init(ADC1, &ADC_InitStructure);//初始化ADC1    
  159.   /* Enable ADC1 DMA */    
  160.   ADC_DMACmd(ADC1, ENABLE);    
  161.   /* Enable ADC1 */    
  162.   ADC_Cmd(ADC1, ENABLE);    
  163. }    
  164.     
  165. int Get_ADC(){    
  166.      /* ADC1 regular channel configuration */     
  167.   ADC_RegularChannelConfig(ADC1, ADC_Channel_8, 1, ADC_SampleTime_55Cycles5);//通道:8 ,采样时间    
  168.     /* Enable ADC1 reset calibration register */       
  169.   ADC_ResetCalibration(ADC1);//重置ADC1的校准寄存器    
  170.   /* Check the end of ADC1 reset calibration register */    
  171.   while(ADC_GetResetCalibrationStatus(ADC1));//确认重置完毕    
  172.   /* Start ADC1 calibration */    
  173.   ADC_StartCalibration(ADC1);    
  174.   /* Check the end of ADC1 calibration */    
  175.   while(ADC_GetCalibrationStatus(ADC1));    
  176.   /* Start ADC1 Software Conversion */     
  177.   ADC_SoftwareStartConvCmd(ADC1, ENABLE);  
  178.     return ADC_GetConversionValue(ADC1);    
  179. }    
  180. void PWM_TEST()    
  181. {    
  182.      
  183.     unsigned int temp0=volt,temp1=0,temp2=volt;    
  184.     printf("PWM-RGB TEST......\r\n");    
  185.    for(;(temp0>0)||(temp1<volt);temp0--,temp1++)     
  186.    {    
  187.        TIM_SetCompare2(TIM2, temp0);//temp0:volt~0    
  188.      TIM_SetCompare3(TIM2, temp1);//temp1:0~volt    
  189.        delay_us(1000);    
  190.    }    
  191.      for(;(temp0<volt)||(temp2>0);temp0++,temp2--)    
  192.      {    
  193.        TIM_SetCompare2(TIM2, temp0);//temp0:0~volt    
  194.        TIM_SetCompare4(TIM2, temp2);//temp2:volt~0    
  195.        delay_us(1000);    
  196.    }    
  197.    for(;(temp1>0)||(temp2<volt);temp1--,temp2++)  
  198.    {    
  199.        TIM_SetCompare4(TIM2, temp2);//temp2:0~volt    
  200.        TIM_SetCompare3(TIM2, temp1);//temp1:volt~0    
  201.        delay_us(1000);    
  202.    }    
  203. }    
  204. int main(void)    
  205. {    
  206.   float Volt=0.00;    
  207.     int ADValue = 0;    
  208.   RCC_Configuration();    
  209.   USART_int(115200);    
  210.     ADC_CONFIG();    
  211.     Get_ADC();    
  212.     PWM_Config();    
  213.     delay_ms(1000);    
  214.     printf(" config done...\r\n");    
  215.     while(1)    
  216.     {    
  217.         ADValue = Get_ADC();    
  218.         Volt = VREF*ADValue/4095;    
  219.         volt=Volt*1000;    
  220.         printf("===============================\r\n");    
  221.         printf("The ADC value is:%d\r\n",ADValue);    
  222.         printf("The Volt is:%f V\r\n",Volt);    
  223.         printf("The volt is:%d \r\n",volt);    
  224.         PWM_TEST();    
  225.         delay_ms(500);    
  226.     }    
  227. }    
  228.     
  229. #ifdef  USE_FULL_ASSERT    
  230.     
  231. void assert_failed(uint8_t* file, uint32_t line)    
  232. {     
  233.   while (1)    
  234.   {    
  235.   }    
  236. }    
  237.     
  238. #endif    
  239.     
  240. #ifdef __GNUC__    
  241.   #define PUTCHAR_PROTOTYPE int __io_putchar(int ch)    
  242. #else    
  243.   #define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)    
  244. #endif /* __GNUC__ */    
  245.       
  246. PUTCHAR_PROTOTYPE    
  247. {    
  248.     
  249.   USART_SendData(EVAL_COM1, (uint8_t) ch);    
  250.   while (USART_GetFlagStatus(EVAL_COM1, USART_FLAG_TC) == RESET)    
  251.   {}    
  252.     
  253.   return ch;    
  254. }    
  255.     
  256. #ifdef  USE_FULL_ASSERT    
  257.     
  258. void assert_failed(uint8_t* file, uint32_t line)    
  259. {     
  260.   while (1)    
  261.   {    
  262.   }    
  263. }    
  264. #endif    

 


共9条 1/1 1 跳转至

回复

匿名不能发帖!请先 [ 登陆 注册 ]