/* Copyright 2019 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. */ /* Intel BASEBOARD-RVP ITE EC specific configuration */ #include "common.h" #include "it83xx_pd.h" #include "keyboard_scan.h" #include "pwm.h" #include "pwm_chip.h" #include "timer.h" #include "usb_pd_tcpm.h" /* USB-C TPCP Configuration */ const struct tcpc_config_t tcpc_config[CONFIG_USB_PD_PORT_COUNT] = { [TYPE_C_PORT_0] = { .bus_type = EC_BUS_TYPE_EMBEDDED, /* TCPC is embedded within EC so no i2c config needed */ .drv = &it83xx_tcpm_drv, #ifdef CONFIG_INTEL_VIRTUAL_MUX .usb23 = TYPE_C_PORT_0_USB2_NUM | (TYPE_C_PORT_0_USB3_NUM << 4), #endif }, #ifdef HAS_TASK_PD_C1 [TYPE_C_PORT_1] = { .bus_type = EC_BUS_TYPE_EMBEDDED, /* TCPC is embedded within EC so no i2c config needed */ .drv = &it83xx_tcpm_drv, #ifdef CONFIG_INTEL_VIRTUAL_MUX .usb23 = TYPE_C_PORT_1_USB2_NUM | (TYPE_C_PORT_1_USB3_NUM << 4), #endif }, #endif /* HAS_TASK_PD_C1 */ }; BUILD_ASSERT(ARRAY_SIZE(tcpc_config) == CONFIG_USB_PD_PORT_COUNT); /* Reset PD MCU */ void board_reset_pd_mcu(void) { /* Not applicable for ITE TCPC */ } uint16_t tcpc_get_alert_status(void) { /* * Since C0/C1 TCPC are embedded within EC, we don't need the * PDCMD tasks. The (embedded) TCPC status since chip driver * code handles its own interrupts and forward the correct * events to the PD_C0 task. See it83xx/intc.c */ return 0; } /* Keyboard scan setting */ struct keyboard_scan_config keyscan_config = { .output_settle_us = 35, .debounce_down_us = 5 * MSEC, .debounce_up_us = 40 * MSEC, .scan_period_us = 3 * MSEC, .min_post_scan_delay_us = 1000, .poll_timeout_us = 100 * MSEC, .actual_key_mask = { 0x14, 0xff, 0xff, 0xff, 0xff, 0xf5, 0xff, 0xa4, 0xff, 0xfe, 0x55, 0xfa, 0xca /* full set */ }, }; /* * PWM HW channelx binding tachometer channelx for fan control. * Four tachometer input pins but two tachometer modules only, * so always binding [TACH_CH_TACH0A | TACH_CH_TACH0B] and/or * [TACH_CH_TACH1A | TACH_CH_TACH1B] */ const struct fan_tach_t fan_tach[] = { [PWM_HW_CH_DCR0] = { .ch_tach = TACH_CH_NULL, .fan_p = -1, .rpm_re = -1, .s_duty = -1, }, [PWM_HW_CH_DCR1] = { .ch_tach = TACH_CH_NULL, .fan_p = -1, .rpm_re = -1, .s_duty = -1, }, [PWM_HW_CH_DCR2] = { .ch_tach = TACH_CH_TACH1A, .fan_p = 2, .rpm_re = 1, .s_duty = 1, }, [PWM_HW_CH_DCR3] = { .ch_tach = TACH_CH_NULL, .fan_p = -1, .rpm_re = -1, .s_duty = -1, }, [PWM_HW_CH_DCR4] = { .ch_tach = TACH_CH_NULL, .fan_p = -1, .rpm_re = -1, .s_duty = -1, }, [PWM_HW_CH_DCR5] = { .ch_tach = TACH_CH_NULL, .fan_p = -1, .rpm_re = -1, .s_duty = -1, }, [PWM_HW_CH_DCR6] = { .ch_tach = TACH_CH_NULL, .fan_p = -1, .rpm_re = -1, .s_duty = -1, }, [PWM_HW_CH_DCR7] = { .ch_tach = TACH_CH_NULL, .fan_p = -1, .rpm_re = -1, .s_duty = -1, }, }; BUILD_ASSERT(ARRAY_SIZE(fan_tach) == PWM_HW_CH_TOTAL); /* PWM channels */ const struct pwm_t pwm_channels[] = { [PWM_CH_FAN] = { .channel = PWM_HW_CH_DCR2, .flags = PWM_CONFIG_HAS_RPM_MODE, .freq_hz = 30000, .pcfsr_sel = PWM_PRESCALER_C7, }, }; BUILD_ASSERT(ARRAY_SIZE(pwm_channels) == PWM_CH_COUNT); #ifdef CONFIG_USBC_VCONN void board_pd_vconn_ctrl(int port, enum usbpd_cc_pin cc_pin, int enabled) { /* * Setting VCONN low by disabling the power switch before * enabling the VCONN on respective CC line */ gpio_set_level(tcpc_gpios[port].vconn.cc1_pin, !tcpc_gpios[port].vconn.pin_pol); gpio_set_level(tcpc_gpios[port].vconn.cc2_pin, !tcpc_gpios[port].vconn.pin_pol); if (enabled) gpio_set_level((cc_pin != USBPD_CC_PIN_1) ? tcpc_gpios[port].vconn.cc2_pin : tcpc_gpios[port].vconn.cc1_pin, tcpc_gpios[port].vconn.pin_pol); } #endif