47 lines
1.3 KiB
C

/* SPDX-License-Identifier: GPL-2.0 */
/*
* techpoint tp9930 regs
*
* Copyright (C) 2023 Rockchip Electronics Co., Ltd.
*/
#ifndef _TECHPOINT_TP9930_H
#define _TECHPOINT_TP9930_H
#include "techpoint_common.h"
#define TP9930_CHIP_ID_H_REG 0xFE
#define TP9930_CHIP_ID_H_VALUE 0x28
#define TP9930_CHIP_ID_L_REG 0xFF
#define TP9930_CHIP_ID_L_VALUE 0x32
#define TP9930_LINK_FREQ_74M25 (74250000)
#define TP9930_LINK_FREQ_148M5 (148500000)
#define TP9930_LINK_FREQ_297M (297000000)
#define INPUT_STATUS_MATCH 0x7a
enum tp9930_support_reso {
TP9930_CVSTD_720P_60 = 0,
TP9930_CVSTD_720P_50,
TP9930_CVSTD_1080P_30,
TP9930_CVSTD_1080P_25,
TP9930_CVSTD_720P_30,
TP9930_CVSTD_720P_25,
TP9930_CVSTD_SD,
TP9930_CVSTD_OTHER,
};
int tp9930_initialize(struct techpoint *techpoint);
int tp9930_do_reset_pll(struct i2c_client *client);
int tp9930_pll_reset(struct i2c_client *client);
int tp9930_set_decoder_mode(struct i2c_client *client, int ch, int status);
int tp9930_set_channel_reso(struct i2c_client *client, int ch,
enum techpoint_support_reso reso);
int tp9930_get_channel_reso(struct i2c_client *client, int ch);
int tp9930_get_channel_input_status(struct techpoint *techpoint, u8 index);
int tp9930_get_all_input_status(struct techpoint *techpoint, u8 *detect_status);
#endif // _TECHPOINT_TP9930_H