-
Notifications
You must be signed in to change notification settings - Fork 3
/
tlc_progmem_utils.h
131 lines (103 loc) · 4.35 KB
/
tlc_progmem_utils.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
/* Copyright (c) 2009 by Alex Leone <acleone ~AT~ gmail.com>
This file is part of the Arduino TLC5940 Library.
The Arduino TLC5940 Library is free software: you can redistribute it
and/or modify it under the terms of the GNU General Public License as
published by the Free Software Foundation, either version 3 of the
License, or (at your option) any later version.
The Arduino TLC5940 Library is distributed in the hope that it will be
useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with The Arduino TLC5940 Library. If not, see
<http://www.gnu.org/licenses/>. */
#ifndef TLC_PROGMEM_UTILS_H
#define TLC_PROGMEM_UTILS_H
/** \file
PROGMEM utility functions for setting grayscale or dot correction data
from PROGMEM. See the UsingProgmem Example for an example. */
#include <avr/pgmspace.h>
#include <avr/io.h>
#include "tlc_config.h"
#include "Tlc5940.h"
void tlc_setGSfromProgmem(prog_uint8_t *gsArray);
#if VPRG_ENABLED
void tlc_setDCfromProgmem(prog_uint8_t *dcArray);
#endif
/** \addtogroup ExtendedFunctions
\code #include "tlc_progmem_utils.h" \endcode
- void tlc_setGSfromProgmem(prog_uint8_t *gsArray) - copies the progmem
grayscale to current grayscale array. Requires a
\link Tlc5940::update Tlc.update() \endlink.
- void tlc_setDCfromProgmem(prog_uint8_t *dcArray) - shifts the data from a
progmem dot correction array (doesn't need an update). */
/* @{ */
/** Sets the grayscale data from an array in progmem. This doesn't shift out
any data: call Tlc.update(). An example:
\code
#include "tlc_progmem_utils.h"
prog_uint8_t gsArray1[NUM_TLCS * 24] = {
GS_DUO((4095 * 16)/16, (4095 * 15)/16), GS_DUO((4095 * 14)/16, (4095 * 13)/16),
GS_DUO((4095 * 12)/16, (4095 * 11)/16), GS_DUO((4095 * 10)/16, (4095 * 9)/16),
GS_DUO((4095 * 8)/16, (4095 * 7)/16), GS_DUO((4095 * 6)/16, (4095 * 5)/16),
GS_DUO((4095 * 4)/16, (4095 * 3)/16), GS_DUO((4095 * 2)/16, (4095 * 1)/16),
};
// sometime after Tlc.init()
tlc_setGSfromProgmem(gsArray1);
Tlc.update();
\endcode
This would set a ramp of values from OUT0 to OUT15. (Although the
NUM_TLCS * 24 looks like an error, each #GS_DUO is 3 bytes). The array
would have to be expanded if #NUM_TLCS != 1.
The format of the grayscale array is explained in #tlc_GSData.
\param gsArray A progmem array of grayscale data. */
void tlc_setGSfromProgmem(prog_uint8_t *gsArray)
{
prog_uint8_t *gsArrayp = gsArray;
uint8_t *gsDatap = tlc_GSData;
while (gsDatap < tlc_GSData + NUM_TLCS * 24) {
*gsDatap++ = pgm_read_byte(gsArrayp++);
*gsDatap++ = pgm_read_byte(gsArrayp++);
*gsDatap++ = pgm_read_byte(gsArrayp++);
}
}
#if VPRG_ENABLED
/** \addtogroup ReqVPRG_ENABLED
From tlc_progmem_utils.h:
- tlc_setDCfromProgmem(prog_uint8_t *dcArray) - shifts the data from a
progmem dot correction array (doesn't need an update). */
/* @{ */
/** Sets the dot correction data from an array in progmem. An example:
\code
#include "tlc_progmem_utils.h"
prog_uint8_t dcArray1[NUM_TLCS * 12] = {
DC_QUARTET(32, 63, 32, 63), DC_QUARTET(32, 63, 32, 63),
DC_QUARTET(32, 63, 32, 63), DC_QUARTET(32, 63, 32, 63),
};
// sometime after Tlc.init()
tlc_setDCfromProgmem(dcArray1);
\endcode
This would set every other channel to have a dot correction value of 32.
(Although the NUM_TLCS * 12 looks like an error, each #DC_QUARTET is 3
bytes). The array would have to be expanded if #NUM_TLCS != 1.
The Format of the array is similar to #tlc_GSData, the last channel of
the last TLC is the first value in the array. In the example above,
the first 32 is setting OUT15, and the last 63 is setting OUT0.
\param dcArray A progmem array of dot correction data to be shifted out.
\see \link Tlc5940::setAllDC Tlc.setAllDC \endlink */
void tlc_setDCfromProgmem(prog_uint8_t *dcArray)
{
tlc_dcModeStart();
prog_uint8_t *p = dcArray;
prog_uint8_t *dcArrayEnd = dcArray + NUM_TLCS * 12;
while (p < dcArrayEnd) {
tlc_shift8(pgm_read_byte(p++));
}
XLAT_PORT |= _BV(XLAT_PIN);
XLAT_PORT &= ~_BV(XLAT_PIN);
tlc_dcModeStop();
}
/* @} */
#endif
/* @} */
#endif