为什么这个简单的PWM在xc8中不起作用

时间:2016-05-06 04:49:43

标签: c pic pwm xc8

我知道互联网上有很多例子,但是这个代码需要做些什么呢?

频率振荡器= 4mhz

periode = 0.25us

duty_cicle = 250

Prescale = 16

PR2 = 124

#include <xc.h>
#include <stdio.h>
#include <stdlib.h>
#include <pic16f88.h>

#pragma config FOSC = HS  // Oscillator Selection bits (INTOSC oscillator: I/O function on RA6/OSC2/CLKOUT pin, I/O function on RA7/OSC1/CLKIN)
#pragma config WDTE = OFF       // Watchdog Timer Enable bit (WDT disabled)
#pragma config PWRTE = OFF      // Power-up Timer Enable bit (PWRT disabled)
#pragma config MCLRE = OFF      // RA5/MCLR/VPP Pin Function Select bit (RA5/MCLR/VPP pin function is digital input, MCLR internally tied to VDD)
#pragma config BOREN = ON       // Brown-out Detect Enable bit (BOD enabled)
#pragma config LVP = OFF        // Low-Voltage Programming Enable bit (RB4/PGM pin has digital I/O function, HV on MCLR must be used for programming)
#pragma config CPD = OFF        // Data EE Memory Code Protection bit (Data memory code protection off)
#pragma config CP = OFF         // Flash Program Memory Code Protection bit (Code protection off)

void main ()
{
     while (1)
     {
            CCP1CON = 0x2C; /*activate PWM mode*/
            PR2 = 0x7C;    /*124 (DECIMAL)*/
            T2CON = 0X06; /*prescale 16 */
            CCPR1L = 0X3E;

     }    
}

我想看看:

PWM周期= 2ms

Dutycicle = 1ms

Sincerilly NIN

2 个答案:

答案 0 :(得分:1)

首先是主题: 不包括pic16f88.h,它包含在xc.h中。

主题更多: 如果使用更现代的部件(例如PIC16f1619),则可以使用MPLAB代码配置器为您生成TMR2和CCP代码。它也会花费更少,闪存/内存更多。该设备位于curiosity board($ 20)。

关于主题: 您的第一站是datasheet

PWM部分有setup for PWM operation

步骤1: timer 2将Fosc / 4作为输入,在您的情况下为1mhz。 目标频率为500Hz。 1e6 / 500 = 2k。 我建议预分频器为16,pr值为125.这将给你正好500Hz。

步骤2: 我们想要50%的工作周期。 CCP1L floor(125/2)= 62. CCP1X:CCP1Y = 0.5 * 4 = 2.

第3步: 清除tris位。

第4步和第5步: 打开它

// Step 1
TMR2ON = 0;
TOUTPS = 0;
T2CKPS = 2;
PR2 = 250U;

// Step 2
CCP1L = 62U;
CCP1X = 1;
CCP1Y = 0;

// Step 3
TRISB3 = 0;

// Step 4
TMR2ON = 1;

// Step 5
CCP1M = 0xC;

希望有所帮助。

答案 1 :(得分:0)

数据表说明:

  

在脉冲宽度调制(PWM)模式下,CCP1引脚   产生高达10位分辨率的PWM输出。以来   CCP1引脚与PORTB数据锁存器复用,   必须清零TRISB位才能产生CCP1   固定输出。

因此必须将CCP1引脚的TRIS位置1:

if

这假定配置字中的temp <- data.frame(temp)是明确的。如果置位,则CCP1在RB0上而不是RB3,但由于我没有在配置编译中提及CCPMX,我认为它已被清除。