81 lines
3.1 KiB
C
81 lines
3.1 KiB
C
/* -*- mode:c -*-
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
/* Declare symbolic names for all the GPIOs that we care about.
|
|
* Note: Those with interrupt handlers must be declared first. */
|
|
|
|
/* Divided Vconn voltage sense */
|
|
GPIO(VCONN_VSENSE, PIN(A, 0), GPIO_ANALOG)
|
|
/* CC ADC, PD in comparator, or tx enable out (low) */
|
|
GPIO(CC_VPDMCU, PIN(A, 1), GPIO_ANALOG)
|
|
/* CC 0.2V comparator during charge-through, active Rd (low) or Rp3A0 (high) */
|
|
GPIO(CC_RP3A0_RD_L, PIN(A, 2), GPIO_ANALOG)
|
|
/* 0.2V resistor divider for various CC comapators */
|
|
GPIO(RDCONNECT_REF, PIN(A, 3), GPIO_ANALOG)
|
|
/* Charger CC1 0.2V comparator and ADC, drive a Rp3A0 (high) or Rd (low) */
|
|
GPIO(CC1_RP3A0_RD_L, PIN(A, 4), GPIO_ANALOG)
|
|
/* Charger CC2 0.2V comparator and ADC, drive a Rp3A0 (high) or Rd (low) */
|
|
GPIO(CC2_RP3A0_RD_L, PIN(A, 5), GPIO_ANALOG)
|
|
/* Divided host VBUS voltage sense */
|
|
GPIO(HOST_VBUS_VSENSE, PIN(A, 6), GPIO_ANALOG)
|
|
/* Divided charger VBUS voltage sense */
|
|
GPIO(CHARGER_VBUS_VSENSE, PIN(A, 7), GPIO_ANALOG)
|
|
/* Charger CC1 ADC, or drive a RpUSB (high) */
|
|
GPIO(CC1_RPUSB_ODH, PIN(B, 0), GPIO_ANALOG)
|
|
/* Charger CC2 ADC, or drive a RpUSB (high) */
|
|
GPIO(CC2_RPUSB_ODH, PIN(B, 1), GPIO_ANALOG)
|
|
|
|
/* PD TX data output */
|
|
GPIO(CC_TX_DATA, PIN(B, 4), GPIO_INPUT)
|
|
|
|
/* Enables the VBUS pass-through (high) */
|
|
GPIO(VBUS_PASS_EN, PIN(B, 2), GPIO_OUT_LOW)
|
|
|
|
/*
|
|
* Desired billboard state. One of "no billboard/nothing connected" (low),
|
|
* "source connected but not in charge-through" (pull-up), or "sink connected"
|
|
* (high)
|
|
*/
|
|
GPIO(PRESENT_BILLBOARD, PIN(A, 8), GPIO_OUT_LOW)
|
|
|
|
/* Enables cReceiver and the path to the PD RX/TX, RpUSB, and Rp1A5 */
|
|
GPIO(VPDMCU_CC_EN, PIN(A, 11), GPIO_OUT_LOW)
|
|
|
|
/* Disables dead battery Rd on host side (low) */
|
|
GPIO(CC_DB_EN_OD, PIN(A, 12), GPIO_ODR_HIGH)
|
|
|
|
/* RpUSB on host side (high) */
|
|
GPIO(CC_RPUSB_ODH, PIN(A, 13), GPIO_INPUT)
|
|
|
|
/*
|
|
* Controls the dead-battery pull-downs on charger side; either dead battery
|
|
* Rd (low) or Hi-Z (high)
|
|
*/
|
|
GPIO(CC1_CC2_DB_EN_L, PIN(A, 15), GPIO_OUT_LOW)
|
|
|
|
/* Chooses between Vconn (low) and VBUS (high) */
|
|
GPIO(VCONN_PWR_SEL_ODL, PIN(B, 6), GPIO_INPUT)
|
|
|
|
/* Passes CC1 to the host CC (high) */
|
|
GPIO(CC1_SEL, PIN(F, 0), GPIO_OUT_LOW)
|
|
/* Passes CC2 to the host CC (high) */
|
|
GPIO(CC2_SEL, PIN(F, 1), GPIO_OUT_LOW)
|
|
/* Debug red LED driver (low). Keep off for power measurements */
|
|
GPIO(DEBUG_LED_R_L, PIN(B, 5), GPIO_ODR_HIGH)
|
|
/* Debug green LED driver (low). Keep off for power measurements */
|
|
GPIO(DEBUG_LED_G_L, PIN(B, 7), GPIO_ODR_HIGH)
|
|
|
|
UNIMPLEMENTED(WP_L)
|
|
UNIMPLEMENTED(ENTERING_RW)
|
|
|
|
/* SCK(PB3): PD_TX_CLK_IN - Clock input for PD TX */
|
|
ALTERNATE(PIN_MASK(B, 0x0008), 0, MODULE_USB_PD, 0)
|
|
/* TIM16_CH1(PB8): PD_TX_CLK_OUT - Clock generator for PD TX */
|
|
ALTERNATE(PIN_MASK(B, 0x0100), 2, MODULE_USB_PD, 0)
|
|
/* USART1 (PA9/PA10): TX/RX for debug and programming */
|
|
ALTERNATE(PIN_MASK(A, 0x0600), 1, MODULE_UART, 0)
|