5105|8

9790

帖子

24

TA的资源

版主

楼主
 

谁有使用ASF采集两个以上ADC数据的程序? [复制链接]

Atmel Studio 6.2里提供的例程都是一路的,我试着改配置,在采集完通道0后再采集通道1,怎么也调不过。
代码里单独采集通道0和通道1都能正常读到数据。

最后完全复制一份配置和代码,一份是通道0一份是通道1,通道0配置,读取,通道1配置,读取。也不能正常读到数据。

快被折磨屎了。

最新回复

主程序中用下面语句读出。结果也是按采集顺序交错的。                 adc_read_buffer_job(&adc_instance, adc_result_buffer, ADC_SAMPLES);                 //! [job_complete_poll]                 while (adc_read_done == false)                 {                         /* Wait for asynchronous ADC read to complete */                 }                   详情 回复 发表于 2015-4-4 19:33
点赞 关注
个人签名虾扯蛋,蛋扯虾,虾扯蛋扯虾
 

回复
举报

1万

帖子

25

TA的资源

版主

沙发
 
可以参考我的程序,里面采集了两路ADC的信号。

https://bbs.eeworld.com.cn/thread-457318-1-1.html

 
 
 

回复

1万

帖子

25

TA的资源

版主

板凳
 


参考函数,这个是SAM R21的,其他型号应该也差不多吧:



  1. uint16_t ADC_get(uint8_t chn)
  2. {
  3.         struct adc_config config_adc;
  4.         struct adc_module adc_instance;
  5.         volatile uint16_t result;

  6.         adc_get_config_defaults(&config_adc);
  7.         config_adc.positive_input = chn;
  8.         config_adc.reference = ADC_REFERENCE_INTVCC1;
  9.         config_adc.gain_factor = ADC_INPUTCTRL_GAIN_DIV2;
  10.         config_adc.clock_prescaler = ADC_CLOCK_PRESCALER_DIV256;
  11.         config_adc.accumulate_samples = ADC_AVGCTRL_SAMPLENUM_8;
  12.         adc_init(&adc_instance, ADC, &config_adc);
  13.         adc_enable(&adc_instance);

  14.         adc_start_conversion(&adc_instance);

  15.         do {
  16.         } while (adc_read(&adc_instance, &result) == STATUS_BUSY);
  17.         adc_disable(&adc_instance);

  18.         return result;
  19. }
复制代码




点评

你的代码测试了很好用。 我在调试的时候发现在下一次执行adc_init()时提示错误信息 /* Module must be disabled before initialization. Abort. */ 你的代码在采集完数据后把ADC关闭了正好解决这个问题,非常  详情 回复 发表于 2015-4-2 14:39
 
 
 

回复

3416

帖子

0

TA的资源

纯净的硅(高级)

4
 
有木有这么诡异?

点评

下一次初始化时没有关闭ADC,所以报错。  详情 回复 发表于 2015-4-2 14:39
 
个人签名

So TM what......?

 

 

回复

9790

帖子

24

TA的资源

版主

5
 
dcexpert 发表于 2015-4-2 14:11
参考函数,这个是SAM R21的,其他型号应该也差不多吧:

你的代码测试了很好用。

我在调试的时候发现在下一次执行adc_init()时提示错误信息                /* Module must be disabled before initialization. Abort. */

你的代码在采集完数据后把ADC关闭了正好解决这个问题,非常感谢。



像这种每采集一个通道就要初始化,使能,再禁能,这样做效率会不会很低?有其它办法可以实现再高效的数据采集吗?比如MSP430的ADC序列功能?

点评

每次都重新初始化,效率肯定不高。但是如果要求不太高,这样也够用了,MCU速度是足够快的。如果需要高速ADC,这样应该是不行。这个是使用了查询方式等待ADC转换,使用中断方式可能会骚好一点。 ASF这个架构虽然  详情 回复 发表于 2015-4-2 15:22
 
个人签名虾扯蛋,蛋扯虾,虾扯蛋扯虾
 
 

回复

9790

帖子

24

TA的资源

版主

6
 
ljj3166 发表于 2015-4-2 14:35
有木有这么诡异?

下一次初始化时没有关闭ADC,所以报错。
 
个人签名虾扯蛋,蛋扯虾,虾扯蛋扯虾
 
 

回复

1万

帖子

25

TA的资源

版主

7
 
本帖最后由 dcexpert 于 2015-4-2 15:26 编辑
littleshrimp 发表于 2015-4-2 14:39
你的代码测试了很好用。

我在调试的时候发现在下一次执行adc_init()时提示错误信息                /* Module must be disabled before initialization. Abort. */

你的代码在采集完数据后把ADC关闭了正好解决这个问题,非常感谢。



像这种每采集一个通道就要初始化,使能,再禁能,这样做效率会不会很低?有其它办法可以实现再高效的数据采集吗?比如MSP430的ADC序列功能?

每次都重新初始化,效率肯定不高。但是如果要求不太高,这样也够用了,MCU速度是足够快的。如果需要高速ADC,这样应该是不行。这个是使用了查询方式等待ADC转换,使用中断方式可能会稍好一点。高速采样通常会使用DMA方式。

ASF这个架构虽然使用方便,不用关心太多底层细节,但是也限制了很多东西。ATMEL现在好像还不支持ADC多通道扫描方式(也可能是我没有看到,至少ASF中没有这个选项)。但是它支持多次采样以及过采样提高转换精度,这个功能在其他MCU中很少见到。


 
 
 

回复

1305

帖子

0

TA的资源

纯净的硅(高级)

8
 
每次都重新初始化,设计是不合理的。SAM系列是支持ADC多通道扫描方式,ASF也支持,只是没有现成的例子。需要自己加代码。如下:
注意:
                config_adc.pin_scan.offset_start_scan    = 0;
                config_adc.pin_scan.inputs_to_scan       = 2;
第二句是扫描2个通道,第一句是扫描起始偏移量为零。
起始通道由下面这句确定。
               config_adc.positive_input  = ADC_POSITIVE_INPUT_PIN6;


  1. void configure_adc7(void)
  2. {
  3.         //! [setup_config]
  4.         struct adc_config config_adc;
  5.         //! [setup_config]
  6.         //! [setup_config_defaults]
  7.         adc_get_config_defaults(&config_adc);
  8.         //! [setup_config_defaults]

  9.         //! [setup_modify_conf]
  10.         config_adc.clock_source    = GCLK_GENERATOR_3;
  11.         config_adc.gain_factor     = ADC_GAIN_FACTOR_1X;
  12.         config_adc.clock_prescaler = ADC_CLOCK_PRESCALER_DIV8;
  13.         config_adc.reference       = ADC_REFCTRL_REFSEL_INT1V;
  14.         config_adc.positive_input  = ADC_POSITIVE_INPUT_PIN6;//ADC_POSITIVE_INPUT_TEMP;
  15.         config_adc.resolution      = ADC_RESOLUTION_12BIT;
  16.        
  17.                 config_adc.pin_scan.offset_start_scan    = 0;
  18.                 config_adc.pin_scan.inputs_to_scan       = 2;
  19.        
  20.         //! [setup_modify_conf]

  21.         //! [setup_set_config;
  22.         adc_init(&adc_instance, ADC, &config_adc);
  23.         //! [setup_set_config]

  24.         //! [setup_enable]
  25.         adc_enable(&adc_instance);
  26.         //! [setup_enable]
  27. }
复制代码
 
 
 

回复

1305

帖子

0

TA的资源

纯净的硅(高级)

9
 

主程序中用下面语句读出。结果也是按采集顺序交错的。

                adc_read_buffer_job(&adc_instance, adc_result_buffer, ADC_SAMPLES);

                //! [job_complete_poll]
                while (adc_read_done == false)
                {
                        /* Wait for asynchronous ADC read to complete */
                }
               
 
 
 

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

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

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

 
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
快速回复 返回顶部 返回列表