0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

測(cè)試代碼中使用DMA傳輸,定時(shí)器觸發(fā)ADC

茶話MCU ? 來(lái)源:ST MCU 信息交流 ? 2020-08-10 16:22 ? 次閱讀

有人在使用STM32G0芯片ADC模塊時(shí),往往因?yàn)閽呙枘J降睦斫獠坏轿换蜻x擇不當(dāng)導(dǎo)致些問(wèn)題。這里就該話題做點(diǎn)簡(jiǎn)單分享介紹,不妨以一個(gè)實(shí)例展開(kāi)。

現(xiàn)在共用到ADC1模塊的4個(gè)ADC通道,即1個(gè)片內(nèi)Vrefint通道和其它三個(gè)外部通道CH8,CH10,CH17。下面測(cè)試代碼中使用DMA傳輸,定時(shí)器觸發(fā)ADC.

它們的硬件連接情況如下,其中VRefint為內(nèi)部參考電壓,其電壓值大概1.2V樣子。

對(duì)于STM32G0系列,ADC掃描模式可以有兩種,分別是不完全配置序列模式和完全配置序列模式。我們先看看不完全配置序列模式。

不完全配置序列模式

在該模式下,ADC_CFGR1寄存器中的CHESELRMOD位必須被清零。

被轉(zhuǎn)換通道的掃描順序按照ADC通道固有序號(hào)的大小順序依次進(jìn)行,掃描方向可以軟件配置為向前【forward】或后退【backward】。任何ADC通道都可以配置進(jìn)該序列中,總的序列長(zhǎng)度由寄存器ADC_CHSELR中被置位的CHSELx個(gè)數(shù)決定,最多可配置18個(gè)通道。

我們以上面提到的CH8、CH10、CH17和VRefint通道【它對(duì)應(yīng)ADC通道CH13】為例,若將上述4個(gè)通道配置為不完全序列模式,只需將ADC_CHSELR寄存器中的CHSELx相應(yīng)位進(jìn)行置1即可。如下圖所示:

若選擇forward掃描模式,則按通道號(hào)從小到大的順序依次實(shí)施轉(zhuǎn)換,生成對(duì)應(yīng)于CH8、CH10、CH13、CH17的結(jié)果。使用STM32CubeMx的配置如下:

既然掃描按默認(rèn)通道號(hào)大小順序進(jìn)行,自然就無(wú)須RANK順序的配置了。

編譯運(yùn)行后可以看到結(jié)果,我在內(nèi)存里放了兩組數(shù)據(jù)以便比較觀察。

從結(jié)果來(lái)看跟實(shí)際情況是一致的,轉(zhuǎn)換結(jié)果依次來(lái)自CH8/CH10/CH13/CH17。其中那個(gè)149x數(shù)值來(lái)自對(duì)內(nèi)部Vrefint的轉(zhuǎn)換結(jié)果。

那么,對(duì)于同樣的ADC通道及硬件連接,若采用完全配置序列模式會(huì)怎么樣呢?

完全配置序列模式

在該模式下,ADC_CFGR1寄存器中的CHESELRMOD位必須被置1。

全序列可支持的通道數(shù)最多8個(gè),掃描順序不是依照硬件約定的通道號(hào)來(lái)安排,而是依據(jù)ADC_CHSELR寄存器中的從SQ1[3:0]到SQ8[3:0]所選擇的通道順序進(jìn)行,即按照我們?cè)贑ubeMX或代碼中配置的RANK順序進(jìn)行,不再涉及掃描方向forward/backward的配置,并且只有通道0 到 通道14可以被選擇!

還有,當(dāng)SQn[3:0]里的賦值等于0b1111,即0x0f時(shí)則該通道選擇域以及后續(xù)SQn的通道選擇無(wú)效。比方說(shuō),假設(shè)SQ3[3:0]的數(shù)據(jù)為0b1111,則表示從SQ3[3:0]開(kāi)始直到SQ8[3:0]的通道選擇無(wú)效。由于SQn[3:0]才4位,所有它也沒(méi)法選擇高于14的有效通道號(hào)?!菊?qǐng)?zhí)貏e注意這些特性!】

看到這里,我們不禁想到前面預(yù)先安排的4個(gè)通道中的有個(gè)CH17,顯然不適合這種模式。如果被錯(cuò)誤地強(qiáng)行使用該模式,基于CubeMx配置和現(xiàn)有Cube庫(kù)所產(chǎn)生的代碼運(yùn)行結(jié)果會(huì)怎么樣呢?

先用CubeMX進(jìn)行配置:

4個(gè)通道的掃描順序配置如下,相比前面多了RANK順序配置。

先撇開(kāi)CH17合法性不談,不難看出這里跟前面的掃描順序配置有點(diǎn)不一樣,這里的配置為我們提供了更多的自主性及便利性,轉(zhuǎn)換掃描并不固定于通道號(hào)的順序,具體由SQn[3:0]的配置選擇決定。我這里讓SQ1選擇CH8,SQ2選擇CH10,SQ3選擇CH17,SQ4選擇CH13,分別對(duì)應(yīng)配置中的RANK1、RANK2、RANK3、RANK4順序。

編譯運(yùn)行查看結(jié)果:

前面說(shuō)過(guò),CH17硬件上是接地的,顯然此時(shí)對(duì)應(yīng)于CH17的轉(zhuǎn)換值【綠色箭頭所指】跟實(shí)際情況完全不符,其它三個(gè)倒是跟實(shí)際情況吻合。409x對(duì)應(yīng)CH8接VDD,0對(duì)應(yīng)CH10接GND,149x對(duì)應(yīng)內(nèi)部vrefint。

我嘗試將CH17接到VDD,轉(zhuǎn)換結(jié)果還是跟實(shí)際情況還是完全不相符。

結(jié)合上面的介紹,我們知道對(duì)于完全配置序列模式不能選用高于通道14的通道號(hào)。我們不妨通過(guò)寄存器進(jìn)一步看看,當(dāng)我們錯(cuò)誤地強(qiáng)行使用CH17時(shí)在現(xiàn)有庫(kù)代碼的情況下,對(duì)應(yīng)的SQ3[3:0]真正的值是多少?到底選擇了什么通道?還是CH17嗎?

在調(diào)試環(huán)境下,打開(kāi)通道選擇寄存器,可以看到下面結(jié)果:

從上面通道選擇寄存器不難看出,除了SQ3外,其它三個(gè)配置都是正確的,跟我們預(yù)設(shè)的通道是一致的。但是,SQ3被錯(cuò)誤地配置為CH1了,也就是說(shuō)上面看到的所謂CH17的轉(zhuǎn)換結(jié)果都是來(lái)自CH1.難怪不論怎么改變CH17的外部連接時(shí),SQ3選擇通道所對(duì)應(yīng)的轉(zhuǎn)換結(jié)果沒(méi)有相應(yīng)變化,跟CH17的管腳電壓也沒(méi)啥關(guān)系。

看到這里有人可能會(huì)想,如果我們?cè)谇懊嬉?guī)劃ADC通道時(shí)把CH1同時(shí)規(guī)劃進(jìn)來(lái)、硬件上恰好也接地,這時(shí)就可能發(fā)生誤判!這種巧合性的誤判,有時(shí)可能給我們的調(diào)試帶來(lái)極大隱患而一會(huì)半會(huì)又找不到原因。當(dāng)然,具體會(huì)發(fā)生些什么要因具體應(yīng)用而定。這里只是簡(jiǎn)單提醒下,就此打住。

總之,這點(diǎn)在STM32G0 ADC應(yīng)用中是個(gè)很容易出錯(cuò)的地方,將本不該用在完全配置序列模式的通道被錯(cuò)誤地強(qiáng)行使用,雖有轉(zhuǎn)換結(jié)果,而轉(zhuǎn)換結(jié)果卻來(lái)自別的通道,往往為此覺(jué)得問(wèn)題詭異、不可思議而備受折騰。

最后,稍微小結(jié)下。對(duì)于STM32G0系列的ADC模塊來(lái)說(shuō),其ADC通道在被轉(zhuǎn)換時(shí)涉及到轉(zhuǎn)換序列配置問(wèn)題,這里有兩種轉(zhuǎn)換序列配置模式,即不完全配置序列模式和完全配置序列模式。

所謂不完全配置序列模式,在進(jìn)行多個(gè)通道AD轉(zhuǎn)換時(shí),轉(zhuǎn)換順序由各通道自身的硬件序列號(hào)和掃描方向決定,其中硬件序列號(hào)即CHn在數(shù)據(jù)手冊(cè)里已經(jīng)明確定義,掃描方向通過(guò)寄存器配置。整個(gè)轉(zhuǎn)換序列可支持的通道數(shù)多達(dá)18個(gè),沒(méi)有被排除在外的通道。

而完全配置序列模式呢,在進(jìn)行多個(gè)通道AD轉(zhuǎn)換時(shí),轉(zhuǎn)換順序由通道選擇寄存器中通道選擇域SQn[3:0]來(lái)決定,即按照SQ1,SQ2.。。。。SQ7,SQ8的順序,而且SQn[3:0]只能選擇CH0到CH14的通道,整個(gè)序列最多支持8個(gè)通道。顯然,CH15~CH18不能使用該模式。

說(shuō)到這里,或許有人會(huì)問(wèn),如果只使用1個(gè)ADC通道,還有這個(gè)轉(zhuǎn)換序列模式的選擇問(wèn)題嗎?你把1個(gè)通道看成一個(gè)特殊的轉(zhuǎn)換序列來(lái)理解就知道有沒(méi)有這個(gè)模式選擇問(wèn)題了。

芯片設(shè)計(jì)人員在此提供了兩種轉(zhuǎn)換序列模式,本意旨在讓我們能在實(shí)際應(yīng)用中可以根據(jù)實(shí)際需求靈活選擇,然而,往往由于開(kāi)發(fā)人員的慣性思維和無(wú)視手冊(cè)導(dǎo)致在這個(gè)地方遇上點(diǎn)麻煩或困惑。在此分享之,祝君好運(yùn)!

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • adc
    adc
    +關(guān)注

    關(guān)注

    98

    文章

    6509

    瀏覽量

    544984
  • 定時(shí)器
    +關(guān)注

    關(guān)注

    23

    文章

    3251

    瀏覽量

    114991
  • dma
    dma
    +關(guān)注

    關(guān)注

    3

    文章

    565

    瀏覽量

    100658

原文標(biāo)題:STM32G0系列ADC掃描序列模式解讀

文章出處:【微信號(hào):stmcu832,微信公眾號(hào):茶話MCU】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    tc397如何使用定時(shí)器的更新事件來(lái)觸發(fā)dma搬運(yùn)數(shù)據(jù)?

    請(qǐng)問(wèn)有沒(méi)有人使用過(guò)定時(shí)器的更新事件來(lái)觸發(fā)dma搬運(yùn)數(shù)據(jù),或者哪里有相關(guān)的示例代碼,我不知道應(yīng)該使用gtm模塊的哪個(gè)子模塊來(lái)做這件事情,有經(jīng)驗(yàn)的大佬可否指教下。
    發(fā)表于 07-05 06:36

    關(guān)于定時(shí)器觸發(fā)ADC連續(xù)采樣dma傳輸的疑問(wèn)求解?

    實(shí)現(xiàn)該功能,但我未找到相關(guān)的API,沒(méi)找到關(guān)于adc這方面的函數(shù)。所以想問(wèn)一下是否有定時(shí)器觸發(fā)ADC連續(xù)采樣并通過(guò)dma
    發(fā)表于 06-14 07:25

    CW32使用DMA單通道、定時(shí)器觸發(fā)ADC實(shí)現(xiàn)了多路AD采集

    測(cè)試樣例基于CW32F030C8T6MCU,使用DMA單通道、定時(shí)器觸發(fā)ADC實(shí)現(xiàn)了12路AD采集。
    的頭像 發(fā)表于 05-24 09:29 ?864次閱讀
    CW32使用<b class='flag-5'>DMA</b>單通道、<b class='flag-5'>定時(shí)器</b><b class='flag-5'>觸發(fā)</b><b class='flag-5'>ADC</b>實(shí)現(xiàn)了多路AD采集

    STM32L151定時(shí)器上升沿觸發(fā)ADC采樣,為什么每個(gè)PWM周期內(nèi)會(huì)觸發(fā)第二次采樣?

    使用定時(shí)器觸發(fā)ADC采樣PWM正脈沖時(shí)刻的負(fù)載電壓電流,觸發(fā)ADC定時(shí)器用的就是產(chǎn)生PWM的
    發(fā)表于 05-24 07:37

    使用dma的方式來(lái)傳輸定時(shí)器輸入捕獲的數(shù)據(jù),是不是每隔100ms會(huì)觸發(fā)dma傳輸完成中斷?

    目前使用dma的方式來(lái)傳輸定時(shí)器輸入捕獲的數(shù)據(jù),內(nèi)存數(shù)據(jù)大小為2,使用normal模式,100ms打開(kāi)dma模式,請(qǐng)問(wèn),這種情況下,是不是每隔100ms會(huì)觸發(fā)
    發(fā)表于 04-18 07:47

    STM32通過(guò)DMA方式傳輸TIM3定時(shí)器計(jì)數(shù)值,數(shù)值重復(fù)是為什么?

    AD值防止數(shù)據(jù)錯(cuò)亂,故DMA配置必須放在ADC之前。) 因此為了排除相同原因?qū)е碌臄?shù)據(jù)重復(fù),所以將DMA配置放在TIM3定時(shí)器初始化之前。 結(jié)果反饋,TIM3計(jì)數(shù)
    發(fā)表于 04-10 06:50

    信號(hào)通過(guò)ADC DMA DAC進(jìn)行轉(zhuǎn)換,非空狀態(tài)下觸發(fā)定時(shí)器中斷進(jìn)行延時(shí),中斷結(jié)束還會(huì)繼續(xù)DMA轉(zhuǎn)換嗎?

    信號(hào)通過(guò)ADC DMA DAC進(jìn)行轉(zhuǎn)換,其中需要延時(shí) 我的想法是 把ADC數(shù)據(jù)存入FIFO,然后根據(jù)DMA_GetFIFOStatus()函數(shù)判斷FIFO狀態(tài),非空狀態(tài)下
    發(fā)表于 04-03 08:06

    STM8L151如何配置定時(shí)器2觸發(fā)ADC,DMA傳輸?

    (REMAP_DMA1Channel_ADC1ToChannel0); DMA_Init(DMA1_Channel0, BUFFER_ADDRESS,//緩沖區(qū)地址 ADC1_D
    發(fā)表于 04-02 06:23

    請(qǐng)問(wèn)如何使用定時(shí)器的更新事件觸發(fā)DMA讀取6字節(jié)SPI數(shù)據(jù)?

    想用定時(shí)器的更新事件觸發(fā)DMA讀取SPI數(shù)據(jù),現(xiàn)在有個(gè)問(wèn)題是一次更新事件只能觸發(fā)一次DMA傳輸,
    發(fā)表于 03-29 06:16

    HAL_ADC_Start_DMA函數(shù)為什么無(wú)法進(jìn)行第二次觸發(fā)?

    我使用定時(shí)器觸發(fā)adc采集 使用dma傳輸dma傳輸
    發(fā)表于 03-26 07:31

    STM32L0使用定時(shí)器上升沿觸發(fā)ADC采樣時(shí),采樣頻率如何確定?

    我想問(wèn)一下,在使用定時(shí)器上升沿觸發(fā)ADC采樣時(shí),采樣頻率如何確定,是定時(shí)器頻率就等于ADC采樣頻率嗎?用的是STM32L0
    發(fā)表于 03-20 06:37

    定時(shí)器觸發(fā)ADC+DMA采集數(shù)據(jù)將信號(hào)發(fā)生給的正玄波通過(guò)串口打印出來(lái),有的波形為0為什么?

    目前是想先利用定時(shí)器觸發(fā)ADC+DMA采集數(shù)據(jù)將信號(hào)發(fā)生給的正玄波通過(guò)串口打印出來(lái),但是波形有一部分為0,是為啥呢,代碼如下: MX_GP
    發(fā)表于 03-19 06:50

    STM32U575定時(shí)器PWM觸發(fā)DMA搬運(yùn)內(nèi)存時(shí),為什么程序在DMA中斷里出不來(lái)?

    STM32U575 定時(shí)器PWM觸發(fā)DMA搬運(yùn)內(nèi)存,為什么程序在DMA中斷里出不來(lái)?
    發(fā)表于 03-12 08:33

    STM32H7做的項(xiàng)目,使用HAL_DMA_Start_IT,但是DMA是以最快的速度傳輸,并不受定時(shí)器周期控制?

    使用STM32H7做的項(xiàng)目,想要用定時(shí)器的溢出事件,觸發(fā)DMA將GPIO的狀態(tài)傳輸到內(nèi)存上。 使用HAL_DMA_Start_IT,但是
    發(fā)表于 03-11 07:23

    如何使用定時(shí)器觸發(fā)器進(jìn)行SPI DMA傳輸

    我正在做一個(gè)項(xiàng)目,在這個(gè)項(xiàng)目中,我必須在 DMA 模式下通過(guò) SPI 定期傳輸數(shù)據(jù)。 為了避免 CPU 干預(yù),我想使用計(jì)時(shí)觸發(fā)器觸發(fā) SP
    發(fā)表于 01-30 08:08