CREELINKS平台_处理器CeAd资源使用说明(CeAd的配置与使用)

时间:2023-03-09 19:27:53
CREELINKS平台_处理器CeAd资源使用说明(CeAd的配置与使用)

0x00 CREELINKS平台简介

    CREELINKS(创e联)是由大信科技有限公司研发,集合软硬件、操作系统、数据云储存、开发工具于一体,用于物联网产品的设计、研发与生产的平台。
    平台涉及智能硬件、车联网、智能家居、可穿戴设备、工业控制等各个物联网领域。旨在辅助中小型企业快速完成物联网产品原型的设计与开发;并为开源软硬件爱好者、硬件DIY极客、教育机构等提供更高效的资源。
    平台包含通用功能模块、操作系统、核心库、模块驱动库、物联网典型产品的解决方案及相关开发工具。

0x01 处理器CeAd资源是什么?

CeAd资源是CREELINKS平台中将不同处理器平台中AD转换(模拟信号采集)的共性提取出来,整理并编写出来的标准库。CeAd标准库包含了Ad操作相关的所有属性及API接口函数,如: 设置获得AD转换结果等。其标准库的头文件为CeAd.h,不同处理器平台实现的源文件名统一为CeAd.c。

    详细介绍如下:

    1、资源介绍

        Creelinks平台Ad对象的操作头文件,包含有关处理器平台Ad内容的相关操作。可能不同处理器平台,Ad转换电压、转换时间、转换速率、位宽等均不一致,使用Ad资源时,尽量使用CeMcu.h中的相关Ad属性宏定义。

    2、相关配置

在CeMcu.h中有与处理器平台有关的配置项如下:

 #define CE_AD_CONVERT_REF_VCC    (fp32)(3.3)       /*!< Ad转换的参考电压3.3V*/
 #define CE_AD_CONVERT_WIDTH      (uint16)(12)      /*!< Ad转换宽度*/
 #define CE_AD_CONVERT_TIME_NS    (uint16)(1000)    /*!< Ad完成一次转换所用的时间ns*/
 #define CE_AD_CONVERT_MAX_VAL    (uint32)(0x0FFF)  /*!< Ad转换所得的最大值*/

其中:

        CE_AD_CONVERT_REF_VCC当前处理器平台Ad资源进行转换所采用的参考电压值,浮点型变量。

        CE_AD_CONVERT_WIDTH当前处理器平台Ad资源转换结果的宽度,如8、12、16等。

        CE_AD_CONVERT_TIME_NS当前处理器平台Ad资源完成一次Ad转换所需要的时间,单位纳秒。

        CE_AD_CONVERT_MAX_VAL当前处理器平台Ad资源转换结果的最大值,如宽度12位,则最大值为0xFFFF。

3、属性对象

 /**
   * @brief  结构体,AD对象可用属性集合
   */
 typedef struct
 {
     CE_RESOURCE     ceResource;                     /*!< Ad对应的资源号*/
     CeExAdPar       ceExAdPar;                      /*!< 与处理器平台相关的额外参数结构体,用以提高代码效率,用户无须关注*/
 }CeAd;

其中:

         ceResource对应核心模块的Ad资源号, 只要在核心板上,资源接口中带A标号即可。

         ceExPwmPar用于存不同的处理器平台,Ad属性对象需要的额外参数。此结构体在CeMcu.h文件中定义。

    4、操作对象

 /**
   * @brief  结构体,AD对象可用操作集合
   */
 typedef struct
 {
     CE_STATUS   (*initial)(CeAd* ceAd);             /*!< @brief 初始化Ad转换
                                                          @param ceAd:Ad属性对象指针*/

     uint32      (*getAdConvertValue)(CeAd* ceAd);   /*!< @brief 获得Ad转换结果
                                                          @param ceAd:Ad属性对象指针
                                                          @return AD转换结果*/
 }CeAdOpBase;
 extern const CeAdOpBase ceAdOp;                     /*!< 所有与Ad相关的操作*/

其中:

        initial对一个Ad资源进行初始化,如果在CeMcu.h中的宏定义 __CE_CHECK_PAR__处于打开状态,则会对输入的CeAd属性对象进行参数检查。

        getAdConmvertValue进行一次Ad转换,并获得转换结果。操作会阻塞并且直到转换完成后才返回,转换时间在CeMcu.h中宏定义CE_AD_CONVERT_TIME_NS有关。

5、执行流程

CREELINKS平台_处理器CeAd资源使用说明(CeAd的配置与使用)

6、应用示例

 /**
 ******************************************************************************
 * @brief  使用流程及示例程序(基于前后台非操作系统环境)
 * @function 读取Ad口转换值,并通过Uart口传输给串口调试助手
 ******************************************************************************
 #include "Creelinks.h"
 CeAd myAd;                                      //定义Ad属性对象
 uint32 convertVal;                              //转换结果保存的临时变量
 int main(void)
 {
     ceSystemOp.initial();                       //Creelinks环境初始化
     ceSystemOp.initialDebug(RxUart);            //通过Uart串口输出Debug信息到上位机
     //TODO:请在此处插入模块初始化等操作
     myAd.ceResource = RxA;                      //定义Ad资源号
     ceAdOp.initial(&myAd);
     while (1)
     {
         ceSystemOp.mainTask();                  //Creelinks环境主循环任务,请保证此函数能够被周期调用
         //TODO:请在此处插入用户操作
         convertVal = ceAdOp.getAdConvertValue(&myAd);   //获得Ad转换结果
         ceSystemOp.printf("ConvertVal = %d",convertVal);//打印Ad转换结果
         ceSystemOp.delayMs(500);                        //延时500ms
     };
 }
 ******************************************************************************
 */

0x02 CeAd的注意事项

    在不同处理器平台或不同的核心板下,Ad转换的参考电压、转换时间、转换速率、位宽等均不一致,Ad资源时,尽量使用CeMcu.h中的相关Ad属性宏定义。

0x03 CeAd在不同处理器的应用实例

1、STM32平台下的ELinkSTM核心板下使用CeAd...。代码及动画效果如下:

    待添加...