cregit-Linux how code gets into the kernel

Release 4.7 drivers/extcon/extcon-sm5502.h

Directory: drivers/extcon
/*
 * sm5502.h
 *
 * Copyright (c) 2014 Samsung Electronics Co., Ltd
 *
 * This program is free software; you can redistribute  it and/or modify it
 * under  the terms of  the GNU General  Public License as published by the
 * Free Software Foundation;  either version 2 of the  License, or (at your
 * option) any later version.
 */

#ifndef __LINUX_EXTCON_SM5502_H

#define __LINUX_EXTCON_SM5502_H


enum sm5502_types {
	
TYPE_SM5502,
};

/* SM5502 registers */

enum sm5502_reg {
	
SM5502_REG_DEVICE_ID = 0x01,
	
SM5502_REG_CONTROL,
	
SM5502_REG_INT1,
	
SM5502_REG_INT2,
	
SM5502_REG_INTMASK1,
	
SM5502_REG_INTMASK2,
	
SM5502_REG_ADC,
	
SM5502_REG_TIMING_SET1,
	
SM5502_REG_TIMING_SET2,
	
SM5502_REG_DEV_TYPE1,
	
SM5502_REG_DEV_TYPE2,
	
SM5502_REG_BUTTON1,
	
SM5502_REG_BUTTON2,
	
SM5502_REG_CAR_KIT_STATUS,
	
SM5502_REG_RSVD1,
	
SM5502_REG_RSVD2,
	
SM5502_REG_RSVD3,
	
SM5502_REG_RSVD4,
	
SM5502_REG_MANUAL_SW1,
	
SM5502_REG_MANUAL_SW2,
	
SM5502_REG_DEV_TYPE3,
	
SM5502_REG_RSVD5,
	
SM5502_REG_RSVD6,
	
SM5502_REG_RSVD7,
	
SM5502_REG_RSVD8,
	
SM5502_REG_RSVD9,
	
SM5502_REG_RESET,
	
SM5502_REG_RSVD10,
	
SM5502_REG_RESERVED_ID1,
	
SM5502_REG_RSVD11,
	
SM5502_REG_RSVD12,
	
SM5502_REG_RESERVED_ID2,
	
SM5502_REG_RSVD13,
	
SM5502_REG_OCP,
	
SM5502_REG_RSVD14,
	
SM5502_REG_RSVD15,
	
SM5502_REG_RSVD16,
	
SM5502_REG_RSVD17,
	
SM5502_REG_RSVD18,
	
SM5502_REG_RSVD19,
	
SM5502_REG_RSVD20,
	
SM5502_REG_RSVD21,
	
SM5502_REG_RSVD22,
	
SM5502_REG_RSVD23,
	
SM5502_REG_RSVD24,
	
SM5502_REG_RSVD25,
	
SM5502_REG_RSVD26,
	
SM5502_REG_RSVD27,
	
SM5502_REG_RSVD28,
	
SM5502_REG_RSVD29,
	
SM5502_REG_RSVD30,
	
SM5502_REG_RSVD31,
	
SM5502_REG_RSVD32,
	
SM5502_REG_RSVD33,
	
SM5502_REG_RSVD34,
	
SM5502_REG_RSVD35,
	
SM5502_REG_RSVD36,
	
SM5502_REG_RESERVED_ID3,

	
SM5502_REG_END,
};

/* Define SM5502 MASK/SHIFT constant */

#define SM5502_REG_DEVICE_ID_VENDOR_SHIFT	0

#define SM5502_REG_DEVICE_ID_VERSION_SHIFT	3

#define SM5502_REG_DEVICE_ID_VENDOR_MASK	(0x3 << SM5502_REG_DEVICE_ID_VENDOR_SHIFT)

#define SM5502_REG_DEVICE_ID_VERSION_MASK	(0x1f << SM5502_REG_DEVICE_ID_VERSION_SHIFT)


#define SM5502_REG_CONTROL_MASK_INT_SHIFT	0

#define SM5502_REG_CONTROL_WAIT_SHIFT		1

#define SM5502_REG_CONTROL_MANUAL_SW_SHIFT	2

#define SM5502_REG_CONTROL_RAW_DATA_SHIFT	3

#define SM5502_REG_CONTROL_SW_OPEN_SHIFT	4

#define SM5502_REG_CONTROL_MASK_INT_MASK	(0x1 << SM5502_REG_CONTROL_MASK_INT_SHIFT)

#define SM5502_REG_CONTROL_WAIT_MASK		(0x1 << SM5502_REG_CONTROL_WAIT_SHIFT)

#define SM5502_REG_CONTROL_MANUAL_SW_MASK	(0x1 << SM5502_REG_CONTROL_MANUAL_SW_SHIFT)

#define SM5502_REG_CONTROL_RAW_DATA_MASK	(0x1 << SM5502_REG_CONTROL_RAW_DATA_SHIFT)

#define SM5502_REG_CONTROL_SW_OPEN_MASK		(0x1 << SM5502_REG_CONTROL_SW_OPEN_SHIFT)


#define SM5502_REG_INTM1_ATTACH_SHIFT		0

#define SM5502_REG_INTM1_DETACH_SHIFT		1

#define SM5502_REG_INTM1_KP_SHIFT		2

#define SM5502_REG_INTM1_LKP_SHIFT		3

#define SM5502_REG_INTM1_LKR_SHIFT		4

#define SM5502_REG_INTM1_OVP_EVENT_SHIFT	5

#define SM5502_REG_INTM1_OCP_EVENT_SHIFT	6

#define SM5502_REG_INTM1_OVP_OCP_DIS_SHIFT	7

#define SM5502_REG_INTM1_ATTACH_MASK		(0x1 << SM5502_REG_INTM1_ATTACH_SHIFT)

#define SM5502_REG_INTM1_DETACH_MASK		(0x1 << SM5502_REG_INTM1_DETACH_SHIFT)

#define SM5502_REG_INTM1_KP_MASK		(0x1 << SM5502_REG_INTM1_KP_SHIFT)

#define SM5502_REG_INTM1_LKP_MASK		(0x1 << SM5502_REG_INTM1_LKP_SHIFT)

#define SM5502_REG_INTM1_LKR_MASK		(0x1 << SM5502_REG_INTM1_LKR_SHIFT)

#define SM5502_REG_INTM1_OVP_EVENT_MASK		(0x1 << SM5502_REG_INTM1_OVP_EVENT_SHIFT)

#define SM5502_REG_INTM1_OCP_EVENT_MASK		(0x1 << SM5502_REG_INTM1_OCP_EVENT_SHIFT)

#define SM5502_REG_INTM1_OVP_OCP_DIS_MASK	(0x1 << SM5502_REG_INTM1_OVP_OCP_DIS_SHIFT)


#define SM5502_REG_INTM2_VBUS_DET_SHIFT		0

#define SM5502_REG_INTM2_REV_ACCE_SHIFT		1

#define SM5502_REG_INTM2_ADC_CHG_SHIFT		2

#define SM5502_REG_INTM2_STUCK_KEY_SHIFT	3

#define SM5502_REG_INTM2_STUCK_KEY_RCV_SHIFT	4

#define SM5502_REG_INTM2_MHL_SHIFT		5

#define SM5502_REG_INTM2_VBUS_DET_MASK		(0x1 << SM5502_REG_INTM2_VBUS_DET_SHIFT)

#define SM5502_REG_INTM2_REV_ACCE_MASK		(0x1 << SM5502_REG_INTM2_REV_ACCE_SHIFT)

#define SM5502_REG_INTM2_ADC_CHG_MASK		(0x1 << SM5502_REG_INTM2_ADC_CHG_SHIFT)

#define SM5502_REG_INTM2_STUCK_KEY_MASK		(0x1 << SM5502_REG_INTM2_STUCK_KEY_SHIFT)

#define SM5502_REG_INTM2_STUCK_KEY_RCV_MASK	(0x1 << SM5502_REG_INTM2_STUCK_KEY_RCV_SHIFT)

#define SM5502_REG_INTM2_MHL_MASK		(0x1 << SM5502_REG_INTM2_MHL_SHIFT)


#define SM5502_REG_ADC_SHIFT			0

#define SM5502_REG_ADC_MASK			(0x1f << SM5502_REG_ADC_SHIFT)


#define SM5502_REG_TIMING_SET1_KEY_PRESS_SHIFT	4

#define SM5502_REG_TIMING_SET1_KEY_PRESS_MASK	(0xf << SM5502_REG_TIMING_SET1_KEY_PRESS_SHIFT)

#define TIMING_KEY_PRESS_100MS			0x0

#define TIMING_KEY_PRESS_200MS			0x1

#define TIMING_KEY_PRESS_300MS			0x2

#define TIMING_KEY_PRESS_400MS			0x3

#define TIMING_KEY_PRESS_500MS			0x4

#define TIMING_KEY_PRESS_600MS			0x5

#define TIMING_KEY_PRESS_700MS			0x6

#define TIMING_KEY_PRESS_800MS			0x7

#define TIMING_KEY_PRESS_900MS			0x8

#define TIMING_KEY_PRESS_1000MS			0x9

#define SM5502_REG_TIMING_SET1_ADC_DET_SHIFT	0

#define SM5502_REG_TIMING_SET1_ADC_DET_MASK	(0xf << SM5502_REG_TIMING_SET1_ADC_DET_SHIFT)

#define TIMING_ADC_DET_50MS			0x0

#define TIMING_ADC_DET_100MS			0x1

#define TIMING_ADC_DET_150MS			0x2

#define TIMING_ADC_DET_200MS			0x3

#define TIMING_ADC_DET_300MS			0x4

#define TIMING_ADC_DET_400MS			0x5

#define TIMING_ADC_DET_500MS			0x6

#define TIMING_ADC_DET_600MS			0x7

#define TIMING_ADC_DET_700MS			0x8

#define TIMING_ADC_DET_800MS			0x9

#define TIMING_ADC_DET_900MS			0xA

#define TIMING_ADC_DET_1000MS			0xB


#define SM5502_REG_TIMING_SET2_SW_WAIT_SHIFT	4

#define SM5502_REG_TIMING_SET2_SW_WAIT_MASK	(0xf << SM5502_REG_TIMING_SET2_SW_WAIT_SHIFT)

#define TIMING_SW_WAIT_10MS			0x0

#define TIMING_SW_WAIT_30MS			0x1

#define TIMING_SW_WAIT_50MS			0x2

#define TIMING_SW_WAIT_70MS			0x3

#define TIMING_SW_WAIT_90MS			0x4

#define TIMING_SW_WAIT_110MS			0x5

#define TIMING_SW_WAIT_130MS			0x6

#define TIMING_SW_WAIT_150MS			0x7

#define TIMING_SW_WAIT_170MS			0x8

#define TIMING_SW_WAIT_190MS			0x9

#define TIMING_SW_WAIT_210MS			0xA

#define SM5502_REG_TIMING_SET2_LONG_KEY_SHIFT	0

#define SM5502_REG_TIMING_SET2_LONG_KEY_MASK	(0xf << SM5502_REG_TIMING_SET2_LONG_KEY_SHIFT)

#define TIMING_LONG_KEY_300MS			0x0

#define TIMING_LONG_KEY_400MS			0x1

#define TIMING_LONG_KEY_500MS			0x2

#define TIMING_LONG_KEY_600MS			0x3

#define TIMING_LONG_KEY_700MS			0x4

#define TIMING_LONG_KEY_800MS			0x5

#define TIMING_LONG_KEY_900MS			0x6

#define TIMING_LONG_KEY_1000MS			0x7

#define TIMING_LONG_KEY_1100MS			0x8

#define TIMING_LONG_KEY_1200MS			0x9

#define TIMING_LONG_KEY_1300MS			0xA

#define TIMING_LONG_KEY_1400MS			0xB

#define TIMING_LONG_KEY_1500MS			0xC


#define SM5502_REG_DEV_TYPE1_AUDIO_TYPE1_SHIFT		0

#define SM5502_REG_DEV_TYPE1_AUDIO_TYPE2_SHIFT		1

#define SM5502_REG_DEV_TYPE1_USB_SDP_SHIFT		2

#define SM5502_REG_DEV_TYPE1_UART_SHIFT			3

#define SM5502_REG_DEV_TYPE1_CAR_KIT_CHARGER_SHIFT	4

#define SM5502_REG_DEV_TYPE1_USB_CHG_SHIFT		5

#define SM5502_REG_DEV_TYPE1_DEDICATED_CHG_SHIFT	6

#define SM5502_REG_DEV_TYPE1_USB_OTG_SHIFT		7

#define SM5502_REG_DEV_TYPE1_AUDIO_TYPE1_MASK		(0x1 << SM5502_REG_DEV_TYPE1_AUDIO_TYPE1_SHIFT)

#define SM5502_REG_DEV_TYPE1_AUDIO_TYPE1__MASK		(0x1 << SM5502_REG_DEV_TYPE1_AUDIO_TYPE2_SHIFT)

#define SM5502_REG_DEV_TYPE1_USB_SDP_MASK		(0x1 << SM5502_REG_DEV_TYPE1_USB_SDP_SHIFT)

#define SM5502_REG_DEV_TYPE1_UART_MASK			(0x1 << SM5502_REG_DEV_TYPE1_UART_SHIFT)

#define SM5502_REG_DEV_TYPE1_CAR_KIT_CHARGER_MASK	(0x1 << SM5502_REG_DEV_TYPE1_CAR_KIT_CHARGER_SHIFT)

#define SM5502_REG_DEV_TYPE1_USB_CHG_MASK		(0x1 << SM5502_REG_DEV_TYPE1_USB_CHG_SHIFT)

#define SM5502_REG_DEV_TYPE1_DEDICATED_CHG_MASK		(0x1 << SM5502_REG_DEV_TYPE1_DEDICATED_CHG_SHIFT)

#define SM5502_REG_DEV_TYPE1_USB_OTG_MASK		(0x1 << SM5502_REG_DEV_TYPE1_USB_OTG_SHIFT)


#define SM5502_REG_DEV_TYPE2_JIG_USB_ON_SHIFT		0

#define SM5502_REG_DEV_TYPE2_JIG_USB_OFF_SHIFT		1

#define SM5502_REG_DEV_TYPE2_JIG_UART_ON_SHIFT		2

#define SM5502_REG_DEV_TYPE2_JIG_UART_OFF_SHIFT		3

#define SM5502_REG_DEV_TYPE2_PPD_SHIFT			4

#define SM5502_REG_DEV_TYPE2_TTY_SHIFT			5

#define SM5502_REG_DEV_TYPE2_AV_CABLE_SHIFT		6

#define SM5502_REG_DEV_TYPE2_JIG_USB_ON_MASK		(0x1 << SM5502_REG_DEV_TYPE2_JIG_USB_ON_SHIFT)

#define SM5502_REG_DEV_TYPE2_JIG_USB_OFF_MASK		(0x1 << SM5502_REG_DEV_TYPE2_JIG_USB_OFF_SHIFT)

#define SM5502_REG_DEV_TYPE2_JIG_UART_ON_MASK		(0x1 << SM5502_REG_DEV_TYPE2_JIG_UART_ON_SHIFT)

#define SM5502_REG_DEV_TYPE2_JIG_UART_OFF_MASK		(0x1 << SM5502_REG_DEV_TYPE2_JIG_UART_OFF_SHIFT)

#define SM5502_REG_DEV_TYPE2_PPD_MASK			(0x1 << SM5502_REG_DEV_TYPE2_PPD_SHIFT)

#define SM5502_REG_DEV_TYPE2_TTY_MASK			(0x1 << SM5502_REG_DEV_TYPE2_TTY_SHIFT)

#define SM5502_REG_DEV_TYPE2_AV_CABLE_MASK		(0x1 << SM5502_REG_DEV_TYPE2_AV_CABLE_SHIFT)


#define SM5502_REG_MANUAL_SW1_VBUSIN_SHIFT	0

#define SM5502_REG_MANUAL_SW1_DP_SHIFT		2

#define SM5502_REG_MANUAL_SW1_DM_SHIFT		5

#define SM5502_REG_MANUAL_SW1_VBUSIN_MASK	(0x3 << SM5502_REG_MANUAL_SW1_VBUSIN_SHIFT)

#define SM5502_REG_MANUAL_SW1_DP_MASK		(0x7 << SM5502_REG_MANUAL_SW1_DP_SHIFT)

#define SM5502_REG_MANUAL_SW1_DM_MASK		(0x7 << SM5502_REG_MANUAL_SW1_DM_SHIFT)

#define VBUSIN_SWITCH_OPEN			0x0

#define VBUSIN_SWITCH_VBUSOUT			0x1

#define VBUSIN_SWITCH_MIC			0x2

#define VBUSIN_SWITCH_VBUSOUT_WITH_USB		0x3

#define DM_DP_CON_SWITCH_OPEN			0x0

#define DM_DP_CON_SWITCH_USB			0x1

#define DM_DP_CON_SWITCH_AUDIO			0x2

#define DM_DP_CON_SWITCH_UART			0x3

#define DM_DP_SWITCH_OPEN			((DM_DP_CON_SWITCH_OPEN <<SM5502_REG_MANUAL_SW1_DP_SHIFT) \
                                                | (DM_DP_CON_SWITCH_OPEN <<SM5502_REG_MANUAL_SW1_DM_SHIFT))

#define DM_DP_SWITCH_USB			((DM_DP_CON_SWITCH_USB <<SM5502_REG_MANUAL_SW1_DP_SHIFT) \
                                                | (DM_DP_CON_SWITCH_USB <<SM5502_REG_MANUAL_SW1_DM_SHIFT))

#define DM_DP_SWITCH_AUDIO			((DM_DP_CON_SWITCH_AUDIO <<SM5502_REG_MANUAL_SW1_DP_SHIFT) \
                                                | (DM_DP_CON_SWITCH_AUDIO <<SM5502_REG_MANUAL_SW1_DM_SHIFT))

#define DM_DP_SWITCH_UART			((DM_DP_CON_SWITCH_UART <<SM5502_REG_MANUAL_SW1_DP_SHIFT) \
                                                | (DM_DP_CON_SWITCH_UART <<SM5502_REG_MANUAL_SW1_DM_SHIFT))

/* SM5502 Interrupts */

enum sm5502_irq {
	/* INT1 */
	
SM5502_IRQ_INT1_ATTACH,
	
SM5502_IRQ_INT1_DETACH,
	
SM5502_IRQ_INT1_KP,
	
SM5502_IRQ_INT1_LKP,
	
SM5502_IRQ_INT1_LKR,
	
SM5502_IRQ_INT1_OVP_EVENT,
	
SM5502_IRQ_INT1_OCP_EVENT,
	
SM5502_IRQ_INT1_OVP_OCP_DIS,

	/* INT2 */
	
SM5502_IRQ_INT2_VBUS_DET,
	
SM5502_IRQ_INT2_REV_ACCE,
	
SM5502_IRQ_INT2_ADC_CHG,
	
SM5502_IRQ_INT2_STUCK_KEY,
	
SM5502_IRQ_INT2_STUCK_KEY_RCV,
	
SM5502_IRQ_INT2_MHL,

	
SM5502_IRQ_NUM,
};


#define SM5502_IRQ_INT1_ATTACH_MASK		BIT(0)

#define SM5502_IRQ_INT1_DETACH_MASK		BIT(1)

#define SM5502_IRQ_INT1_KP_MASK			BIT(2)

#define SM5502_IRQ_INT1_LKP_MASK		BIT(3)

#define SM5502_IRQ_INT1_LKR_MASK		BIT(4)

#define SM5502_IRQ_INT1_OVP_EVENT_MASK		BIT(5)

#define SM5502_IRQ_INT1_OCP_EVENT_MASK		BIT(6)

#define SM5502_IRQ_INT1_OVP_OCP_DIS_MASK	BIT(7)

#define SM5502_IRQ_INT2_VBUS_DET_MASK		BIT(0)

#define SM5502_IRQ_INT2_REV_ACCE_MASK		BIT(1)

#define SM5502_IRQ_INT2_ADC_CHG_MASK		BIT(2)

#define SM5502_IRQ_INT2_STUCK_KEY_MASK		BIT(3)

#define SM5502_IRQ_INT2_STUCK_KEY_RCV_MASK	BIT(4)

#define SM5502_IRQ_INT2_MHL_MASK		BIT(5)

#endif /*  __LINUX_EXTCON_SM5502_H */

Overall Contributors

PersonTokensPropCommitsCommitProp
chanwoo choichanwoo choi819100.00%3100.00%
Total819100.00%3100.00%
Directory: drivers/extcon
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
{% endraw %}