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

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

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

HPM6000系列PWM波盡在掌握

331062281 ? 來源:先楫半導(dǎo)體HPMicro ? 2023-05-30 14:36 ? 次閱讀

概 述

在進行電機類、電源類應(yīng)用開發(fā)時,如何使用PWM定時器模塊靈活、高效的實現(xiàn)所需 PWM波形的輸出,是眾多開發(fā)者關(guān)注的問題。在上篇文章里,我們介紹了PWM定時器模塊內(nèi)的一些概念,以及如何生成普通PWM的過程。本篇內(nèi)容將繼續(xù)介紹互補PWM、同步 PWM、錯相 PWM以及PWM如何使用ACMP封波等內(nèi)容。

互補PWM

關(guān)于相同的代碼部分,此處不再重復(fù)講解,請參考《上篇》的普通PWM的講解。

14bfcf74-feb3-11ed-90ce-dac502259ad0.jpg14d6ca80-feb3-11ed-90ce-dac502259ad0.jpg

此處設(shè)置了 3 個比較器:cmp_config[0]與 cmp_config[1]用來生成中心對稱 PWM,cmp_config[2]作為 PWM 影子寄存器的更新事件源,當(dāng) CNT 等于 cmp_config[2]時,影子寄存器寫入寄存器內(nèi)生效。

14e82afa-feb3-11ed-90ce-dac502259ad0.jpg

互補 PWM 對的配置,配置左死區(qū)寬度為 8000 個 half_clock,右死區(qū)寬度為 16000 個 half_clock。

1500a79c-feb3-11ed-90ce-dac502259ad0.jpg

設(shè)置 cmp_config[2]作為 PWM 影子寄存器的更新事件源,啟動計數(shù)器。

1518721e-feb3-11ed-90ce-dac502259ad0.jpg

通過修改 CMP0 與 CMP1 的值,每 100ms 更新一次互補 PWM 占空比。運行結(jié)果如下:

152de09a-feb3-11ed-90ce-dac502259ad0.jpg

互補PWM

同步PWM

本節(jié)實驗設(shè)計:使用 PWM0 的比較器比較事件去做 PWM1、PWM2、PWM3 的同步事件。故輸出波形上看,PWM1、PWM2、PWM3 應(yīng)完全同步,PWM0 與其則不同步。代碼如下:

15475fde-feb3-11ed-90ce-dac502259ad0.jpg

使能 4 個 PWM 定時器的 SYNCI 信號。

15693c94-feb3-11ed-90ce-dac502259ad0.jpg

設(shè)置 STA 與 RLD。

15872966-feb3-11ed-90ce-dac502259ad0.jpg

cmp_config[0]與 cmp_config[1]用來做中心對稱 PWM 所需的比較器。

15a67866-feb3-11ed-90ce-dac502259ad0.jpg

cmp_config[2]用來做使 PWM 影子寄存器生效的比較器。

15bd57fc-feb3-11ed-90ce-dac502259ad0.jpg

cmp_config[3]設(shè)置在 PWM0 CH8 上,用來產(chǎn)生比較事件,同步 PWM1、PWM2、PWM3。

15d506ae-feb3-11ed-90ce-dac502259ad0.jpg

互補 PWM 的死區(qū)設(shè)置與輸出設(shè)置。

15e9b252-feb3-11ed-90ce-dac502259ad0.jpg

設(shè)置 PWM0 CH0 CH1 互補輸出,同時設(shè)置 PWM1 CH8 使用 CMP3 產(chǎn)生比較事件。

160ba9ca-feb3-11ed-90ce-dac502259ad0.jpg

設(shè)置 PWM1、PWM2、PWM3 互補輸出。

162fcda0-feb3-11ed-90ce-dac502259ad0.jpg

啟動計數(shù)器。

以下代碼是對互聯(lián)管理器的配置。配置 PWM0 CH8 的下降沿輸出到TRGM0_OUTX0 上,同時 TRGM0_OUTX0 作為 TRGM1、TRGM2、TRGM3的輸入,路由到 PWM1、PWM2、PWM3 的 SYNCI 信號上。

1647908e-feb3-11ed-90ce-dac502259ad0.jpg

波形如下:

1669d0c2-feb3-11ed-90ce-dac502259ad0.jpg

可見 PWM1、PWM2、PWM3 是完全同步的,PWM0 則與其有 20ns 的不同步。

同步PWM

錯相 PWM

本節(jié)實驗設(shè)計:使用 SYNT 實現(xiàn) PWM0、PWM1、PWM2、PWM3 錯相90°。代碼如下:

168bcbdc-feb3-11ed-90ce-dac502259ad0.jpg

16b106e0-feb3-11ed-90ce-dac502259ad0.jpg

16cef268-feb3-11ed-90ce-dac502259ad0.jpg

16e530c8-feb3-11ed-90ce-dac502259ad0.jpg

16ff0e30-feb3-11ed-90ce-dac502259ad0.jpg

以上代碼請參考上文 “同步PWM” 章節(jié)的講解,主要目的是生成 4 對互補PWM。

17189666-feb3-11ed-90ce-dac502259ad0.jpg

配置 TRGM,將 SYNT CH0 的比較事件路由到 PWM0 的 SYNCI 信號上,將 SYNT CH1 的比較事件路由到 PWM1 的 SYNCI 信號上,將 SYNT CH2 的21 / 24先楫半導(dǎo)體比較事件路由到 PWM2 的 SYNCI 信號上,將 SYNT CH3 的比較事件路由到PWM3 的 SYNCI 信號上。

173593b0-feb3-11ed-90ce-dac502259ad0.jpg

配置 SYNT,分別設(shè)置 SYNT CH0 比較器比較值為 0,SYNT CH1 比較器比較值為 reload/4,SYNT CH2 比較器比較值為 reload/2,SYNT CH4 比較器比較值為 reload*3/4。

波形如下:

1753bf48-feb3-11ed-90ce-dac502259ad0.jpg

錯相PWM

PWM+ACMP 封波

本節(jié)實驗設(shè)計:使用兩個片上 ACMP 對目標(biāo)模擬電壓進行監(jiān)控,當(dāng)電壓超過 1.65V 時停止 PWM 輸出。其基本思路為,將 ACMP 的輸出信號通過互聯(lián)管理器 TRGM 路由到 PWM 的內(nèi)部 Fault 信號上,當(dāng) Fault 信號有效時 PWM波停止輸出(故障保護功能)。

代碼如下:

176d5fac-feb3-11ed-90ce-dac502259ad0.jpg

初始化 PWM 引腳,初始化 DAC 時鐘與引腳(使用 DAC 輸出模擬電壓到ACMP 上模擬過壓)。

1786cd70-feb3-11ed-90ce-dac502259ad0.jpg

輸出互補 PWM 波。

179a1056-feb3-11ed-90ce-dac502259ad0.jpg

設(shè)置 Fault 信號高電平有效;使能 FaultI0 與 FaultI1 有效(PWM 共 4 內(nèi)2 外 fault 信號,哪些信號生效可選)。

17b10766-feb3-11ed-90ce-dac502259ad0.jpg

設(shè)置 DAC 輸出為直接模式,12bit DAC 輸出范圍 0~4095,4030 約為3.247V。該部分代碼請直接參考 DAC 例程。

17c8d6b6-feb3-11ed-90ce-dac502259ad0.jpg

配置 ACMP,使能 ACMP2 與 ACMP3。

17dfdd52-feb3-11ed-90ce-dac502259ad0.jpg

配置互聯(lián)管理器,將 ACMP2 與 ACMP3 的輸出信號路由到 PWM 的FaultI0 與 FaultI1 上去。

17fb6734-feb3-11ed-90ce-dac502259ad0.jpg

acmp_config 函數(shù)源碼如下:

180bba58-feb3-11ed-90ce-dac502259ad0.jpg

代碼中將 ACMP 的正極輸入選擇為 IO 引腳,負極輸入選擇為 ACMP 內(nèi)部專用 DAC,參考電壓設(shè)置為 0x80,即 1.65V。

當(dāng) IO 引腳電壓 3.247V 時(來自于外設(shè) DAC 輸出),ACMP 正極電壓超過負極電壓 1.65V,ACMP 輸出有效,為高電平;經(jīng)過互聯(lián)管理器路由到PWM 的 Fault 信號上;由于 PWM 模塊內(nèi)配置了 Fault 信號為高電平有效,因此此時 Fault 信號有效,PWM 波形停止輸出。

當(dāng) IO 引腳電壓 0V 時(將引腳與 GND 短接),ACMP 正極電壓未超過負極電壓 1.65V,ACMP 輸出無效,PWM 波形正常輸出。

PWM+ACMP

小 結(jié)

本文首先介紹了 PWM 定時器內(nèi)各模塊的基本概念與功能,而后對 PWM的使用由淺入深依次以代碼實例進行講解??梢钥吹?,PWM 的使用只要配置好 STA、RLD、CMPx、影子寄存器等即可實現(xiàn)輸出;如果有同步需求或與其它外設(shè)協(xié)同使用需求,則主要通過互聯(lián)管理器 TRGM 的配置進行實現(xiàn)。





審核編輯:劉清

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

    關(guān)注

    3513

    文章

    1811

    瀏覽量

    267352
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5254

    瀏覽量

    119214
  • 比較器
    +關(guān)注

    關(guān)注

    14

    文章

    1616

    瀏覽量

    106838
  • pwm定時器
    +關(guān)注

    關(guān)注

    0

    文章

    6

    瀏覽量

    1982

原文標(biāo)題:看完這一篇,HPM6000系列PWM波盡在掌握(下)

文章出處:【微信號:HPMicro,微信公眾號:先楫半導(dǎo)體HPMicro】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    請問HPM6000系列CPU中斷有何特點,注意事項有哪些?

    HPM6000系列CPU中斷有何特點,注意事項有哪些?
    發(fā)表于 05-26 06:19

    請問HPM6000系列MCU如何使用硬件DSP單元?

    HPM6000系列MCU如何使用硬件DSP單元?
    發(fā)表于 05-26 06:18

    請問HPM6000系列MCU如何使用硬件浮點數(shù)單元?

    HPM6000系列MCU如何使用硬件浮點數(shù)單元?
    發(fā)表于 05-26 06:49

    HPM6000系列微控制器的片上各類SRAM使用指南

    HPM6000系列微控制器片上SRAM使用指南
    發(fā)表于 06-01 06:19

    HPM6000系列微控制器片上閃存使用指南

    HPM6000系列MCU片上Flash使用指南
    發(fā)表于 06-01 06:20

    HPM6000系列微控制器BOOT模式的說明資料

    HPM6000系列微控制器BOOT MODE指南
    發(fā)表于 06-01 08:43

    HPM6000系列微控制器片上閃存使用指南

    HPM6000系列MCU片上Flash使用指南
    發(fā)表于 06-02 08:54

    HPM6000系列芯片內(nèi)部模擬地和數(shù)字地

    HPM6000系列芯片內(nèi)部模擬地和數(shù)字地是隔離開的嗎?
    發(fā)表于 07-10 17:49

    HPM6000系列微控制器 CMSIS DAP調(diào)試器使用指南

    在上海先楫提供的HPM系列MCU評估套件上,多數(shù)集成了基于FTDI的FT2232芯片的板載調(diào)試器,方便了開發(fā)人員直接調(diào)試并評估HPM6000系列產(chǎn)品。當(dāng)用戶開始基于
    的頭像 發(fā)表于 06-19 17:02 ?3446次閱讀
    <b class='flag-5'>HPM6000</b><b class='flag-5'>系列</b>微控制器 CMSIS DAP調(diào)試器使用指南

    HPM6000系列 ADC 相關(guān)硬件設(shè)計教程

    本文將為大家展示國產(chǎn)芯片HPM6000系列ADC性能出色的測試結(jié)果并為您提供了與HPM6000系列微控制器的模數(shù)轉(zhuǎn)換器ADC相關(guān)的外部電路設(shè)計建議。在
    的頭像 發(fā)表于 07-22 11:18 ?1149次閱讀
    <b class='flag-5'>HPM6000</b><b class='flag-5'>系列</b> ADC 相關(guān)硬件設(shè)計教程

    HPM6000系列微控制器的BOOT 模式的說明以及相應(yīng)的外部電路設(shè)計建議

    1.簡介HPM6000系列MCU目前提供了不同的啟動方式,方便客戶在研發(fā)生產(chǎn)等不同階段使用。本文提供了HPM6000系列微控制器的BOOT模式的說明以及相應(yīng)的外部電路設(shè)計建議。2.BO
    的頭像 發(fā)表于 07-21 15:15 ?1439次閱讀
    <b class='flag-5'>HPM6000</b><b class='flag-5'>系列</b>微控制器的BOOT 模式的說明以及相應(yīng)的外部電路設(shè)計建議

    應(yīng)用分享| HPM6000系列片上SRAM揭秘

    本期開發(fā)筆記由費神編寫主要會為大家介紹HPM6000系列的各類片上SRAM并結(jié)合SeggerEmbeddedStudio的linker文件介紹,提供了如何使用這些SRAM的建議,趕快來了解吧~簡介
    的頭像 發(fā)表于 09-19 11:02 ?1627次閱讀
    應(yīng)用分享| <b class='flag-5'>HPM6000</b><b class='flag-5'>系列</b>片上SRAM揭秘

    看完這一篇,HPM6000系列PWM盡在掌握(上)

    概述在進行電機類、電源類應(yīng)用開發(fā)時,如何使用PWM定時器模塊靈活、高效的實現(xiàn)所需PWM波形的輸出,是眾多開發(fā)者關(guān)注的問題。先楫半導(dǎo)體已發(fā)布的HPM6000系列芯片上,均帶有
    的頭像 發(fā)表于 05-30 10:03 ?1171次閱讀
    看完這一篇,<b class='flag-5'>HPM6000</b><b class='flag-5'>系列</b><b class='flag-5'>PWM</b><b class='flag-5'>波</b><b class='flag-5'>盡在</b><b class='flag-5'>掌握</b>(上)

    看完這一篇,HPM6000系列PWM盡在掌握(下)

    的過程。本篇內(nèi)容將繼續(xù)介紹互補PWM、同步PWM、錯相PWM以及PWM如何使用ACMP封等內(nèi)容?;パaP
    的頭像 發(fā)表于 06-01 15:28 ?978次閱讀
    看完這一篇,<b class='flag-5'>HPM6000</b><b class='flag-5'>系列</b><b class='flag-5'>PWM</b><b class='flag-5'>波</b><b class='flag-5'>盡在</b><b class='flag-5'>掌握</b>(下)

    HPM6000系列微控制器DSP/FFT使用介紹

    電子發(fā)燒友網(wǎng)站提供《HPM6000系列微控制器DSP/FFT使用介紹.pdf》資料免費下載
    發(fā)表于 09-19 15:21 ?1次下載
    <b class='flag-5'>HPM6000</b><b class='flag-5'>系列</b>微控制器DSP/FFT使用介紹