1 /* vim: set et sw=4 sts=4 : */
8 /** Cantidad mínima de columnas (es más un límite estético que físico) */
9 #define LEDS_MIN_COLS 8
11 /** Cantidad máxima de columnas */
12 #define LEDS_MAX_COLS 32
14 /** Tamaño de la matriz de leds, en cantidad de columnas */
15 extern unsigned char leds_matrix_len;
17 /** Matriz de leds, cada elemento del array es una columna */
18 extern idata unsigned int leds_matrix[LEDS_MAX_COLS];
20 /** Setea retardo de refresco de la matriz */
21 #define leds_delay_set(delay) (RCAP2H = ((unsigned char) -delay))
22 /* usamos directamente el rcap2h negado (complementado) */
24 /** Obtiene retardo de refresco de la matriz */
25 #define leds_delay_get() ((unsigned char) -RCAP2H)
26 /* usamos directamente el rcap2h negado (complementado) */
28 /** Tamaño del retardo de refresco de la matriz */
29 #define LEDS_DELAY_SIZE sizeof(RCAP2H)
30 /* usamos directamente el rcap2h */
34 * El 'dibujado' de la matriz se puede controlar fácilmente parando y/o
35 * iniciando el timer2. Para comenzar a 'dibujar' la matriz sólo es necesario
36 * setear el bit TR2 del registro T2CON (y habilitar las interrupciones
37 * globalmente si aún no se hizo, bit EA del registro IE).
41 /** Realiza un testeo simple de los leds */
44 /** Escribe un word (16 bits) en la columna de leds */
45 void leds_write(unsigned int);
47 /** Escribe un byte en la parte baja de la columna de leds */
48 void leds_write_low(unsigned char);
50 /** Escribe un byte en la parte alta de la columna de leds */
51 void leds_write_high(unsigned char);
53 /** Actualiza el delay al recomendado según el tamaño de la matriz */
54 void leds_delay_update();
56 /** Bloquea timer de leds cuando se accede a una zona crítica (P0 y/o P2). */
59 /** Desbloquea el timer de los leds.
60 * @precond Se llamó a leds_lock();
64 /** Atiende interrupción del timer2 para 'dibujar' la matriz */
65 void leds_timer2_isr() interrupt 5;