soc/amd/stoneyridge: Add I2C support
BUG=b:69416132 BRANCH=none TEST=make Change-Id: Id940af917c9525aba7bc25eea0821f5f36a36653 Signed-off-by: Chris Ching <chingcodes@chromium.org> Reviewed-on: https://review.coreboot.org/22959 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Martin Roth <martinroth@google.com>
This commit is contained in:
parent
fc511277a5
commit
6fc39d47d0
5 changed files with 49 additions and 0 deletions
|
@ -32,6 +32,7 @@ config CPU_SPECIFIC_OPTIONS
|
|||
select ARCH_ROMSTAGE_X86_32
|
||||
select ARCH_RAMSTAGE_X86_32
|
||||
select ACPI_AMD_HARDWARE_SLEEP_VALUES
|
||||
select DRIVERS_I2C_DESIGNWARE
|
||||
select GENERIC_GPIO_LIB
|
||||
select IOAPIC
|
||||
select HAVE_USBDEBUG_OPTIONS
|
||||
|
@ -371,4 +372,8 @@ config RO_REGION_ONLY
|
|||
depends on CHROMEOS
|
||||
default "apu/amdfw"
|
||||
|
||||
config DRIVERS_I2C_DESIGNWARE_CLOCK_MHZ
|
||||
int
|
||||
default 133
|
||||
|
||||
endif # SOC_AMD_STONEYRIDGE_FP4 || SOC_AMD_STONEYRIDGE_FT4
|
||||
|
|
|
@ -40,6 +40,7 @@ subdirs-y += ../../../cpu/x86/smm
|
|||
bootblock-$(CONFIG_STONEYRIDGE_UART) += uart.c
|
||||
bootblock-y += BiosCallOuts.c
|
||||
bootblock-y += bootblock/bootblock.c
|
||||
bootblock-y += i2c.c
|
||||
bootblock-y += pmutil.c
|
||||
bootblock-y += reset.c
|
||||
bootblock-y += sb_util.c
|
||||
|
@ -47,6 +48,7 @@ bootblock-y += tsc_freq.c
|
|||
bootblock-y += southbridge.c
|
||||
|
||||
romstage-y += BiosCallOuts.c
|
||||
romstage-y += i2c.c
|
||||
romstage-y += romstage.c
|
||||
romstage-$(CONFIG_USBDEBUG_IN_ROMSTAGE) += enable_usbdebug.c
|
||||
romstage-y += gpio.c
|
||||
|
@ -61,6 +63,7 @@ romstage-$(CONFIG_STONEYRIDGE_UART) += uart.c
|
|||
romstage-y += tsc_freq.c
|
||||
romstage-y += southbridge.c
|
||||
|
||||
verstage-y += i2c.c
|
||||
verstage-y += sb_util.c
|
||||
verstage-y += pmutil.c
|
||||
verstage-y += reset.c
|
||||
|
@ -71,6 +74,7 @@ postcar-$(CONFIG_STONEYRIDGE_UART) += uart.c
|
|||
postcar-y += ramtop.c
|
||||
|
||||
ramstage-y += BiosCallOuts.c
|
||||
ramstage-y += i2c.c
|
||||
ramstage-y += chip.c
|
||||
ramstage-y += cpu.c
|
||||
ramstage-$(CONFIG_USBDEBUG) += enable_usbdebug.c
|
||||
|
|
29
src/soc/amd/stoneyridge/i2c.c
Normal file
29
src/soc/amd/stoneyridge/i2c.c
Normal file
|
@ -0,0 +1,29 @@
|
|||
/*
|
||||
* This file is part of the coreboot project.
|
||||
*
|
||||
* Copyright (C) 2017 Google
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; version 2 of the License.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*/
|
||||
|
||||
#include <drivers/i2c/designware/dw_i2c.h>
|
||||
#include <soc/iomap.h>
|
||||
|
||||
const uintptr_t i2c_bus_address[] = { I2C_BASE_ADDRESS,
|
||||
I2C_BASE_ADDRESS + I2C_DEVICE_SIZE * 1,
|
||||
I2C_BASE_ADDRESS + I2C_DEVICE_SIZE * 2,
|
||||
I2C_BASE_ADDRESS + I2C_DEVICE_SIZE * 3,
|
||||
};
|
||||
|
||||
|
||||
uintptr_t dw_i2c_base_address(unsigned int bus)
|
||||
{
|
||||
return bus < I2C_DEVICE_COUNT ? i2c_bus_address[bus] : 0;
|
||||
}
|
|
@ -22,6 +22,11 @@
|
|||
#define SPI_BASE_ADDRESS 0xfec10000
|
||||
#define IO_APIC2_ADDR 0xfec20000
|
||||
|
||||
/* I2C fixed address */
|
||||
#define I2C_BASE_ADDRESS 0xfedc2000
|
||||
#define I2C_DEVICE_SIZE 0x00001000
|
||||
#define I2C_DEVICE_COUNT 4
|
||||
|
||||
#if IS_ENABLED(CONFIG_HPET_ADDRESS_OVERRIDE)
|
||||
#error HPET address override is not allowed and must be fixed at 0xfed00000
|
||||
#endif
|
||||
|
|
|
@ -137,6 +137,12 @@ static void lpc_read_resources(device_t dev)
|
|||
res->size = 0x00001000;
|
||||
res->flags = IORESOURCE_MEM | IORESOURCE_ASSIGNED | IORESOURCE_FIXED;
|
||||
|
||||
/* I2C devices (all 4 devices) */
|
||||
res = new_resource(dev, 4);
|
||||
res->base = I2C_BASE_ADDRESS;
|
||||
res->size = I2C_DEVICE_SIZE * I2C_DEVICE_COUNT;
|
||||
res->flags = IORESOURCE_MEM | IORESOURCE_ASSIGNED | IORESOURCE_FIXED;
|
||||
|
||||
compact_resources(dev);
|
||||
|
||||
/* Allocate ACPI NVS in CBMEM */
|
||||
|
|
Loading…
Reference in a new issue