/* Copyright 2014 The Chromium OS Authors. All rights reserved. * Use of this source code is governed by a BSD-style license that can be * found in the LICENSE file. * * Pericom PI3USB9281 USB port switch. */ #ifndef __CROS_EC_PI3USB9281_H #define __CROS_EC_PI3USB9281_H #define PI3USB9281_REG_DEV_ID 0x01 #define PI3USB9281_REG_CONTROL 0x02 #define PI3USB9281_REG_INT 0x03 #define PI3USB9281_REG_INT_MASK 0x05 #define PI3USB9281_REG_DEV_TYPE 0x0a #define PI3USB9281_REG_CHG_STATUS 0x0e #define PI3USB9281_REG_MANUAL 0x13 #define PI3USB9281_REG_RESET 0x1b #define PI3USB9281_REG_VBUS 0x1d #define PI3USB9281_DEV_ID 0x10 #define PI3USB9281_DEV_ID_A 0x18 #define PI3USB9281_CTRL_INT_DIS BIT(0) #define PI3USB9281_CTRL_AUTO BIT(2) #define PI3USB9281_CTRL_SWITCH_AUTO BIT(4) /* Bits 5 thru 7 are read X, write 0 */ #define PI3USB9281_CTRL_MASK 0x1f /* Bits 1 and 3 are read 1, write 1 */ #define PI3USB9281_CTRL_RSVD_1 0x0a #define PI3USB9281_PIN_MANUAL_VBUS (3 << 0) #define PI3USB9281_PIN_MANUAL_DP BIT(2) #define PI3USB9281_PIN_MANUAL_DM BIT(5) #define PI3USB9281_INT_ATTACH BIT(0) #define PI3USB9281_INT_DETACH BIT(1) #define PI3USB9281_INT_OVP BIT(5) #define PI3USB9281_INT_OCP BIT(6) #define PI3USB9281_INT_OVP_OC BIT(7) #define PI3USB9281_INT_ATTACH_DETACH (PI3USB9281_INT_ATTACH | \ PI3USB9281_INT_DETACH) #define PI3USB9281_TYPE_NONE 0 #define PI3USB9281_TYPE_MHL BIT(0) #define PI3USB9281_TYPE_OTG BIT(1) #define PI3USB9281_TYPE_SDP BIT(2) #define PI3USB9281_TYPE_CAR BIT(4) #define PI3USB9281_TYPE_CDP BIT(5) #define PI3USB9281_TYPE_DCP BIT(6) #define PI3USB9281_CHG_NONE 0 #define PI3USB9281_CHG_CAR_TYPE1 BIT(1) #define PI3USB9281_CHG_CAR_TYPE2 (3 << 0) #define PI3USB9281_CHG_APPLE_1A BIT(2) #define PI3USB9281_CHG_APPLE_2A BIT(3) #define PI3USB9281_CHG_APPLE_2_4A BIT(4) /* Check if charge status has any connection */ #define PI3USB9281_CHG_STATUS_ANY(x) (((x) & 0x1f) > 1) /* Define configuration of one pi3usb9281 part */ struct pi3usb9281_config { /* i2c port that chip resides on */ int i2c_port; /* GPIO for chip selection in muxed configuration */ enum gpio_signal mux_gpio; /* Logic level of mux_gpio to select chip */ int mux_gpio_level; /* Mutex to lock access to mux gpio or NULL if no mux exists */ struct mutex *mux_lock; }; /* Configuration struct defined at board level */ extern struct pi3usb9281_config pi3usb9281_chips[]; /* Enable interrupts. */ int pi3usb9281_enable_interrupts(int port); /* Get the device type */ int pi3usb9281_get_device_type(int port); extern const struct bc12_drv pi3usb9281_drv; #endif /* __CROS_EC_PI3USB9281_H */