Мне не удается получить GP4 в качестве цифрового выхода (даже GP2 не настроен как GPIO, так что это может быть проблемой конфигурации аналогового вывода?) Я должен был отключить все функции, кроме регистра TRIS, на GP4 иGP2, но это не так ...
Это код (не обращайте слишком много внимания на правильность аналоговых данных, потому что я работаю над этим и все еще учусь;не против даже комментарии на итальянском):
// PIC12F675 Configuration Bit Settings // 'C' source line config statements //
#pragma config FOSC = INTRCIO // Oscillator Selection bits (INTOSC oscillator: I/O function on GP4/OSC2/CLKOUT pin, I/O function on GP5/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 // GP3/MCLR pin function select (GP3/MCLR pin function is GP3)
#pragma config BOREN = ON // Brown-out Detect Enable bit (BOD enabled)
#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)
#define _XTAL_FREQ 4000000
#include <xc.h>
/* ADCON serve, tra l'altro a selezionare il canale analogico da convertire in digitale * e, quindi, se si hanno piu' canali in un ciclo, da convertire, bisogna agire sempre * su questo registro */
int i = 0;
int j = 0;
unsigned short int A = 0;
void main(void) {
OSCCAL= 0x80;
CMCON = 0b00000111;
T1CON = 0b00000100;
OPTION_REG = 0b11000000;
// TRISIO = 0b001011;
TRISIObits.TRISIO0 = 1;
TRISIObits.TRISIO1 = 1;
TRISIObits.TRISIO2 = 0;
TRISIObits.TRISIO3 = 1;
TRISIObits.TRISIO4 = 0;
TRISIObits.TRISIO5 = 0;
ADCON0 = 0x00;
ANSEL = 0b00000011; // analog and digital channel selection
while(1) {
ADCON0 = 0b10000011; // select channel and start AD conversion cycle
__delay_ms(10);
A = ((ADRESH <<8)+ ADRESL);
for(i=10;i>=0;i--) { // controlla i singoli bit
j = A >> i;
if (j & 1) { // se = 1, manda un segnale sul canale GP5
GPIObits.GP5 = 1;
__delay_ms(250);
GPIObits.GP5 = 0;
__delay_ms(250);
}
if (j & 0) { // se = 1, manda un segnale sul canale GP4
GPIObits.GP4 = 1; __delay_ms(250);
GPIObits.GP4 = 0; __delay_ms(250);
}
__delay_ms(1000);
}
}
return;
}