0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

IWR1642/AWR1642 GPADC功能介绍与实现

星星科技指导员 来源:TI 作者:Chris Meng 2023-04-03 10:13 次阅读

GPADC功能介绍

IWR1642/AWR1642的毫米波传感器芯片上集成了通用ADC(GPADC)的功能。用户可以利用GPADC对外部电压,例如电源电压进行监控。IWR1642/AWR1642上的ADC采样率为625Ksps,精度为10-bit,提供给用户6个ADC管脚进行测量。其中5个ADC支持缓冲模式和非缓冲模式,一个ADC仅支持非缓冲模式。在非缓冲模式下,ADC的测量范围是0V~1.8V,而缓冲模式下,测量范围是0.4V~1.3V。

GPADC本身是由雷达子系统控制,用户可以通过在MSS或者DSS调用检测GPADC的API,向雷达子系统发送相关请求来获取GPADC相关信息。雷达子系统收到ADC检测的消息后,会调度ADC测量和其他射频模拟的检测功能。用户可以配置ADC设定时间,也就是跳过多少采样点后开始正式采用,以及连续采样点数。雷达子系统会在一帧结束的时候把ADC采样的最小值,最大值和平均值通过消息发给GPADC采样的发起者(MSS或者DSS)。

注意事项

这里有两点需要注意。一个是BSS里面异步消息发送对象的设置。对于GPADC这个检测,是调用配置GPADC的那个核会收到BSS发出的消息。一个是mmwave Link下消息发送的对象。在mmw demo里面使用了mmwave link的消息,这个消息是不同于BSS的异步消息配置。在mmw demo里MMS代码的消息处理函数MmwDemo_mssMmwaveEventCallbackFxn()的返回值默认为0,表示在接收到消息后,同样需要把消息发给DSS。所以当MSS发起了GPADC的配置,默认情况下不仅MSS会收到GPADC的消息,DSS也是会收到GPADC的消息。如果DSS不处理收到的GPADC消息,DSS侧就会报错。所以如果不需要DSP处理相关事件,可以在DSP侧的MmwDemo_dssMmwaveEventCallbackFxn函数里添加GPADC消息的处理,例如收到消息后break。但是,更好的方法是在mss侧把相应消息事件的返回值设置为1。这样可以减少对DSS的打断。默认的代码MmwDemo_mssMmwaveEventCallbackFxn()函数的返回值只有统一的一个值,因为mmw demo每个核都会处理多个消息,所以最好修改一下MmwDemo_mssMmwaveEventCallbackFxn为不需要传给dss的消息返回值为1,而需要的返回值为0。如果用户需要在DSS侧调用GPADC的配置代码,也需要类似的处理。

GPADC功能实现

下面以MSS读取GPADC为例,介绍一下如何在mmWave SDK2.0的mmw demo下实现多次获取GPADC数值的功能。下面的测试基于IWR1642 BOOST ES2.0。DSS读取GPADC,也可以使用类似方法。

首先需要在mss_main.c里面添加GPADC配置的相关代码。每调用一次配置GPADC,就能够收到一个相关GPADC的消息,获取GPADC的值。如果需要多次读取GPADC的值,需要多次调用GPADC的配置。

#include

#include

rlUInt8_t isGetGpAdcMeasData = 0U;

rlRecvdGpAdcData_t rcvGpAdcData = {0};

const rlGpAdcCfg_t gpAdcCfg =

{

.enable = 0x3F,

.bufferEnable = 0,//0表示非缓冲模式,

//1表示使能缓冲模式,如果全部ADC使能缓冲模式则配置0x3F

.numOfSamples[0].sampleCnt = 20,

.numOfSamples[0].settlingTime = 3,

.numOfSamples[1].sampleCnt = 14,

.numOfSamples[1].settlingTime = 3,

.numOfSamples[2].sampleCnt = 14,

.numOfSamples[2].settlingTime = 3,

.numOfSamples[3].sampleCnt = 14,

.numOfSamples[3].settlingTime = 3,

.numOfSamples[4].sampleCnt = 14,

.numOfSamples[4].settlingTime = 3,

.numOfSamples[5].sampleCnt = 14,

.numOfSamples[5].settlingTime = 3,

.numOfSamples[6].sampleCnt = 14,

.numOfSamples[6].settlingTime = 3,

.numOfSamples[7].sampleCnt = 14,

.numOfSamples[7].settlingTime = 3

.numOfSamples[8].sampleCnt = 14,

.numOfSamples[8].settlingTime = 3,

.numOfSamples[9].sampleCnt = 14,

.numOfSamples[9].settlingTime = 3,

.numOfSamples[10].sampleCnt = 14,

.numOfSamples[10].settlingTime = 3,

.numOfSamples[11].sampleCnt = 14,

.reserved0 = 0

};

int32_t MmwaveLink_setGpAdcConfig (void)

{

int32_t retVal;

retVal = rlSetGpAdcConfig(RL_DEVICE_MAP_INTERNAL_BSS, (rlGpAdcCfg_t*)&gpAdcCfg);

/* Check for mmWaveLink API call status */

if(retVal != 0)

{

/* Error: Link reported an issue. */

System_printf("Error: rlSetGpAdcConfig retVal=%dn", retVal);

return -1;

}

while(isGetGpAdcMeasData == 0U)

{

/* Sleep and poll again: */

Task_sleep(1);

}

return 0;

}

下面是具体调用GPADC配置的代码,可以添加在用户需要测试外部电压的地方。

if (MmwaveLink_setGpAdcConfig() < 0)               

{

System_printf ("Error: MmwaveLink_setGpAdcConfign"); break;

}

接下来在MSS侧添加GPADC消息的处理代码。下面的处理代码是在CCS输出窗口打印出ADC5的平均值。相关代码添加在MmwDemo_mssMmwaveEventCallbackFxn()函数里。将MmwDemo_mssMmwaveEventCallbackFxn函数的返回值设置为1,这样DSP就不会收到该消息,也就不需要在DSP侧添加消息处理代码了。当GPADC的配置代码被调用的时候,用户就可以在CCS打印输出窗口看到测量的GPADC的值。

case RL_RF_AE_GPADC_MEAS_DATA_SB:

{

isGetGpAdcMeasData = 1U;

memcpy(&rcvGpAdcData, payload, sizeof(rlRecvdGpAdcData_t));

System_printf ("GPADC value: %d Vn", rcvGpAdcData.sensor[4].avg);

break;

}

下面是在IWR1642BOOST上实测的数据和万用表测量的数据的比较。

万用表测量(V) ADC5的平均值 GPADC值转换为电压 (V)
IWR1642 ES2.0 EVM 1.7176 980 1.8/1024*980=1.722656
0 0 1.8/1024*0=0

上面介绍的GPADC使用方法适用于IWR1642/AWR1642,对于IWR1443/AWR1443上的GPADC的使用也是很好的参考。

审核编辑:郭婷

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 芯片
    +关注

    关注

    447

    文章

    47788

    浏览量

    409134
  • adc
    adc
    +关注

    关注

    95

    文章

    5651

    浏览量

    539470
  • 毫米波传感器

    关注

    3

    文章

    84

    浏览量

    11335
收藏 人收藏

    评论

    相关推荐

    德州仪器宣布AWR1642IWR1642毫米波传感器可以批量生产

    继发布全球精度最高的CMOS单芯片毫米波雷达传感器一年后,德州仪器(TI)近日宣布,其高集成度超宽带AWR1642IWR1642 毫米波传感器实现批量生产。这两款传感器均支持在76GHz-81GHz的频率下,
    的头像 发表于 06-01 11:06 1.2w次阅读

    请问毫米波雷达AWR1642 CAN功能如何使用?

    按着sdk中的教程使用AWR1642的CAN模块,但没有实现CAN数据的发送和接收,求教CAN功能的使用方法
    发表于 08-19 07:31

    IWR1642/AWR1642毫米波传感器的GPADC功能介绍功能实现

    作者:TI 工程师 Chris MengGPADC功能介绍 IWR1642/AWR1642的毫米波传感器芯片上集成了通用ADC(GPADC
    发表于 03-04 06:45

    IWR1642/AWR1642上修改代码改变L3 RAM分布

    本文以AWR1642为例,介绍了在AWR1642 ES2.0 EVM上基于mmWave SDK 2.1的mmw demo下如何修改代码来改变L3 RAM分布的具体流程和步骤。IWR1642
    发表于 03-12 06:45

    请问IWR1642能调制FSK波形吗?

    IWR1642和1443,手册及波形产生文档里只描述了产生锯齿波的多种组合方法,可以产生常规的三角波,或者FSK调频波吗?
    发表于 03-25 08:50

    怎样去设计一种基于IWR1642芯片的板载天线呢

    IWR1642芯片的内部结构是怎样组成的?怎样去设计一种基于IWR1642芯片的板载天线呢?
    发表于 10-22 09:29

    如何在IWR1642/AWR1642上修改L3 RAM的分布?

    本文以AWR1642为例,介绍了在AWR1642 ES2.0 EVM上基于mmWave SDK 2.1的mmw demo下如何修改代码来改变L3 RAM分布的具体流程和步骤。IWR1642
    发表于 11-10 08:06

    实现IWR1642/AWR1642 GPADC功能

    GPADC功能介绍 IWR1642/AWR1642的毫米波传感器芯片上集成了通用ADC(GPADC
    发表于 11-11 07:30

    德州仪器将开始量产其高度集成的超宽频AWR1642IWR1642毫米波传感器

    据外媒报道,在推出世界上最精确的毫米波(mmWave)单芯片互补金属氧化物半导体(CMOS)传感器一年后,美国德州仪器公司(TI)现在宣布将开始量产其高度集成的超宽频AWR1642IWR1642毫米波(mmWave)传感器。
    发表于 06-04 17:30 1451次阅读

    德州仪器将量产其高度集成的超宽频AWR1642IWR1642毫米波传感器

    据外媒报道,在推出世界上最精确的毫米波(mmWave)单芯片互补金属氧化物半导体(CMOS)传感器一年后,美国德州仪器公司(TI)现在宣布将开始量产其高度集成的超宽频AWR1642IWR1642毫米波(mmWave)传感器。
    发表于 06-04 15:08 1980次阅读

    基于IWR1642 IWR在楼宇自动化的应用

    毫米波雷达的应用无处不在- 1.2 用 IWR1642 进行人员数量统计的演示说明
    的头像 发表于 05-07 06:40 4078次阅读
    基于<b class='flag-5'>IWR1642</b> <b class='flag-5'>IWR</b>在楼宇自动化的应用

    GPADC功能介绍实现

    GPADC功能介绍              IWR1642/AWR1642的毫米波传感器芯片上集成了通用ADC(
    的头像 发表于 01-12 15:33 4260次阅读

    IWR1642/AWR1642上修改L3 RAM的分布

    IWR1642/AWR1642上修改L3 RAM的分布
    发表于 11-01 08:26 2次下载
    在<b class='flag-5'>IWR1642</b>/<b class='flag-5'>AWR1642</b>上修改L3 RAM的分布

    IWR1642/AWR1642 GPADC功能介绍实现

    IWR1642/AWR1642 GPADC功能介绍实现
    发表于 11-01 08:26 3次下载
    <b class='flag-5'>IWR1642</b>/<b class='flag-5'>AWR1642</b> <b class='flag-5'>GPADC</b><b class='flag-5'>功能</b><b class='flag-5'>介绍</b>与<b class='flag-5'>实现</b>

    IWR1642/AWR1642上修改L3 RAM的分布

      本文以AWR1642为例,介绍了在AWR1642 ES2.0 EVM上基于mmWave SDK 2.1的mmw demo下如何修改代码来改变L3 RAM分布的具体流程和步骤。
    的头像 发表于 04-03 09:24 1046次阅读
    在<b class='flag-5'>IWR1642</b>/<b class='flag-5'>AWR1642</b>上修改L3 RAM的分布