162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-or-later */
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci *  Driver for Xceive XC5000 "QAM/8VSB single chip tuner"
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci *  Copyright (c) 2007 Steven Toth <stoth@linuxtv.org>
662306a36Sopenharmony_ci */
762306a36Sopenharmony_ci
862306a36Sopenharmony_ci#ifndef __XC5000_H__
962306a36Sopenharmony_ci#define __XC5000_H__
1062306a36Sopenharmony_ci
1162306a36Sopenharmony_ci#include <linux/firmware.h>
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_cistruct dvb_frontend;
1462306a36Sopenharmony_cistruct i2c_adapter;
1562306a36Sopenharmony_ci
1662306a36Sopenharmony_ci#define XC5000A 1
1762306a36Sopenharmony_ci#define XC5000C 2
1862306a36Sopenharmony_ci
1962306a36Sopenharmony_cistruct xc5000_config {
2062306a36Sopenharmony_ci	u8   i2c_address;
2162306a36Sopenharmony_ci	u32  if_khz;
2262306a36Sopenharmony_ci	u8   radio_input;
2362306a36Sopenharmony_ci	u16  xtal_khz;
2462306a36Sopenharmony_ci	u16  output_amp;
2562306a36Sopenharmony_ci
2662306a36Sopenharmony_ci	int chip_id;
2762306a36Sopenharmony_ci};
2862306a36Sopenharmony_ci
2962306a36Sopenharmony_ci/* xc5000 callback command */
3062306a36Sopenharmony_ci#define XC5000_TUNER_RESET		0
3162306a36Sopenharmony_ci
3262306a36Sopenharmony_ci/* Possible Radio inputs */
3362306a36Sopenharmony_ci#define XC5000_RADIO_NOT_CONFIGURED		0
3462306a36Sopenharmony_ci#define XC5000_RADIO_FM1			1
3562306a36Sopenharmony_ci#define XC5000_RADIO_FM2			2
3662306a36Sopenharmony_ci#define XC5000_RADIO_FM1_MONO			3
3762306a36Sopenharmony_ci
3862306a36Sopenharmony_ci/* For each bridge framework, when it attaches either analog or digital,
3962306a36Sopenharmony_ci * it has to store a reference back to its _core equivalent structure,
4062306a36Sopenharmony_ci * so that it can service the hardware by steering gpio's etc.
4162306a36Sopenharmony_ci * Each bridge implementation is different so cast devptr accordingly.
4262306a36Sopenharmony_ci * The xc5000 driver cares not for this value, other than ensuring
4362306a36Sopenharmony_ci * it's passed back to a bridge during tuner_callback().
4462306a36Sopenharmony_ci */
4562306a36Sopenharmony_ci
4662306a36Sopenharmony_ci#if IS_REACHABLE(CONFIG_MEDIA_TUNER_XC5000)
4762306a36Sopenharmony_ciextern struct dvb_frontend *xc5000_attach(struct dvb_frontend *fe,
4862306a36Sopenharmony_ci					  struct i2c_adapter *i2c,
4962306a36Sopenharmony_ci					  const struct xc5000_config *cfg);
5062306a36Sopenharmony_ci#else
5162306a36Sopenharmony_cistatic inline struct dvb_frontend *xc5000_attach(struct dvb_frontend *fe,
5262306a36Sopenharmony_ci						 struct i2c_adapter *i2c,
5362306a36Sopenharmony_ci						 const struct xc5000_config *cfg)
5462306a36Sopenharmony_ci{
5562306a36Sopenharmony_ci	printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
5662306a36Sopenharmony_ci	return NULL;
5762306a36Sopenharmony_ci}
5862306a36Sopenharmony_ci#endif
5962306a36Sopenharmony_ci
6062306a36Sopenharmony_ci#endif
61