47 lines
1.3 KiB
C
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
|