2016-05-06 75 views
0

我知道互联网上有很多例子,但是需要这些代码才能工作?为什么这个简单的PWM不能在xc8中工作

frecuency振荡器= 4MHz的

periode = 0.25us

duty_cicle = 250

预分频= 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 = 1毫秒

Sincerilly NIN

回答

0

首题主题: 不包含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。

第二步: 我们想要一个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; 

希望有所帮助。

0

数据表中指出:

在脉宽调制(PWM)模式下,CCP1销 产生高达10位分辨率的PWM输出。由于 CCP1引脚与PORTB数据锁存器 复用,必须清零TRISB位以使CCP1 引脚为输出。

所以,你必须为CCP1引脚的TRIS位设置为输出:

TRISB &= ~(1 << 3); //Clear bit RB3/CCP1 in TRISB, makes PORTB3/CCP1 output. 

这在配置字假设CCPMX: CCP1 Pin Selection bit是明确的。如果设置,那么CCP1在RB0而不是RB3,但由于我没有看到你的配置编译指示中的CCPMX,我认为它被清除。

+0

嗨。我不工作。即使你的instruccion是由XC8执行的。我在“while(1)”之后放置了你的instruccion。会有什么问题? – NIN

相关问题