1 /* sane - Scanner Access Now Easy.
2 
3    Copyright (C) 2019 Povilas Kanapickas <povilas@radix.lt>
4 
5    This file is part of the SANE package.
6 
7    This program is free software; you can redistribute it and/or
8    modify it under the terms of the GNU General Public License as
9    published by the Free Software Foundation; either version 2 of the
10    License, or (at your option) any later version.
11 
12    This program is distributed in the hope that it will be useful, but
13    WITHOUT ANY WARRANTY; without even the implied warranty of
14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15    General Public License for more details.
16 
17    You should have received a copy of the GNU General Public License
18    along with this program.  If not, see <https://www.gnu.org/licenses/>.
19 
20    As a special exception, the authors of SANE give permission for
21    additional uses of the libraries contained in this release of SANE.
22 
23    The exception is that, if you link a SANE library with other files
24    to produce an executable, this does not by itself cause the
25    resulting executable to be covered by the GNU General Public
26    License.  Your use of that executable is in no way restricted on
27    account of linking the SANE library code into it.
28 
29    This exception does not, however, invalidate any other reasons why
30    the executable file might be covered by the GNU General Public
31    License.
32 
33    If you submit changes to SANE to the maintainers to be included in
34    a subsequent release, you agree by submitting the changes that
35    those changes may be distributed with this exception intact.
36 
37    If you write modifications of your own for SANE, it is your choice
38    whether to permit this exception to apply to your modifications.
39    If you do not wish that, delete this exception notice.
40 */
41 
42 #ifndef BACKEND_GENESYS_gl842_REGISTERS_H
43 #define BACKEND_GENESYS_gl842_REGISTERS_H
44 
45 #include <cstdint>
46 
47 namespace genesys {
48 namespace gl842 {
49 
50 using RegAddr = std::uint16_t;
51 using RegMask = std::uint8_t;
52 using RegShift = unsigned;
53 
54 static constexpr RegAddr REG_0x01 = 0x01;
55 static constexpr RegMask REG_0x01_CISSET = 0x80;
56 static constexpr RegMask REG_0x01_DOGENB = 0x40;
57 static constexpr RegMask REG_0x01_DVDSET = 0x20;
58 static constexpr RegMask REG_0x01_M15DRAM = 0x08;
59 static constexpr RegMask REG_0x01_DRAMSEL = 0x04;
60 static constexpr RegMask REG_0x01_SHDAREA = 0x02;
61 static constexpr RegMask REG_0x01_SCAN = 0x01;
62 
63 static constexpr RegAddr REG_0x02 = 0x02;
64 static constexpr RegMask REG_0x02_NOTHOME = 0x80;
65 static constexpr RegMask REG_0x02_ACDCDIS = 0x40;
66 static constexpr RegMask REG_0x02_AGOHOME = 0x20;
67 static constexpr RegMask REG_0x02_MTRPWR = 0x10;
68 static constexpr RegMask REG_0x02_FASTFED = 0x08;
69 static constexpr RegMask REG_0x02_MTRREV = 0x04;
70 static constexpr RegMask REG_0x02_HOMENEG = 0x02;
71 static constexpr RegMask REG_0x02_LONGCURV = 0x01;
72 
73 static constexpr RegAddr REG_0x03 = 0x03;
74 static constexpr RegMask REG_0x03_LAMPDOG = 0x80;
75 static constexpr RegMask REG_0x03_AVEENB = 0x40;
76 static constexpr RegMask REG_0x03_XPASEL = 0x20;
77 static constexpr RegMask REG_0x03_LAMPPWR = 0x10;
78 static constexpr RegMask REG_0x03_LAMPTIM = 0x0f;
79 
80 static constexpr RegAddr REG_0x04 = 0x04;
81 static constexpr RegMask REG_0x04_LINEART = 0x80;
82 static constexpr RegMask REG_0x04_BITSET = 0x40;
83 static constexpr RegMask REG_0x04_AFEMOD = 0x30;
84 static constexpr RegMask REG_0x04_FILTER = 0x0c;
85 static constexpr RegMask REG_0x04_FESET = 0x03;
86 
87 static constexpr RegShift REG_0x04S_AFEMOD = 4;
88 
89 static constexpr RegAddr REG_0x05 = 0x05;
90 static constexpr RegMask REG_0x05_DPIHW = 0xc0;
91 static constexpr RegMask REG_0x05_DPIHW_600 = 0x00;
92 static constexpr RegMask REG_0x05_DPIHW_1200 = 0x40;
93 static constexpr RegMask REG_0x05_DPIHW_2400 = 0x80;
94 static constexpr RegMask REG_0x05_DPIHW_4800 = 0xc0;
95 static constexpr RegMask REG_0x05_MTLLAMP = 0x30;
96 static constexpr RegMask REG_0x05_GMMENB = 0x08;
97 static constexpr RegMask REG_0x05_MTLBASE = 0x03;
98 
99 static constexpr RegAddr REG_0x06 = 0x06;
100 static constexpr RegMask REG_0x06_SCANMOD = 0xe0;
101 static constexpr RegShift REG_0x06S_SCANMOD = 5;
102 static constexpr RegMask REG_0x06_PWRBIT = 0x10;
103 static constexpr RegMask REG_0x06_GAIN4 = 0x08;
104 static constexpr RegMask REG_0x06_OPTEST = 0x07;
105 
106 static constexpr RegMask REG_0x08_DECFLAG = 0x40;
107 static constexpr RegMask REG_0x08_GMMFFR = 0x20;
108 static constexpr RegMask REG_0x08_GMMFFG = 0x10;
109 static constexpr RegMask REG_0x08_GMMFFB = 0x08;
110 static constexpr RegMask REG_0x08_GMMZR = 0x04;
111 static constexpr RegMask REG_0x08_GMMZG = 0x02;
112 static constexpr RegMask REG_0x08_GMMZB = 0x01;
113 
114 static constexpr RegMask REG_0x09_MCNTSET = 0xc0;
115 static constexpr RegMask REG_0x09_CLKSET = 0x30;
116 static constexpr RegMask REG_0x09_BACKSCAN = 0x08;
117 static constexpr RegMask REG_0x09_ENHANCE = 0x04;
118 static constexpr RegMask REG_0x09_SHORTTG = 0x02;
119 static constexpr RegMask REG_0x09_NWAIT = 0x01;
120 
121 static constexpr RegAddr REG_0x0D = 0x0d;
122 static constexpr RegMask REG_0x0D_CLRLNCNT = 0x01;
123 
124 static constexpr RegAddr REG_0x0F = 0x0f;
125 
126 static constexpr RegAddr REG_EXPR = 0x10;
127 static constexpr RegAddr REG_EXPG = 0x12;
128 static constexpr RegAddr REG_EXPB = 0x14;
129 
130 static constexpr RegMask REG_0x16_CTRLHI = 0x80;
131 static constexpr RegMask REG_0x16_TOSHIBA = 0x40;
132 static constexpr RegMask REG_0x16_TGINV = 0x20;
133 static constexpr RegMask REG_0x16_CK1INV = 0x10;
134 static constexpr RegMask REG_0x16_CK2INV = 0x08;
135 static constexpr RegMask REG_0x16_CTRLINV = 0x04;
136 static constexpr RegMask REG_0x16_CKDIS = 0x02;
137 static constexpr RegMask REG_0x16_CTRLDIS = 0x01;
138 
139 static constexpr RegMask REG_0x17_TGMODE = 0xc0;
140 static constexpr RegMask REG_0x17_TGMODE_NO_DUMMY = 0x00;
141 static constexpr RegMask REG_0x17_TGMODE_REF = 0x40;
142 static constexpr RegMask REG_0x17_TGMODE_XPA = 0x80;
143 static constexpr RegMask REG_0x17_TGW = 0x3f;
144 
145 static constexpr RegAddr REG_0x18 = 0x18;
146 static constexpr RegMask REG_0x18_CNSET = 0x80;
147 static constexpr RegMask REG_0x18_DCKSEL = 0x60;
148 static constexpr RegMask REG_0x18_CKTOGGLE = 0x10;
149 static constexpr RegMask REG_0x18_CKDELAY = 0x0c;
150 static constexpr RegMask REG_0x18_CKSEL = 0x03;
151 
152 static constexpr RegAddr REG_EXPDMY = 0x19;
153 
154 static constexpr RegAddr REG_0x1A = 0x1a;
155 static constexpr RegMask REG_0x1A_MANUAL3 = 0x02;
156 static constexpr RegMask REG_0x1A_MANUAL1 = 0x01;
157 static constexpr RegMask REG_0x1A_CK4INV = 0x08;
158 static constexpr RegMask REG_0x1A_CK3INV = 0x04;
159 static constexpr RegMask REG_0x1A_LINECLP = 0x02;
160 
161 static constexpr RegAddr REG_0x1C = 0x1c;
162 static constexpr RegMask REG_0x1C_TGTIME = 0x07;
163 
164 static constexpr RegMask REG_0x1D_CK4LOW = 0x80;
165 static constexpr RegMask REG_0x1D_CK3LOW = 0x40;
166 static constexpr RegMask REG_0x1D_CK1LOW = 0x20;
167 static constexpr RegMask REG_0x1D_TGSHLD = 0x1f;
168 
169 static constexpr RegAddr REG_0x1E = 0x1e;
170 static constexpr RegMask REG_0x1E_WDTIME = 0xf0;
171 static constexpr RegShift REG_0x1ES_WDTIME = 4;
172 static constexpr RegMask REG_0x1E_LINESEL = 0x0f;
173 static constexpr RegShift REG_0x1ES_LINESEL = 0;
174 
175 static constexpr RegAddr REG_0x21 = 0x21;
176 static constexpr RegAddr REG_STEPNO = 0x21;
177 static constexpr RegAddr REG_FWDSTEP = 0x22;
178 static constexpr RegAddr REG_BWDSTEP = 0x23;
179 static constexpr RegAddr REG_FASTNO = 0x24;
180 static constexpr RegAddr REG_LINCNT = 0x25;
181 
182 static constexpr RegAddr REG_0x29 = 0x29;
183 static constexpr RegAddr REG_0x2A = 0x2a;
184 static constexpr RegAddr REG_0x2B = 0x2b;
185 static constexpr RegAddr REG_DPISET = 0x2c;
186 static constexpr RegAddr REG_0x2E = 0x2e;
187 static constexpr RegAddr REG_0x2F = 0x2f;
188 
189 static constexpr RegAddr REG_STRPIXEL = 0x30;
190 static constexpr RegAddr REG_ENDPIXEL = 0x32;
191 static constexpr RegAddr REG_DUMMY = 0x34;
192 static constexpr RegAddr REG_MAXWD = 0x35;
193 static constexpr RegAddr REG_LPERIOD = 0x38;
194 static constexpr RegAddr REG_FEEDL = 0x3d;
195 
196 static constexpr RegAddr REG_0x40 = 0x40;
197 static constexpr RegMask REG_0x40_HISPDFLG = 0x04;
198 static constexpr RegMask REG_0x40_MOTMFLG = 0x02;
199 static constexpr RegMask REG_0x40_DATAENB = 0x01;
200 
201 static constexpr RegMask REG_0x41_PWRBIT = 0x80;
202 static constexpr RegMask REG_0x41_BUFEMPTY = 0x40;
203 static constexpr RegMask REG_0x41_FEEDFSH = 0x20;
204 static constexpr RegMask REG_0x41_SCANFSH = 0x10;
205 static constexpr RegMask REG_0x41_HOMESNR = 0x08;
206 static constexpr RegMask REG_0x41_LAMPSTS = 0x04;
207 static constexpr RegMask REG_0x41_FEBUSY = 0x02;
208 static constexpr RegMask REG_0x41_MOTORENB = 0x01;
209 
210 static constexpr RegMask REG_0x5A_ADCLKINV = 0x80;
211 static constexpr RegMask REG_0x5A_RLCSEL = 0x40;
212 static constexpr RegMask REG_0x5A_CDSREF = 0x30;
213 static constexpr RegShift REG_0x5AS_CDSREF = 4;
214 static constexpr RegMask REG_0x5A_RLC = 0x0f;
215 static constexpr RegShift REG_0x5AS_RLC = 0;
216 
217 static constexpr RegAddr REG_0x5E = 0x5e;
218 static constexpr RegMask REG_0x5E_DECSEL = 0xe0;
219 static constexpr RegShift REG_0x5ES_DECSEL = 5;
220 static constexpr RegMask REG_0x5E_STOPTIM = 0x1f;
221 static constexpr RegShift REG_0x5ES_STOPTIM = 0;
222 
223 static constexpr RegAddr REG_FMOVDEC = 0x5f;
224 
225 static constexpr RegAddr REG_0x60 = 0x60;
226 static constexpr RegMask REG_0x60_Z1MOD = 0x1f;
227 static constexpr RegAddr REG_0x61 = 0x61;
228 static constexpr RegMask REG_0x61_Z1MOD = 0xff;
229 static constexpr RegAddr REG_0x62 = 0x62;
230 static constexpr RegMask REG_0x62_Z1MOD = 0xff;
231 
232 static constexpr RegAddr REG_0x63 = 0x63;
233 static constexpr RegMask REG_0x63_Z2MOD = 0x1f;
234 static constexpr RegAddr REG_0x64 = 0x64;
235 static constexpr RegMask REG_0x64_Z2MOD = 0xff;
236 static constexpr RegAddr REG_0x65 = 0x65;
237 static constexpr RegMask REG_0x65_Z2MOD = 0xff;
238 
239 static constexpr RegAddr REG_0x67 = 0x67;
240 static constexpr RegAddr REG_0x68 = 0x68;
241 
242 static constexpr RegShift REG_0x67S_STEPSEL = 6;
243 static constexpr RegMask REG_0x67_STEPSEL = 0xc0;
244 
245 static constexpr RegShift REG_0x68S_FSTPSEL = 6;
246 static constexpr RegMask REG_0x68_FSTPSEL = 0xc0;
247 
248 static constexpr RegAddr REG_FSHDEC = 0x69;
249 static constexpr RegAddr REG_FMOVNO = 0x6a;
250 
251 static constexpr RegAddr REG_0x6B = 0x6b;
252 static constexpr RegMask REG_0x6B_MULTFILM = 0x80;
253 
254 static constexpr RegAddr REG_Z1MOD = 0x60;
255 static constexpr RegAddr REG_Z2MOD = 0x63;
256 
257 static constexpr RegAddr REG_0x6C = 0x6c;
258 static constexpr RegAddr REG_0x6D = 0x6d;
259 static constexpr RegAddr REG_0x6E = 0x6e;
260 static constexpr RegAddr REG_0x6F = 0x6f;
261 
262 static constexpr RegAddr REG_CK1MAP = 0x74;
263 static constexpr RegAddr REG_CK3MAP = 0x77;
264 static constexpr RegAddr REG_CK4MAP = 0x7a;
265 
266 static constexpr RegAddr REG_0x7E = 0x7e;
267 
268 static constexpr RegAddr REG_0x80 = 0x80;
269 static constexpr RegMask REG_0x80_TABLE1_NORMAL = 0x03;
270 static constexpr RegShift REG_0x80S_TABLE1_NORMAL = 0;
271 static constexpr RegMask REG_0x80_TABLE2_BACK = 0x0c;
272 static constexpr RegShift REG_0x80S_TABLE2_BACK = 2;
273 static constexpr RegMask REG_0x80_TABLE4_FAST = 0x30;
274 static constexpr RegShift REG_0x80S_TABLE4_FAST = 4;
275 static constexpr RegMask REG_0x80_TABLE5_GO_HOME = 0xc0;
276 static constexpr RegShift REG_0x80S_TABLE5_GO_HOME = 6;
277 
278 static constexpr RegMask REG_0x87_LEDADD = 0x04;
279 
280 } // namespace gl842
281 } // namespace genesys
282 
283 #endif // BACKEND_GENESYS_gl842_REGISTERS_H
284