blob: 8edd1c6f7e8ad20c52d07c0cdc80ec6aca869c7b [file] [log] [blame]
/* SPDX-License-Identifier: (GPL-2.0+ OR MIT) */
/*
* Copyright (c) 2019 Amlogic, Inc. All rights reserved.
*/
#ifndef TVAFE_AVIN_DETECT_H_
#define TVAFE_AVIN_DETECT_H_
#include <linux/cdev.h>
#include <linux/workqueue.h>
#include <linux/mutex.h>
#define ANACTRL_CVBS_DETECT_CNTL 0x9f
#define HHI_CVBS_DETECT_CNTL 0x2e
#define AFE_DETECT_RSV3_BIT 31
#define AFE_DETECT_RSV3_WIDTH 1
#define AFE_DETECT_RSV2_BIT 30
#define AFE_DETECT_RSV2_WIDTH 1
#define AFE_DETECT_RSV1_BIT 29
#define AFE_DETECT_RSV1_WIDTH 1
#define AFE_DETECT_RSV0_BIT 28
#define AFE_DETECT_RSV0_WIDTH 1
#define AFE_CH2_SYNC_HYS_ADJ_BIT 13
#define AFE_CH2_SYNC_HYS_ADJ_WIDTH 2
#define AFE_CH2_SYNC_LEVEL_ADJ_BIT 10
#define AFE_CH2_SYNC_LEVEL_ADJ_WIDTH 3
#define AFE_CH2_EN_SYNC_TIP_BIT 9
#define AFE_CH2_EN_SYNC_TIP_WIDTH 1
#define AFE_CH2_EN_DETECT_BIT 8
#define AFE_CH2_EN_DETECT_WIDTH 1
#define AFE_CH1_SYNC_HYS_ADJ_BIT 5
#define AFE_CH1_SYNC_HYS_ADJ_WIDTH 2
#define AFE_CH1_SYNC_LEVEL_ADJ_BIT 2
#define AFE_CH1_SYNC_LEVEL_ADJ_WIDTH 3
#define AFE_CH1_EN_SYNC_TIP_BIT 1
#define AFE_CH1_EN_SYNC_TIP_WIDTH 1
#define AFE_CH1_EN_DETECT_BIT 0
#define AFE_CH1_EN_DETECT_WIDTH 1
#define AFE_DETECT_RSV_BIT 28
#define AFE_DETECT_RSV_WIDTH 4
#define AFE_CH2_DC_LEVEL_ADJ_BIT 22
#define AFE_CH2_DC_LEVEL_ADJ_WIDTH 3
#define AFE_CH2_COMP_LEVEL_ADJ_BIT 19
#define AFE_CH2_COMP_LEVEL_ADJ_WIDTH 3
#define AFE_CH2_EN_DC_BIAS_BIT 18
#define AFE_CH2_EN_DC_BIAS_WIDTH 1
#define AFE_CH2_DETECT_MODE_SELECT_BIT 17
#define AFE_CH2_DETECT_MODE_SELECT_WIDTH 1
#define AFE_CH2_COMP_HYS_ADJ_BIT 16
#define AFE_CH2_COMP_HYS_ADJ_WIDTH 1
#define AFE_TL_CH2_EN_DETECT_BIT 15
#define AFE_TL_CH2_EN_DETECT_WIDTH 1
#define AFE_CH1_DC_LEVEL_ADJ_BIT 7
#define AFE_CH1_DC_LEVEL_ADJ_WIDTH 3
#define AFE_CH1_COMP_LEVEL_ADJ_BIT 4
#define AFE_CH1_COMP_LEVEL_ADJ_WIDTH 3
#define AFE_CH1_EN_DC_BIAS_BIT 3
#define AFE_CH1_EN_DC_BIAS_WIDTH 1
#define AFE_CH1_DETECT_MODE_SELECT_BIT 2
#define AFE_CH1_DETECT_MODE_SELECT_WIDTH 1
#define AFE_CH1_COMP_HYS_ADJ_BIT 1
#define AFE_CH1_COMP_HYS_ADJ_WIDTH 1
#define AFE_T5_CH2_EN_DC_BIAS_BIT 11
#define AFE_T5_CH2_EN_DC_BIAS_WIDTH 1
#define AFE_T5_AFE_PGA_MANMODE_GAIN_BIT 16
#define AFE_T5_AFE_PGA_MANMODE_GAIN_WIDTH 8
#define AFE_T5_AFE_MAN_MODE_BIT 24
#define AFE_T5_AFE_MAN_MODE_WIDTH 1
#define CVBS_IRQ0_CNTL 0x3c24
#define CVBS_IRQ_MODE_BIT 6
#define CVBS_IRQ_MODE_WIDTH 3
#define CVBS_IRQ_MODE_MASK 7
#define CVBS_IRQ_TRIGGER_SEL_BIT 5
#define CVBS_IRQ_TRIGGER_SEL_WIDTH 1
#define CVBS_IRQ_TRIGGER_SEL_MASK 1
#define CVBS_IRQ_EDGE_EN_BIT 4
#define CVBS_IRQ_EDGE_EN_WIDTH 1
#define CVBS_IRQ_EDGE_EN_MASK 1
#define CVBS_IRQ_FILTER_BIT 1
#define CVBS_IRQ_FILTER_WIDTH 3
#define CVBS_IRQ_FILTER_MASK 7
#define CVBS_IRQ_POL_BIT 0
#define CVBS_IRQ_POL_WIDTH 1
#define CVBS_IRQ_POL_MASK 1
#define CVBS_IRQ1_CNTL 0x3c25
#define CVBS_IRQ0_COUNTER 0x3c26
#define CVBS_IRQ1_COUNTER 0x3c27
/* add t3 */
#define IRQCTRL_CVBS_IRQ0_CNTL 0x90
#define IRQCTRL_CVBS_IRQ1_CNTL 0x91
#define IRQCTRL_CVBS_IRQ0_COUNTER 0x92
#define IRQCTRL_CVBS_IRQ1_COUNTER 0x93
enum tvafe_avin_status_e {
TVAFE_AVIN_STATUS_IN = 0,
TVAFE_AVIN_STATUS_OUT = 1,
TVAFE_AVIN_STATUS_UNKNOWN = 2,
};
enum tvafe_avin_channel_e {
TVAFE_AVIN_CHANNEL1 = 0,
TVAFE_AVIN_CHANNEL2 = 1,
TVAFE_AVIN_CHANNEL_MAX = 2,
};
struct tvafe_report_data_s {
enum tvafe_avin_channel_e channel;
enum tvafe_avin_status_e status;
};
struct tvafe_dts_const_param_s {
unsigned int device_mask;/*bit0:av1;bit1:av2*/
/*when mask==3,sequence 0:bit0->av1 bit1->av2;1:bit0->av2 bit1->av1*/
unsigned int device_sequence;
unsigned int irq[2];
};
struct tvafe_avin_det_s {
char config_name[20];
dev_t avin_devno;
struct device *config_dev;
struct class *config_class;
struct cdev avin_cdev;
struct tvafe_dts_const_param_s dts_param;
struct tvafe_report_data_s report_data_s[2];
struct work_struct work_struct_update;
unsigned int irq_counter[2];
unsigned int device_num;
};
enum avin_cpu_type {
AVIN_CPU_TYPE_TL1 = 3,
AVIN_CPU_TYPE_TM2 = 4,
AVIN_CPU_TYPE_T5 = 5,
AVIN_CPU_TYPE_T5D = 6,
AVIN_CPU_TYPE_T3 = 7,
AVIN_CPU_TYPE_T5W = 8,
AVIN_CPU_TYPE_MAX,
};
struct meson_avin_data {
enum avin_cpu_type cpu_id;
const char *name;
void __iomem *irq_reg_base;
unsigned int detect_cntl;
unsigned int irq0_cntl;
unsigned int irq1_cntl;
unsigned int irq0_cnt;
unsigned int irq1_cnt;
};
void tvafe_cha1_SYNCTIP_close_config(void);
void tvafe_cha2_SYNCTIP_close_config(void);
void tvafe_cha1_detect_restart_config(void);
void tvafe_cha2_detect_restart_config(void);
void tvafe_avin_detect_ch1_anlog_enable(bool enable);
void tvafe_avin_detect_ch2_anlog_enable(bool enable);
/*opened port,1:av1, 2:av2, 0:none av*/
extern unsigned int avport_opened;
/*0:in, 1:out*/
extern unsigned int av1_plugin_state;
extern unsigned int av2_plugin_state;
#endif /* TVAFE_AVIN_DETECT_H_ */