/* Copyright (c) 2013 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. */ #ifndef __CROS_EC_CONFIG_CHIP_H #define __CROS_EC_CONFIG_CHIP_H /* CPU core BFD configuration */ #include "core/nds32/config_core.h" /* Number of IRQ vectors on the IVIC */ #define CONFIG_IRQ_COUNT IT83XX_IRQ_COUNT /* Interval between HOOK_TICK notifications */ #define HOOK_TICK_INTERVAL_MS 500 #define HOOK_TICK_INTERVAL (HOOK_TICK_INTERVAL_MS * MSEC) /* Default PLL frequency. */ #define PLL_CLOCK 48000000 /* Number of I2C ports */ #define I2C_PORT_COUNT 6 /* I2C ports on chip * IT83xx - There are three i2c standard ports. * There are three i2c enhanced ports. */ #define I2C_STANDARD_PORT_COUNT 3 #define I2C_ENHANCED_PORT_COUNT 3 /****************************************************************************/ /* Memory mapping */ #define CONFIG_RAM_BASE 0x00080000 #define CONFIG_RAM_SIZE 0x0000C000 /* System stack size */ #define CONFIG_STACK_SIZE 1024 /* non-standard task stack sizes */ #define SMALLER_TASK_STACK_SIZE 384 #define IDLE_TASK_STACK_SIZE 512 #define LARGER_TASK_STACK_SIZE 768 #define VENTI_TASK_STACK_SIZE 896 /* Default task stack size */ #define TASK_STACK_SIZE 512 #define CONFIG_PROGRAM_MEMORY_BASE 0x00000000 #define CONFIG_FLASH_BANK_SIZE 0x00000800 /* protect bank size */ #define CONFIG_FLASH_ERASE_SIZE 0x00000400 /* erase bank size */ #define CONFIG_FLASH_WRITE_SIZE 0x00000004 /* minimum write size */ /* * This is the block size of the ILM on the it83xx chip. * The ILM for static code cache, CPU fetch instruction from * ILM(ILM -> CPU)instead of flash(flash -> IMMU -> CPU) if enabled. */ #define IT83XX_ILM_BLOCK_SIZE 0x00001000 /* * The AAI program instruction allows continue write flash * until write disable instruction. */ #define CONFIG_FLASH_WRITE_IDEAL_SIZE CONFIG_FLASH_ERASE_SIZE #if defined(CHIP_VARIANT_IT8320BX) /* This is the physical size of the flash on the chip. We'll reserve one bank * in order to emulate per-bank write-protection UNTIL REBOOT. The hardware * doesn't support a write-protect pin, and if we make the write-protection * permanent, it can't be undone easily enough to support RMA. */ #define CONFIG_FLASH_SIZE 0x00040000 /* For IT8320BX, we have to reload cc parameters after ec softreset. */ #define IT83XX_USBPD_CC_PARAMETER_RELOAD /* * The voltage detector of CC1 and CC2 is enabled/disabled by different bit * of the control register (bit1 and bit5 at register IT83XX_USBPD_CCCSR). */ #define IT83XX_USBPD_CC_VOLTAGE_DETECTOR_INDEPENDENT /* For IT8320BX, we have to write 0xff to clear pending bit.*/ #define IT83XX_ESPI_VWCTRL1_WRITE_FF_CLEAR /* For IT8320BX, we have to read observation register of external timer two * times to get correct time. */ #define IT83XX_EXT_OBSERVATION_REG_READ_TWO_TIMES #elif defined(CHIP_VARIANT_IT8320DX) #define CONFIG_FLASH_SIZE 0x00080000 /* * Disable eSPI pad, then PLL change * (include EC clock frequency) is succeed even CS# is low. */ #define IT83XX_ESPI_INHIBIT_CS_BY_PAD_DISABLED /* The slave frequency is adjustable (bit[2-0] at register IT83XX_ESPI_GCAC1) */ #define IT83XX_ESPI_SLAVE_MAX_FREQ_CONFIGURABLE /* * TODO(b/111480168): eSPI HW reset can't be used because the DMA address * gets set incorrectly resulting in a memory access exception. */ #define IT83XX_ESPI_RESET_MODULE_BY_FW /* Watchdog reset supports hardware reset. */ /* TODO(b/111264984): watchdog hardware reset function failed. */ #undef IT83XX_ETWD_HW_RESET_SUPPORT /* * (b/112452221): * Floating-point multiplication single-precision is failed on DX version, * so we use the formula "A/(1/B)" to replace a multiplication operation * (A*B = A/(1/B)). */ #define IT83XX_FPU_MUL_BY_DIV /* * More GPIOs can be set as 1.8v input. * Please refer to gpio_1p8v_sel[] for 1.8v GPIOs. */ #define IT83XX_GPIO_1P8V_PIN_EXTENDED /* All GPIOs support interrupt on rising, falling, and either edge. */ #define IT83XX_GPIO_INT_FLEXIBLE /* Enable interrupts of group 21 and 22. */ #define IT83XX_INTC_GROUP_21_22_SUPPORT /* Enable detect type-c plug in interrupt. */ #define IT83XX_INTC_PLUG_IN_SUPPORT #else #error "Unsupported chip variant!" #endif /****************************************************************************/ /* Define our flash layout. */ /* Memory-mapped internal flash */ #define CONFIG_INTERNAL_STORAGE #define CONFIG_MAPPED_STORAGE /* Program is run directly from storage */ #define CONFIG_MAPPED_STORAGE_BASE CONFIG_PROGRAM_MEMORY_BASE /* Compute the rest of the flash params from these */ #include "config_std_internal_flash.h" /****************************************************************************/ /* H2RAM memory mapping */ /* * Only it839x series and IT838x DX support mapping LPC I/O cycle 800h ~ 9FFh * to 0x8D800h ~ 0x8D9FFh of DLM13. */ #define CONFIG_H2RAM_BASE 0x0008D000 #define CONFIG_H2RAM_SIZE 0x00001000 #define CONFIG_H2RAM_HOST_LPC_IO_BASE 0x800 /****************************************************************************/ /* Customize the build */ #define CONFIG_FW_RESET_VECTOR /* Optional features present on this chip */ #define CHIP_FAMILY_IT83XX #define CONFIG_ADC #define CONFIG_HOSTCMD_X86 #define CONFIG_SWITCH /* Chip needs to do custom pre-init */ #define CONFIG_CHIP_PRE_INIT #define GPIO_PIN(port, index) GPIO_##port, BIT(index) #define GPIO_PIN_MASK(p, m) .port = GPIO_##p, .mask = (m) #endif /* __CROS_EC_CONFIG_CHIP_H */