5803|7

82

帖子

0

TA的资源

一粒金砂(中级)

楼主
 

有人帮我看看代码吗,问题在adc1和adc2处 [复制链接]

#include "stm32f10x_lib.h"
#include "main.h"
#include "platform_config.h"
#include "main.h"
#include
static vu32 TimingDelay = 0;  
ADC_InitTypeDef  ADC_InitStructure;
USART_InitTypeDef USART_InitStructure;
ErrorStatus HSEStartUpStatus;
void RCC_Configuration(void);
void GPIO_Configuration(void);
void USART_Configuration(void);
u16 adc1(void);
u16 adc2(void);
int main(void)
{
int AD_value;
u8 i,j;
#ifdef DEBUG
debug();
#endif
RCC_Configuration();
GPIO_Configuration();
USART_Configuration();
SysTick_Config();
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 = 2;
ADC_Init(ADC1, &ADC_InitStructure);
while (1)
{
  AD_value = adc1();
//      ADC_SoftwareStartConvCmd(ADC1, DISABLE);
  ADC_Cmd(ADC1,  DISABLE);
  j=AD_value%256;
  i=AD_value/256;
  USART_SendData(USART1, i);
  while(USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  USART_SendData(USART1, j);
  while(USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  Delay(200);
  AD_value = adc2();
//      ADC_SoftwareStartConvCmd(ADC1, DISABLE);
  ADC_Cmd(ADC1,  DISABLE);
  j=AD_value%256;
  i=AD_value/256;
  i=i|0xf0;
  USART_SendData(USART1, i);
  while(USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  USART_SendData(USART1, j);
  while(USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
  Delay(200);
}
}
u16 adc1(void)
{
ADC_RegularChannelConfig(ADC1, ADC_Channel_9, 1, ADC_SampleTime_13Cycles5);
ADC_Cmd(ADC1, ENABLE);
ADC_ResetCalibration(ADC1);
while(ADC_GetResetCalibrationStatus(ADC1));
ADC_StartCalibration(ADC1);
while(ADC_GetCalibrationStatus(ADC1));
//  ADC_SoftwareStartConvCmd(ADC1, ENABLE);
return(ADC_GetConversionValue(ADC1));
}
u16 adc2(void)
{
ADC_RegularChannelConfig(ADC1, ADC_Channel_10, 1, ADC_SampleTime_13Cycles5);
ADC_Cmd(ADC1, ENABLE);
ADC_ResetCalibration(ADC1);
while(ADC_GetResetCalibrationStatus(ADC1));
ADC_StartCalibration(ADC1);
while(ADC_GetCalibrationStatus(ADC1));
//  ADC_SoftwareStartConvCmd(ADC1, ENABLE);
return(ADC_GetConversionValue(ADC1));
}
void RCC_Configuration(void)
{
RCC_DeInit();  //将外设 RCC寄存器重设为缺省值      V
RCC_HSEConfig(RCC_HSE_ON);   //#define RCC_HSE_ON    ((u32)0x00010000)   V
HSEStartUpStatus = RCC_WaitForHSEStartUp(); //等待HSE起振   该函数将等待直到 HSE 就绪,或者在超时的情况下退出   V
if(HSEStartUpStatus == SUCCESS)
{
  FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);  //使能或者失能预取指缓存
  FLASH_SetLatency(FLASH_Latency_2);  //设置代码延时值      2个延时周期
  RCC_HCLKConfig(RCC_SYSCLK_Div1);     //设置 AHB 时钟(HCLK)  即设置AHB时钟     V
  RCC_PCLK2Config(RCC_HCLK_Div1);    //设置高速 AHB 时钟(PCLK2) 即设置APB2时钟    V
  RCC_PCLK1Config(RCC_HCLK_Div2);    //设置低速 AHB 时钟(PCLK1) 即设置APB1时钟    V
  RCC_ADCCLKConfig(RCC_PCLK2_Div4);    //设置 ADC 时钟
  RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_7);  //设置 PLL 时钟源及倍频系数      V
  RCC_PLLCmd(ENABLE);    //使能或者失能 PLL                 V
  while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)  //检查指定的 RCC 标志位设置与否    V
  {    }
  RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);  //设置系统时钟          V
  while(RCC_GetSYSCLKSource() != 0x08)               // V
  { }
}
RCC_APB2PeriphClockCmd(RCC_APB2Periph_ALL, ENABLE); //使能或者失能 APB2 外设时钟     V
}
void GPIO_Configuration(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
GPIO_Init(GPIO_LED, &GPIO_InitStructure);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
GPIO_Init(GPIOB, &GPIO_InitStructure);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;
GPIO_Init(GPIOC, &GPIO_InitStructure);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_Init(GPIOA, &GPIO_InitStructure);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_Init(GPIOA, &GPIO_InitStructure);
}
void SysTick_Config(void)
{
SysTick_CLKSourceConfig(SysTick_CLKSource_HCLK);    //设置 SysTick时钟源
SysTick_SetReload(720000);
SysTick_ITConfig(ENABLE);
}
void Delay(u32 nCount)
{
TimingDelay = nCount;
SysTick_CounterCmd(SysTick_Counter_Enable); //使能或者失能 SysTick 计数器
while(TimingDelay != 0)
{}
SysTick_CounterCmd(SysTick_Counter_Disable);
SysTick_CounterCmd(SysTick_Counter_Clear);
}
void Decrement_TimingDelay(void)
{
if (TimingDelay != 0x00)
{
TimingDelay--;
}
}
void USART_Configuration(void)
{
USART_InitStructure.USART_BaudRate = 9600;
USART_InitStructure.USART_WordLength = USART_WordLength_8b;
USART_InitStructure.USART_StopBits = USART_StopBits_1;
USART_InitStructure.USART_Parity =USART_Parity_No ;
USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
USART_InitStructure.USART_Mode = USART_Mode_Tx| USART_Mode_Rx;
USART_InitStructure.USART_Clock = USART_Clock_Disable;
USART_InitStructure.USART_CPOL = USART_CPOL_Low;
USART_InitStructure.USART_CPHA = USART_CPHA_2Edge;
USART_InitStructure.USART_LastBit = USART_LastBit_Disable;
USART_Init(USART1, &USART_InitStructure);
USART_Cmd(USART1, ENABLE);
}
此帖出自stm32/stm8论坛

最新回复

你不是一分钟搞一次AD转换吗?使用定时器启动单次转换,ADC转换完成后使用中断,在那里读值,这样不影响整个系统的,ADC的开消很小。  详情 回复 发表于 2012-12-15 15:48
点赞 关注
 

回复
举报

436

帖子

5

TA的资源

五彩晶圆(初级)

沙发
 
实在是不想调代码了
此帖出自stm32/stm8论坛

点评

关注adc1和adc2  详情 回复 发表于 2012-12-15 14:47
 
 

回复

82

帖子

0

TA的资源

一粒金砂(中级)

板凳
 

回复 沙发 lr2131 的帖子

关注adc1和adc2
此帖出自stm32/stm8论坛
 
 

回复

1万

帖子

25

TA的资源

裸片初长成(高级)

4
 
看看ST的例程,照着人家的做吧。

1、你的那个adc1()和adc2中的功能,应该放到初始化函数中,不要每次都要初始化一次。
2、while(ADC_GetCalibrationStatus(ADC1));
//  ADC_SoftwareStartConvCmd(ADC1, ENABLE);
return(ADC_GetConversionValue(ADC1));
ADC还在校准呢,你就读ADC结果?
此帖出自stm32/stm8论坛

点评

https://bbs.eeworld.com.cn/thread-362144-1-1.html,sorry 忘记复制粘贴了  详情 回复 发表于 2012-12-15 15:26
关于第一个问题config的问题我不知道是配置成 ADC_RegularChannelConfig(ADC1, ADC_Channel_9, 1, ADC_SampleTime_13Cycles5); ADC_RegularChannelConfig(ADC1, ADC_Channel_10, 1, ADC_SampleTime_13Cycles5);  详情 回复 发表于 2012-12-15 15:25
 
 
 

回复

82

帖子

0

TA的资源

一粒金砂(中级)

5
 

回复 4楼 dontium 的帖子

关于第一个问题config的问题我不知道是配置成
ADC_RegularChannelConfig(ADC1, ADC_Channel_9, 1, ADC_SampleTime_13Cycles5);
ADC_RegularChannelConfig(ADC1, ADC_Channel_10, 1, ADC_SampleTime_13Cycles5);
还是
ADC_RegularChannelConfig(ADC1, ADC_Channel_9, 1, ADC_SampleTime_13Cycles5);
ADC_RegularChannelConfig(ADC1, ADC_Channel_10, 2, ADC_SampleTime_13Cycles5);
因为涉及到关闭后的再次打开,所以不清楚怎么弄
关于第二个问题,我这两天已经加了while(!ADC_GetFlagStatus(ADC1,ADC_FLAG_EOC)),但是没有效果

这是我发的另外一个帖子,看了你就明白我大概想做的东西了
此帖出自stm32/stm8论坛
 
 
 

回复

82

帖子

0

TA的资源

一粒金砂(中级)

6
 

回复 4楼 dontium 的帖子

https://bbs.eeworld.com.cn/thread-362144-1-1.html,sorry 忘记复制粘贴了
此帖出自stm32/stm8论坛
 
 
 

回复

1万

帖子

25

TA的资源

裸片初长成(高级)

7
 
你不是一分钟搞一次AD转换吗?使用定时器启动单次转换,ADC转换完成后使用中断,在那里读值,这样不影响整个系统的,ADC的开消很小。
此帖出自stm32/stm8论坛

点评

亲,这不是关键,关键是通道切换功能没有实现  详情 回复 发表于 2012-12-15 16:13
 
 
 

回复

82

帖子

0

TA的资源

一粒金砂(中级)

8
 

回复 7楼 dontium 的帖子

亲,这不是关键,关键是通道切换功能没有实现
此帖出自stm32/stm8论坛
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/7 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表