?? main.c
字號:
/****************************************Copyright (c)**************************************************
** Guangzhou ZHIYUAN electronics Co.,LTD.
**
** http://www.embedtools.com
**
**--------------File Info-------------------------------------------------------------------------------
** File Name: Main.c
** Last modified Date: 2007-03-24
** Last Version: 1.0
** Description: Use PWM0 & PWM1 to drive leds 使用PWM0和PWM1驅動LED
**
**------------------------------------------------------------------------------------------------------
** Created By: Steven Zhou 周紹剛
** Created date: 2007-03-24
** Version: 1.0
** Descriptions: The original version 初始版本
**
**------------------------------------------------------------------------------------------------------
** Modified by: Kang qinhua
** Modified date: 2008.01.19
** Version: v1.1
** Description:
**
********************************************************************************************************/
#define HWREG(x) ( *((volatile unsigned long *)(x)) )
#define SYSCTL_RCC 0x400fe060 // 運行模式時鐘門控寄存器
#define SYSCTL_RCGC0 0x400fe100 // 運行模式時鐘門控寄存器0
#define SYSCTL_RCGC2 0x400fe108 // 運行模式時鐘門控寄存器2
#define SYSCTL_RCC_USE_PWMDIV 0x00100000 // PWM分頻系數
#define SYSCTL_PERIPH_GPIOD 0x20000008 // GPIO D在系統控制器中的地址
#define SYSCTL_PERIPH_PWM 0x00100000 // PWM在系統控制器中的地址
#define GPIO_PORTD_BASE 0x40007000 // GPIO D的基地址
#define GPIO_O_DIR 0x00000400 // 方向寄存器
#define GPIO_O_AFSEL 0x00000420 // 模式選擇寄存器
#define PWM_BASE 0x40028000 // PWM的基地址
#define PWM_GEN_0_OFFSET 0x00000040 // PWM發生器0的偏移地址
#define PWM_O_X_CTL 0x00000000 // PWM發生器0控制寄存器
#define PWM_O_X_GENA 0x00000020 // PWM發生器0發生寄存器A
#define PWM_O_X_GENB 0x00000024 // PWM發生器0發生寄存器B
#define PWM_O_X_CMPA 0x00000018 // PWM發生器0比較寄存器A
#define PWM_O_X_CMPB 0x0000001C // PWM發生器0比較寄存器B
#define PWM_O_ENABLE 0x00000008 // PWM發生器0使能寄存器
#define PWM_O_X_LOAD 0x00000010 // PWM發生器0裝載寄存器
#define PWM_GEN_MODE_UP_DOWN 0x00000002 // 上下計數模式
#define PWM_GEN_ACT_ZERO 0x2 // 設置輸出為0
#define PWM_GEN_ACT_ONE 0x3 // 設置輸出為1
#define PWM_GEN_ACT_ZERO_SHIFT 0 // 設置輸出為0時的移位數
#define PWM_GEN_ACT_A_UP_SHIFT 4 // 設置A向上時的移位數
#define PWM_GEN_ACT_A_DN_SHIFT 6 // 設置A向下時的移位數
#define PWM_GEN_ACT_B_UP_SHIFT 8 // 設置B向上時的移位數
#define PWM_GEN_ACT_B_DN_SHIFT 10 // 設置B向下時的移位數
/*********************************************************************************************************
** Function name: main
**
** Descriptions: Main function of the project 工程的主函數
**
** Input parameters: None 無
** Returned value: None 無
**
** Used global variables: None 無
** Calling modules: SysCtlClockSet,SysCtlPWMClockSet,SysCtlPeripheralEnable,GPIOPinTypePWM,
** GPIOPadConfigSet,PWMGenConfigure,PWMGenPeriodSet,PWMPulseWidthSet,
** PWMOutputState,PWMGenEnable
**
** Created by: Steven Zhou 周紹剛
** Created Date: 2007-01-18
**-------------------------------------------------------------------------------------------------------
** Modified by: Kang qinhua
** Modified date: 2008.01.19
**------------------------------------------------------------------------------------------------------
********************************************************************************************************/
int main(void)
{
HWREG(SYSCTL_RCC) &= (~SYSCTL_RCC_USE_PWMDIV); // PWM時鐘源1分頻
HWREG(SYSCTL_RCGC2) |= SYSCTL_PERIPH_GPIOD; // 使能PD口外設
HWREG(SYSCTL_RCGC0) |= SYSCTL_PERIPH_PWM; // 使能PWM外設
HWREG(GPIO_PORTD_BASE + GPIO_O_DIR) |= 0x00000003; // 設置PD0,PD1為輸出
HWREG(GPIO_PORTD_BASE + GPIO_O_AFSEL) |= 0x00000003; // 選擇硬件功能,即PWM
// 設置PWM發生器0為上下計數方式,兩路PWM不同步
HWREG(PWM_BASE + PWM_GEN_0_OFFSET + PWM_O_X_CTL ) &= (~0x0000003F);
HWREG(PWM_BASE + PWM_GEN_0_OFFSET + PWM_O_X_CTL ) |= PWM_GEN_MODE_UP_DOWN;
HWREG(PWM_BASE + PWM_GEN_0_OFFSET + PWM_O_X_GENA) &=(~0x00000FFF);
HWREG(PWM_BASE + PWM_GEN_0_OFFSET + PWM_O_X_GENA) |=((PWM_GEN_ACT_ONE<<PWM_GEN_ACT_A_UP_SHIFT)|
(PWM_GEN_ACT_ZERO<<PWM_GEN_ACT_A_DN_SHIFT));
HWREG(PWM_BASE + PWM_GEN_0_OFFSET + PWM_O_X_GENB) &=(~0x00000FFF);
HWREG(PWM_BASE + PWM_GEN_0_OFFSET + PWM_O_X_GENB) |=((PWM_GEN_ACT_ONE<<PWM_GEN_ACT_B_UP_SHIFT)|
(PWM_GEN_ACT_ZERO <<PWM_GEN_ACT_B_DN_SHIFT));
HWREG(PWM_BASE + PWM_GEN_0_OFFSET + PWM_O_X_LOAD) = 60000/2; // 設置兩路PWM的共同周期
HWREG(PWM_BASE + PWM_GEN_0_OFFSET + PWM_O_X_CMPA) = (60000-50000)/2;// 分別設置兩路PWM的匹配值
HWREG(PWM_BASE + PWM_GEN_0_OFFSET + PWM_O_X_CMPB) = (60000-10000)/2;
HWREG(PWM_BASE + PWM_O_ENABLE) |= 0x00000003; // 使能PWM0和PWM1
HWREG(PWM_BASE + PWM_GEN_0_OFFSET + PWM_O_X_CTL ) |= 0x00000001; // 使能PWM發生器0
while(1);
}
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -