CCS Programacion

Descargar como pdf o txt
Descargar como pdf o txt
Está en la página 1de 27

Parte VII

CCS PARA
MICROCONTROLADORES
PIC

POR: EULER DEZA FIGUEROA

EULER DEZA FIGUEROA


[email protected]
PROGRAMAS EN CCS COMPILER
TIMER0
El bloque funcional TIMER0/WATCHDOG es un contador (registro) de
8 bits, incrementado por hardware y programable. La cuenta máxima
es de 255(el incremento es constante e independiente).

 CONTADOR: Cuenta los eventos externos(a través del pin


RA4/TOCK1)
 TEMPORIZADOR: Cuenta los pulsos internos del reloj

Se puede insertar un prescaler, es decir, un divisor de frecuencia


programable que puede dividir por 2, 4, 8, 16, 32, 64, 128 o 256.
La frecuencia de reloj (fosc/4). Posteriormente, con el uso del
prescaler se puede dividir la frecuencia.
El bloque del TIMER0 puede funcionar como WATCHDOG, lo que
permite que durante el funcionamiento normal del microcontrolador,
un desbordamiento (o timeout) del Watchdog provoque un reset
(Watchdog Timer Reset). Para evitar el desbordamiento se debe, cada
cierto tiempo y antes de que llegue el limite, ejecutar una instrucción
CLRWDT que borra el Watchdog y que hace comenzar un nuevo
conteo desde cero
EULER DEZFIGUEROA
[email protected]
PROGRAMAS EN CCS COMPILER
TIMER0 …
Se basa en un oscilador RC interno, independiente del oscilador
del microcontrolador y que no requiere ningún componente
externo. El Wachdog cuenta incluso si el reloj conectado a
OSC1/CLK1 y/o OSC2/CLK2 esta parado, por ejemplo por la
ejecucion de una instrucicion SLEEP o por un defecto del cristal
oscilador

Los regisros implicados en la configuracion del TIMER0/WDT son


los siguientes:

 OPTION_REG: configura el «hardware» del TIMER0/WDT.


 INTCON: permite trabajar con la interrupcion el TIMER0/WDT
 TRISA: habilita la patilla RA4.

EULER DEZFIGUEROA
[email protected]
PROGRAMAS EN CCS COMPILER
REGISTRO OPTION_REG (DIRECCION RAM : 81H,/181H) [pic16f877]

EULER DEZA FIGUEROA


[email protected]
PROGRAMAS EN CCS COMPILER
REGISTRO OPTION_REG (DIRECCION RAM : 81H,/181H) [pic16f877]

EULER DEZA FIGUEROA


[email protected]
PROGRAMAS EN CCS COMPILER
REGISTRO OPTION_REG (DIRECCION RAM : 81H,/181H) [pic16f877]

 TOCS: Procedencia de las señales


1= RA4/TOCK1
0=Reloj interno
 TOSE: Tipo de flanco en el TOCK1/RA4:
1= Flanco descendente
0=Flanco ascendente
 PSA: Asignacion del divisor de frecuencias:
1= WDT
0=TMR0

EULER DEZA FIGUEROA


[email protected]
PROGRAMAS EN CCS COMPILER
REGISTRO OPTION_REG (DIRECCION RAM : 81H,/181H) [pic16f877]
 PS2:PS1:PS0: Determina el divisor de frecuencias a actuar
según la siguiente tabla

 El tiempo de desbordamiento del TIMER0 se calcula según la siguiente


ecuación:
T =TCM . Prescaler.(256 – Carga TMR0 )
 Donde TCM es el ciclo maquina que se puede calcular mediante la
ecuacion:
TCM = 4/FOSC
EULER DEZA FIGUEROA
[email protected]
PROGRAMAS EN CCS COMPILER
TIMER0 EN C
La funcion para configurar el TIMER0 es;

Setup_timer_0(modo);
Donde modo esta definido en el fichero de cabecera (afecta a
los bits 5:0 del OPTION_REG):

Setup_Timer_0(modo); T2CON(12h)
RTCC_INTERNAL 00000000 / 00h
RTCC_EXT_L_TO_H 00100000 / 20h

Los distintos modos se pueden agrupar mediante el empleo del


símbolo |

Setup_timer_0 (RTCC_DIV2 | RTCC-EXT_L_TO_H);


EULER DEZA FIGUEROA
[email protected]
PROGRAMAS EN CCS COMPILER
TIMER0 EN C …

Los distintos modos


se pueden agrupar
mediante el empleo
del símbolo |

Setup_timer_0
(RTCC_DIV2 | RTCC-
EXT_L_TO_H);

EULER DEZA FIGUEROA


[email protected]
PROGRAMAS EN CCS COMPILER
TIMER0 EN C
La función para configurar el WDT es;

Setup_wdt(modo);
Donde modo esta definido en el fichero de cabecera (afecta a
los bits 3:0 del OPTION_REG):

EULER DEZA FIGUEROA


[email protected]
PROGRAMAS EN CCS COMPILER
TIMER0 EN C

Para activar el Watchdog se deben utilizar los bits de


configuracion mediante la directiva #FUSES
#fuses WDT Activado
#fuses NOWDT Desactivado
EULER DEZA FIGUEROA
[email protected]
PROGRAMAS EN CCS COMPILER
TIMER0 EN C
El compilador C suministra una serie de funciones
para leer o escribir en el TMER0/WDT.

Para escribir un valor en el registro:


Set_timer0(valor);
Valor: entero de 8 bits.

Para leer el valor actual del registro:


Valor=get_timer0();
Valor: entero de 8 bits.

Tambien permite realizar la puesta a cero del


Watchdog (como CLRWDT):
Restart_wdt(); EULER DEZA FIGUEROA
[email protected]
PROGRAMAS EN CCS COMPILER
Programa 19: Generara una señal cuadrada de 1KHz
 Generar una señal cuadrada de 1khz , utilizando la interrupcion del TIMER0

Para generar una señal cuadrada de 1KHz se necesita un


semiperiodo de 500us.
Según la ecuación de desbordamiento del K, utilizando un cristal de
4MHz y un prescaler de 2:

T =TCM . Prescaler.(256 – Carga TMR0 )


TCM = 4/FOSC
500us =(4/4 000 000). 2.(256 – Carga TMR0 )

Donde: X = Carga TMR0 = 6


 Es decir se debe cargar el TMR0 con el valor 6. Pero esta relación solo se
cumple si se trabaja en ensamblador. Al trabajar en C, el compilador genera
líneas de código que aumentan el tiempo de ejecución del programa y, por
ello es necesario ajustar el valor final. En este caso se ha utilizado un valor
de carga de 29 (0X1D)
EULER DEZA FIGUEROA
[email protected]
PROGRAMAS EN CCS COMPILER
Programa 19: Generara una señal cuadrada de 1KHz ….

EULER DEZA FIGUEROA


[email protected]
PROGRAMAS EN CCS COMPILER
Programa 19: Generara una señal cuadrada de 1KHz ….

EULER DEZA FIGUEROA


[email protected]
PROGRAMAS EN CCS COMPILER
TIMER1
 El modulo TIMER1 es otro temporizador/contador con las siguientes
características:
 Trabaja con 16 bits (con dos registros de 8 bits: TMR1H y TMR1L).
 Ambos registros se pueden leer y escribir
 Interrupción por desbordamiento de FFFFh a 0000h
 Reset por disparo del modulo CCP
 Controlado por el registro T1CON. Con el bit TMR1ON (T1CON<0>), se
puede habilitar o deshabilitar.
Registro T1CON [dirección RAM: 10h] [pic16f87x]

EULER DEZA FIGUEROA


[email protected]
PROGRAMAS EN CCS COMPILER
TIMER1
Registro T1CON [dirección RAM: 10h] [pic16f87x]

 [bit 7:6]: No implementados: se leen como 0


 [Bit 5:4]: T1CKPS1:T1CKPS0: Selección del valor del prescaler del reloj
del TMR1:
11 = Prescaler a 1:8.
10 = Prescaler a 1:4.
01 = Prescaler a 1:2.
00 = Prescaler a 1:1
 [Bit 3]: T1OSCEN: Bit de habilitación del oscilador del TMR1:
1 = Oscilador habilitado
0 = Oscilador parado
 [Bit 2]: T1SYNC: Sincronización de la entrada de reloj externa:
Si TMR1CS = 1:
1 = No sincronizado con la entrada de reloj interno
0 = Sincronización de la entrada de reloj externo
Si TMR1CS = 0:
Este bit es ignorado. TMR1 utiliza el reloj interno.
EULER DEZA FIGUEROA
[email protected]
PROGRAMAS EN CCS COMPILER
TIMER1 …
Registro T1CON [dirección RAM: 10h] [pic16f87x] …

 [Bit 1]: TMR1CS: Bit de selección de la fuente de reloj para el TMR1:


1 = Reloj externo desde el pin RC0/T10S0/T1CK1 (flanco de subida)
0 = Reloj interno (Fosc/4)

 [Bit 0]: TMR1ON: Bit de habilitacion del TMR1:


1 = TMR1 habilitado
0 = TMR1 parado
 El modulo TIMER1 puede operar con los siguientes modos:
Como temporizador
Como contador síncrono
Como contador asíncrono
 El modo de operación se establece mediante el bit TMR1CS (T1CON<1>).
En modo temporizador, el TIMER1 se incrementa en cada ciclo de
instrucción. En modo contador se incrementa por flanco de subida de la
señal externa.
EULER DEZA FIGUEROA
[email protected]
PROGRAMAS EN CCS COMPILER
TIMER1 …
 Cuando se habilita el oscilador interno del TIMER1 mediante el bit
T1OSCEN, las patillas RC1/T1OSI y RC0/T1OSO/T1CKI se configuran como
entradas ignorando el valor de TRISC<1:0>.
 EL TIMER1 tiene un reset interno que puede ser generado por el modulo
CCP.
 Las interrupciones del TIMER1 se controlan a través de los registros PIE1 Y
PIR1.

El tiempo de desbordamiento del TIMER1 se calcula según la siguiente


ecuación:
T =TCM . Prescaler.(65536– Carga TMR1 )
Donde TCM es el ciclo maquina que se puede calcular mediante la ecuación:
TCM = 4/FOSC

EULER DEZA FIGUEROA


[email protected]
PROGRAMAS EN CCS COMPILER
TIMER2
El TIMER2 es un modulo temporizador con las siguientes características:

 Temporizador de 8 bits (Registro TMR2)


 Registro de periodo de 8 bits (PR2)
 Ambos registros se pueden leer o escribir
 Prescaler programable por programa (1:1, 1:4, 1:16)
 Postscaler programable por programa (1:1 a 1:16)
 Interrupción controlada por PR2
 El modulo SSP utiliza opcionalmente el TIMER2 para generar una señal de
reloj

El TIMER2 tiene un registro de control T2CON. El TIMER2 puede ser


habilitado mediante el bit TM2ON (T2CON<2>) para optimizar el consumo de
potencia

EULER DEZA FIGUEROA


[email protected]
PROGRAMAS EN CCS COMPILER
TIMER2
Registro T2CON [dirección RAM: 12h] [pic16f87x]

 [bit 7]: No implementado: se lee como 0

 [Bit 6:3]: TOUTPS3:TOUTPS0: Selección del valor del postscaler del reloj
del TMR2:
0000 = Postscaler a 1:1.
0001 = Postscaler a 1:2.
0010 = Postscaler a 1:3.
.
.
.
1111= Postscaler a 1:16.

 [Bit 2]: TMR2ON: Bit de habilitación del Timer2


1 = TMR2 habilitado
0 = TMR2 parado
EULER DEZA FIGUEROA
[email protected]
PROGRAMAS EN CCS COMPILER
TIMER2 …
 [Bit 1:0]: T2CKPS1:T2CKPS0: Selección del valor del prescaler del TMR2
00 = Prescaler a 1:1
01 = Prescaler a 1:4
1x = Prescaler a 1:16

 El TIMER2 se puede emplear como base de tiempos para la modulación


en ancho de pulso (PWM) mediante la utilización del modulo CCP. El
TIMER2 se puede leer o escribir y es borrado en el reset .
 La entrada de reloj (FOSC/4) tiene un prescaler de 1:1. 1:4 o 1:16
seleccionado mediante los bits T2CKPS1:T2CKPS0 (T2CON<1:0>).
 La interrupción cuyo flag se encuentra en TM221F, (PIR<1>). Los
contadores de prescaler y postscaler son borrados cuando se escribe en
el registro TIMER2 no se borra cuando se escribe en el T2CON.
 EL tiempo de desbordamiento del TIMER2 se calcula según la siguiente
ecuación:
T =TCM . [Prescaler.( Carga TMR2 + 1 ).Postscaler
 Donde TCM es el ciclo maquina que se puede calcular mediante la
ecuacion:
TCM = 4/FOSC
EULER DEZA FIGUEROA
[email protected]
PROGRAMAS EN CCS COMPILER
TIMER1 y TIMER2 en C
 La configuracion del modulo TMR1 en el compilador de C se realiza a
traves de la funcion:
Setup_timer1(modo)
Donde modo esta definido en el fichero de cabecera (afecta a los 5:0 del
registro T1CON):

Setup_Timer_1(modo); T1CON(10h)
T1_DISABLED 00000000 / 00h
T1_INTERNAL 10000101 / 85h
T1_EXTERNAL 10000111 / 87h
T1_EXTERNAL_SYNC 10000011 / 83h
T1_CLK_OUT 00001000 / 08h
T1_DIV_BY_1 00000000 / 00h
T1_DIV_BY_2 00010000 / 10h
T1_DIV_BY_4 00100000 / 20h
T1_DIV_BY_8 00110000 / 30h
EULER DEZA FIGUEROA
[email protected]
PROGRAMAS EN CCS COMPILER
TIMER1 y TIMER2 en C
 Los distintos modos se pueden agrupar mediante el simbolo |.
 La lectura y escritura en el modulo TMR1 se realiza a traves de las
siguientes funciones:
Valor = get_timer1();
set_timer1(valor); Donde valor es un entero de 16 bits

 La configuracion del modulo TMR2 en el compilador de C se realiza con


la funcion:

Setup_timer_2(modo, periodo, postscaler);


Donde:
Periodo: es un valor entero de 8 bits (0 a 255) para el registro PR2;
Postsclaer: es el valor del postscaler (1 A 16). afecta a los bits 6:3 del
registro T2CON; y
Modo: afecta a los bits 2:0 del registro T2CON

EULER DEZA FIGUEROA


[email protected]
PROGRAMAS EN CCS COMPILER
TIMER1 y TIMER2 en C

Setup_Timer_2(modo, periodo, T2CON(12h)


postscaler);
T2_DISABLE 00000000 / 00h
T1_DIV_BY_1 00000100 / 04h
T1_DIV_BY_4 00000000 / 05h
T1_DIV_BY_16 00000110 / 06h

 La lectura y escritura en el modulo TMR2 se realiza con la ayuda de las


siguientes funciones:

Valor = get_timer2();
set_timer2(valor); Donde valor es un entero de 16 bits

EULER DEZA FIGUEROA


[email protected]
PROGRAMAS EN CCS COMPILER
TIMER1 y TIMER2 en C

 EJEMPLOS …

EULER DEZA FIGUEROA


[email protected]
PROGRAMAS EN CCS COMPILER

Bibliografía
 CCS C Compiler Manual – PCD – CCS INC – FEBREO 2015
 CCS C Compiler Manual – PCB/PCM/PCH– CCS INC – FEBREO
2015
 Compilador C CCS y simulador PROTEUS para
Microcontroladores PIC – Eduardo García Breijo
 Diseño y simulacion de Sistemas microcontrolados en lenguaje
C – Juan Ricardo Clavijo Mendoza
 Programacion en CCS para Microcontroladores PIC – Aaron
Castro Bazua
 Datasheets

ING. EULER DEZA FIGUEROA


[email protected]

EULER DEZA FIGUEROA


[email protected]

También podría gustarte