Generating phase-shift PWM signal with SCTimer/PWM module

取消
显示结果 
显示  仅  | 搜索替代 
您的意思是: 

Generating phase-shift PWM signal with SCTimer/PWM module

Generating phase-shift PWM signal with SCTimer/PWM module

The documentation discusses how to generate phase-shift PWM signals based on SCTimer/PWM module, the code is developed based on MCUXpresso IDE version 10.3 and LPCXpresso5411x board.

The LPC family has SCTimer/PWM module and CTimer modules, both of them can generate PWM signals, but only the SCTimer/PWM module  can generate phase-shift PWM signals.

In the code, only the match registers are used to generate events, I/O signals are not used. 

The match0 register is set up as (SystemCoreClock/100), which determines the PWM signal frequency.

The the match1 register is set up as 0x00, which generate event1.

The the match2 register is set up as (SystemCoreClock/100)/2;, which generate event2.

The duty cycle is (SystemCoreClock/100)/2-0x00= (SystemCoreClock/100)/2, which is 50% duty cycle, the cycle time is (SystemCoreClock/100).

The event1 sets the SCT0_OUT1, event2 clears the SCT0_OUT1, so SCT0_OUT1 has 50% duty cycle.

The the match3 register is set up as (SystemCoreClock/100)/4;, which generate even3.

The the match4 register is set up as 3*(SystemCoreClock/100)/4, which generate event4.

The duty cycle is 3*(SystemCoreClock/100)/4  -  (SystemCoreClock/100)/4= (SystemCoreClock/100)/2, which is 50% duty cycle.

The event3 sets the SCT0_OUT2, event4 clears the SCT0_OUT2, so SCT0_OUT2 has 50% duty cycle.

The phase shift is (SystemCoreClock/100)/4 - 0x00= (SystemCoreClock/100)/4, which corresponds 90 degree phase shift.

PWM initilization code:

//The SCT0_OUT1 can output PWM signal with 50 duty cycle from PIO0_8 pin
//The SCT_OUT2 can output PWM signal with 50 duty cycle fron PIO0_9 pin
//The SCT0_OUT1 and SCT0_OUT2 PWM signal has 90 degree phase shift.

void SCT0_PWM(void)
{
    SYSCON->AHBCLKCTRL[1]|=(1<<2); //SET SCT0 bit
    SCT0->CONFIG = (1 << 0) | (1 << 17); // unified 32-bit timer, auto limit
    SCT0->SCTMATCHREL[0] = SystemCoreClock/100; // match 0 @ 100 Hz = 10 msec
    SCT0->EVENT[0].STATE = 0xFFFFFFFF; // event 0 happens in all states


    //set event1
    SCT0->SCTMATCHREL[1]=0x00;
    SCT0->EVENT[1].STATE = 0xFFFFFFFF; // event 1 happens in all states
    SCT0->EVENT[1].CTRL = (1 << 12)|(1<<0); // match 1 condition only

    //set event2
    SCT0->SCTMATCHREL[2]=(SystemCoreClock/100)/2;
    SCT0->EVENT[2].STATE = 0xFFFFFFFF; // event 2 happens in all states
    SCT0->EVENT[2].CTRL = (1 << 12)|(2<<0); // match 2 condition only

    //set event3
    SCT0->SCTMATCHREL[3]=(SystemCoreClock/100)/4;
    SCT0->EVENT[3].STATE = 0xFFFFFFFF; // event 3 happens in all states
    SCT0->EVENT[3].CTRL = (1 << 12)|(3<<0); // match 3 condition only

    //set event4
    SCT0->SCTMATCHREL[4]=3*(SystemCoreClock/100)/4;
    SCT0->EVENT[4].STATE = 0xFFFFFFFF; // event 4 happens in all states
    SCT0->EVENT[4].CTRL = (1 << 12)|(4<<0); // match 4 condition only

    //PWM output1 signal
    SCT0->OUT[1].SET = (1 << 1); // event 1 will set SCT1_OUT0
    SCT0->OUT[1].CLR = (1 << 2); // event 2 will clear SCT1_OUT0
    SCT0->RES |= (3 << 2); // output 0 toggles on conflict

    //PWM output2 signal
    SCT0->OUT[2].SET = (1 << 3); // event 3 will set SCT1_OUT0
    SCT0->OUT[2].CLR = (1 << 4); // event 4 will clear SCT1_OUT0
    SCT0->RES = (3 << 4); // output 0 toggles on conflict

    //PWM start
    SCT0->CTRL &= ~(1 << 2); // unhalt by clearing bit 2 of the CTRL
}

Pin initialization code:

//PIO0_8 PIO0_8 FC2_RXD_SDA_MOSI SCT0_OUT1 CTIMER0_MAT3
//PIO0_9 PIO0_9 FC2_TXD_SCL_MISO SCT0_OUT2 CTIMER3_CAP0 - FC3_CTS_SDA_SSEL0

void SCTimerPinInit(void)
{
    //Enable the     SCTimer clock
    SYSCON->AHBCLKCTRL[0]|=(1<<13); //set IOCON bit


    //SCTimer pin assignment

    IOCON->PIO[0][8]=0x182;
    IOCON->PIO[0][9]=0x182;
    IOCON->PIO[0][10]=0x182;


}

Main Code:

#include <stdio.h>
#include "board.h"
#include "peripherals.h"
#include "pin_mux.h"
#include "clock_config.h"
#include "LPC54114_cm4.h"

void SCT0_Init(void);
void SCTimerPinInit(void);
void P1_9_GPIO(void);
void SCT0_PWM(void);

int main(void) {
      /* Init board hardware. */
    BOARD_InitBootPins();
    BOARD_InitBootClocks();
    BOARD_InitBootPeripherals();

    printf("Hello World\n");
   // SCT0_Init();
   // P1_9_GPIO();

    SCTimerPinInit();
    SCT0_PWM();
    /* Force the counter to be placed into memory. */
    volatile static int i = 0 ;
    /* Enter an infinite loop, just incrementing a counter. */
    while(1) {
        i++ ;
    }
    return 0 ;
}

pastedImage_4.png

The Yellow channel is PIO0_8 pin output signal, which is SCT0_OUT1 PWM output signal.

The Bule channel is PIO0_9 pin output signal, which is SCT0_OUT2 PWM output signal.

%3CLINGO-SUB%20id%3D%22lingo-sub-1102461%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%E4%BD%BF%E7%94%A8%20SCTimer%2FPWM%20%E6%A8%A1%E5%9D%97%E7%94%9F%E6%88%90%E7%9B%B8%E7%A7%BB%20PWM%20%E4%BF%A1%E5%8F%B7%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1102461%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%26lt%3Bmeta%20http-equiv%3D%22Content-Type%22%20content%3D%22text%2Fhtml%3B%20charset%3Dutf-8%22%20%2F%26gt%3B%0A%3CP%3E%E6%96%87%E6%A1%A3%E8%AE%A8%E8%AE%BA%E4%BA%86%E5%A6%82%E4%BD%95%E5%9F%BA%E4%BA%8E%20SCTimer%2FPWM%20%E6%A8%A1%E5%9D%97%E7%94%9F%E6%88%90%E7%9B%B8%E7%A7%BB%20PWM%20%E4%BF%A1%E5%8F%B7%EF%BC%8C%E4%BB%A3%E7%A0%81%E6%98%AF%E5%9F%BA%E4%BA%8E%20MCUXpresso%20IDE%20%E7%89%88%E6%9C%AC%2010.3%20%E5%92%8C%20LPCXpresso5411x%20%E6%9D%BF%E5%BC%80%E5%8F%91%E7%9A%84%E3%80%82%3C%2FP%3E%3CP%3ELPC%E7%B3%BB%E5%88%97%E6%9C%89SCTimer%2FPWM%E6%A8%A1%E5%9D%97%E5%92%8CCTimer%E6%A8%A1%E5%9D%97%EF%BC%8C%E5%AE%83%E4%BB%AC%E9%83%BD%E5%8F%AF%E4%BB%A5%E4%BA%A7%E7%94%9FPWM%E4%BF%A1%E5%8F%B7%EF%BC%8C%E4%BD%86%E5%8F%AA%E6%9C%89SCTimer%2FPWM%E6%A8%A1%E5%9D%97%E5%8F%AF%E4%BB%A5%E4%BA%A7%E7%94%9F%E7%9B%B8%E7%A7%BBPWM%E4%BF%A1%E5%8F%B7%E3%80%82%3C%2FP%3E%3CP%3E%E5%9C%A8%E4%BB%A3%E7%A0%81%E4%B8%AD%EF%BC%8C%E4%BB%85%E4%BD%BF%E7%94%A8%E5%8C%B9%E9%85%8D%E5%AF%84%E5%AD%98%E5%99%A8%E6%9D%A5%E7%94%9F%E6%88%90%E4%BA%8B%E4%BB%B6%EF%BC%8C%E4%B8%8D%E4%BD%BF%E7%94%A8I%2FO%E4%BF%A1%E5%8F%B7%E3%80%82%3C%2FP%3E%3CP%3E%3C%2FP%3E%3CP%3Ematch0%E5%AF%84%E5%AD%98%E5%99%A8%E8%AE%BE%E7%BD%AE%E4%B8%BA%EF%BC%88SystemCoreClock%2F100%EF%BC%89%EF%BC%8C%E5%86%B3%E5%AE%9APWM%E4%BF%A1%E5%8F%B7%E9%A2%91%E7%8E%87%E3%80%82%3C%2FP%3E%3CP%3E%3C%2FP%3E%3CP%3Ematch1%E5%AF%84%E5%AD%98%E5%99%A8%E8%AE%BE%E7%BD%AE%E4%B8%BA0x00%EF%BC%8C%E4%BA%A7%E7%94%9Fevent1%E3%80%82%3C%2FP%3E%3CP%3Ematch2%E5%AF%84%E5%AD%98%E5%99%A8%E8%AE%BE%E7%BD%AE%E4%B8%BA(SystemCoreClock%2F100)%2F2%EF%BC%9B%EF%BC%8C%E5%8D%B3%E4%BA%A7%E7%94%9Fevent2%E3%80%82%3C%2FP%3E%3CP%3E%E5%8D%A0%E7%A9%BA%E6%AF%94%E4%B8%BA%EF%BC%88SystemCoreClock%2F100%EF%BC%89%2F2-0x00%3D%EF%BC%88SystemCoreClock%2F100%EF%BC%89%2F2%EF%BC%8C%E5%8D%B350%25%E5%8D%A0%E7%A9%BA%E6%AF%94%EF%BC%8C%E5%BE%AA%E7%8E%AF%E6%97%B6%E9%97%B4%E4%B8%BA%EF%BC%88SystemCoreClock%2F100%EF%BC%89%E3%80%82%3C%2FP%3E%3CP%3E%E4%BA%8B%E4%BB%B6%201%20%E8%AE%BE%E7%BD%AE%20SCT0_OUT1%EF%BC%8C%E4%BA%8B%E4%BB%B6%202%20%E6%B8%85%E9%99%A4%20SCT0_OUT1%EF%BC%8C%E5%9B%A0%E6%AD%A4%20SCT0_OUT1%20%E5%85%B7%E6%9C%89%2050%25%20%E7%9A%84%E5%8D%A0%E7%A9%BA%E6%AF%94%E3%80%82%3C%2FP%3E%3CP%3E%3C%2FP%3E%3CP%3Ematch3%E5%AF%84%E5%AD%98%E5%99%A8%E8%AE%BE%E7%BD%AE%E4%B8%BA%EF%BC%88SystemCoreClock%2F100%EF%BC%89%2F4%EF%BC%9B%EF%BC%8C%E5%8D%B3%E7%94%9F%E6%88%90even3%E3%80%82%3C%2FP%3E%3CP%3Ematch4%E5%AF%84%E5%AD%98%E5%99%A8%E8%AE%BE%E7%BD%AE%E4%B8%BA3*(SystemCoreClock%2F100)%2F4%EF%BC%8C%E4%BA%A7%E7%94%9Fevent4%E3%80%82%3C%2FP%3E%3CP%3E%E5%8D%A0%E7%A9%BA%E6%AF%94%E4%B8%BA3*(SystemCoreClock%2F100)%2F4%20-%20(SystemCoreClock%2F100)%2F4%3D%20(SystemCoreClock%2F100)%2F2%EF%BC%8C%E5%8D%B350%25%E5%8D%A0%E7%A9%BA%E6%AF%94%E3%80%82%3C%2FP%3E%3CP%3E%E4%BA%8B%E4%BB%B6%203%20%E8%AE%BE%E7%BD%AE%20SCT0_OUT2%EF%BC%8C%E4%BA%8B%E4%BB%B6%204%20%E6%B8%85%E9%99%A4%20SCT0_OUT2%EF%BC%8C%E5%9B%A0%E6%AD%A4%20SCT0_OUT2%20%E5%85%B7%E6%9C%89%2050%25%20%E7%9A%84%E5%8D%A0%E7%A9%BA%E6%AF%94%E3%80%82%3C%2FP%3E%3CP%3E%3C%2FP%3E%3CP%3E%E7%9B%B8%E7%A7%BB%E4%B8%BA%20(SystemCoreClock%2F100)%2F4%20-%200x00%3D%20(SystemCoreClock%2F100)%2F4%EF%BC%8C%E5%AF%B9%E5%BA%94%2090%20%E5%BA%A6%E7%9B%B8%E7%A7%BB%E3%80%82%3C%2FP%3E%3CP%3E%3C%2FP%3E%3CP%3E%3CSTRONG%3EPWM%E5%88%9D%E5%A7%8B%E5%8C%96%E4%BB%A3%E7%A0%81%EF%BC%9A%3C%2FSTRONG%3E%3C%2FP%3E%3CP%3E%2F%2FSCT0_OUT1%20%E5%8F%AF%E4%BB%A5%E4%BB%8E%20PIO0_8%20%E5%BC%95%E8%84%9A%E8%BE%93%E5%87%BA%E5%8D%A0%E7%A9%BA%E6%AF%94%E4%B8%BA%2050%20%E7%9A%84%20PWM%20%E4%BF%A1%E5%8F%B7%3CBR%20%2F%3E%2F%2FSCT_OUT2%20%E5%8F%AF%E4%BB%A5%E4%BB%8E%20PIO0_9%20%E5%BC%95%E8%84%9A%E8%BE%93%E5%87%BA%E5%8D%A0%E7%A9%BA%E6%AF%94%E4%B8%BA%2050%20%E7%9A%84%20PWM%20%E4%BF%A1%E5%8F%B7%3CBR%20%2F%3E%2F%2FSCT0_OUT1%20%E5%92%8C%20SCT0_OUT2%20PWM%20%E4%BF%A1%E5%8F%B7%E5%85%B7%E6%9C%89%2090%20%E5%BA%A6%E7%9B%B8%E7%A7%BB%E3%80%82%3C%2FP%3E%3CP%3E%3C%2FP%3E%3CP%3E%E6%97%A0%E6%95%88SCT0_PWM%EF%BC%88%E6%97%A0%E6%95%88%EF%BC%89%3CBR%20%2F%3E%20%7B%3CBR%20%2F%3E%20SYSCON-%26gt%3BAHBCLKCTRL%5B1%5D%7C%3D(1%26lt%3B%26lt%3B2)%3B%20%2F%2F%E8%AE%BE%E7%BD%AESCT0%E4%BD%8D%3CBR%20%2F%3ESCT0-%26gt%3BCONFIG%20%3D%20(1%20%26lt%3B%26lt%3B%200)%20%7C%20(1%20%26lt%3B%26lt%3B%2017)%3B%20%2F%2F%E7%BB%9F%E4%B8%8032%E4%BD%8D%E5%AE%9A%E6%97%B6%E5%99%A8%EF%BC%8C%E8%87%AA%E5%8A%A8%E9%99%90%E5%88%B6%3CBR%20%2F%3ESCT0-%26gt%3BSCTMATCHREL%5B0%5D%20%3D%20SystemCoreClock%2F100%3B%20%2F%2F%E5%8C%B9%E9%85%8D%200%20%40%20100%20Hz%20%3D%2010%20%E6%AF%AB%E7%A7%92%3CBR%20%2F%3ESCT0-%26gt%3BEVENT%5B0%5D.STATE%20%3D%200xFFFFFFFF%3B%20%2F%2F%20%E4%BA%8B%E4%BB%B6%200%20%E5%9C%A8%E6%89%80%E6%9C%89%E7%8A%B6%E6%80%81%E4%B8%8B%E5%8F%91%E7%94%9F%3C%2FP%3E%3CP%3E%3C%2FP%3E%3CP%3E%3CBR%20%2F%3E%2F%2F%E8%AE%BE%E7%BD%AE%E4%BA%8B%E4%BB%B61%3CBR%20%2F%3E%20SCT0-%26gt%3BSCTMATCHREL%5B1%5D%3D0x00%EF%BC%9B%3CBR%20%2F%3E%20SCT0-%26gt%3BEVENT%5B1%5D.STATE%20%3D%200xFFFFFFFF%3B%20%2F%2F%20%E4%BA%8B%E4%BB%B6%201%20%E5%9C%A8%E6%89%80%E6%9C%89%E7%8A%B6%E6%80%81%E4%B8%8B%E5%8F%91%E7%94%9F%3CBR%20%2F%3ESCT0-%26gt%3BEVENT%5B1%5D.CTRL%20%3D%20(1%20%26lt%3B%26lt%3B%2012)%7C(1%26lt%3B%26lt%3B0)%3B%20%2F%2F%20%E4%BB%85%E5%8C%B9%E9%85%8D%201%20%E4%B8%AA%E6%9D%A1%E4%BB%B6%3C%2FP%3E%3CP%3E%3C%2FP%3E%3CP%3E%2F%2F%E8%AE%BE%E7%BD%AE%E4%BA%8B%E4%BB%B62%3CBR%20%2F%3E%20SCT0-%26gt%3BSCTMATCHREL%5B2%5D%3D(SystemCoreClock%2F100)%2F2%3B%3CBR%20%2F%3E%20SCT0-%26gt%3BEVENT%5B2%5D.STATE%20%3D%200xFFFFFFFF%3B%20%2F%2F%20%E4%BA%8B%E4%BB%B6%202%20%E5%9C%A8%E6%89%80%E6%9C%89%E7%8A%B6%E6%80%81%E4%B8%8B%E5%8F%91%E7%94%9F%3CBR%20%2F%3ESCT0-%26gt%3BEVENT%5B2%5D.CTRL%20%3D%20(1%20%26lt%3B%26lt%3B%2012)%7C(2%26lt%3B%26lt%3B0)%3B%20%2F%2F%20%E4%BB%85%E5%8C%B9%E9%85%8D%202%20%E4%B8%AA%E6%9D%A1%E4%BB%B6%3C%2FP%3E%3CP%3E%3C%2FP%3E%3CP%3E%2F%2F%E8%AE%BE%E7%BD%AE%E4%BA%8B%E4%BB%B63%3CBR%20%2F%3E%20SCT0-%26gt%3BSCTMATCHREL%5B3%5D%3D(SystemCoreClock%2F100)%2F4%3B%3CBR%20%2F%3E%20SCT0-%26gt%3BEVENT%5B3%5D.STATE%20%3D%200xFFFFFFFF%3B%20%2F%2F%20%E4%BA%8B%E4%BB%B6%203%20%E5%9C%A8%E6%89%80%E6%9C%89%E7%8A%B6%E6%80%81%E4%B8%8B%E5%8F%91%E7%94%9F%3CBR%20%2F%3ESCT0-%26gt%3BEVENT%5B3%5D.CTRL%20%3D%20(1%20%26lt%3B%26lt%3B%2012)%7C(3%26lt%3B%26lt%3B0)%3B%20%2F%2F%20%E4%BB%85%E5%8C%B9%E9%85%8D%203%20%E4%B8%AA%E6%9D%A1%E4%BB%B6%3C%2FP%3E%3CP%3E%3C%2FP%3E%3CP%3E%2F%2F%E8%AE%BE%E7%BD%AE%E4%BA%8B%E4%BB%B64%3CBR%20%2F%3E%20SCT0-%26gt%3BSCTMATCHREL%5B4%5D%3D3*(SystemCoreClock%2F100)%2F4%3B%3CBR%20%2F%3E%20SCT0-%26gt%3BEVENT%5B4%5D.STATE%20%3D%200xFFFFFFFF%3B%20%2F%2F%20%E4%BA%8B%E4%BB%B6%204%20%E5%9C%A8%E6%89%80%E6%9C%89%E7%8A%B6%E6%80%81%E4%B8%8B%E5%8F%91%E7%94%9F%3CBR%20%2F%3ESCT0-%26gt%3BEVENT%5B4%5D.CTRL%20%3D%20(1%20%26lt%3B%26lt%3B%2012)%7C(4%26lt%3B%26lt%3B0)%3B%20%2F%2F%20%E4%BB%85%E5%8C%B9%E9%85%8D%204%20%E4%B8%AA%E6%9D%A1%E4%BB%B6%3C%2FP%3E%3CP%3E%3C%2FP%3E%3CP%3E%2F%2FPWM%E8%BE%93%E5%87%BA1%E4%BF%A1%E5%8F%B7%3CBR%20%2F%3ESCT0-%26gt%3BOUT%5B1%5D.SET%20%3D%20(1%20%26lt%3B%26lt%3B%201)%3B%20%2F%2F%20%E4%BA%8B%E4%BB%B6%201%20%E5%B0%86%E8%AE%BE%E7%BD%AE%20SCT1_OUT0%3CBR%20%2F%3E%20SCT0-%26gt%3BOUT%5B1%5D.CLR%20%3D%20(1%20%26lt%3B%26lt%3B%202)%3B%20%2F%2F%20%E4%BA%8B%E4%BB%B6%202%20%E5%B0%86%E6%B8%85%E9%99%A4%20SCT1_OUT0%3CBR%20%2F%3E%20SCT0-%26gt%3BRES%20%7C%3D%20(3%20%26lt%3B%26lt%3B%202)%3B%20%2F%2F%20%E8%BE%93%E5%87%BA%200%20%E5%9C%A8%E5%86%B2%E7%AA%81%E6%97%B6%E5%88%87%E6%8D%A2%3C%2FP%3E%3CP%3E%3C%2FP%3E%3CP%3E%2F%2FPWM%E8%BE%93%E5%87%BA2%E4%BF%A1%E5%8F%B7%3CBR%20%2F%3ESCT0-%26gt%3BOUT%5B2%5D.SET%20%3D%20(1%20%26lt%3B%26lt%3B%203)%3B%20%2F%2F%20%E4%BA%8B%E4%BB%B6%203%20%E5%B0%86%E8%AE%BE%E7%BD%AE%20SCT1_OUT0%3CBR%20%2F%3E%20SCT0-%26gt%3BOUT%5B2%5D.CLR%20%3D%20(1%20%26lt%3B%26lt%3B%204)%3B%20%2F%2F%20%E4%BA%8B%E4%BB%B6%204%20%E5%B0%86%E6%B8%85%E9%99%A4%20SCT1_OUT0%3CBR%20%2F%3E%20SCT0-%26gt%3BRES%20%3D%20(3%20%26lt%3B%26lt%3B%204)%3B%20%2F%2F%20%E8%BE%93%E5%87%BA%200%20%E5%9C%A8%E5%86%B2%E7%AA%81%E6%97%B6%E5%88%87%E6%8D%A2%3C%2FP%3E%3CP%3E%3C%2FP%3E%3CP%3E%2F%2FPWM%E5%90%AF%E5%8A%A8%3CBR%20%2F%3ESCT0-%26gt%3BCTRL%20%26amp%3B%3D%20~(1%20%26lt%3B%26lt%3B%202)%3B%20%2F%2F%E9%80%9A%E8%BF%87%E6%B8%85%E9%99%A4%20CTRL%20%E7%9A%84%E7%AC%AC%202%20%E4%BD%8D%E6%9D%A5%E5%8F%96%E6%B6%88%E6%9A%82%E5%81%9C%3CBR%20%2F%3E%7D%3C%2FP%3E%3CP%3E%3C%2FP%3E%3CP%3E%3CSTRONG%3E%E5%BC%95%E8%84%9A%E5%88%9D%E5%A7%8B%E5%8C%96%E4%BB%A3%E7%A0%81%EF%BC%9A%3C%2FSTRONG%3E%3C%2FP%3E%3CP%3E%2F%2FPIO0_8%20PIO0_8%20FC2_RXD_SDA_MOSI%20SCT0_OUT1%20CTIMER0_MAT3%3CBR%20%2F%3E%20%2F%2FPIO0_9%20PIO0_9%20FC2_TXD_SCL_MISO%20SCT0_OUT2%20CTIMER3_CAP0%20-%20FC3_CTS_SDA_SSEL0%3CBR%20%2F%3E%3CBR%20%2F%3E%E6%97%A0%E6%95%88%20SCTimerPinInit%EF%BC%88%E6%97%A0%E6%95%88%EF%BC%89%3CBR%20%2F%3E%20%7B%3CBR%20%2F%3E%20%2F%2F%E5%90%AF%E7%94%A8SCTimer%E6%97%B6%E9%92%9F%3CBR%20%2F%3ESYSCON-%26gt%3BAHBCLKCTRL%5B0%5D%7C%3D(1%26lt%3B%26lt%3B13)%3B%20%2F%2F%E8%AE%BE%E7%BD%AE%20IOCON%20%E4%BD%8D%3C%2FP%3E%3CP%3E%3C%2FP%3E%3CP%3E%3CBR%20%2F%3E%2F%2FSCTimer%20%E5%BC%95%E8%84%9A%E5%88%86%E9%85%8D%3C%2FP%3E%3CP%3E%3C%2FP%3E%3CP%3E%26nbsp%3B%26nbsp%3B%26nbsp%3B%20IOCON-%26gt%3BPIO%5B0%5D%5B8%5D%3D0x182%3B%3CBR%20%2F%3E%26nbsp%3B%26nbsp%3B%26nbsp%3B%20IOCON-%26gt%3BPIO%5B0%5D%5B9%5D%3D0x182%3B%3CBR%20%2F%3E%26nbsp%3B%26nbsp%3B%20%26nbsp%3BIOCON-%26gt%3BPIO%5B0%5D%5B10%5D%3D0x182%3B%3C%2FP%3E%3CP%3E%3C%2FP%3E%3CP%3E%3CBR%20%2F%3E%7D%3C%2FP%3E%3CP%3E%3CSTRONG%3E%E4%B8%BB%E8%A6%81%E4%BB%A3%E7%A0%81%EF%BC%9A%3C%2FSTRONG%3E%3C%2FP%3E%3CP%3E%23include%20%3CSTDIO.H%3E%3CBR%20%2F%3E%23%E5%8C%85%E6%8B%AC%E2%80%9Cboard.h%E2%80%9D%3CBR%20%2F%3E%23%E5%8C%85%E6%8B%AC%E2%80%9C%E5%A4%96%E8%AE%BE.h%E2%80%9D%3CBR%20%2F%3E%23%E5%8C%85%E6%8B%AC%E2%80%9Cpin_mux.h%E2%80%9D%3CBR%20%2F%3E%23%E5%8C%85%E6%8B%AC%E2%80%9Cclock_config.h%E2%80%9D%3CBR%20%2F%3E%23%E5%8C%85%E6%8B%AC%E2%80%9CLPC54114_cm4.h%E2%80%9D%3C%2FSTDIO.H%3E%3C%2FP%3E%3CP%3E%3C%2FP%3E%3CP%3Evoid%20SCT0_Init(void)%3B%3CBR%20%2F%3Evoid%20SCTimerPinInit(void)%3B%3CBR%20%2F%3Evoid%20P1_9_GPIO(void)%3B%3CBR%20%2F%3Evoid%20SCT0_PWM(void)%3B%3C%2FP%3E%3CP%3Eint%20main%EF%BC%88void%EF%BC%89%7B%3CBR%20%2F%3E%20%2F*%20%E5%88%9D%E5%A7%8B%E5%8C%96%E6%9D%BF%E7%A1%AC%E4%BB%B6%E3%80%82*%2F%3CBR%20%2F%3E%E6%9D%BF%E5%88%9D%E5%A7%8B%E5%8C%96%E5%90%AF%E5%8A%A8%E5%BC%95%E8%84%9A%EF%BC%88%EF%BC%89%EF%BC%9B%3CBR%20%2F%3E%E4%B8%BB%E6%9D%BF%E5%88%9D%E5%A7%8B%E5%8C%96%E5%90%AF%E5%8A%A8%E6%97%B6%E9%92%9F%EF%BC%88%EF%BC%89%EF%BC%9B%3CBR%20%2F%3E%20BOARD_InitBootPeripherals%EF%BC%88%EF%BC%89%EF%BC%9B%3C%2FP%3E%3CP%3E%3C%2FP%3E%3CP%3Eprintf(%E2%80%9C%E4%BD%A0%E5%A5%BD%EF%BC%8C%E4%B8%96%E7%95%8C%5Cn%E2%80%9D)%3B%3CBR%20%2F%3E%20%2F%2FSCT0_Init()%EF%BC%9B%3CBR%20%2F%3E%20%2F%2FP1_9_GPIO()%EF%BC%9B%3C%2FP%3E%3CP%3E%3C%2FP%3E%3CP%3ESCTimerPinInit%EF%BC%88%EF%BC%89%EF%BC%9B%3CBR%20%2F%3E%20SCT0_PWM%EF%BC%88%EF%BC%89%EF%BC%9B%3CBR%20%2F%3E%20%2F*%20%E5%BC%BA%E5%88%B6%E5%B0%86%E8%AE%A1%E6%95%B0%E5%99%A8%E6%94%BE%E5%85%A5%E5%86%85%E5%AD%98%E3%80%82*%2F%3CBR%20%2F%3E%E6%98%93%E5%A4%B1%E6%80%A7%E9%9D%99%E6%80%81%20int%20i%20%3D%200%EF%BC%9B%3CBR%20%2F%3E%20%2F*%20%E8%BF%9B%E5%85%A5%E6%97%A0%E9%99%90%E5%BE%AA%E7%8E%AF%EF%BC%8C%E4%BB%85%E5%A2%9E%E5%8A%A0%E8%AE%A1%E6%95%B0%E5%99%A8%E3%80%82*%2F%3CBR%20%2F%3E%20while(1)%7B%3CBR%20%2F%3E%20i%2B%2B%EF%BC%9B%3CBR%20%2F%3E%20%7D%3CBR%20%2F%3E%E8%BF%94%E5%9B%9E%200%EF%BC%9B%3CBR%20%2F%3E%20%7D%3C%2FP%3E%3CP%3E%3C%2FP%3E%3CP%3E%3CSPAN%20class%3D%22lia-inline-image-display-wrapper%22%20image-alt%3D%22pastedImage_4.png%22%3E%3Cspan%20class%3D%22lia-inline-image-display-wrapper%22%20image-alt%3D%22pastedImage_4.png%22%20style%3D%22width%3A%20999px%3B%22%3E%3Cimg%20src%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fimage%2Fserverpage%2Fimage-id%2F82960iD3E1E03896B56A62%2Fimage-size%2Flarge%3Fv%3Dv2%26amp%3Bpx%3D999%22%20role%3D%22button%22%20title%3D%22pastedImage_4.png%22%20alt%3D%22pastedImage_4.png%22%20%2F%3E%3C%2Fspan%3E%3C%2FSPAN%3E%3C%2FP%3E%3CP%3E%E9%BB%84%E8%89%B2%E9%80%9A%E9%81%93%E4%B8%BAPIO0_8%E5%BC%95%E8%84%9A%E8%BE%93%E5%87%BA%E4%BF%A1%E5%8F%B7%EF%BC%8C%E5%8D%B3SCT0_OUT1%E7%9A%84PWM%E8%BE%93%E5%87%BA%E4%BF%A1%E5%8F%B7%E3%80%82%3C%2FP%3E%3CP%3E%E8%93%9D%E8%89%B2%E9%80%9A%E9%81%93%E4%B8%BAPIO0_9%E5%BC%95%E8%84%9A%E8%BE%93%E5%87%BA%E4%BF%A1%E5%8F%B7%EF%BC%8C%E5%8D%B3SCT0_OUT2%E7%9A%84PWM%E8%BE%93%E5%87%BA%E4%BF%A1%E5%8F%B7%E3%80%82%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-LABS%20id%3D%22lingo-labs-1102461%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CLINGO-LABEL%3ELPC%E8%90%A5%E9%94%80%3C%2FLINGO-LABEL%3E%3CLINGO-LABEL%3ELPC43xx%3C%2FLINGO-LABEL%3E%3CLINGO-LABEL%3ELPC51Uxx%3C%2FLINGO-LABEL%3E%3CLINGO-LABEL%3ELPC546xx%3C%2FLINGO-LABEL%3E%3CLINGO-LABEL%3ELPC54xxx%3C%2FLINGO-LABEL%3E%3CLINGO-LABEL%3ELPC55xx%3C%2FLINGO-LABEL%3E%3CLINGO-LABEL%3ELPC800%3C%2FLINGO-LABEL%3E%3C%2FLINGO-LABS%3E
100% 有帮助 (1/1)
版本历史
最后更新:
‎07-24-2019 01:41 AM
更新人: