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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

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

基于Cortex-A9的PWM

GReq_mcu168 ? 來源:玩轉單片機 ? 作者:玩轉單片機 ? 2021-02-14 15:04 ? 次閱讀

一、什么是PWM

PWM,英文名Pulse Width Modulation,是脈沖寬度調(diào)制縮寫,它是通過對一系列脈沖的寬度進行調(diào)制,等效出所需要的波形(包含形狀以及幅值),對模擬信號電平進行數(shù)字編碼,也就是說通過調(diào)節(jié)占空比的變化來調(diào)節(jié)信號、能量等的變化,占空比就是指在一個周期內(nèi),信號處于高電平的時間占據(jù)整個信號周期的百分比,例如方波的占空比就是50%.

4e6d4fb4-56fc-11eb-8b86-12bb97331649.png

二、PWM信號輸出輸出和作用

1. 如果要實現(xiàn)PWM信號輸出如何輸出呢?

1)可以直接通過芯片內(nèi)部模塊輸出PWM信號,前提是這個I/O口要有集成的pwm控制器,只需要通過對應的寄存器即可,這種自帶有PWM輸出的功能模塊在程序設計更簡便,同時數(shù)據(jù)更精確。

2)但是如果IC內(nèi)部沒有PWM功能模塊,或者要求不是很高的話可以利用I/O口設置一些參數(shù)來輸出PWM信號,因為PWM 信號其實就是一高一低的一系列電平組合在一起。具體方法是給I/O加一個定時器,對于你要求輸出的PWM信號頻率與你的定時器一致,用定時器中斷來計數(shù),但是這種方法一般不采用,除非對于精度、頻率等要求不是很高可以這樣實現(xiàn)。

2. PWM信號應用

PWM信號把模擬信號轉化為數(shù)字電路所需要的編碼,現(xiàn)在基本是采用數(shù)字電路,因此在很多場合都采用PWM信號。

我們經(jīng)常見到的就是交流調(diào)光電路,也可以說是無級調(diào)速,高電平占多一點,也就是占空比大一點亮度就亮一點,占空比小一點亮度就沒有那么亮,前提是PWM的頻率要大于我們?nèi)搜圩R別頻率,要不然會出現(xiàn)閃爍現(xiàn)象。

除了在調(diào)光電路應用,還有在直流斬波電路、蜂鳴器驅(qū)動、電機驅(qū)動、逆變電路、加濕機霧化量等都會有應用。

三、蜂鳴器

蜂鳴器廣泛用于計算機、打印機、復印機、報警器、電子玩具、汽車電子設備、電話機、定時器等電子產(chǎn)品中作發(fā)聲器件。

蜂鳴器分為壓電式及電磁式的二大類:

壓電式蜂鳴器主要由多諧振蕩器、壓電蜂鳴片、阻抗匹配器及共鳴箱、外殼等組成。它是以壓電陶瓷的壓電效應,來帶動金屬片的振動而發(fā)聲;

電磁式的蜂鳴器,由振蕩器、電磁線圈、磁鐵、振動膜片及外殼等組成。接通電源后,振蕩器產(chǎn)生的音頻信號電流通過電磁線圈,使電磁線圈產(chǎn)生磁場。振動膜片在電磁線圈和磁鐵的相互作用下,周期性地振動發(fā)聲。通電時將金屬振動膜吸下,不通電時依振動膜的彈力彈回。

有源蜂鳴器, 只要給它加上恒定的電壓, 就能發(fā)聲;無源蜂鳴器, 必須給它加上一定頻率的方波或正弦波才能發(fā)聲

有源蜂鳴器內(nèi)部帶震蕩源,所以一通電就會叫。而無源內(nèi)部不帶震蕩源,所以如果用直流信號無法令其鳴叫。

有源蜂鳴器往往比無源的貴,就是因為里面多個震蕩電路。

【優(yōu)點】無源蜂鳴器的優(yōu)點是:

便宜

聲音頻率可控,可以做出“多來米發(fā)索拉西”的效果。

在一些特例中,可以和LED復用一個控制口有源蜂鳴器的優(yōu)點是:

程序控制方便 。

應用:電風扇、收音機的聲音按鈕、任何模擬值都可以使用PWM進行編碼

四、fs4412電路圖

本例采用fs4412開發(fā)板,pwm外接了一個蜂鳴器BUZZER,電路圖如下:

4edd9648-56fc-11eb-8b86-12bb97331649.png

從上面電路圖可知:

該BUZZER是無源蜂鳴器,如果要想發(fā)出聲音,需要正負極產(chǎn)生電流變化,我們通過生成方波,從而實現(xiàn)圖中三極管1->2周期性導通和關閉來讓BUZZER倆邊電壓產(chǎn)生變化,從而實現(xiàn)電流變化;

三極管的基極連接的是SOC的GPD0_0引腳;

產(chǎn)生方波我們借助的是PWM,標號為MOTOR_PWM。

繼續(xù)查找MOTOR_PWM:

4f13c24a-56fc-11eb-8b86-12bb97331649.png

由上圖可知,MOTOR_PWM連接的是PWM的XpwmTOUT0,和LCD一起復用引腳GPD0_0,

去datasheet繼續(xù)查看GPD0_0說明,

4f467596-56fc-11eb-8b86-12bb97331649.png

由上圖可知,GPD0_0配置由寄存器的GPD0CON[3:0]位控制,要想作為PWM輸出,要設置為TOUT_0即0x2。

同時也可以看到,該引腳還可以設置為外部中斷信號[EXT_INT6]功能即0xF。

五、Exynos 4412 PWM

概述

Exynos 4412 SCP有五個32位脈沖寬度調(diào)制(PWM)定時器。這些定時器產(chǎn)生內(nèi)部中斷對于ARM子系統(tǒng)。此外,定時器0、1、2和3包括驅(qū)動外部I/O的PWM功能信號。定時器0中的PWM有一個可選的死區(qū)發(fā)生器功能,以支持大量的設備。定時器4是一個沒有輸出引腳的內(nèi)部定時器。

定時器使用APB-PCLK作為源時鐘。定時器0和1共享可編程8位預分頻器為PCLK提供第一級分頻。定時器2、3和4共享不同的8位預分頻器。每個計時器都有它自己的專用時鐘分頻器,提供第二級時鐘劃分頻(預分頻器除以2、4、8或16)。

每個定時器都有它的32位遞減計數(shù)器;定時器時鐘驅(qū)動這個計數(shù)器。定時器計數(shù)緩沖寄存器(TCNTBn)加載遞減計數(shù)器的初始值。如果遞減計數(shù)器達到零,它將生成計時器中斷請求,通知CPU定時器操作完成。如果定時器下降計數(shù)器達到零,相應TCNTBn的值自動重新加載到下一個循環(huán)開始。但是,如果定時器停止,例如,在定時器運行模式下,通過清除TCONn的定時器使能位,TCNTBn的值將不會重新加載到計數(shù)器中。

PWM功能使用TCMPBn寄存器的值。定時器控制邏輯改變輸出電平下計數(shù)器值與定時器控制邏輯中比較寄存器的值相匹配。因此,比較寄存器決定PWM輸出的開啟時間或關閉時間。

每個定時器都是雙緩沖結構,帶有TCNTBn和TCMPBn寄存器,允許定時器參數(shù)在周期中更新。新值在當前計時器周期完成之前不會生效。

Exynos PWM定時器的特性

1)5個32位定時器;

2)2個8位PCLK分頻器提供一級預分,5個2級分頻器用來預分外部時鐘;3)可編程選擇PWM獨立通道。

4)4個獨立的可編程的控制及支持校驗的PWM通道。

5)靜態(tài)配置:PWM停止;

6)動態(tài)配置:PWM啟動;

7)支持自動重裝模式及觸發(fā)脈沖模式;

8)一個外部啟動引腳。

9)兩個PWM輸出可帶Dead-Zone 發(fā)生器。

10)中斷發(fā)生器。

PWM內(nèi)部模塊圖

4f863e9c-56fc-11eb-8b86-12bb97331649.png

工作的步驟:

當時鐘PCLK被使能后,定時器計數(shù)緩沖寄存器(TCNTBn)把計數(shù)器初始值下載到遞減計數(shù)器中。

定時器比較緩沖寄存器(TCMPBn)把其初始值下載到比較寄存器中,并將該值與遞減計數(shù)器的值進行比較。當遞減計數(shù)器和比較寄存器值相同時,輸出電平翻轉。

遞減計數(shù)器減至0后,輸出電平再次翻轉,完成一個輸出周期。這種基于TCNTBn和TCMPBn的雙緩沖特性使定時器在頻率和占空比變化時能產(chǎn)生穩(wěn)定的輸出。

每個定時器都有一個專用的由定時器時鐘驅(qū)動的16位遞減計數(shù)器。當遞減計數(shù)器的計數(shù)值達到0時,就會產(chǎn)生定時器中斷請求來通知CPU定時器操作完成。當定時器遞減計數(shù)器達到0的時候,如果設置了Auto-Reload 功能,相應的TCNTBn的值會自動重載到遞減計數(shù)器中以繼續(xù)下次操作。

然而,如果定時器停止了,比如在定時器運行時清除TCON中定時器使能位,TCNTBn的值不會被重載到遞減計數(shù)器中。

TCMPBn 的值用于脈沖寬度調(diào)制。當定時器的遞減計數(shù)器的值和比較寄存器的值相匹配的時候,定時器控制邏輯將改變輸出電平。因此,比較寄存器決定了PWM 輸出的開關時間。

舉例

下面我們舉個實例來看下,

4fd245da-56fc-11eb-8b86-12bb97331649.png

初始化寄存器 TCNTBn = 159 (50 + 109) ,TCMPBn =109.

開啟定時器: 通過設置TCON的開啟位.寄存器TCNTBn 的值159將自動加載到遞減寄存器down-counter, 同時輸出引腳TOUTn 設置為低電平.

當down-counter 的值遞減打破和寄存器TCMPBn 的值109相同時, 輸出引腳將從低拉到高.

當down-counter遞減到0時, 產(chǎn)生一個中斷請求.

如果我們設置成autoreload模式,那么down-counter會自動加載TCNTBn的值到down-counter,開啟新的一個周期。

我們可以通過設置TCNTBn、TCMPBn來控制占空比,而每個pwm周期后都可以重新設置新的值到TCNTBn、TCMPBn,我們通過精確的計算來設置TCNTBn、TCMPBn的值并通過設置dead zone我們可以設計出各種復雜的矩形波。

如下圖所示:

50482638-56fc-11eb-8b86-12bb97331649.png

本例我們只需要產(chǎn)生規(guī)則的舉行方波即可,所以我們只需要設置占空比為50%即可。

六、寄存器

由第四章可知,我們使用PWM控制器的timer 0,對應的寄存器組如下圖所示:

508633ec-56fc-11eb-8b86-12bb97331649.png

1、TFCG0

定時器配置寄存器0(TFCG0) ,主要用于預分頻設置。

50ae142a-56fc-11eb-8b86-12bb97331649.png

我們是timer 0,所以只需要設置該寄存器的bite【7:0】即可,最終的輸出頻率和value的公式如下:

50d54a04-56fc-11eb-8b86-12bb97331649.png

參考24.3.1節(jié):

50fce3d4-56fc-11eb-8b86-12bb97331649.png

其中方波的頻率必須在音頻范圍內(nèi),也就是20Hz到20KHZ之間, 但是20Hz到20KHZ的頻率送給蜂鳴器后, 只有某一點的頻率是最響的, 這個頻率稱為蜂鳴器的諧振頻率, 離它越遠, 蜂鳴器發(fā)出的聲音越輕。

所以Prescaler 0 value值應該設置為255,divider value 應該是1/16,值由TCFG1設置。

PWM.TCFG0=PWM.TCFG0&(~(0xff))|0xf9;

2、TCFG1

定時器配置寄存器1(TCFG1) 主要用于PWM定時器的divider value設置。

5130fbce-56fc-11eb-8b86-12bb97331649.png

由上一節(jié)分析,秩序設置TCFG1 bite【3:0】為0100即0x2即可。

PWM.TCFG1=PWM.TCFG1&(~(0xf))|0x2;

3、TCON

timer控制寄存器TCON

515c08dc-56fc-11eb-8b86-12bb97331649.png

bite[3] : 設置定時器是只執(zhí)行一個周期(One-shot)還是周期執(zhí)行(auto-reload)

bite[1]: 置為1,則更新TCNTB0 、TCMPB0 的值

bit[0]:開啟或者停止定時器

針對不同操作,我們可以設置不同的值:

裝載

PWM.TCON=PWM.TCON&(~(0xff))|(1<

開啟定時器,蜂鳴器響

PWM.TCON=PWM.TCON&(~(0xff))|(1<

關閉定時器,蜂鳴器滅

PWM.TCON=PWM.TCON&(~(1<

4、TCNTB0

定時器計數(shù)緩沖寄存器(TCNTB0)根據(jù)測算,設置為100

519ad49a-56fc-11eb-8b86-12bb97331649.png

TCNTB0

PWM.TCNTB0=100;

5、TCMPB0

定時器比較緩沖寄存器(TCMPB0 )設置為50,占空比為50%

51e79eb0-56fc-11eb-8b86-12bb97331649.png

PWM.TCMPB0=50;

責任編輯:xj

原文標題:基于Cortex-A9的pwm詳解

文章出處:【微信公眾號:玩轉單片機】歡迎添加關注!文章轉載請注明出處。

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

    關注

    114

    文章

    5121

    瀏覽量

    213227
  • CORTEX-A9
    +關注

    關注

    0

    文章

    38

    瀏覽量

    35205
  • 無源蜂鳴器
    +關注

    關注

    0

    文章

    41

    瀏覽量

    11081

原文標題:基于Cortex-A9的pwm詳解

文章出處:【微信號:mcu168,微信公眾號:硬件攻城獅】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    MHMF044A1A9M-MINAS A6N系列 介紹 松下

    電子發(fā)燒友網(wǎng)為你提供Panasonic(Panasonic)MHMF044A1A9M-MINAS A6N系列 介紹相關產(chǎn)品參數(shù)、數(shù)據(jù)手冊,更有MHMF044A1A9M-MINAS A6
    發(fā)表于 10-18 19:11
    MHMF044<b class='flag-5'>A1A9</b>M-MINAS <b class='flag-5'>A</b>6N系列 介紹 松下

    智能機械臂人臉識別特效丨國產(chǎn)Cortex-A55人工智能實驗箱案例分享

    智能機械臂人臉識別特效丨國產(chǎn)Cortex-A55人工智能實驗箱案例分享
    的頭像 發(fā)表于 08-30 13:03 ?399次閱讀
    智能機械臂人臉識別特效丨國產(chǎn)<b class='flag-5'>Cortex-A</b>55人工智能實驗箱案例分享

    MHMF024A1A9M-MINAS A6N系列 介紹 松下

    電子發(fā)燒友網(wǎng)為你提供Panasonic(Panasonic)MHMF024A1A9M-MINAS A6N系列 介紹相關產(chǎn)品參數(shù)、數(shù)據(jù)手冊,更有MHMF024A1A9M-MINAS A6
    發(fā)表于 08-27 18:31
    MHMF024<b class='flag-5'>A1A9</b>M-MINAS <b class='flag-5'>A</b>6N系列 介紹 松下

    智能目標顏色識別抓取丨國產(chǎn)Cortex-A55人工智能實驗箱機械臂案例分享

    智能目標顏色識別抓取丨國產(chǎn)Cortex-A55人工智能實驗箱機械臂案例分享
    的頭像 發(fā)表于 08-10 08:32 ?301次閱讀
    智能目標顏色識別抓取丨國產(chǎn)<b class='flag-5'>Cortex-A</b>55人工智能實驗箱機械臂案例分享

    國產(chǎn)Cortex-A55高性能人工智能實驗箱機械臂姿態(tài)識別案例

    國產(chǎn)Cortex-A55高性能人工智能實驗箱機械臂姿態(tài)識別案例
    的頭像 發(fā)表于 07-19 08:32 ?235次閱讀
    國產(chǎn)<b class='flag-5'>Cortex-A</b>55高性能人工智能實驗箱機械臂姿態(tài)識別案例

    為什么更推薦Cortex-A55教學實驗箱?我來告訴您!

    丨國產(chǎn)嵌入式芯片,助力“中國芯”工程!TL3568-PlusTEB是一款基于瑞芯微RK3568國產(chǎn)化處理器設計的4核ARMCortex-A55嵌入式教學實驗箱。Cortex-A55/53性能對比表
    的頭像 發(fā)表于 05-31 08:32 ?694次閱讀
    為什么更推薦<b class='flag-5'>Cortex-A</b>55教學實驗箱?我來告訴您!

    ARM Cortex-A53嵌入式開發(fā)平臺Android手冊

    電子發(fā)燒友網(wǎng)站提供《ARM Cortex-A53嵌入式開發(fā)平臺Android手冊.pdf》資料免費下載
    發(fā)表于 04-28 15:10 ?0次下載

    Imagination新推APXM-6200 CPU,性能超越Cortex-A53

    該CPU為新時代的64位應用型處理器,采用11級別雙通道線(11-stage, dual-issue pipeline),相較現(xiàn)有市場產(chǎn)品,其性能超出Arm Cortex-A53高達65%,賽過Cortex-A510則多出20%之多。
    的頭像 發(fā)表于 04-09 15:04 ?584次閱讀

    9-A輸出,3-V至4-V輸入跟蹤/終止帶集成FET的同步PWM開關TPS54972數(shù)據(jù)表

    電子發(fā)燒友網(wǎng)站提供《9-A輸出,3-V至4-V輸入跟蹤/終止帶集成FET的同步PWM開關TPS54972數(shù)據(jù)表.pdf》資料免費下載
    發(fā)表于 03-13 10:13 ?0次下載
    <b class='flag-5'>9-A</b>輸出,3-V至4-V輸入跟蹤/終止帶集成FET的同步<b class='flag-5'>PWM</b>開關TPS54972數(shù)據(jù)表

    適用于ARM? Cortex?-A8/A9 SOC 和 FPGA 的TPS65218電源管理數(shù)據(jù)表

    電子發(fā)燒友網(wǎng)站提供《適用于ARM? Cortex?-A8/A9 SOC 和 FPGA 的TPS65218電源管理數(shù)據(jù)表.pdf》資料免費下載
    發(fā)表于 03-06 14:18 ?0次下載
    適用于ARM? <b class='flag-5'>Cortex</b>?-<b class='flag-5'>A</b>8/<b class='flag-5'>A9</b> SOC 和 FPGA 的TPS65218電源管理數(shù)據(jù)表

    入門級64位ARM?CORTEX?-A55 MPU數(shù)據(jù)手冊

    電子發(fā)燒友網(wǎng)站提供《入門級64位ARM?CORTEX?-A55 MPU數(shù)據(jù)手冊.pdf》資料免費下載
    發(fā)表于 02-19 10:59 ?1次下載
    入門級64位ARM?<b class='flag-5'>CORTEX</b>?-<b class='flag-5'>A</b>55 MPU數(shù)據(jù)手冊

    Cortex-A72應用實戰(zhàn)

    下面Cortex-A72培訓營VIP學員問:單核CPU PR做完后,怎么輸出數(shù)據(jù)到TOP去做多核的hierarchy集成?
    的頭像 發(fā)表于 01-24 10:17 ?752次閱讀
    <b class='flag-5'>Cortex-A</b>72應用實戰(zhàn)

    GD32A490 Arm?Cortex?-M4 32位MCU用戶手冊

    電子發(fā)燒友網(wǎng)站提供《GD32A490 Arm?Cortex?-M4 32位MCU用戶手冊.pdf》資料免費下載
    發(fā)表于 12-14 10:30 ?3次下載
    GD32<b class='flag-5'>A</b>490 Arm?<b class='flag-5'>Cortex</b>?-M4 32位MCU用戶手冊

    請問ad7763使用的接口是不是標準的SPI協(xié)議?

    我想用NI公司的myRIO來驅(qū)動AD7763(myRIO內(nèi)含ARM Cortex-A9和一個FPGA,通過labVIEW編程)。現(xiàn)遇到問題:myRIO提供SPI接口無法與AD7763相連接。 所以
    發(fā)表于 12-12 08:23

    簡單介紹NXP LH75401 MCU特性

     NXP LH75401 是一款高性能的 ARM Cortex-A9 32 位微控制器單元(MCU),采用 40 納米工藝制造。該 MCU 擁有主頻高達 800MHz,集成了多個接口和外設,包括
    的頭像 發(fā)表于 11-24 17:10 ?1324次閱讀
    簡單介紹NXP LH75401 MCU特性