这些小活动你都参加了吗?快来围观一下吧!>>
电子产品世界 » 论坛首页 » 高校专区 » 漓东e学堂 » 【更新】stm32系统滴答时钟18b20

共36条 4/4 |‹ 1 2 3 4 跳转至
菜鸟
2014-12-25 22:41:50     打赏
31楼
spi总线执行代码

 
#include "stm32f10x.h"  
#include "stm32_eval.h"  
#include <stdio.h>  
#include "spi_flash.h"  
#define VREF 3.3  
  
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);  
}  
  
  
#define TxBufferSize1   (countof(TxBuffer1) - 1)  
#define RxBufferSize1   (countof(TxBuffer1) - 1)  
#define countof(a)      (sizeof(a) / sizeof(*(a)))  
#define  BufferSize (countof(Tx_Buffer)-1)  
typedef enum { FAILED = 0, PASSED = !FAILED} TestStatus;  
#define  FLASH_WriteAddress     0x00000  
#define  FLASH_ReadAddress      FLASH_WriteAddress  
#define  FLASH_SectorToErase    FLASH_WriteAddress  
#define  sFLASH_ID              0xEF3015     //W25X16  
//#define  sFLASH_ID              0xEF4015   //W25Q16  
#define buff_size  16;       
char rx_buff[],rx_buff_count=0;  
/* ???????? */  
uint8_t Tx_Buffer[4096] ;  
uint8_t Rx_Buffer[BufferSize];  
__IO uint32_t DeviceID = 0;  
__IO uint32_t FlashID = 0;  
__IO TestStatus TransferStatus1 = FAILED;  
  
// ??????  
void Delay(__IO uint32_t nCount);  
TestStatus Buffercmp(uint8_t* pBuffer1, uint8_t* pBuffer2, uint16_t BufferLength);  
  
/** @addtogroup STM32F10x_StdPeriph_Examples 
  * @{ 
  */  
  
/** @addtogroup EXTI_Config 
  * @{ 
  */   
  
/* Private typedef -----------------------------------------------------------*/  
/* Private define ------------------------------------------------------------*/  
/* Private macro -------------------------------------------------------------*/  
/* Private variables ---------------------------------------------------------*/  
GPIO_InitTypeDef   GPIO_InitStructure;  
USART_InitTypeDef USART_InitStructure;  
USART_ClockInitTypeDef USART_ClockInitStructure;  
  
char *int_to_string(int number,char *strnum)//整形数据转换为字符型  
{  
int j=0,i=0,n=0;  
char temp;  
while(number>0)  
{  
*(strnum+j)=number%10+48;  
j++;  
number=number/10;  
n++;  
}  
  
      
for(i=0;i<n/2;i++)  
{  
temp=*(strnum+j+i-n);  
*(strnum+j+i-n)=*(strnum+j-i-1);  
*(strnum+j-i-1)=temp;  
}  
strnum[n]='\0';  
return strnum;  
}  
  
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);  
  
      
    //SystemInit();  
      
    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_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);  
      RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);  
}   
  
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_50MHz;  
    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);  
}  
  
TestStatus Buffercmp(uint8_t* pBuffer1, uint8_t* pBuffer2, uint16_t BufferLength)  
{  
  while(BufferLength--)  
  {  
    if(*pBuffer1 != *pBuffer2)  
    {  
      return FAILED;  
    }  
  
    pBuffer1++;  
    pBuffer2++;  
  }  
  return PASSED;  
}  
  
void Delay(__IO uint32_t nCount)  
{  
  for(; nCount != 0; nCount--);  
}  
  
void ADC_CONFIG(){  
    ADC_InitTypeDef ADC_InitStructure;  
    #if defined (STM32F10X_LD_VL) || defined (STM32F10X_MD_VL) || defined (STM32F10X_HD_VL)  
  /* ADCCLK = PCLK2/2 */  
  RCC_ADCCLKConfig(RCC_PCLK2_Div2);   
#else  
  /* ADCCLK = PCLK2/4 */  
  RCC_ADCCLKConfig(RCC_PCLK2_Div4);   
#endif  
ADC_DeInit(ADC1);  
  /* Enable ADC1 and GPIOC clock */  
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1 | RCC_APB2Periph_GPIOB, ENABLE);  
      
    /* Configure PB0 (ADC Channel14) as analog input -------------------------*/  
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;  
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;  
  GPIO_Init(GPIOB, &GPIO_InitStructure);  
      
    
  /* ADC1 configuration ------------------------------------------------------*/  
  ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;  
  ADC_InitStructure.ADC_ScanConvMode = ENABLE;  
  ADC_InitStructure.ADC_ContinuousConvMode = ENABLE;  
  ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;  
  ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;  
  ADC_InitStructure.ADC_NbrOfChannel = 1;  
  ADC_Init(ADC1, &ADC_InitStructure);  
  
  
  /* Enable ADC1 DMA */  
  ADC_DMACmd(ADC1, ENABLE);  
    
  /* Enable ADC1 */  
  ADC_Cmd(ADC1, ENABLE);  
  
}  
  
int Get_ADC(){  
     /* ADC1 regular channel configuration */   
  ADC_RegularChannelConfig(ADC1, ADC_Channel_8, 1, ADC_SampleTime_55Cycles5);  
    /* Enable ADC1 reset calibration register */     
  ADC_ResetCalibration(ADC1);  
  /* Check the end of ADC1 reset calibration register */  
  while(ADC_GetResetCalibrationStatus(ADC1));  
  
  /* Start ADC1 calibration */  
  ADC_StartCalibration(ADC1);  
  /* Check the end of ADC1 calibration */  
  while(ADC_GetCalibrationStatus(ADC1));  
       
  /* Start ADC1 Software Conversion */   
  ADC_SoftwareStartConvCmd(ADC1, ENABLE);  
      
    return ADC_GetConversionValue(ADC1);  
}  
  
  
void SPI_TEST()  
{  
    printf("\r\n这是一个2M SPI总线flash(W25X16)测试 \r\n");  
    SPI_FLASH_Init();  
    /* Get SPI Flash Device ID */  
    DeviceID = SPI_FLASH_ReadDeviceID();  
    Delay( 200 );  
    /* Get SPI Flash ID */  
    FlashID = SPI_FLASH_ReadID();  
    printf("\r\n FlashID is 0x%X,  Manufacturer Device ID is 0x%X\r\n", FlashID, DeviceID);  
    /* Check the SPI Flash ID */  
    if (FlashID == sFLASH_ID)  /* #define  sFLASH_ID  0xEF3015 */  
    {  
        printf("\r\n 检测到华邦flash W25X16 !\r\n");  
        /* Erase SPI FLASH Sector to write on */  
        SPI_FLASH_SectorErase(FLASH_SectorToErase);        
          
        /*写缓存并发送*/  
        SPI_FLASH_BufferWrite(Tx_Buffer, FLASH_WriteAddress, BufferSize);  
        printf("\r\n写入的数据是:%s \r\t", Tx_Buffer);  
          
        /* 读出刚才写入的数据*/  
        SPI_FLASH_BufferRead(Rx_Buffer, FLASH_ReadAddress, BufferSize);  
        printf("\r\n读出的数据是:%s \r\n", Rx_Buffer);  
          
        /* ????????????????? */  
        TransferStatus1 = Buffercmp(Tx_Buffer, Rx_Buffer, BufferSize);  
          
        if( PASSED == TransferStatus1 )  
        {      
            printf("\r\n 2M SPI总线flash(W25X16)测试成功!\n\r");  
        }  
        else  
        {          
            printf("\r\n 2M SPI总线flash(W25X16)测试失败!\n\r");  
        }  
    }// if (FlashID == sFLASH_ID)  
    else  
    {      
        printf("\r\n 未检测到 W25X16 ID!\n\r");  
    }  
      
    SPI_Flash_PowerDown();    
    printf("\r\n=================================================\n\r");  
}  
/* Private functions ---------------------------------------------------------*/  
  
/** 
  * @brief  Main program. 
  * @param  None 
  * @retval None 
  */  
int main(void)  
{  
          
  /*!< At this stage the microcontroller clock setting is already configured,  
       this is done through SystemInit() function which is called from startup 
       file (startup_stm32f10x_xx.s) before to branch to application main. 
       To reconfigure the default setting of SystemInit() function, refer to 
       system_stm32f10x.c file 
     */       
         
  /* System Clocks Configuration */  
    int i=0;  
    int ADValue = 0;  
     char shu[20];  
  RCC_Configuration();  
  USART_int(115200);  
 printf(" config done...\r\n");  
    ADC_CONFIG();  
    delay_ms(1000);  
    while(1)  
    {  
          
        for(i=0;i<5;i++)  
        {   
              ADValue = Get_ADC();  
              int_to_string(ADValue,shu);  
            Tx_Buffer[i]=shu[i];  
    }  
      SPI_TEST();  
        delay_ms(1000);  
    }  
}  
  
  
  
  
#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  
  

 


菜鸟
2014-12-25 23:29:41     打赏
32楼

#include "stm32f10x.h"    
#include "stm32_eval.h"    
#include <stdio.h>    
#define VREF 3.3    
GPIO_InitTypeDef   GPIO_InitStructure;    
USART_InitTypeDef USART_InitStructure;    
USART_ClockInitTypeDef USART_ClockInitStructure;    
    
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);  
*/    
    SystemInit();    
    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_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);    
      RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);    
}     
    
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);    
}    
    
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 PWM_Config()    
{uint16_t PrescalerValue = 0;    
    TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;    
TIM_OCInitTypeDef  TIM_OCInitStructure;    
    /* TIM2 clock enable */    
  RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);    
  /* GPIOA  enable */    
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO  , ENABLE);    
        
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3;    
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;    
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;    
  GPIO_Init(GPIOA, &GPIO_InitStructure);    
        TIM_Cmd(TIM2, ENABLE);    
      /* Compute the prescaler value */    
  PrescalerValue = (uint16_t) (SystemCoreClock / 24000000) - 1;    
  /* Time base configuration */    
  TIM_TimeBaseStructure.TIM_Period = 0x07FF;    
  TIM_TimeBaseStructure.TIM_Prescaler = PrescalerValue;    
  TIM_TimeBaseStructure.TIM_ClockDivision = 0;    
  TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;    
  TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure);    
  TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1;    
  TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;    
  /* PWM1 Mode configuration: Channel2 */    
  TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;    
  TIM_OCInitStructure.TIM_Pulse = 0xFFFF;    
  TIM_OC2Init(TIM2, &TIM_OCInitStructure);    
    /* PWM1 Mode configuration: Channel3 */    
  TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;    
  TIM_OCInitStructure.TIM_Pulse = 0xFFFF;    
  TIM_OC3Init(TIM2, &TIM_OCInitStructure);    
    /* PWM1 Mode configuration: Channel4 */    
  TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;    
  TIM_OCInitStructure.TIM_Pulse = 0xFFFF;    
  TIM_OC4Init(TIM2, &TIM_OCInitStructure);    
  TIM_ARRPreloadConfig(TIM2, ENABLE);    
}    
    
    
    
void ADC_CONFIG(){    
    ADC_InitTypeDef ADC_InitStructure;    
    #if defined (STM32F10X_LD_VL) || defined (STM32F10X_MD_VL) || defined (STM32F10X_HD_VL)     
  RCC_ADCCLKConfig(RCC_PCLK2_Div2);     
#else    
  /* ADCCLK = PCLK2/4 */    
  RCC_ADCCLKConfig(RCC_PCLK2_Div4);     
#endif    
ADC_DeInit(ADC1);      
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1 | RCC_APB2Periph_GPIOB, ENABLE);    
     
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;    
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;    
  GPIO_Init(GPIOB, &GPIO_InitStructure);    
        
       
  ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;    
  ADC_InitStructure.ADC_ScanConvMode = ENABLE;    
  ADC_InitStructure.ADC_ContinuousConvMode = ENABLE;    
  ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;    
  ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;    
  ADC_InitStructure.ADC_NbrOfChannel = 1;    
  ADC_Init(ADC1, &ADC_InitStructure);    
    
    
  
  ADC_DMACmd(ADC1, ENABLE);    
  ADC_Cmd(ADC1, ENABLE);    
    
}    
    
int Get_ADC(){    
  ADC_RegularChannelConfig(ADC1, ADC_Channel_8, 1, ADC_SampleTime_55Cycles5);         
  ADC_ResetCalibration(ADC1);      
  while(ADC_GetResetCalibrationStatus(ADC1));     
  ADC_StartCalibration(ADC1);      
  while(ADC_GetCalibrationStatus(ADC1));       
  ADC_SoftwareStartConvCmd(ADC1, ENABLE);    
        
    return ADC_GetConversionValue(ADC1);    
}    
    
void PWM_TEST()    
{     
    float Volt=0.00;    
    unsigned int temp0,temp1,temp2,ADValue = 0;    
    while(1)    
{    
      ADValue = Get_ADC();    
        Volt = VREF*ADValue/4095;    
        printf("===============================\r\n");    
        printf("The ADC value is:%d\r\n",ADValue);    
        printf("The Volt is:%f V\r\n",Volt);    
      TIM_SetCompare2(TIM2, temp0);    
      TIM_SetCompare3(TIM2, temp1);    
      TIM_SetCompare4(TIM2, temp2);    
        if(ADValue>3000)    
         {  temp0=ADValue/2-1300;temp1=ADValue/2-700;temp2=ADValue/2-150;    
         }if(2000<ADValue<=3000)    
        {  temp0=ADValue/2-300;temp1=ADValue/2-900;temp2=ADValue/2-50;    
        }if(1000<ADValue<=2000)    
        {  temp0=ADValue/2+900;temp1=ADValue/2;temp2=ADValue/2-500;    
        }if(ADValue<=1000)    
        {  temp0=ADValue+100;temp1=ADValue+600;temp2=ADValue+1000;    
        }    
            delay_ms(50);    
}    
        
}    
    
  
int main(void)    
{    
    RCC_Configuration();    
  USART_int(115200);    
    ADC_CONFIG();    
    printf(" config done...\r\n");    
    Get_ADC();    
    PWM_Config();    
    delay_ms(200);    
    while(1)    
    {      
        PWM_TEST();    
    }    
}    
    
    
    
#ifdef  USE_FULL_ASSERT    
    
  
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__ */    
      
    
    
  
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    

 


菜鸟
2014-12-25 23:46:08     打赏
33楼

#include "stm32f10x.h"    
#include "stm32_eval.h"    
#include <stdio.h>    
#define VREF 3.3    
GPIO_InitTypeDef   GPIO_InitStructure;    
USART_InitTypeDef USART_InitStructure;    
USART_ClockInitTypeDef USART_ClockInitStructure;    
    
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);  
*/    
    SystemInit();    
    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_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);    
      RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);    
}     
    
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);    
}    
    
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 PWM_Config()    
{uint16_t PrescalerValue = 0;    
    TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;    
TIM_OCInitTypeDef  TIM_OCInitStructure;    
    /* TIM2 clock enable */    
  RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);    
  /* GPIOA  enable */    
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO  , ENABLE);    
        
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3;    
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;    
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;    
  GPIO_Init(GPIOA, &GPIO_InitStructure);    
        TIM_Cmd(TIM2, ENABLE);    
      /* Compute the prescaler value */    
  PrescalerValue = (uint16_t) (SystemCoreClock / 24000000) - 1;    
  /* Time base configuration */    
  TIM_TimeBaseStructure.TIM_Period = 0x07FF;    
  TIM_TimeBaseStructure.TIM_Prescaler = PrescalerValue;    
  TIM_TimeBaseStructure.TIM_ClockDivision = 0;    
  TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;    
  TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure);    
  TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1;    
  TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;    
  /* PWM1 Mode configuration: Channel2 */    
  TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;    
  TIM_OCInitStructure.TIM_Pulse = 0xFFFF;    
  TIM_OC2Init(TIM2, &TIM_OCInitStructure);    
    /* PWM1 Mode configuration: Channel3 */    
  TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;    
  TIM_OCInitStructure.TIM_Pulse = 0xFFFF;    
  TIM_OC3Init(TIM2, &TIM_OCInitStructure);    
    /* PWM1 Mode configuration: Channel4 */    
  TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;    
  TIM_OCInitStructure.TIM_Pulse = 0xFFFF;    
  TIM_OC4Init(TIM2, &TIM_OCInitStructure);    
  TIM_ARRPreloadConfig(TIM2, ENABLE);    
}    
    
    
    
void ADC_CONFIG(){    
    ADC_InitTypeDef ADC_InitStructure;    
    #if defined (STM32F10X_LD_VL) || defined (STM32F10X_MD_VL) || defined (STM32F10X_HD_VL)     
  RCC_ADCCLKConfig(RCC_PCLK2_Div2);     
#else    
  /* ADCCLK = PCLK2/4 */    
  RCC_ADCCLKConfig(RCC_PCLK2_Div4);     
#endif    
ADC_DeInit(ADC1);      
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1 | RCC_APB2Periph_GPIOB, ENABLE);    
     
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;    
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;    
  GPIO_Init(GPIOB, &GPIO_InitStructure);    
        
       
  ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;    
  ADC_InitStructure.ADC_ScanConvMode = ENABLE;    
  ADC_InitStructure.ADC_ContinuousConvMode = ENABLE;    
  ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;    
  ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;    
  ADC_InitStructure.ADC_NbrOfChannel = 1;    
  ADC_Init(ADC1, &ADC_InitStructure);    
    
    
  
  ADC_DMACmd(ADC1, ENABLE);    
  ADC_Cmd(ADC1, ENABLE);    
    
}    
    
int Get_ADC(){    
  ADC_RegularChannelConfig(ADC1, ADC_Channel_8, 1, ADC_SampleTime_55Cycles5);         
  ADC_ResetCalibration(ADC1);      
  while(ADC_GetResetCalibrationStatus(ADC1));     
  ADC_StartCalibration(ADC1);      
  while(ADC_GetCalibrationStatus(ADC1));       
  ADC_SoftwareStartConvCmd(ADC1, ENABLE);    
        
    return ADC_GetConversionValue(ADC1);    
}    
    
void PWM_TEST()    
{     
    float Volt=0.00;    
    unsigned int temp0,temp1,temp2,ADValue = 0;    
    while(1)    
{    
      ADValue = Get_ADC();    
        Volt = VREF*ADValue/4095;    
        printf("===============================\r\n");    
        printf("The ADC value is:%d\r\n",ADValue);    
        printf("The Volt is:%f V\r\n",Volt);    
      TIM_SetCompare2(TIM2, temp0);    
      TIM_SetCompare3(TIM2, temp1);    
      TIM_SetCompare4(TIM2, temp2);    
        if(ADValue>3000)    
         {  temp0=ADValue/2-1300;temp1=ADValue/2-700;temp2=ADValue/2-150;    
         }if(2000<ADValue<=3000)    
        {  temp0=ADValue/2-300;temp1=ADValue/2-900;temp2=ADValue/2-50;    
        }if(1000<ADValue<=2000)    
        {  temp0=ADValue/2+900;temp1=ADValue/2;temp2=ADValue/2-500;    
        }if(ADValue<=1000)    
        {  temp0=ADValue+100;temp1=ADValue+600;temp2=ADValue+1000;    
        }    
            delay_ms(50);    
}    
        
}    
    
  
int main(void)    
{    
    RCC_Configuration();    
  USART_int(115200);    
    ADC_CONFIG();    
    printf(" config done...\r\n");    
    Get_ADC();    
    PWM_Config();    
    delay_ms(200);    
    while(1)    
    {      
        PWM_TEST();    
    }    
}    
    
    
    
#ifdef  USE_FULL_ASSERT    
    
  
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__ */    
      
    
    
  
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    

 


菜鸟
2014-12-25 23:52:21     打赏
34楼

高工
2015-01-06 21:12:43     打赏
35楼
还不错

菜鸟
2015-02-06 21:00:01     打赏
36楼
啥?你说视频啊,。。哈哈

共36条 4/4 |‹ 1 2 3 4 跳转至

回复

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