^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1) /* SPDX-License-Identifier: GPL-2.0-or-later */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 3) * Driver for the Integrant ITD1000 "Zero-IF Tuner IC for Direct Broadcast Satellite"
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 4) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 5) * Copyright (c) 2007 Patrick Boettcher <pb@linuxtv.org>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 6) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 7)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 8) #ifndef ITD1000_PRIV_H
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 9) #define ITD1000_PRIV_H
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 10)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 11) struct itd1000_state {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 12) struct itd1000_config *cfg;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 13) struct i2c_adapter *i2c;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 14)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 15) u32 frequency; /* contains the value resulting from the LO-setting */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 16)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 17) /* ugly workaround for flexcop's incapable i2c-controller
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 18) * FIXME, if possible
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 19) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 20) u8 shadow[256];
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 21) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 22)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 23) enum itd1000_register {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 24) VCO_CHP1 = 0x65,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 25) VCO_CHP2,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 26) PLLCON1,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 27) PLLNH,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 28) PLLNL,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 29) PLLFH,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 30) PLLFM,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 31) PLLFL,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 32) RESERVED_0X6D,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 33) PLLLOCK,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 34) VCO_CHP2_I2C,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 35) VCO_CHP1_I2C,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 36) BW,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 37) RESERVED_0X73 = 0x73,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 38) RESERVED_0X74,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 39) RESERVED_0X75,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 40) GVBB,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 41) GVRF,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 42) GVBB_I2C,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 43) EXTGVBBRF,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 44) DIVAGCCK,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 45) BBTR,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 46) RFTR,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 47) BBGVMIN,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 48) RESERVED_0X7E,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 49) RESERVED_0X85 = 0x85,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 50) RESERVED_0X86,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 51) CON1,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 52) RESERVED_0X88,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 53) RESERVED_0X89,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 54) RFST0,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 55) RFST1,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 56) RFST2,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 57) RFST3,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 58) RFST4,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 59) RFST5,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 60) RFST6,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 61) RFST7,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 62) RFST8,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 63) RFST9,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 64) RESERVED_0X94,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 65) RESERVED_0X95,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 66) RESERVED_0X96,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 67) RESERVED_0X97,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 68) RESERVED_0X98,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 69) RESERVED_0X99,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 70) RESERVED_0X9A,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 71) RESERVED_0X9B,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 72) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 73)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 74) #endif