|
100黑幣
論壇下載的STM32F103C8T6八路ADC串口輸出程序,仿真時有輸出,但PA9 和PA10都波形都是0,下載到板子上串口沒有輸出
/**
* 文件名 :main.c
* 描述 :串口1(USART1)向電腦的超級終端以1s為間隔打印當前ADC1的轉換電壓值
* 實驗平臺:MINI STM32開發板 基于STM32F103C8T6
* 庫版本 :ST3.0.0
**********************************************************************************/
#include "stm32f10x.h"
#include "usart1.h"
#include "adc.h"
#include "stdio.h"
extern __IO u16 ADC_ConvertedValue[9];
// 軟件延時
void Delay(unsigned long time)
{unsigned long i,j;
for(j=0; j<time; j++)
{
for(i=0;i<12000;i++);
}
}
int main(void)
{
volatile u32 AD1_value,AD2_value,AD3_value,AD4_value,AD5_value,AD6_value,AD7_value,AD8_value;
/* 配置系統時鐘為72M */
SystemInit();
/* 配置串口 */
USART1_Config();
/* 初始化ADC1 */
ADC1_Init();
printf("\r\n -------這是一個ADC實驗------\r\n");
printf("\r\n -------ADC采樣的是PA0口------\r\n");
while (1)
{
Delay(500);
AD1_value = 3300000/4096*ADC_ConvertedValue[0]/1000*1.53;
AD2_value = 3300000/4096*ADC_ConvertedValue[1]/1000*1.53;
AD3_value = 3300000/4096*ADC_ConvertedValue[2]/1000*1.53;
AD4_value = 3300000/4096*ADC_ConvertedValue[3]/1000*1.53;
AD5_value = 3300000/4096*ADC_ConvertedValue[4]/1000*1.53;
AD6_value = 3300000/4096*ADC_ConvertedValue[5]/1000*1.53;
AD7_value = 3300000/4096*ADC_ConvertedValue[6]/1000*1.53;
AD8_value = 3300000/4096*ADC_ConvertedValue[7]/1000*1.53;
printf("AD1 value = %d mV \r\n", AD1_value);
printf("AD2 value = %d mV \r\n", AD2_value);
printf("AD3 value = %d mV \r\n", AD3_value);
printf("AD4 value = %d mV \r\n", AD4_value);
printf("AD5 value = %d mV \r\n", AD5_value);
printf("AD6 value = %d mV \r\n", AD6_value);
printf("AD7 value = %d mV \r\n", AD7_value);
printf("AD8 value = %d mV \r\n", AD8_value);
}
}
/********
* 文件名 :usart1.c
* 描述 :將printf函數重定向到USART1。這樣就可以用printf函數將單片機的數據
* 打印到PC上的超級終端或串口調試助手。
* 實驗平臺:MINI STM32開發板 基于STM32F103C8T6
* 硬件連接:------------------------
* | PA9 - USART1(Tx) |
* | PA10 - USART1(Rx) |
* ------------------------
* 庫版本 :ST3.0.0 *
**********************************************************************************/
#include "usart1.h"
#include <stdarg.h>
#include <stdio.h>
void USART1_Config(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
USART_InitTypeDef USART_InitStructure;
/* 使能 USART1 時鐘*/
RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_GPIOA, ENABLE);
/* USART1 使用IO端口配置 */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; //復用推挽輸出
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOA, &GPIO_InitStructure);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; //浮空輸入
GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;
GPIO_Init(GPIOA, &GPIO_InitStructure); //初始化GPIOA
/* USART1 工作模式配置 */
USART_InitStructure.USART_BaudRate = 115200; //波特率設置:115200
USART_InitStructure.USART_WordLength = USART_WordLength_8b; //數據位數設置:8位
USART_InitStructure.USART_StopBits = USART_StopBits_1; //停止位設置:1位
USART_InitStructure.USART_Parity = USART_Parity_No ; //是否奇偶校驗:無
USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None; //硬件流控制模式設置:沒有使能
USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;//接收與發送都使能
USART_Init(USART1, &USART_InitStructure); //初始化USART1
USART_Cmd(USART1, ENABLE);// USART1使能
}
/* 描述 :重定向c庫函數printf到USART1*/
int fputc(int ch, FILE *f)
{
/* 將Printf內容發往串口 */
USART_SendData(USART1, (unsigned char) ch);
while (!(USART1->SR & USART_FLAG_TXE));
return (ch);
}
|
|