From 26c325d15e2fa47bbe26636939fb29779d02bc57 Mon Sep 17 00:00:00 2001 From: Nicolas Boichat Date: Mon, 7 Nov 2016 08:25:45 +0800 Subject: hammer: Enable I2C passthrough This interface will be used to update the trackpad firmware. BRANCH=none BUG=b:35587174 TEST=make BOARD=hammer -j; flash hammer; lsusb -v -v shows I2C interface Change-Id: Ia4533c758f80eb786bd6dbb9f35feb66eb631793 Reviewed-on: https://chromium-review.googlesource.com/474667 Commit-Ready: Nicolas Boichat Tested-by: Nicolas Boichat Reviewed-by: Chun-ta Lin --- board/hammer/board.c | 8 +++++++- board/hammer/board.h | 10 +++++++--- 2 files changed, 14 insertions(+), 4 deletions(-) diff --git a/board/hammer/board.c b/board/hammer/board.c index 5bc8b86fcb..baf7b41f08 100644 --- a/board/hammer/board.c +++ b/board/hammer/board.c @@ -20,6 +20,7 @@ #include "usart_tx_dma.h" #include "usart_rx_dma.h" #include "usb_descriptor.h" +#include "usb_i2c.h" #include "util.h" #include "gpio_list.h" @@ -33,13 +34,15 @@ const void *const usb_strings[] = { [USB_STR_PRODUCT] = USB_STRING_DESC("Hammer"), [USB_STR_SERIALNO] = 0, [USB_STR_VERSION] = USB_STRING_DESC(CROS_EC_VERSION32), + [USB_STR_I2C_NAME] = USB_STRING_DESC("I2C"), [USB_STR_UPDATE_NAME] = USB_STRING_DESC("Firmware update"), }; BUILD_ASSERT(ARRAY_SIZE(usb_strings) == USB_STR_COUNT); /****************************************************************************** - * Support I2C master port for trackpad. + * Support I2C bridging over USB, this requires usb_i2c_board_enable and + * usb_i2c_board_disable to be defined to enable and disable the I2C bridge. */ /* I2C ports */ @@ -55,6 +58,9 @@ const struct pwm_t pwm_channels[] = { }; BUILD_ASSERT(ARRAY_SIZE(pwm_channels) == PWM_CH_COUNT); +int usb_i2c_board_enable(void) { return EC_SUCCESS; } +void usb_i2c_board_disable(void) {} + /****************************************************************************** * Support firmware upgrade over USB. We can update whichever section is not * the current section. diff --git a/board/hammer/board.h b/board/hammer/board.h index a035ee2965..c8d6bfa005 100644 --- a/board/hammer/board.h +++ b/board/hammer/board.h @@ -101,14 +101,16 @@ #define USB_IFACE_UPDATE 0 #define USB_IFACE_HID_KEYBOARD 1 #define USB_IFACE_HID_TOUCHPAD 2 -#define USB_IFACE_COUNT 3 +#define USB_IFACE_I2C 3 +#define USB_IFACE_COUNT 4 /* USB endpoint indexes (use define rather than enum to expand them) */ #define USB_EP_CONTROL 0 #define USB_EP_UPDATE 1 #define USB_EP_HID_KEYBOARD 2 #define USB_EP_HID_TOUCHPAD 3 -#define USB_EP_COUNT 4 +#define USB_EP_I2C 4 +#define USB_EP_COUNT 5 /* Optional features */ #define CONFIG_BOARD_PRE_INIT @@ -121,7 +123,8 @@ #define CONFIG_KEYBOARD_DEBUG #define KB_OUT_PORT_LIST GPIO_A, GPIO_B, GPIO_C, GPIO_F -/* Enable I2C */ +/* Enable control of I2C over USB */ +#define CONFIG_USB_I2C #define CONFIG_I2C #define CONFIG_I2C_MASTER #define I2C_PORT_MASTER 0 @@ -164,6 +167,7 @@ enum usb_strings { USB_STR_PRODUCT, USB_STR_SERIALNO, USB_STR_VERSION, + USB_STR_I2C_NAME, USB_STR_UPDATE_NAME, USB_STR_COUNT }; -- cgit v1.2.1