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

    CREELINKS http://www.creelinks.com

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

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

    详细介绍如下:

    1、资源介绍

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

    2、相关配置

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

1 #define CE_AD_CONVERT_REF_VCC    (fp32)(3.3)       /*!< Ad转换的参考电压3.3V*/2 #define CE_AD_CONVERT_WIDTH      (uint16)(12)      /*!< Ad转换宽度*/3 #define CE_AD_CONVERT_TIME_NS    (uint16)(1000)    /*!< Ad完成一次转换所用的时间ns*/4 #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、属性对象

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

         其中:

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

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

    4、操作对象

 1 /** 2   * @brief  结构体,AD对象可用操作集合 3   */ 4 typedef struct 5 { 6     CE_STATUS   (*initial)(CeAd* ceAd);             /*!< @brief 初始化Ad转换 7                                                          @param ceAd:Ad属性对象指针*/ 8  9     uint32      (*getAdConvertValue)(CeAd* ceAd);   /*!< @brief 获得Ad转换结果10                                                          @param ceAd:Ad属性对象指针11                                                          @return AD转换结果*/12 }CeAdOpBase;13 extern const CeAdOpBase ceAdOp;                     /*!< 所有与Ad相关的操作*/

        其中:

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

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

    5、执行流程

    6、应用示例

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