cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

extcon-rt8973a.h (8069B)


      1/* SPDX-License-Identifier: GPL-2.0-or-later */
      2/*
      3 * rt8973a.h
      4 *
      5 * Copyright (c) 2014 Samsung Electronics Co., Ltd
      6 */
      7
      8#ifndef __LINUX_EXTCON_RT8973A_H
      9#define __LINUX_EXTCON_RT8973A_H
     10
     11enum rt8973a_types {
     12	TYPE_RT8973A,
     13};
     14
     15/* RT8973A registers */
     16enum rt8973A_reg {
     17	RT8973A_REG_DEVICE_ID = 0x1,
     18	RT8973A_REG_CONTROL1,
     19	RT8973A_REG_INT1,
     20	RT8973A_REG_INT2,
     21	RT8973A_REG_INTM1,
     22	RT8973A_REG_INTM2,
     23	RT8973A_REG_ADC,
     24	RT8973A_REG_RSVD_1,
     25	RT8973A_REG_RSVD_2,
     26	RT8973A_REG_DEV1,
     27	RT8973A_REG_DEV2,
     28	RT8973A_REG_RSVD_3,
     29	RT8973A_REG_RSVD_4,
     30	RT8973A_REG_RSVD_5,
     31	RT8973A_REG_RSVD_6,
     32	RT8973A_REG_RSVD_7,
     33	RT8973A_REG_RSVD_8,
     34	RT8973A_REG_RSVD_9,
     35	RT8973A_REG_MANUAL_SW1,
     36	RT8973A_REG_MANUAL_SW2,
     37	RT8973A_REG_RSVD_10,
     38	RT8973A_REG_RSVD_11,
     39	RT8973A_REG_RSVD_12,
     40	RT8973A_REG_RSVD_13,
     41	RT8973A_REG_RSVD_14,
     42	RT8973A_REG_RSVD_15,
     43	RT8973A_REG_RESET,
     44
     45	RT8973A_REG_END,
     46};
     47
     48/* Define RT8973A MASK/SHIFT constant */
     49#define RT8973A_REG_DEVICE_ID_VENDOR_SHIFT	0
     50#define RT8973A_REG_DEVICE_ID_VERSION_SHIFT	3
     51#define RT8973A_REG_DEVICE_ID_VENDOR_MASK	(0x7 << RT8973A_REG_DEVICE_ID_VENDOR_SHIFT)
     52#define RT8973A_REG_DEVICE_ID_VERSION_MASK	(0x1f << RT8973A_REG_DEVICE_ID_VERSION_SHIFT)
     53
     54#define RT8973A_REG_CONTROL1_INTM_SHIFT	0
     55#define RT8973A_REG_CONTROL1_AUTO_CONFIG_SHIFT	2
     56#define RT8973A_REG_CONTROL1_I2C_RST_EN_SHIFT	3
     57#define RT8973A_REG_CONTROL1_SWITCH_OPEN_SHIFT	4
     58#define RT8973A_REG_CONTROL1_CHGTYP_SHIFT	5
     59#define RT8973A_REG_CONTROL1_USB_CHD_EN_SHIFT	6
     60#define RT8973A_REG_CONTROL1_ADC_EN_SHIFT	7
     61#define RT8973A_REG_CONTROL1_INTM_MASK		(0x1 << RT8973A_REG_CONTROL1_INTM_SHIFT)
     62#define RT8973A_REG_CONTROL1_AUTO_CONFIG_MASK	(0x1 << RT8973A_REG_CONTROL1_AUTO_CONFIG_SHIFT)
     63#define RT8973A_REG_CONTROL1_I2C_RST_EN_MASK	(0x1 << RT8973A_REG_CONTROL1_I2C_RST_EN_SHIFT)
     64#define RT8973A_REG_CONTROL1_SWITCH_OPEN_MASK	(0x1 << RT8973A_REG_CONTROL1_SWITCH_OPEN_SHIFT)
     65#define RT8973A_REG_CONTROL1_CHGTYP_MASK	(0x1 << RT8973A_REG_CONTROL1_CHGTYP_SHIFT)
     66#define RT8973A_REG_CONTROL1_USB_CHD_EN_MASK	(0x1 << RT8973A_REG_CONTROL1_USB_CHD_EN_SHIFT)
     67#define RT8973A_REG_CONTROL1_ADC_EN_MASK	(0x1 << RT8973A_REG_CONTROL1_ADC_EN_SHIFT)
     68
     69#define RT9873A_REG_INTM1_ATTACH_SHIFT		0
     70#define RT9873A_REG_INTM1_DETACH_SHIFT		1
     71#define RT9873A_REG_INTM1_CHGDET_SHIFT		2
     72#define RT9873A_REG_INTM1_DCD_T_SHIFT		3
     73#define RT9873A_REG_INTM1_OVP_SHIFT		4
     74#define RT9873A_REG_INTM1_CONNECT_SHIFT		5
     75#define RT9873A_REG_INTM1_ADC_CHG_SHIFT		6
     76#define RT9873A_REG_INTM1_OTP_SHIFT		7
     77#define RT9873A_REG_INTM1_ATTACH_MASK		(0x1 << RT9873A_REG_INTM1_ATTACH_SHIFT)
     78#define RT9873A_REG_INTM1_DETACH_MASK		(0x1 <<  RT9873A_REG_INTM1_DETACH_SHIFT)
     79#define RT9873A_REG_INTM1_CHGDET_MASK		(0x1 <<  RT9873A_REG_INTM1_CHGDET_SHIFT)
     80#define RT9873A_REG_INTM1_DCD_T_MASK		(0x1 <<  RT9873A_REG_INTM1_DCD_T_SHIFT)
     81#define RT9873A_REG_INTM1_OVP_MASK		(0x1 <<  RT9873A_REG_INTM1_OVP_SHIFT)
     82#define RT9873A_REG_INTM1_CONNECT_MASK		(0x1 <<  RT9873A_REG_INTM1_CONNECT_SHIFT)
     83#define RT9873A_REG_INTM1_ADC_CHG_MASK		(0x1 <<  RT9873A_REG_INTM1_ADC_CHG_SHIFT)
     84#define RT9873A_REG_INTM1_OTP_MASK		(0x1 <<  RT9873A_REG_INTM1_OTP_SHIFT)
     85
     86#define RT9873A_REG_INTM2_UVLO_SHIFT		1
     87#define RT9873A_REG_INTM2_POR_SHIFT		2
     88#define RT9873A_REG_INTM2_OTP_FET_SHIFT		3
     89#define RT9873A_REG_INTM2_OVP_FET_SHIFT		4
     90#define RT9873A_REG_INTM2_OCP_LATCH_SHIFT	5
     91#define RT9873A_REG_INTM2_OCP_SHIFT		6
     92#define RT9873A_REG_INTM2_OVP_OCP_SHIFT		7
     93#define RT9873A_REG_INTM2_UVLO_MASK		(0x1 << RT9873A_REG_INTM2_UVLO_SHIFT)
     94#define RT9873A_REG_INTM2_POR_MASK		(0x1 <<  RT9873A_REG_INTM2_POR_SHIFT)
     95#define RT9873A_REG_INTM2_OTP_FET_MASK		(0x1 <<  RT9873A_REG_INTM2_OTP_FET_SHIFT)
     96#define RT9873A_REG_INTM2_OVP_FET_MASK		(0x1 <<  RT9873A_REG_INTM2_OVP_FET_SHIFT)
     97#define RT9873A_REG_INTM2_OCP_LATCH_MASK	(0x1 <<  RT9873A_REG_INTM2_OCP_LATCH_SHIFT)
     98#define RT9873A_REG_INTM2_OCP_MASK		(0x1 <<  RT9873A_REG_INTM2_OCP_SHIFT)
     99#define RT9873A_REG_INTM2_OVP_OCP_MASK		(0x1 <<  RT9873A_REG_INTM2_OVP_OCP_SHIFT)
    100
    101#define RT8973A_REG_ADC_SHIFT			0
    102#define RT8973A_REG_ADC_MASK			(0x1f << RT8973A_REG_ADC_SHIFT)
    103
    104#define RT8973A_REG_DEV1_OTG_SHIFT		0
    105#define RT8973A_REG_DEV1_SDP_SHIFT		2
    106#define RT8973A_REG_DEV1_UART_SHIFT		3
    107#define RT8973A_REG_DEV1_CAR_KIT_TYPE1_SHIFT	4
    108#define RT8973A_REG_DEV1_CDPORT_SHIFT		5
    109#define RT8973A_REG_DEV1_DCPORT_SHIFT		6
    110#define RT8973A_REG_DEV1_OTG_MASK		(0x1 << RT8973A_REG_DEV1_OTG_SHIFT)
    111#define RT8973A_REG_DEV1_SDP_MASK		(0x1 << RT8973A_REG_DEV1_SDP_SHIFT)
    112#define RT8973A_REG_DEV1_UART_MASK		(0x1 << RT8973A_REG_DEV1_UART_SHIFT)
    113#define RT8973A_REG_DEV1_CAR_KIT_TYPE1_MASK	(0x1 << RT8973A_REG_DEV1_CAR_KIT_TYPE1_SHIFT)
    114#define RT8973A_REG_DEV1_CDPORT_MASK		(0x1 << RT8973A_REG_DEV1_CDPORT_SHIFT)
    115#define RT8973A_REG_DEV1_DCPORT_MASK		(0x1 << RT8973A_REG_DEV1_DCPORT_SHIFT)
    116#define RT8973A_REG_DEV1_USB_MASK		(RT8973A_REG_DEV1_SDP_MASK \
    117						| RT8973A_REG_DEV1_CDPORT_MASK)
    118
    119#define RT8973A_REG_DEV2_JIG_USB_ON_SHIFT	0
    120#define RT8973A_REG_DEV2_JIG_USB_OFF_SHIFT	1
    121#define RT8973A_REG_DEV2_JIG_UART_ON_SHIFT	2
    122#define RT8973A_REG_DEV2_JIG_UART_OFF_SHIFT	3
    123#define RT8973A_REG_DEV2_JIG_USB_ON_MASK	(0x1 << RT8973A_REG_DEV2_JIG_USB_ON_SHIFT)
    124#define RT8973A_REG_DEV2_JIG_USB_OFF_MASK	(0x1 << RT8973A_REG_DEV2_JIG_USB_OFF_SHIFT)
    125#define RT8973A_REG_DEV2_JIG_UART_ON_MASK	(0x1 << RT8973A_REG_DEV2_JIG_UART_ON_SHIFT)
    126#define RT8973A_REG_DEV2_JIG_UART_OFF_MASK	(0x1 << RT8973A_REG_DEV2_JIG_UART_OFF_SHIFT)
    127
    128#define RT8973A_REG_MANUAL_SW1_DP_SHIFT		2
    129#define RT8973A_REG_MANUAL_SW1_DM_SHIFT		5
    130#define RT8973A_REG_MANUAL_SW1_DP_MASK		(0x7 << RT8973A_REG_MANUAL_SW1_DP_SHIFT)
    131#define RT8973A_REG_MANUAL_SW1_DM_MASK		(0x7 << RT8973A_REG_MANUAL_SW1_DM_SHIFT)
    132#define DM_DP_CON_SWITCH_OPEN			0x0
    133#define DM_DP_CON_SWITCH_USB			0x1
    134#define DM_DP_CON_SWITCH_UART			0x3
    135#define DM_DP_SWITCH_OPEN			((DM_DP_CON_SWITCH_OPEN << RT8973A_REG_MANUAL_SW1_DP_SHIFT) \
    136						| (DM_DP_CON_SWITCH_OPEN << RT8973A_REG_MANUAL_SW1_DM_SHIFT))
    137#define DM_DP_SWITCH_USB			((DM_DP_CON_SWITCH_USB << RT8973A_REG_MANUAL_SW1_DP_SHIFT) \
    138						| (DM_DP_CON_SWITCH_USB << RT8973A_REG_MANUAL_SW1_DM_SHIFT))
    139#define DM_DP_SWITCH_UART			((DM_DP_CON_SWITCH_UART << RT8973A_REG_MANUAL_SW1_DP_SHIFT) \
    140						| (DM_DP_CON_SWITCH_UART << RT8973A_REG_MANUAL_SW1_DM_SHIFT))
    141
    142#define RT8973A_REG_MANUAL_SW2_FET_ON_SHIFT	0
    143#define RT8973A_REG_MANUAL_SW2_JIG_ON_SHIFT	2
    144#define RT8973A_REG_MANUAL_SW2_BOOT_SW_SHIFT	3
    145#define RT8973A_REG_MANUAL_SW2_FET_ON_MASK	(0x1 << RT8973A_REG_MANUAL_SW2_FET_ON_SHIFT)
    146#define RT8973A_REG_MANUAL_SW2_JIG_ON_MASK	(0x1 << RT8973A_REG_MANUAL_SW2_JIG_ON_SHIFT)
    147#define RT8973A_REG_MANUAL_SW2_BOOT_SW_MASK	(0x1 << RT8973A_REG_MANUAL_SW2_BOOT_SW_SHIFT)
    148#define RT8973A_REG_MANUAL_SW2_FET_ON		0
    149#define RT8973A_REG_MANUAL_SW2_FET_OFF		0x1
    150#define RT8973A_REG_MANUAL_SW2_JIG_OFF		0
    151#define RT8973A_REG_MANUAL_SW2_JIG_ON		0x1
    152#define RT8973A_REG_MANUAL_SW2_BOOT_SW_ON	0
    153#define RT8973A_REG_MANUAL_SW2_BOOT_SW_OFF	0x1
    154
    155#define RT8973A_REG_RESET_SHIFT			0
    156#define RT8973A_REG_RESET_MASK			(0x1 << RT8973A_REG_RESET_SHIFT)
    157#define RT8973A_REG_RESET			0x1
    158
    159/* RT8973A Interrupts */
    160enum rt8973a_irq {
    161	/* Interrupt1*/
    162	RT8973A_INT1_ATTACH,
    163	RT8973A_INT1_DETACH,
    164	RT8973A_INT1_CHGDET,
    165	RT8973A_INT1_DCD_T,
    166	RT8973A_INT1_OVP,
    167	RT8973A_INT1_CONNECT,
    168	RT8973A_INT1_ADC_CHG,
    169	RT8973A_INT1_OTP,
    170
    171	/* Interrupt2*/
    172	RT8973A_INT2_UVLO,
    173	RT8973A_INT2_POR,
    174	RT8973A_INT2_OTP_FET,
    175	RT8973A_INT2_OVP_FET,
    176	RT8973A_INT2_OCP_LATCH,
    177	RT8973A_INT2_OCP,
    178	RT8973A_INT2_OVP_OCP,
    179
    180	RT8973A_NUM,
    181};
    182
    183#define RT8973A_INT1_ATTACH_MASK		BIT(0)
    184#define RT8973A_INT1_DETACH_MASK		BIT(1)
    185#define RT8973A_INT1_CHGDET_MASK		BIT(2)
    186#define RT8973A_INT1_DCD_T_MASK			BIT(3)
    187#define RT8973A_INT1_OVP_MASK			BIT(4)
    188#define RT8973A_INT1_CONNECT_MASK		BIT(5)
    189#define RT8973A_INT1_ADC_CHG_MASK		BIT(6)
    190#define RT8973A_INT1_OTP_MASK			BIT(7)
    191#define RT8973A_INT2_UVLOT_MASK			BIT(0)
    192#define RT8973A_INT2_POR_MASK			BIT(1)
    193#define RT8973A_INT2_OTP_FET_MASK		BIT(2)
    194#define RT8973A_INT2_OVP_FET_MASK		BIT(3)
    195#define RT8973A_INT2_OCP_LATCH_MASK		BIT(4)
    196#define RT8973A_INT2_OCP_MASK			BIT(5)
    197#define RT8973A_INT2_OVP_OCP_MASK		BIT(6)
    198
    199#endif /*  __LINUX_EXTCON_RT8973A_H */