18c2ecf20Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */
28c2ecf20Sopenharmony_ci/*
38c2ecf20Sopenharmony_ci * cxd2880_tnrdmd_dvbt2.h
48c2ecf20Sopenharmony_ci * Sony CXD2880 DVB-T2/T tuner + demodulator driver
58c2ecf20Sopenharmony_ci * control interface for DVB-T2
68c2ecf20Sopenharmony_ci *
78c2ecf20Sopenharmony_ci * Copyright (C) 2016, 2017, 2018 Sony Semiconductor Solutions Corporation
88c2ecf20Sopenharmony_ci */
98c2ecf20Sopenharmony_ci
108c2ecf20Sopenharmony_ci#ifndef CXD2880_TNRDMD_DVBT2_H
118c2ecf20Sopenharmony_ci#define CXD2880_TNRDMD_DVBT2_H
128c2ecf20Sopenharmony_ci
138c2ecf20Sopenharmony_ci#include "cxd2880_common.h"
148c2ecf20Sopenharmony_ci#include "cxd2880_tnrdmd.h"
158c2ecf20Sopenharmony_ci
168c2ecf20Sopenharmony_cienum cxd2880_tnrdmd_dvbt2_tune_info {
178c2ecf20Sopenharmony_ci	CXD2880_TNRDMD_DVBT2_TUNE_INFO_OK,
188c2ecf20Sopenharmony_ci	CXD2880_TNRDMD_DVBT2_TUNE_INFO_INVALID_PLP_ID
198c2ecf20Sopenharmony_ci};
208c2ecf20Sopenharmony_ci
218c2ecf20Sopenharmony_cistruct cxd2880_dvbt2_tune_param {
228c2ecf20Sopenharmony_ci	u32 center_freq_khz;
238c2ecf20Sopenharmony_ci	enum cxd2880_dtv_bandwidth bandwidth;
248c2ecf20Sopenharmony_ci	u16 data_plp_id;
258c2ecf20Sopenharmony_ci	enum cxd2880_dvbt2_profile profile;
268c2ecf20Sopenharmony_ci	enum cxd2880_tnrdmd_dvbt2_tune_info tune_info;
278c2ecf20Sopenharmony_ci};
288c2ecf20Sopenharmony_ci
298c2ecf20Sopenharmony_ci#define CXD2880_DVBT2_TUNE_PARAM_PLPID_AUTO  0xffff
308c2ecf20Sopenharmony_ci
318c2ecf20Sopenharmony_ciint cxd2880_tnrdmd_dvbt2_tune1(struct cxd2880_tnrdmd *tnr_dmd,
328c2ecf20Sopenharmony_ci			       struct cxd2880_dvbt2_tune_param
338c2ecf20Sopenharmony_ci			       *tune_param);
348c2ecf20Sopenharmony_ci
358c2ecf20Sopenharmony_ciint cxd2880_tnrdmd_dvbt2_tune2(struct cxd2880_tnrdmd *tnr_dmd,
368c2ecf20Sopenharmony_ci			       struct cxd2880_dvbt2_tune_param
378c2ecf20Sopenharmony_ci			       *tune_param);
388c2ecf20Sopenharmony_ci
398c2ecf20Sopenharmony_ciint cxd2880_tnrdmd_dvbt2_sleep_setting(struct cxd2880_tnrdmd
408c2ecf20Sopenharmony_ci				       *tnr_dmd);
418c2ecf20Sopenharmony_ci
428c2ecf20Sopenharmony_ciint cxd2880_tnrdmd_dvbt2_check_demod_lock(struct cxd2880_tnrdmd
438c2ecf20Sopenharmony_ci					  *tnr_dmd,
448c2ecf20Sopenharmony_ci					  enum
458c2ecf20Sopenharmony_ci					  cxd2880_tnrdmd_lock_result
468c2ecf20Sopenharmony_ci					  *lock);
478c2ecf20Sopenharmony_ci
488c2ecf20Sopenharmony_ciint cxd2880_tnrdmd_dvbt2_check_ts_lock(struct cxd2880_tnrdmd
498c2ecf20Sopenharmony_ci				       *tnr_dmd,
508c2ecf20Sopenharmony_ci				       enum
518c2ecf20Sopenharmony_ci				       cxd2880_tnrdmd_lock_result
528c2ecf20Sopenharmony_ci				       *lock);
538c2ecf20Sopenharmony_ci
548c2ecf20Sopenharmony_ciint cxd2880_tnrdmd_dvbt2_set_plp_cfg(struct cxd2880_tnrdmd
558c2ecf20Sopenharmony_ci				     *tnr_dmd, u8 auto_plp,
568c2ecf20Sopenharmony_ci				     u8 plp_id);
578c2ecf20Sopenharmony_ci
588c2ecf20Sopenharmony_ciint cxd2880_tnrdmd_dvbt2_diver_fef_setting(struct cxd2880_tnrdmd
598c2ecf20Sopenharmony_ci					   *tnr_dmd);
608c2ecf20Sopenharmony_ci
618c2ecf20Sopenharmony_ciint cxd2880_tnrdmd_dvbt2_check_l1post_valid(struct cxd2880_tnrdmd
628c2ecf20Sopenharmony_ci					    *tnr_dmd,
638c2ecf20Sopenharmony_ci					    u8 *l1_post_valid);
648c2ecf20Sopenharmony_ci
658c2ecf20Sopenharmony_ci#endif
66