Funpack2-2 AURIX TC275 lite Kit 任务二 呼吸灯设计
Funpack2-2 AURIX TC275 lite Kit 任务二:adc读取电位计电压调整led闪烁频率并通过串口输出读取数据至电脑
标签
嵌入式系统
AURIX
xuyu
更新2022-10-10
693

 摘要

本文对 如何使用 AURIX TM TC275 lite Kit 实现adc数据的读取、数字端口IO的操作以及串口输出数据进行了简要介绍,关键代码在文中被列出, 此外本文附加材料包括完整的实现代码。

 

本文介绍的内容对应于 Funpack第二季第二期活动规则中的任务二:

任务二项目描述:设计一个呼吸灯,通过旋转板卡上的电位计,改变呼吸灯闪烁速率,同时将ADC采集的数据通过串口/CAN,发送到另一台设备上显示. 

一、基本功能拆分:

  1. 电位计所对应输入adc端口的数据读取。
  2. 数据处理后转换为对LED数字输出端口高低电平切换时间间隔的控制。
  3. 数据处理后通过串口输出数据至电脑。
  4. 电脑端读取串口数据并实时绘图。

二、功能实现:

  1. 读取电位计对应IO的电压 

官方提供的电路原理图可以看到,电位计对应AN0 归属于 adc 中的 group 0 Chanel id 0 

FhUuhUx4Cymr8PTNuYv1JYnwa4IzFs7I26SgLmb5bWJUj5Zi79AT6G8M

 

 

因此,配置ADC 读取 AN0 即可跟踪电位计变化。

对应部分程序:

/* Function to initialize the VADC group */
void initVADCGroup(void)
{
    IfxVadc_Adc_GroupConfig adcGroupConf;                               /* Define a configuration structure         */
    IfxVadc_Adc_initGroupConfig(&adcGroupConf, &g_vadc);                /* Fill it with default values              */

    adcGroupConf.groupId = IfxVadc_GroupId_0;                           /* Select the Group 0                       */
    adcGroupConf.master = adcGroupConf.groupId;                         /* Set the same group as master group       */

    /* Enable the background scan source and the background auto scan functionality */
    adcGroupConf.arbiter.requestSlotBackgroundScanEnabled = TRUE;
    adcGroupConf.backgroundScanRequest.autoBackgroundScanEnabled = TRUE;

    /* Enable the gate in "always" mode (no edge detection) */
    adcGroupConf.backgroundScanRequest.triggerConfig.gatingMode = IfxVadc_GatingMode_always;

    IfxVadc_Adc_initGroup(&g_vadcGroup, &adcGroupConf);                 /* Apply the configuration                  */
}

/* Function to initialize the VADC used channels */
void initVADCChannels(void)
{
    IfxVadc_Adc_ChannelConfig adcChannelConf[CHANNELS_NUM];             /* Array of configuration structures        */

    uint16 chn;
    for(chn = 0; chn < CHANNELS_NUM; chn++)                             /* Initialize all the channels in a loop    */
    {
        /* Fill the configuration with default values */
        IfxVadc_Adc_initChannelConfig(&adcChannelConf[chn], &g_vadcGroup);

        /* Set the channel ID and the corresponding result register */
        adcChannelConf[chn].channelId = g_vadcChannelIDs[chn];          /* The channels are initialized        */
        adcChannelConf[chn].resultRegister = (IfxVadc_ChannelResult)(chn);
        adcChannelConf[chn].backgroundChannel = TRUE;                   /* Enable background scan for the channel   */

        /* Apply the channel configuration */
        IfxVadc_Adc_initChannel(&g_vadcChannel[chn], &adcChannelConf[chn]);

        /* Add the channel to background scan */
        unsigned chnEnableBit = (1 << adcChannelConf[chn].channelId);   /* Set the the corresponding input channel  */
        unsigned mask = chnEnableBit;                                   /* of the respective group to be added in   */
        IfxVadc_Adc_setBackgroundScan(&g_vadc, &g_vadcGroup, chnEnableBit, mask); /* the background scan sequence.  */
    }
}

 

2. 数据处理后转换为对LED数字输出端口高低电平切换时间间隔的控制

FhPbcixBUDp5NMEYpWpCFJfKhznv

初始化LED对应IO并修改闪烁时间间隔,闪烁时间间隔是关于adc读取数据的函数。本文采用读取adc数据除以20 对应毫秒的闪烁间隔。此时间间隔较为恰当,肉眼可见闪烁频率随电位器的在较大范围内的调整而改变。

图中所示 1 2 对应LED所在位置

为了实现对多核的利用,LED闪烁部分代码运行于CPU core1

对应部分程序:

#include "Ifx_Types.h"
#include "IfxCpu.h"
#include "IfxScuWdt.h"
#include "Blinky_LED.h"
#include "Bsp.h"
extern IfxCpu_syncEvent g_cpuSyncEvent;
extern uint16 read_adc_result;
int core1_main(void)
{
    IfxCpu_enableInterrupts();
    
    /* !!WATCHDOG1 IS DISABLED HERE!!
     * Enable the watchdog and service it periodically if it is required
     */
    IfxScuWdt_disableCpuWatchdog(IfxScuWdt_getCpuWatchdogPassword());
    initLED();  /* Initialize the LED port pin      */
    init_GPIOs();
    /* Wait for CPU sync event */
    IfxCpu_emitEvent(&g_cpuSyncEvent);
    IfxCpu_waitEvent(&g_cpuSyncEvent, 1);
    
    while(1)
    {
        blinkLED(); 
        waitTime(IfxStm_getTicksFromMilliseconds(BSP_DEFAULT_TIMER, (read_adc_result/20)));    /* unit :milliseconds            */

    }
    return (1);
}

 

3. 数据处理后通过串口输出数据至电脑。

读取结果数据为 uint16 转换为 str 后发送至串口, 使用cpu core0 运行这部分程序。


void send_UART_message2(uint16 x)
{
    char buf[4];
    int n = sprintf( buf, "%d", x);
    Ifx_SizeT count = sizeof(buf);                                               /* Size of the message                      */
    IfxAsclin_Asc_write(&g_asc, buf , &count, TIME_INFINITE);         /* Transfer of data                         */
}

 

while(1)
    {
        chn36Measurement = readADCValue(CHN_36);
        read_adc_result=chn36Measurement;
        send_UART_message();   
        send_UART_message2(chn36Measurement);   
        send_UART_message3();   
        waitTime(IfxStm_getTicksFromMilliseconds(BSP_DEFAULT_TIMER, 100));    /* Wait 500 milliseconds            */
    }

 4.  电脑端读取串口数据并实时绘图。

这部分的功能实现基于VOFA+ , 在符合匹配协议的情况下实时对串口数据进行绘图并显示。

配置格式例子 “ sample: 3000 \n ”

其中需要注意一定是\n 否则无法自动匹配

 

三、对本活动的心得体会:

感觉回到了本科的夏天,在选修课上用51单片机实现最基本的串口和模拟数据读取功能,也是一样的闷热,也是一样的基础功能的实现。

英飞凌的代码例程足够多,本文结尾附加代码是在范例的基础上进行的修改。

附件下载
Task2.zip
团队介绍
EE Ph.D. 在读
评论
0 / 100
查看更多
目录
硬禾服务号
关注最新动态
0512-67862536
info@eetree.cn
江苏省苏州市苏州工业园区新平街388号腾飞创新园A2幢815室
苏州硬禾信息科技有限公司
Copyright © 2024 苏州硬禾信息科技有限公司 All Rights Reserved 苏ICP备19040198号