Режим захвата PIC не вызывает прерывания - PullRequest
2 голосов
/ 28 марта 2011

Я пытаюсь использовать модуль захвата на PIC 16LF1827, но ISR никогда не вводится.Я начал с базового прерывания по заднему фронту (работал), затем добавил в конфигурацию таймера 1 (все еще работает), затем отключил прерывание IOC и настроил / включил соответствующее прерывание CCP (ISR никогда не вводится).Код ниже: закомментированный раздел является исходной базовой настройкой IOC.

Я проверил с помощью отладчика MPLab, что ISR не введен, и подтвердил это, подключив его к логическому анализатору и просмотрев RB1..

#include "htc.h"

//config1
//internal osc, no wdt, use power-up timer, enable reset
//  no code protection, brown-out-reset enabled, clkout is gpio, 
//  internal-external switchover off, failsafe clock monitor off
__CONFIG(FOSC_INTOSC & WDTE_OFF & PWRTE_ON 
  & MCLRE_ON & CP_OFF & CPD_OFF & BOREN_ON 
  & CLKOUTEN_OFF & IESO_OFF & FCMEN_OFF);

//config2 (following MPLab's complaints when running debugger)
//low-voltage programming off, debug on, brown-out reset at 2.7 v
//  stack over/under flow triggers reset, no 4x pll, 
//  no flash write protection
__CONFIG(LVP_OFF & DEBUG_ON & BORV_27 
  & STVREN_ON & PLLEN_OFF & WRT_OFF);

void interrupt isr(void){
    //bounce pin 1
    LATB ^= 0b10;
    LATB ^= 0b10;
    if(IOCIF && IOCBF0){
        IOCBF0 = 0;
        IOCIF = 0; 
    }
    if (CCP1IF){
        CCP1IF = 0;
    }
}

void main(void){
    //configure internal oscillator: 
    //PLL = 0, source = from config 1, frequency = 4 mhz 
    //0b0: SPLLEN_OFF
    OSCCONbits.SPLLEN = 0b0;
    //0b00: use config word 1
    OSCCONbits.SCS = 0b00;
    //0b1101: 4 mhz frequency
    OSCCONbits.IRCF = 0b1101;

    //configure peripherals
    //PORT A: LEDs (output), digital
    TRISA = 0x00;
    ANSELA = 0;
    //PORT B: digital, 0 = input, 1 = output, rest don't care
    TRISB = 0b11111101;
    ANSELB = 0;

    //configure timer 1 (not needed for basic IOC)
    //source = instruction clock, prescale = 1:1, disable LP osc, do synchronize (DC)
    //0b00: instruction clock
    T1CONbits.TMR1CS = 0b00;
    //0b00: 1:1
    T1CONbits.T1CKPS = 0b00;
    //0b0: lp osc off
    T1OSCEN = 0b0;
    //0b0: synch (ignored)
    nT1SYNC = 0b0;

    //interrupts
    /*
    //IOC enabled on falling edge for port B 0
    IOCBN0 = 0b00000001;
    IOCIE = 1;
    */

    //Capture on falling edge for port B 0
    //notes in 23.1 of DS: disable interrupt, set operating mode, clear flag, enable interrupt
    CCP1IE = 0b0;
    //0b100: every falling edge
    CCP1CONbits.CCP1M = 0b100;
    CCP1IF = 0b0;
    CCP1IE = 0b1;
    //enable peripheral interrupts, global interrupts
    PEIE = 1;
    GIE = 1;

    //start timer 1
    TMR1ON = 1;
    while(1){
        //Toggle led 0
        LATA ^= 0b1;
    }
}

Я использую компилятор HI-TECH C (lite), работающий в MPLab.

Любые предложения будут с благодарностью.Приношу свои извинения, если я разделываю терминологию, это мой первый проект на PIC.

1 Ответ

1 голос
/ 29 марта 2011

Ваша настройка для TRISB1 является выходной.Согласно данным таблицы, вывод захвата должен быть настроен как вход.Для выводов GPIO установка бита TRIS: 0 - это выход, 1 - для входа.

РЕДАКТИРОВАТЬ: Простите за первоначальный глупый ответ, поскольку я не осознавал, что вы используете PORTB1 в качестве индикатора GPIO для своей области.

Итак, изначально вы использовали PORTB0 в качестве правильного пин-кода(используя МОК)?Модуль захвата использует другой порт GPIO для своего входа (PORTB3 для CCP1).Вы переместили соединение с PORTB3 для своего источника захвата?

РЕДАКТИРОВАТЬ: После еще одного просмотра таблицы PIC я заметил, что вывод GPIO CCP1 можно переместить с PORTB3 на PORTB0, но я не вижу никакой ссылки накак вы установите бит APFCON0.CCP1SEL.Это было бы что-то еще, чтобы проверить.

...