18c2ecf20Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-or-later */
28c2ecf20Sopenharmony_ci/*
38c2ecf20Sopenharmony_ci *  mxl111sf-tuner.h - driver for the MaxLinear MXL111SF CMOS tuner
48c2ecf20Sopenharmony_ci *
58c2ecf20Sopenharmony_ci *  Copyright (C) 2010-2014 Michael Krufky <mkrufky@linuxtv.org>
68c2ecf20Sopenharmony_ci */
78c2ecf20Sopenharmony_ci
88c2ecf20Sopenharmony_ci#ifndef __MXL111SF_TUNER_H__
98c2ecf20Sopenharmony_ci#define __MXL111SF_TUNER_H__
108c2ecf20Sopenharmony_ci
118c2ecf20Sopenharmony_ci#include <media/dvb_frontend.h>
128c2ecf20Sopenharmony_ci#include "mxl111sf.h"
138c2ecf20Sopenharmony_ci
148c2ecf20Sopenharmony_cienum mxl_if_freq {
158c2ecf20Sopenharmony_ci#if 0
168c2ecf20Sopenharmony_ci	MXL_IF_LO    = 0x00, /* other IF < 9MHz */
178c2ecf20Sopenharmony_ci#endif
188c2ecf20Sopenharmony_ci	MXL_IF_4_0   = 0x01, /* 4.0   MHz */
198c2ecf20Sopenharmony_ci	MXL_IF_4_5   = 0x02, /* 4.5   MHz */
208c2ecf20Sopenharmony_ci	MXL_IF_4_57  = 0x03, /* 4.57  MHz */
218c2ecf20Sopenharmony_ci	MXL_IF_5_0   = 0x04, /* 5.0   MHz */
228c2ecf20Sopenharmony_ci	MXL_IF_5_38  = 0x05, /* 5.38  MHz */
238c2ecf20Sopenharmony_ci	MXL_IF_6_0   = 0x06, /* 6.0   MHz */
248c2ecf20Sopenharmony_ci	MXL_IF_6_28  = 0x07, /* 6.28  MHz */
258c2ecf20Sopenharmony_ci	MXL_IF_7_2   = 0x08, /* 7.2   MHz */
268c2ecf20Sopenharmony_ci	MXL_IF_35_25 = 0x09, /* 35.25 MHz */
278c2ecf20Sopenharmony_ci	MXL_IF_36    = 0x0a, /* 36    MHz */
288c2ecf20Sopenharmony_ci	MXL_IF_36_15 = 0x0b, /* 36.15 MHz */
298c2ecf20Sopenharmony_ci	MXL_IF_44    = 0x0c, /* 44    MHz */
308c2ecf20Sopenharmony_ci#if 0
318c2ecf20Sopenharmony_ci	MXL_IF_HI    = 0x0f, /* other IF > 35 MHz and < 45 MHz */
328c2ecf20Sopenharmony_ci#endif
338c2ecf20Sopenharmony_ci};
348c2ecf20Sopenharmony_ci
358c2ecf20Sopenharmony_cistruct mxl111sf_tuner_config {
368c2ecf20Sopenharmony_ci	enum mxl_if_freq if_freq;
378c2ecf20Sopenharmony_ci	unsigned int invert_spectrum:1;
388c2ecf20Sopenharmony_ci
398c2ecf20Sopenharmony_ci	int (*read_reg)(struct mxl111sf_state *state, u8 addr, u8 *data);
408c2ecf20Sopenharmony_ci	int (*write_reg)(struct mxl111sf_state *state, u8 addr, u8 data);
418c2ecf20Sopenharmony_ci	int (*program_regs)(struct mxl111sf_state *state,
428c2ecf20Sopenharmony_ci			    struct mxl111sf_reg_ctrl_info *ctrl_reg_info);
438c2ecf20Sopenharmony_ci	int (*top_master_ctrl)(struct mxl111sf_state *state, int onoff);
448c2ecf20Sopenharmony_ci	int (*ant_hunt)(struct dvb_frontend *fe);
458c2ecf20Sopenharmony_ci};
468c2ecf20Sopenharmony_ci
478c2ecf20Sopenharmony_ci/* ------------------------------------------------------------------------ */
488c2ecf20Sopenharmony_ci
498c2ecf20Sopenharmony_ci#if IS_ENABLED(CONFIG_DVB_USB_MXL111SF)
508c2ecf20Sopenharmony_ciextern
518c2ecf20Sopenharmony_cistruct dvb_frontend *mxl111sf_tuner_attach(struct dvb_frontend *fe,
528c2ecf20Sopenharmony_ci				struct mxl111sf_state *mxl_state,
538c2ecf20Sopenharmony_ci				const struct mxl111sf_tuner_config *cfg);
548c2ecf20Sopenharmony_ci#else
558c2ecf20Sopenharmony_cistatic inline
568c2ecf20Sopenharmony_cistruct dvb_frontend *mxl111sf_tuner_attach(struct dvb_frontend *fe,
578c2ecf20Sopenharmony_ci				struct mxl111sf_state *mxl_state,
588c2ecf20Sopenharmony_ci				const struct mxl111sf_tuner_config *cfg)
598c2ecf20Sopenharmony_ci{
608c2ecf20Sopenharmony_ci	printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
618c2ecf20Sopenharmony_ci	return NULL;
628c2ecf20Sopenharmony_ci}
638c2ecf20Sopenharmony_ci#endif
648c2ecf20Sopenharmony_ci
658c2ecf20Sopenharmony_ci#endif /* __MXL111SF_TUNER_H__ */
66