Chào các bạn trong bài đăng này mình sẽ hương dẫn các bạn về Counter của Timer 0 nên nếu bạn nào chưa xem bài đăng trước về Timer 0 thì xem lại TẠI ĐÂY để hiểu về Timer 0 để các bạn không bỡ ngỡ khi xem bài đăng này ! Cụ thể trong bài này chúng ta sẽ sử dụng chức năng Counter của Timer 0 để đếm từ 0 đến 99 ! Và để thực hiện được việc đó chúng ta chỉ cần chú ý 2 phần quan trọng để làm được bài này đó là lựa chọn 2 bít liên quan tới chế độ Counter của Timer 0 là :
OPTION_REGbits.T0CS = 1; // Dem xung ngoai
OPTION_REGbits.PSA = 1; // Su dung bo chia truoc WDT
Chỉ cần 2 bit này chúng ta có thể sử dụng chức năng Counter của Timer 0 trong nhiều ứng dụng ví dụ như là : đếm sản phẩm, đếm xung từ encoder….
Và chúng ta sẽ gắn giá trị đếm cho TMR0 chú ý giá trị đếm phải nhỏ hơn hoặc bằng 255 nha ! Và giải thuật của chúng ta được viết như sau !
Và muốn chương trình của chúng ta chạy được thì 1 điều quan trọng nữa là phải cấp xung vào chân RA4/T0CKI là chân chân xung của Timer 0 như vậy thì khi có cạnh lên hoặc cạnh xuống thì chương trình của chúng ta sẽ bắt đầu đếm.Và chúng ta sẽ gắn giá trị đếm cho TMR0 chú ý giá trị đếm phải nhỏ hơn hoặc bằng 255 nha ! Và giải thuật của chúng ta được viết như sau !
dem=TMR0;
if(dem>=100)
{
TMR0=0;
dem=0;
}
if(dem>=100)
{
TMR0=0;
dem=0;
}
- Đây là ảnh mô phỏng protues.
- Đây là code chương trình.
#include <stdio.h>
#include <stdlib.h>
#define _XTAL_FREQ 8000000
#include <xc.h>
// CONFIG1
#pragma config FOSC = HS // Oscillator Selection bits (HS oscillator: High-speed crystal/resonator on RA6/OSC2/CLKOUT and RA7/OSC1/CLKIN)
#pragma config WDTE = OFF // Watchdog Timer Enable bit (WDT disabled and can be enabled by SWDTEN bit of the WDTCON register)
#pragma config PWRTE = OFF // Power-up Timer Enable bit (PWRT disabled)
#pragma config MCLRE = OFF // RE3/MCLR pin function select bit (RE3/MCLR pin function is digital input, MCLR internally tied to VDD)
#pragma config CP = OFF // Code Protection bit (Program memory code protection is disabled)
#pragma config CPD = OFF // Data Code Protection bit (Data memory code protection is disabled)
#pragma config BOREN = OFF // Brown Out Reset Selection bits (BOR disabled)
#pragma config IESO = OFF // Internal External Switchover bit (Internal/External Switchover mode is disabled)
#pragma config FCMEN = OFF // Fail-Safe Clock Monitor Enabled bit (Fail-Safe Clock Monitor is disabled)
#pragma config LVP = OFF // Low Voltage Programming Enable bit (RB3 pin has digital I/O, HV on MCLR must be used for programming)
// CONFIG2
#pragma config BOR4V = BOR40V // Brown-out Reset Selection bit (Brown-out Reset set to 4.0V)
#pragma config WRT = OFF // Flash Program Memory Self Write Enable bits (Write protection off)
unsigned int dem = 0,nghin,tram,chuc,donvi;
const unsigned char maled[] = {0x3F, 0x06, 0x5B, 0x4F, 0x66, 0x6D, 0x7D, 0x07, 0x7F, 0x6F};
void display(void);
void main(void)
{
OPTION_REGbits.T0CS = 1; // Dem xung ngoai
OPTION_REGbits.PSA = 1; // Su dung bo chia truoc WDT
TRISB = 0;
PORTB = 0;
TRISDbits.TRISD0 = 0;
TRISDbits.TRISD1 = 0;
PORTD = 0;
while (1)
{
display();
dem=TMR0;
if(dem>=100)
{
TMR0=0;
dem=0;
}
}
}
void display (void)
{
chuc = dem/10;
donvi = dem%10;
PORTB = maled[chuc];
RD0=0;
__delay_ms(10);
RD0=1;
PORTB = maled[donvi];
RD1=0;
__delay_ms(10);
RD1=1;
}
#include <stdlib.h>
#define _XTAL_FREQ 8000000
#include <xc.h>
// CONFIG1
#pragma config FOSC = HS // Oscillator Selection bits (HS oscillator: High-speed crystal/resonator on RA6/OSC2/CLKOUT and RA7/OSC1/CLKIN)
#pragma config WDTE = OFF // Watchdog Timer Enable bit (WDT disabled and can be enabled by SWDTEN bit of the WDTCON register)
#pragma config PWRTE = OFF // Power-up Timer Enable bit (PWRT disabled)
#pragma config MCLRE = OFF // RE3/MCLR pin function select bit (RE3/MCLR pin function is digital input, MCLR internally tied to VDD)
#pragma config CP = OFF // Code Protection bit (Program memory code protection is disabled)
#pragma config CPD = OFF // Data Code Protection bit (Data memory code protection is disabled)
#pragma config BOREN = OFF // Brown Out Reset Selection bits (BOR disabled)
#pragma config IESO = OFF // Internal External Switchover bit (Internal/External Switchover mode is disabled)
#pragma config FCMEN = OFF // Fail-Safe Clock Monitor Enabled bit (Fail-Safe Clock Monitor is disabled)
#pragma config LVP = OFF // Low Voltage Programming Enable bit (RB3 pin has digital I/O, HV on MCLR must be used for programming)
// CONFIG2
#pragma config BOR4V = BOR40V // Brown-out Reset Selection bit (Brown-out Reset set to 4.0V)
#pragma config WRT = OFF // Flash Program Memory Self Write Enable bits (Write protection off)
unsigned int dem = 0,nghin,tram,chuc,donvi;
const unsigned char maled[] = {0x3F, 0x06, 0x5B, 0x4F, 0x66, 0x6D, 0x7D, 0x07, 0x7F, 0x6F};
void display(void);
void main(void)
{
OPTION_REGbits.T0CS = 1; // Dem xung ngoai
OPTION_REGbits.PSA = 1; // Su dung bo chia truoc WDT
TRISB = 0;
PORTB = 0;
TRISDbits.TRISD0 = 0;
TRISDbits.TRISD1 = 0;
PORTD = 0;
while (1)
{
display();
dem=TMR0;
if(dem>=100)
{
TMR0=0;
dem=0;
}
}
}
void display (void)
{
chuc = dem/10;
donvi = dem%10;
PORTB = maled[chuc];
RD0=0;
__delay_ms(10);
RD0=1;
PORTB = maled[donvi];
RD1=0;
__delay_ms(10);
RD1=1;
}
No comments:
Post a Comment