^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) STV6110(A) Silicon tuner driver
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 4)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 5) Copyright (C) Manu Abraham <abraham.manu@gmail.com>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 6)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 7) Copyright (C) ST Microelectronics
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 8)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 9) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 10)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 11) #ifndef __STV6110x_PRIV_H
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 12) #define __STV6110x_PRIV_H
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 13)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 14) #define FE_ERROR 0
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 15) #define FE_NOTICE 1
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 16) #define FE_INFO 2
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 17) #define FE_DEBUG 3
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 18) #define FE_DEBUGREG 4
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 19)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 20) #define dprintk(__y, __z, format, arg...) do { \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 21) if (__z) { \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 22) if ((verbose > FE_ERROR) && (verbose > __y)) \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 23) printk(KERN_ERR "%s: " format "\n", __func__ , ##arg); \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 24) else if ((verbose > FE_NOTICE) && (verbose > __y)) \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 25) printk(KERN_NOTICE "%s: " format "\n", __func__ , ##arg); \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 26) else if ((verbose > FE_INFO) && (verbose > __y)) \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 27) printk(KERN_INFO "%s: " format "\n", __func__ , ##arg); \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 28) else if ((verbose > FE_DEBUG) && (verbose > __y)) \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 29) printk(KERN_DEBUG "%s: " format "\n", __func__ , ##arg); \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 30) } else { \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 31) if (verbose > __y) \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 32) printk(format, ##arg); \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 33) } \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 34) } while (0)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 35)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 36)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 37) #define STV6110x_SETFIELD(mask, bitf, val) \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 38) (mask = (mask & (~(((1 << STV6110x_WIDTH_##bitf) - 1) << \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 39) STV6110x_OFFST_##bitf))) | \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 40) (val << STV6110x_OFFST_##bitf))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 41)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 42) #define STV6110x_GETFIELD(bitf, val) \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 43) ((val >> STV6110x_OFFST_##bitf) & \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 44) ((1 << STV6110x_WIDTH_##bitf) - 1))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 45)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 46) #define MAKEWORD16(a, b) (((a) << 8) | (b))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 47)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 48) #define LSB(x) ((x & 0xff))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 49) #define MSB(y) ((y >> 8) & 0xff)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 50)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 51) #define TRIALS 10
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 52) #define R_DIV(__div) (1 << (__div + 1))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 53) #define REFCLOCK_kHz (stv6110x->config->refclk / 1000)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 54) #define REFCLOCK_MHz (stv6110x->config->refclk / 1000000)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 55)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 56) struct stv6110x_state {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 57) struct dvb_frontend *frontend;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 58) struct i2c_adapter *i2c;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 59) const struct stv6110x_config *config;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 60) u8 regs[8];
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 61)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 62) struct stv6110x_devctl *devctl;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 63) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 64)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 65) #endif /* __STV6110x_PRIV_H */