sane-project-backends/backend/genesys/gl847_registers.h

333 wiersze
8.9 KiB
C++

/* sane - Scanner Access Now Easy.
Copyright (C) 2019 Povilas Kanapickas <povilas@radix.lt>
This file is part of the SANE package.
This program 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 2 of the
License, or (at your option) any later version.
This program 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 this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston,
MA 02111-1307, USA.
As a special exception, the authors of SANE give permission for
additional uses of the libraries contained in this release of SANE.
The exception is that, if you link a SANE library with other files
to produce an executable, this does not by itself cause the
resulting executable to be covered by the GNU General Public
License. Your use of that executable is in no way restricted on
account of linking the SANE library code into it.
This exception does not, however, invalidate any other reasons why
the executable file might be covered by the GNU General Public
License.
If you submit changes to SANE to the maintainers to be included in
a subsequent release, you agree by submitting the changes that
those changes may be distributed with this exception intact.
If you write modifications of your own for SANE, it is your choice
whether to permit this exception to apply to your modifications.
If you do not wish that, delete this exception notice.
*/
#ifndef BACKEND_GENESYS_GL847_REGISTERS_H
#define BACKEND_GENESYS_GL847_REGISTERS_H
namespace genesys {
namespace gl847 {
#define REG_0x01 0x01
#define REG_0x01_CISSET 0x80
#define REG_0x01_DOGENB 0x40
#define REG_0x01_DVDSET 0x20
#define REG_0x01_STAGGER 0x10
#define REG_0x01_COMPENB 0x08
#define REG_0x01_TRUEGRAY 0x04
#define REG_0x01_SHDAREA 0x02
#define REG_0x01_SCAN 0x01
#define REG_0x02 0x02
#define REG_0x02_NOTHOME 0x80
#define REG_0x02_ACDCDIS 0x40
#define REG_0x02_AGOHOME 0x20
#define REG_0x02_MTRPWR 0x10
#define REG_0x02_FASTFED 0x08
#define REG_0x02_MTRREV 0x04
#define REG_0x02_HOMENEG 0x02
#define REG_0x02_LONGCURV 0x01
#define REG_0x03 0x03
#define REG_0x03_LAMPDOG 0x80
#define REG_0x03_AVEENB 0x40
#define REG_0x03_XPASEL 0x20
#define REG_0x03_LAMPPWR 0x10
#define REG_0x03_LAMPTIM 0x0f
#define REG_0x04 0x04
#define REG_0x04_LINEART 0x80
#define REG_0x04_BITSET 0x40
#define REG_0x04_AFEMOD 0x30
#define REG_0x04_FILTER 0x0c
#define REG_0x04_FESET 0x03
#define REG_0x04S_AFEMOD 4
#define REG_0x05 0x05
#define REG_0x05_DPIHW 0xc0
#define REG_0x05_DPIHW_600 0x00
#define REG_0x05_DPIHW_1200 0x40
#define REG_0x05_DPIHW_2400 0x80
#define REG_0x05_DPIHW_4800 0xc0
#define REG_0x05_MTLLAMP 0x30
#define REG_0x05_GMMENB 0x08
#define REG_0x05_MTLBASE 0x03
#define REG_0x06_SCANMOD 0xe0
#define REG_0x06S_SCANMOD 5
#define REG_0x06_PWRBIT 0x10
#define REG_0x06_GAIN4 0x08
#define REG_0x06_OPTEST 0x07
#define REG_0x07_LAMPSIM 0x80
#define REG_0x08_DRAM2X 0x80
#define REG_0x08_MPENB 0x20
#define REG_0x08_CIS_LINE 0x10
#define REG_0x08_IR1ENB 0x08
#define REG_0x08_IR2ENB 0x04
#define REG_0x08_ENB24M 0x01
#define REG_0x09_MCNTSET 0xc0
#define REG_0x09_EVEN1ST 0x20
#define REG_0x09_BLINE1ST 0x10
#define REG_0x09_BACKSCAN 0x08
#define REG_0x09_ENHANCE 0x04
#define REG_0x09_SHORTTG 0x02
#define REG_0x09_NWAIT 0x01
#define REG_0x09S_MCNTSET 6
#define REG_0x09S_CLKSET 4
#define REG_0x0A_LPWMEN 0x10
#define REG_0x0B 0x0b
#define REG_0x0B_DRAMSEL 0x07
#define REG_0x0B_ENBDRAM 0x08
#define REG_0x0B_ENBDRAM 0x08
#define REG_0x0B_RFHDIS 0x10
#define REG_0x0B_CLKSET 0xe0
#define REG_0x0B_24MHZ 0x00
#define REG_0x0B_30MHZ 0x20
#define REG_0x0B_40MHZ 0x40
#define REG_0x0B_48MHZ 0x60
#define REG_0x0B_60MHZ 0x80
#define REG_0x0C 0x0c
#define REG_0x0C_CCDLMT 0x0f
#define REG_0x0D 0x0d
#define REG_0x0D_FULLSTP 0x10
#define REG_0x0D_SEND 0x80
#define REG_0x0D_CLRMCNT 0x04
#define REG_0x0D_CLRDOCJM 0x02
#define REG_0x0D_CLRLNCNT 0x01
#define REG_0x0F 0x0f
#define REG_0x16_CTRLHI 0x80
#define REG_0x16_TOSHIBA 0x40
#define REG_0x16_TGINV 0x20
#define REG_0x16_CK1INV 0x10
#define REG_0x16_CK2INV 0x08
#define REG_0x16_CTRLINV 0x04
#define REG_0x16_CKDIS 0x02
#define REG_0x16_CTRLDIS 0x01
#define REG_0x17_TGMODE 0xc0
#define REG_0x17_TGMODE_NO_DUMMY 0x00
#define REG_0x17_TGMODE_REF 0x40
#define REG_0x17_TGMODE_XPA 0x80
#define REG_0x17_TGW 0x3f
#define REG_0x17S_TGW 0
#define REG_0x18 0x18
#define REG_0x18_CNSET 0x80
#define REG_0x18_DCKSEL 0x60
#define REG_0x18_CKTOGGLE 0x10
#define REG_0x18_CKDELAY 0x0c
#define REG_0x18_CKSEL 0x03
#define REG_0x1A_SW2SET 0x80
#define REG_0x1A_SW1SET 0x40
#define REG_0x1A_MANUAL3 0x02
#define REG_0x1A_MANUAL1 0x01
#define REG_0x1A_CK4INV 0x08
#define REG_0x1A_CK3INV 0x04
#define REG_0x1A_LINECLP 0x02
#define REG_0x1C 0x1c
#define REG_0x1C_TGTIME 0x07
#define REG_0x1D_CK4LOW 0x80
#define REG_0x1D_CK3LOW 0x40
#define REG_0x1D_CK1LOW 0x20
#define REG_0x1D_TGSHLD 0x1f
#define REG_0x1DS_TGSHLD 0
#define REG_0x1E_WDTIME 0xf0
#define REG_0x1ES_WDTIME 4
#define REG_0x1E_LINESEL 0x0f
#define REG_0x1ES_LINESEL 0
#define REG_FEDCNT 0x1f
#define REG_0x24 0x1c
#define REG_0x40 0x40
#define REG_0x40_CHKVER 0x10
#define REG_0x40_HISPDFLG 0x04
#define REG_0x40_MOTMFLG 0x02
#define REG_0x40_DATAENB 0x01
#define REG_0x41_PWRBIT 0x80
#define REG_0x41_BUFEMPTY 0x40
#define REG_0x41_FEEDFSH 0x20
#define REG_0x41_SCANFSH 0x10
#define REG_0x41_HOMESNR 0x08
#define REG_0x41_LAMPSTS 0x04
#define REG_0x41_FEBUSY 0x02
#define REG_0x41_MOTORENB 0x01
#define REG_0x58_VSMP 0xf8
#define REG_0x58S_VSMP 3
#define REG_0x58_VSMPW 0x07
#define REG_0x58S_VSMPW 0
#define REG_0x59_BSMP 0xf8
#define REG_0x59S_BSMP 3
#define REG_0x59_BSMPW 0x07
#define REG_0x59S_BSMPW 0
#define REG_0x5A_ADCLKINV 0x80
#define REG_0x5A_RLCSEL 0x40
#define REG_0x5A_CDSREF 0x30
#define REG_0x5AS_CDSREF 4
#define REG_0x5A_RLC 0x0f
#define REG_0x5AS_RLC 0
#define REG_0x5E_DECSEL 0xe0
#define REG_0x5ES_DECSEL 5
#define REG_0x5E_STOPTIM 0x1f
#define REG_0x5ES_STOPTIM 0
#define REG_0x60 0x60
#define REG_0x60_Z1MOD 0x1f
#define REG_0x61 0x61
#define REG_0x61_Z1MOD 0xff
#define REG_0x62 0x62
#define REG_0x62_Z1MOD 0xff
#define REG_0x63 0x63
#define REG_0x63_Z2MOD 0x1f
#define REG_0x64 0x64
#define REG_0x64_Z2MOD 0xff
#define REG_0x65 0x65
#define REG_0x65_Z2MOD 0xff
#define REG_0x60S_STEPSEL 5
#define REG_0x60_STEPSEL 0xe0
#define REG_0x60_FULLSTEP 0x00
#define REG_0x60_HALFSTEP 0x20
#define REG_0x60_EIGHTHSTEP 0x60
#define REG_0x60_16THSTEP 0x80
#define REG_0x63S_FSTPSEL 5
#define REG_0x63_FSTPSEL 0xe0
#define REG_0x63_FULLSTEP 0x00
#define REG_0x63_HALFSTEP 0x20
#define REG_0x63_EIGHTHSTEP 0x60
#define REG_0x63_16THSTEP 0x80
#define REG_0x67 0x67
#define REG_0x67_MTRPWM 0x80
#define REG_0x68 0x68
#define REG_0x68_FASTPWM 0x80
#define REG_0x6B 0x6b
#define REG_0x6B_MULTFILM 0x80
#define REG_0x6B_GPOM13 0x40
#define REG_0x6B_GPOM12 0x20
#define REG_0x6B_GPOM11 0x10
#define REG_0x6B_GPO18 0x02
#define REG_0x6B_GPO17 0x01
#define REG_0x6C 0x6c
#define REG_0x6C_GPIO16 0x80
#define REG_0x6C_GPIO15 0x40
#define REG_0x6C_GPIO14 0x20
#define REG_0x6C_GPIO13 0x10
#define REG_0x6C_GPIO12 0x08
#define REG_0x6C_GPIO11 0x04
#define REG_0x6C_GPIO10 0x02
#define REG_0x6C_GPIO9 0x01
#define REG_0x6C_GPIOH 0xff
#define REG_0x6C_GPIOL 0xff
#define REG_0x6D 0x6d
#define REG_0x6E 0x6e
#define REG_0x6F 0x6f
#define REG_0x7E 0x7e
#define REG_0x87_LEDADD 0x04
#define REG_0x9E 0x9e
#define REG_0x9F 0x9f
#define REG_0xA6 0xa6
#define REG_0xA7 0xa7
#define REG_0xA8 0xa8
#define REG_0xA9 0xa9
#define REG_0xAB 0xab
#define REG_EXPR 0x10
#define REG_EXPG 0x12
#define REG_EXPB 0x14
#define REG_EXPDMY 0x19
#define REG_STEPNO 0x21
#define REG_FWDSTEP 0x22
#define REG_BWDSTEP 0x23
#define REG_FASTNO 0x24
#define REG_DPISET 0x2c
#define REG_STRPIXEL 0x30
#define REG_ENDPIXEL 0x32
#define REG_LINCNT 0x25
#define REG_MAXWD 0x35
#define REG_LPERIOD 0x38
#define REG_FEEDL 0x3d
#define REG_FMOVDEC 0x5f
#define REG_FSHDEC 0x69
#define REG_FMOVNO 0x6a
#define REG_CK1MAP 0x74
#define REG_CK3MAP 0x77
#define REG_CK4MAP 0x7a
#define SETREG(adr,val) { dev->reg.init_reg(adr, val); }
} // namespace gl847
} // namespace genesys
#endif // BACKEND_GENESYS_GL847_REGISTERS_H