summaryrefslogtreecommitdiff
path: root/src/soc
diff options
context:
space:
mode:
Diffstat (limited to 'src/soc')
-rw-r--r--src/soc/intel/quark/Kconfig240
-rw-r--r--src/soc/intel/quark/Makefile.inc72
-rw-r--r--src/soc/intel/quark/acpi.c76
-rw-r--r--src/soc/intel/quark/bootblock/bootblock.c109
-rw-r--r--src/soc/intel/quark/bootblock/esram_init.S505
-rw-r--r--src/soc/intel/quark/chip.c126
-rw-r--r--src/soc/intel/quark/chip.h101
-rw-r--r--src/soc/intel/quark/ehci.c119
-rw-r--r--src/soc/intel/quark/fsp_params.c12
-rw-r--r--src/soc/intel/quark/gpio_i2c.c29
-rw-r--r--src/soc/intel/quark/i2c.c357
-rw-r--r--src/soc/intel/quark/include/soc/IntelQNCConfig.h61
-rw-r--r--src/soc/intel/quark/include/soc/Ioh.h244
-rw-r--r--src/soc/intel/quark/include/soc/QuarkNcSocId.h826
-rw-r--r--src/soc/intel/quark/include/soc/acpi.h9
-rw-r--r--src/soc/intel/quark/include/soc/car.h16
-rw-r--r--src/soc/intel/quark/include/soc/cpu.h11
-rw-r--r--src/soc/intel/quark/include/soc/i2c.h120
-rw-r--r--src/soc/intel/quark/include/soc/iomap.h34
-rw-r--r--src/soc/intel/quark/include/soc/nvs.h17
-rw-r--r--src/soc/intel/quark/include/soc/pci_devs.h54
-rw-r--r--src/soc/intel/quark/include/soc/pei_wrapper.h31
-rw-r--r--src/soc/intel/quark/include/soc/pm.h19
-rw-r--r--src/soc/intel/quark/include/soc/ramstage.h15
-rw-r--r--src/soc/intel/quark/include/soc/reg_access.h247
-rw-r--r--src/soc/intel/quark/include/soc/romstage.h16
-rw-r--r--src/soc/intel/quark/include/soc/sd.h13
-rw-r--r--src/soc/intel/quark/include/soc/spi.h82
-rw-r--r--src/soc/intel/quark/include/soc/storage_test.h37
-rw-r--r--src/soc/intel/quark/lpc.c56
-rw-r--r--src/soc/intel/quark/memmap.c31
-rw-r--r--src/soc/intel/quark/northcluster.c50
-rw-r--r--src/soc/intel/quark/reg_access.c478
-rw-r--r--src/soc/intel/quark/reset.c12
-rw-r--r--src/soc/intel/quark/romstage/Makefile.inc9
-rw-r--r--src/soc/intel/quark/romstage/car.c52
-rw-r--r--src/soc/intel/quark/romstage/debug.c78
-rw-r--r--src/soc/intel/quark/romstage/fsp_params.c146
-rw-r--r--src/soc/intel/quark/romstage/pcie.c90
-rw-r--r--src/soc/intel/quark/romstage/report_platform.c113
-rw-r--r--src/soc/intel/quark/romstage/romstage.c64
-rw-r--r--src/soc/intel/quark/sd.c35
-rw-r--r--src/soc/intel/quark/spi.c290
-rw-r--r--src/soc/intel/quark/spi_debug.c98
-rw-r--r--src/soc/intel/quark/storage_test.c244
-rw-r--r--src/soc/intel/quark/tsc_freq.c9
-rw-r--r--src/soc/intel/quark/uart.c32
-rw-r--r--src/soc/intel/quark/uart_common.c14
48 files changed, 0 insertions, 5499 deletions
diff --git a/src/soc/intel/quark/Kconfig b/src/soc/intel/quark/Kconfig
deleted file mode 100644
index 631755cca1..0000000000
--- a/src/soc/intel/quark/Kconfig
+++ /dev/null
@@ -1,240 +0,0 @@
-# SPDX-License-Identifier: GPL-2.0-only
-
-config SOC_INTEL_QUARK
- bool
- help
- Intel Quark support
-
-if SOC_INTEL_QUARK
-
-config CPU_SPECIFIC_OPTIONS
- def_bool y
- select ACPI_NO_CUSTOM_MADT
- select ARCH_X86
- select NO_ECAM_MMCONF_SUPPORT
- select NO_SMM
- select REG_SCRIPT
- select PLATFORM_USES_FSP2_0
- select SOC_INTEL_COMMON
- select SOC_INTEL_COMMON_RESET
- select SOC_SETS_MSRS
- select SPI_FLASH
- select UART_OVERRIDE_REFCLK
- select UDELAY_TSC
- select TSC_MONOTONIC_TIMER
- select UNCOMPRESSED_RAMSTAGE
- select USE_FSP_NOTIFY_PHASE_POST_PCI_ENUM
- select USE_FSP_NOTIFY_PHASE_READY_TO_BOOT
- select USE_FSP_NOTIFY_PHASE_END_OF_FIRMWARE
- select USE_MARCH_586
-
-#####
-# Debug serial output
-# The following options configure the debug serial port
-#####
-
-config ENABLE_BUILTIN_HSUART0
- bool "Enable built-in HSUART0"
- default n
- select NO_UART_ON_SUPERIO
- select DRIVERS_UART_8250MEM_32
- help
- The Quark SoC has two HSUART. Choose this option to configure the pads
- and enable HSUART0, which can be used for the debug console.
-
-config ENABLE_BUILTIN_HSUART1
- bool "Enable built-in HSUART1"
- default n
- depends on ! ENABLE_BUILTIN_HSUART0
- select NO_UART_ON_SUPERIO
- select DRIVERS_UART_8250MEM_32
- help
- The Quark SoC has two HSUART. Choose this option to configure the pads
- and enable HSUART1, which can be used for the debug console.
-
-config TTYS0_BASE
- hex "HSUART Base Address"
- default 0xA0019000
- depends on ENABLE_BUILTIN_HSUART0 || ENABLE_BUILTIN_HSUART1
- help
- Memory mapped MMIO of HSUART.
-
-config TTYS0_LCS
- int
- default 3
- depends on ENABLE_BUILTIN_HSUART0 || ENABLE_BUILTIN_HSUART1
-
-#####
-# Debug support
-# The following options provide debug support for the Quark coreboot
-# code. The SD LED is used as a binary marker to determine if a
-# specific point in the execution flow has been reached.
-#####
-
-config ENABLE_DEBUG_LED
- bool
- default n
- help
- Enable the use of the SD LED for early debugging before serial output
- is available. Setting this LED indicates that control has reached the
- desired check point.
-
-config ENABLE_DEBUG_LED_ESRAM
- bool "SD LED indicates ESRAM initialized"
- default n
- select ENABLE_DEBUG_LED
- help
- Indicate that ESRAM has been successfully initialized. If the SD LED
- does not light then the ESRAM initialization needs to be debugged.
-
-config ENABLE_DEBUG_LED_BOOTBLOCK_ENTRY
- bool "SD LED indicates bootblock.c successfully entered"
- default n
- select ENABLE_DEBUG_LED
- help
- Indicate that bootblock_c_entry was entered. If the SD LED does not
- light then debug the code between ESRAM and bootblock_c_entry.
-
-config ENABLE_DEBUG_LED_SOC_EARLY_INIT_ENTRY
- bool "SD LED indicates bootblock_soc_early_init successfully entered"
- default n
- select ENABLE_DEBUG_LED
- help
- Indicate that bootblock_soc_early_init was entered. If the SD LED
- does not light then debug the code in bootblock_main_with_timestamp.
-
-config ENABLE_DEBUG_LED_SOC_EARLY_INIT_EXIT
- bool "SD LED indicates bootblock_soc_early_init successfully exited"
- default n
- select ENABLE_DEBUG_LED
- help
- Indicate that bootblock_soc_early_init exited. If the SD LED does not
- light then debug the scripts in bootblock_soc_early_init.
-
-config ENABLE_DEBUG_LED_SOC_INIT_ENTRY
- bool "SD LED indicates bootblock_soc_init successfully entered"
- default n
- select ENABLE_DEBUG_LED
- help
- Indicate that bootblock_soc_init was entered. If the SD LED does not
- light then debug the code in bootblock_mainboard_early_init and
- console_init. If the SD LED does light but there is no serial then
- debug the serial port configuration and initialization.
-
-#####
-# ESRAM layout
-# Specify the portion of the ESRAM for coreboot to use as its data area.
-#####
-
-config DCACHE_RAM_BASE
- hex
- default 0x80000000
-
-config DCACHE_RAM_SIZE
- hex
- default 0x40000
-
-config DISPLAY_ESRAM_LAYOUT
- bool "Display ESRAM layout"
- default n
- help
- Select this option to display coreboot's use of ESRAM.
-
-#####
-# Flash layout
-# Specify the size of the coreboot file system in the read-only
-# (recovery) portion of the flash part.
-#####
-
-config CBFS_SIZE
- default 0x200000
- help
- Specify the size of the coreboot file system in the read-only (recovery)
- portion of the flash part. On Quark systems the firmware image stores
- more than just coreboot, including:
- - The chipset microcode (RMU) binary file located at 0xFFF00000
- - Intel Trusted Execution Engine firmware
-
-#####
-# FSP binary
-# The following options control the FSP binary file placement in
-# the flash image and ESRAM. This file is required by the Quark
-# SoC code to boot coreboot and its payload.
-#####
-
-config FSP_ESRAM_LOC
- hex
- default 0x80040000
- help
- The location in ESRAM where a copy of the FSP binary is placed.
-
-config FSP_M_FILE
- string
- default "3rdparty/blobs/soc/intel/quark/\$(CONFIG_FSP_TYPE)/\$(CONFIG_FSP_BUILD_TYPE)/FSP_M.fd"
-
-config FSP_S_FILE
- string
- default "3rdparty/blobs/soc/intel/quark/\$(CONFIG_FSP_TYPE)/\$(CONFIG_FSP_BUILD_TYPE)/FSP_S.fd"
-
-#####
-# RMU binary
-# The following options control the Quark chipset microcode file
-# placement in the flash image. This file is required to bring
-# the Quark processor out of reset.
-#####
-
-config ADD_RMU_FILE
- bool "Should the RMU binary be added to the flash image?"
- default n
- help
- The RMU file is required to get the chip out of reset.
-
-config RMU_FILE
- string
- default "3rdparty/blobs/soc/intel/quark/rmu.bin"
- depends on ADD_RMU_FILE
- help
- The path and filename of the Intel Quark RMU binary.
-
-config RMU_LOC
- hex
- default 0xfff00000
- depends on ADD_RMU_FILE
- help
- The location in CBFS that the RMU is located. It must match the
- strap-determined base address.
-
-config DCACHE_BSP_STACK_SIZE
- hex
- default 0x4000
-
-#####
-# Test support
-#####
-
-config STORAGE_TEST
- bool "Test SD/MMC/eMMC card or device access"
- default n
- select COMMONLIB_STORAGE
- select SDHCI_CONTROLLER
- help
- Read block 0 from each partition of the storage device. User
- must also enable one or both of COMMONLIB_STORAGE_SD or
- COMMONLIB_STORAGE_MMC.
-
-config STORAGE_LOG
- bool "Log and display SD/MMC commands"
- default n
- depends on STORAGE_TEST
-
-#####
-# I2C debug support
-#####
-
-config I2C_DEBUG
- bool "Enable I2C debugging"
- default n
- help
- Display the I2C segments and controller errors
-
-endif # SOC_INTEL_QUARK
diff --git a/src/soc/intel/quark/Makefile.inc b/src/soc/intel/quark/Makefile.inc
deleted file mode 100644
index e4df2ccaf9..0000000000
--- a/src/soc/intel/quark/Makefile.inc
+++ /dev/null
@@ -1,72 +0,0 @@
-# SPDX-License-Identifier: GPL-2.0-only
-
-ifeq ($(CONFIG_SOC_INTEL_QUARK),y)
-
-subdirs-y += romstage
-
-bootblock-y += bootblock/esram_init.S
-bootblock-y += bootblock/bootblock.c
-bootblock-y += i2c.c
-bootblock-y += reg_access.c
-bootblock-y += tsc_freq.c
-bootblock-y += uart_common.c
-
-verstage-y += i2c.c
-verstage-y += reg_access.c
-verstage-y += tsc_freq.c
-verstage-$(CONFIG_ENABLE_BUILTIN_HSUART1) += uart_common.c
-
-romstage-y += i2c.c
-romstage-y += memmap.c
-romstage-y += reg_access.c
-romstage-$(CONFIG_STORAGE_TEST) += storage_test.c
-romstage-y += tsc_freq.c
-romstage-$(CONFIG_ENABLE_BUILTIN_HSUART1) += uart_common.c
-romstage-y += reset.c
-
-postcar-y += fsp_params.c
-postcar-y += i2c.c
-postcar-y += reg_access.c
-postcar-y += tsc_freq.c
-postcar-$(CONFIG_ENABLE_BUILTIN_HSUART1) += uart_common.c
-
-ramstage-$(CONFIG_HAVE_ACPI_TABLES) += acpi.c
-ramstage-y += chip.c
-ramstage-y += ehci.c
-ramstage-y += fsp_params.c
-ramstage-y += gpio_i2c.c
-ramstage-y += i2c.c
-ramstage-y += lpc.c
-ramstage-y += northcluster.c
-ramstage-y += reg_access.c
-ramstage-y += reset.c
-ramstage-y += sd.c
-ramstage-y += spi.c
-ramstage-y += spi_debug.c
-ramstage-$(CONFIG_STORAGE_TEST) += storage_test.c
-ramstage-y += tsc_freq.c
-ramstage-$(CONFIG_ENABLE_BUILTIN_HSUART1) += uart_common.c
-ramstage-$(CONFIG_ENABLE_BUILTIN_HSUART1) += uart.c
-
-CPPFLAGS_common += -I$(src)/soc/intel/quark
-CPPFLAGS_common += -I$(src)/soc/intel/quark/include
-
-# Chipset microcode path
-CPPFLAGS_common += -I3rdparty/blobs/soc/intel/quark
-
-# Since FSP-M runs in CAR we need to relocate it to a specific address
-$(call strip_quotes,$(CONFIG_FSP_M_CBFS))-options := -b $(CONFIG_FSP_ESRAM_LOC)
-
-# Add the FSP binary to the CBFS image
-cbfs-files-$(CONFIG_ADD_FSP_RAW_BIN) += fsp.bin
-fsp.bin-file := $(call strip_quotes,$(CONFIG_FSP_FILE))
-fsp.bin-position := $(CONFIG_FSP_LOC)
-fsp.bin-type := raw
-
-# Add the chipset microcode file to the CBFS image
-cbfs-files-$(CONFIG_ADD_RMU_FILE) += rmu.bin
-rmu.bin-file := $(call strip_quotes,$(CONFIG_RMU_FILE))
-rmu.bin-position := $(CONFIG_RMU_LOC)
-rmu.bin-type := raw
-
-endif # CONFIG_SOC_INTEL_QUARK
diff --git a/src/soc/intel/quark/acpi.c b/src/soc/intel/quark/acpi.c
deleted file mode 100644
index 8e36723816..0000000000
--- a/src/soc/intel/quark/acpi.c
+++ /dev/null
@@ -1,76 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <console/console.h>
-#include <device/pci_ops.h>
-#include <soc/acpi.h>
-#include <soc/ramstage.h>
-
-void acpi_fill_fadt(acpi_fadt_t *fadt)
-{
- struct device *dev = pcidev_on_root(PCI_DEVICE_NUMBER_QNC_LPC,
- PCI_FUNCTION_NUMBER_QNC_LPC);
- uint32_t gpe0_base = pci_read_config32(dev, R_QNC_LPC_GPE0BLK)
- & B_QNC_LPC_GPE0BLK_MASK;
- uint32_t pmbase = pci_read_config32(dev, R_QNC_LPC_PM1BLK)
- & B_QNC_LPC_PM1BLK_MASK;
-
- fadt->flags |= ACPI_FADT_PLATFORM_CLOCK;
-
- /* PM1 Status: ACPI 4.8.3.1.1 */
- fadt->pm1a_evt_blk = pmbase + R_QNC_PM1BLK_PM1S;
- fadt->pm1_evt_len = 2;
-
- fadt->x_pm1a_evt_blk.space_id = ACPI_ADDRESS_SPACE_IO;
- fadt->x_pm1a_evt_blk.bit_width = fadt->pm1_evt_len * 8;
- fadt->x_pm1a_evt_blk.bit_offset = 0;
- fadt->x_pm1a_evt_blk.access_size = ACPI_ACCESS_SIZE_WORD_ACCESS;
- fadt->x_pm1a_evt_blk.addrl = fadt->pm1a_evt_blk;
- fadt->x_pm1a_evt_blk.addrh = 0x0;
-
- /* PM1 Control: ACPI 4.8.3.2.1 */
- fadt->pm1a_cnt_blk = pmbase + R_QNC_PM1BLK_PM1C;
- fadt->pm1_cnt_len = 2;
-
- fadt->x_pm1a_cnt_blk.space_id = ACPI_ADDRESS_SPACE_IO;
- fadt->x_pm1a_cnt_blk.bit_width = fadt->pm1_cnt_len * 8;
- fadt->x_pm1a_cnt_blk.bit_offset = 0;
- fadt->x_pm1a_cnt_blk.access_size = ACPI_ACCESS_SIZE_WORD_ACCESS;
- fadt->x_pm1a_cnt_blk.addrl = fadt->pm1a_cnt_blk;
- fadt->x_pm1a_cnt_blk.addrh = 0x0;
-
- /* PM Timer: ACPI 4.8.3.3 */
- fadt->pm_tmr_blk = pmbase + R_QNC_PM1BLK_PM1T;
- fadt->pm_tmr_len = 4;
-
- fadt->x_pm_tmr_blk.space_id = ACPI_ADDRESS_SPACE_IO;
- fadt->x_pm_tmr_blk.bit_width = fadt->pm_tmr_len * 8;
- fadt->x_pm_tmr_blk.bit_offset = 0;
- fadt->x_pm_tmr_blk.access_size = ACPI_ACCESS_SIZE_DWORD_ACCESS;
- fadt->x_pm_tmr_blk.addrl = fadt->pm_tmr_blk;
- fadt->x_pm_tmr_blk.addrh = 0x0;
-
- /* General-Purpose Event 0 Registers: ACPI 4.8.4.1 */
- fadt->gpe0_blk = gpe0_base;
- fadt->gpe0_blk_len = 4 * 2;
-
- fadt->x_gpe0_blk.space_id = ACPI_ADDRESS_SPACE_IO;
- fadt->x_gpe0_blk.bit_width = fadt->gpe0_blk_len * 8;
- fadt->x_gpe0_blk.bit_offset = 0;
- fadt->x_gpe0_blk.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
- fadt->x_gpe0_blk.addrl = fadt->gpe0_blk;
- fadt->x_gpe0_blk.addrh = 0x0;
-
- /* Display the base registers */
- printk(BIOS_SPEW, "FADT:\n");
- printk(BIOS_SPEW, " 0x%08x: GPE0_BASE\n", gpe0_base);
- printk(BIOS_SPEW, " 0x%08x: PMBASE\n", pmbase);
- printk(BIOS_SPEW, " 0x%08x: RESET\n", fadt->reset_reg.addrl);
-
-}
-
-uint16_t get_pmbase(void)
-{
- struct device *dev = pcidev_on_root(PCI_DEVICE_NUMBER_QNC_LPC,
- PCI_FUNCTION_NUMBER_QNC_LPC);
- return (uint16_t)pci_read_config32(dev, R_QNC_LPC_PM1BLK) & B_QNC_LPC_PM1BLK_MASK;
-}
diff --git a/src/soc/intel/quark/bootblock/bootblock.c b/src/soc/intel/quark/bootblock/bootblock.c
deleted file mode 100644
index 6b73d03bc0..0000000000
--- a/src/soc/intel/quark/bootblock/bootblock.c
+++ /dev/null
@@ -1,109 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-#include <bootblock_common.h>
-#include <console/console.h>
-#include <cpu/x86/mtrr.h>
-#include <device/pci_def.h>
-#include <program_loading.h>
-#include <soc/iomap.h>
-#include <soc/pci_devs.h>
-#include <soc/reg_access.h>
-
-extern asmlinkage void light_sd_led(void);
-
-static const struct reg_script legacy_gpio_init[] = {
- /* Temporarily enable the legacy GPIO controller */
- REG_PCI_WRITE32(R_QNC_LPC_GBA_BASE, IO_ADDRESS_VALID
- | LEGACY_GPIO_BASE_ADDRESS),
- /* Temporarily enable the GPE controller */
- REG_PCI_WRITE32(R_QNC_LPC_GPE0BLK, IO_ADDRESS_VALID
- | GPE0_BASE_ADDRESS),
- REG_PCI_OR8(PCI_COMMAND, PCI_COMMAND_IO),
- REG_SCRIPT_END
-};
-
-static const struct reg_script i2c_gpio_controller_init[] = {
- /* Temporarily enable the GPIO controller */
- REG_PCI_WRITE32(PCI_BASE_ADDRESS_0, I2C_BASE_ADDRESS),
- REG_PCI_WRITE32(PCI_BASE_ADDRESS_1, GPIO_BASE_ADDRESS),
- REG_PCI_OR8(PCI_COMMAND, PCI_COMMAND_MEMORY),
- REG_SCRIPT_END
-};
-
-static const struct reg_script hsuart_init[] = {
- /* Enable the HSUART */
- REG_PCI_WRITE32(PCI_BASE_ADDRESS_0, UART_BASE_ADDRESS),
- REG_PCI_OR8(PCI_COMMAND, PCI_COMMAND_MEMORY),
- REG_SCRIPT_END
-};
-
-static const struct reg_script mtrr_init[] = {
- /* Use write-through caching, for FSP 2.0 the cache will be invalidated
- * postchar (arch/x86/exit_car.S).
- */
-
- /* Enable the cache */
- REG_CPU_CR_AND(0, ~(CR0_CD | CR0_NW)),
-
- /* Cache the SPI flash */
- REG_MSR_WRITE(MTRR_PHYS_BASE(0), (uint32_t)((-CONFIG_ROM_SIZE)
- | MTRR_TYPE_WRTHROUGH)),
- REG_MSR_WRITE(MTRR_PHYS_MASK(0), (uint32_t)((-CONFIG_ROM_SIZE)
- | MTRR_PHYS_MASK_VALID)),
-
- /* Cache ESRAM */
- REG_MSR_WRITE(MTRR_PHYS_BASE(1), (uint32_t)(0x80000000
- | MTRR_TYPE_WRTHROUGH)),
- REG_MSR_WRITE(MTRR_PHYS_MASK(1), (uint32_t)((~0x7ffff)
- | MTRR_PHYS_MASK_VALID)),
-
- /* Enable the variable MTRRs */
- REG_MSR_WRITE(MTRR_DEF_TYPE_MSR, MTRR_DEF_TYPE_EN
- | MTRR_TYPE_UNCACHEABLE),
-
- REG_SCRIPT_END
-};
-
-asmlinkage void bootblock_c_entry(uint64_t base_timestamp)
-{
- if (CONFIG(ENABLE_DEBUG_LED_BOOTBLOCK_ENTRY))
- light_sd_led();
-
- bootblock_main_with_basetime(base_timestamp);
-}
-
-void bootblock_soc_early_init(void)
-{
- if (CONFIG(ENABLE_DEBUG_LED_SOC_EARLY_INIT_ENTRY))
- light_sd_led();
-
- /* Initialize the MTRRs */
- reg_script_run(mtrr_init);
-
- /* Initialize the controllers */
- reg_script_run_on_dev(I2CGPIO_BDF, i2c_gpio_controller_init);
- reg_script_run_on_dev(LPC_BDF, legacy_gpio_init);
-
- /* Enable the HSUART */
- if (CONFIG(ENABLE_BUILTIN_HSUART0))
- reg_script_run_on_dev(HSUART0_BDF, hsuart_init);
- if (CONFIG(ENABLE_BUILTIN_HSUART1))
- reg_script_run_on_dev(HSUART1_BDF, hsuart_init);
-
- if (CONFIG(ENABLE_DEBUG_LED_SOC_EARLY_INIT_EXIT))
- light_sd_led();
-}
-
-void bootblock_soc_init(void)
-{
- if (CONFIG(ENABLE_DEBUG_LED_SOC_INIT_ENTRY))
- light_sd_led();
-
- display_mtrrs();
-}
-
-void platform_prog_run(struct prog *prog)
-{
- /* Display the program entry point */
- printk(BIOS_SPEW, "Calling %s, %p(%p)\n", prog->name,
- prog->entry, prog->arg);
-}
diff --git a/src/soc/intel/quark/bootblock/esram_init.S b/src/soc/intel/quark/bootblock/esram_init.S
deleted file mode 100644
index 39ce7bd02d..0000000000
--- a/src/soc/intel/quark/bootblock/esram_init.S
+++ /dev/null
@@ -1,505 +0,0 @@
-/* SPDX-License-Identifier: BSD-3-Clause */
-
-#include <cpu/x86/cr.h>
-#include <cpu/x86/post_code.h>
-#include <soc/QuarkNcSocId.h>
-#include <soc/sd.h>
-
-.macro RET32
- jmp *%esp
-.endm
-
-/* ROM/SPI/MEMORY Definitions */
-.equ QUARK_DDR3_MEM_BASE_ADDRESS, (0x000000000) /* Memory Base Address = 0 */
-.equ QUARK_MAX_DDR3_MEM_SIZE_BYTES, (0x80000000) /* DDR3 Memory Size = 2GB */
-.equ QUARK_ESRAM_MEM_BASE_ADDRESS, (QUARK_DDR3_MEM_BASE_ADDRESS \
- + QUARK_MAX_DDR3_MEM_SIZE_BYTES) /* eSRAM Memory above DDR3 */
-.equ QUARK_ESRAM_MEM_SIZE_BYTES, (0x00080000) /* eSRAM Memory Size = 512K */
-.equ QUARK_STACK_SIZE_BYTES, (0x008000) /* Quark stack size = 32K */
-.equ QUARK_STACK_BASE_ADDRESS, (QUARK_ESRAM_MEM_BASE_ADDRESS \
- + QUARK_ESRAM_MEM_SIZE_BYTES \
- - QUARK_STACK_SIZE_BYTES) /* Top of eSRAM - stack size */
-.equ QUARK_CMH_SIZE_BYTES, (0x0400) /* Quark Module Header size */
-.equ QUARK_ESRAM_STAGE1_BASE_ADDRESS, (QUARK_ESRAM_MEM_BASE_ADDRESS \
- + QUARK_CMH_SIZE_BYTES) /* Start of Stage1 code in eSRAM */
-
-/* RTC/CMOS definitions */
-.equ RTC_INDEX, (0x70)
-.equ NMI_DISABLE, (0x80) /* Bit7=1 disables NMI */
-.equ RTC_DATA, (0x71)
-
-/* PCI Configuration definitions (Datasheet 5.5.1) */
-.equ PCI_CFG, (0x80000000) /* PCI configuration access mechanism */
-.equ PCI_ADDRESS_PORT, (0xCF8)
-.equ PCI_DATA_PORT, (0xCFC)
-
-/* Quark PCI devices */
-.equ HOST_BRIDGE_PFA, (0 << 11) /* B0:D0:F0 (Host Bridge) */
-.equ ILB_PFA, (0x1F << 11) /* B0:D31:F0 (Legacy Block) */
-
-/* ILB PCI Config Registers */
-.equ BDE, (0x0D4) /* BIOS Decode Enable register */
-.equ DECODE_ALL_REGIONS_ENABLE, (0xFF000000) /* Decode all BIOS ranges */
-
-/* iLB Reset Register */
-.equ ILB_RESET_REG, (0x0CF9)
-.equ CF9_WARM_RESET, (0x02)
-.equ CF9_COLD_RESET, (0x08)
-
-/* Memory Arbiter Config Registers */
-.equ AEC_CTRL_OFFSET, (0x00)
-
-/* Host Bridge Config Registers */
-.equ HMBOUND_OFFSET, (0x08)
-.equ HMBOUND_ADDRESS, (QUARK_DDR3_MEM_BASE_ADDRESS \
- + QUARK_MAX_DDR3_MEM_SIZE_BYTES + QUARK_ESRAM_MEM_SIZE_BYTES)
-.equ HECREG_OFFSET, (0x09)
-.equ EC_BASE, (0xE0000000)
-.equ EC_ENABLE, (0x01)
-
-/* Memory Manager Config Registers */
-.equ ESRAM_ADDRESS_2G, (0x10000080)
-.equ BIMRVCTL_OFFSET, (0x19)
-.equ ENABLE_IMR_INTERRUPT, (0x80000000)
-
-/* SOC UNIT Debug Registers */
-.equ CFGSTICKY_W1_OFFSET, (0x50)
-.equ FORCE_COLD_RESET, (0x00000001)
-.equ CFGSTICKY_RW_OFFSET, (0x51)
-.equ RESET_FOR_ESRAM_LOCK, (0x00000020)
-.equ RESET_FOR_HMBOUND_LOCK, (0x00000040)
-.equ CFGNONSTICKY_W1_OFFSET, (0x52)
-.equ FORCE_WARM_RESET, (0x00000001)
-
-.section .init, "ax", @progbits
-
- .global bootblock_pre_c_entry
-
-bootblock_pre_c_entry:
-
- /* Get the timestamp since code in bootblock_crt0.S requires
- * MMX register support.
- */
- rdtsc
- movl %eax, %ebp
- movl %edx, %edi
-
- /* Registers:
- * ebp: Low 32-bits of timestamp
- * edi: High 32-bits of timestamp
- */
-
-setup_esram:
- /* Ensure cache is disabled. */
- movl %cr0, %eax
- orl $(CR0_CD | CR0_NW), %eax
- invd
- movl %eax, %cr0
-
- /*
- * Disable NMI operation
- * Good convention suggests you should read back RTC data port after
- * accessing the RTC index port.
- */
- movb $(NMI_DISABLE), %al
- movw $(RTC_INDEX), %dx
- outb %al, %dx
- movw $(RTC_DATA), %dx
- inb %dx, %al
-
- /* Disable SMI (Disables SMI wire, not SMI messages) */
- movl $((QUARK_OPCODE_READ << QNC_MCR_OP_OFFSET) \
- | (QUARK_NC_HOST_BRIDGE_SB_PORT_ID << QNC_MCR_PORT_OFFSET) \
- | (QNC_MSG_FSBIC_REG_HMISC << QNC_MCR_REG_OFFSET)), %ecx
- leal L1, %esp
- jmp stackless_SideBand_Read
-L1:
- andl $(~SMI_EN), %eax
- movl $((QUARK_OPCODE_WRITE << QNC_MCR_OP_OFFSET) \
- | (QUARK_NC_HOST_BRIDGE_SB_PORT_ID << QNC_MCR_PORT_OFFSET) \
- | (QNC_MSG_FSBIC_REG_HMISC << QNC_MCR_REG_OFFSET)), %ecx
- leal L2, %esp
- jmp stackless_SideBand_Write
-L2:
-
- /*
- * Before we get going, check SOC Unit Registers to see if we are
- * required to issue a warm/cold reset
- */
- movl $((QUARK_ALT_OPCODE_READ << QNC_MCR_OP_OFFSET) \
- | (QUARK_SCSS_SOC_UNIT_SB_PORT_ID << QNC_MCR_PORT_OFFSET) \
- | (CFGNONSTICKY_W1_OFFSET << QNC_MCR_REG_OFFSET)), %ecx
- leal L3, %esp
- jmp stackless_SideBand_Read
-L3:
- andl $(FORCE_WARM_RESET), %eax
- jz TestForceColdReset /* No warm reset - branch */
- jmp IssueWarmReset
-
-TestForceColdReset:
- movl $((QUARK_ALT_OPCODE_READ << QNC_MCR_OP_OFFSET) \
- | (QUARK_SCSS_SOC_UNIT_SB_PORT_ID << QNC_MCR_PORT_OFFSET) \
- | (CFGNONSTICKY_W1_OFFSET << QNC_MCR_REG_OFFSET)), %ecx
- leal L4, %esp
- jmp stackless_SideBand_Read
-L4:
- andl $(FORCE_COLD_RESET), %eax
- jz TestHmboundLock /* No cold reset - branch */
- jmp IssueColdReset
-
- /* Before setting HMBOUND, check it's not locked */
-TestHmboundLock:
- movl $((QUARK_OPCODE_READ << QNC_MCR_OP_OFFSET) \
- | (QUARK_NC_HOST_BRIDGE_SB_PORT_ID << QNC_MCR_PORT_OFFSET) \
- | (HMBOUND_OFFSET << QNC_MCR_REG_OFFSET)), %ecx
- leal L5, %esp
- jmp stackless_SideBand_Read
-L5:
- andl $(HMBOUND_LOCK), %eax
- jz ConfigHmbound /* Good configuration - branch */
-
- /* Failed to config - store sticky bit debug */
- movl $((QUARK_ALT_OPCODE_READ << QNC_MCR_OP_OFFSET) \
- | (QUARK_SCSS_SOC_UNIT_SB_PORT_ID << QNC_MCR_PORT_OFFSET) \
- | (CFGSTICKY_RW_OFFSET << QNC_MCR_REG_OFFSET)), %ecx
- leal L6, %esp
- jmp stackless_SideBand_Read
-L6:
- orl $(RESET_FOR_HMBOUND_LOCK), %eax
- movl $((QUARK_ALT_OPCODE_WRITE << QNC_MCR_OP_OFFSET) \
- | (QUARK_SCSS_SOC_UNIT_SB_PORT_ID << QNC_MCR_PORT_OFFSET) \
- | (CFGSTICKY_RW_OFFSET << QNC_MCR_REG_OFFSET)), %ecx
- leal L7, %esp
- jmp stackless_SideBand_Write
-L7:
- jmp IssueWarmReset
-
- /* Set up the HMBOUND register */
-ConfigHmbound:
- movl $(HMBOUND_ADDRESS), %eax /* Data (Set HMBOUND location) */
- movl $((QUARK_OPCODE_WRITE << QNC_MCR_OP_OFFSET) \
- | (QUARK_NC_HOST_BRIDGE_SB_PORT_ID << QNC_MCR_PORT_OFFSET) \
- | (HMBOUND_OFFSET << QNC_MCR_REG_OFFSET)), %ecx
- leal L8, %esp
- jmp stackless_SideBand_Write
-L8:
-
- /*
- * Enable interrupts to Remote Management Unit when a IMR/SMM/HMBOUND
- * violation occurs.
- */
- movl $(ENABLE_IMR_INTERRUPT), %eax /* Set interrupt enable mask */
- movl $((QUARK_OPCODE_WRITE << QNC_MCR_OP_OFFSET) \
- | (QUARK_NC_MEMORY_MANAGER_SB_PORT_ID << QNC_MCR_PORT_OFFSET) \
- | (BIMRVCTL_OFFSET << QNC_MCR_REG_OFFSET)), %ecx
- leal L9, %esp
- jmp stackless_SideBand_Write
-L9:
-
- /* Move eSRAM memory to 2GB */
- movl $(ESRAM_ADDRESS_2G), %eax /* Data (Set eSRAM location) */
- movl $((QUARK_OPCODE_WRITE << QNC_MCR_OP_OFFSET) \
- | (QUARK_NC_MEMORY_MANAGER_SB_PORT_ID << QNC_MCR_PORT_OFFSET) \
- | (QUARK_NC_MEMORY_MANAGER_ESRAMPGCTRL_BLOCK \
- << QNC_MCR_REG_OFFSET)), %ecx
- leal L10, %esp
- jmp stackless_SideBand_Write
-L10:
-
- /* Check that we're not blocked from setting the config that we want. */
- movl $((QUARK_OPCODE_READ << QNC_MCR_OP_OFFSET) \
- | (QUARK_NC_MEMORY_MANAGER_SB_PORT_ID << QNC_MCR_PORT_OFFSET) \
- | (QUARK_NC_MEMORY_MANAGER_ESRAMPGCTRL_BLOCK \
- << QNC_MCR_REG_OFFSET)), %ecx
- leal L11, %esp
- jmp stackless_SideBand_Read
-L11:
- andl $(BLOCK_ENABLE_PG), %eax
- jnz ConfigPci /* Good configuration - branch */
-
- /* Failed to config - store sticky bit debug */
- movl $((QUARK_ALT_OPCODE_READ << QNC_MCR_OP_OFFSET) \
- | (QUARK_SCSS_SOC_UNIT_SB_PORT_ID << QNC_MCR_PORT_OFFSET) \
- | (CFGSTICKY_RW_OFFSET << QNC_MCR_REG_OFFSET)), %ecx
- leal L12, %esp
- jmp stackless_SideBand_Read
-L12:
- orl $(RESET_FOR_ESRAM_LOCK), %eax
- movl $((QUARK_ALT_OPCODE_WRITE << QNC_MCR_OP_OFFSET) \
- | (QUARK_SCSS_SOC_UNIT_SB_PORT_ID << QNC_MCR_PORT_OFFSET) \
- | (CFGSTICKY_RW_OFFSET << QNC_MCR_REG_OFFSET)), %ecx
- leal L13, %esp
- jmp stackless_SideBand_Write
-L13:
- jmp IssueWarmReset
-
- /* Enable PCIEXBAR */
-ConfigPci:
- movl $(EC_BASE + EC_ENABLE), %eax /* Data */
- movl $((QUARK_OPCODE_WRITE << QNC_MCR_OP_OFFSET) \
- | (QUARK_NC_MEMORY_ARBITER_SB_PORT_ID << QNC_MCR_PORT_OFFSET) \
- | (AEC_CTRL_OFFSET << QNC_MCR_REG_OFFSET)), %ecx
- leal L14, %esp
- jmp stackless_SideBand_Write
-L14:
-
- movl $(EC_BASE + EC_ENABLE), %eax /* Data */
- movl $((QUARK_OPCODE_WRITE << QNC_MCR_OP_OFFSET) \
- | (QUARK_NC_HOST_BRIDGE_SB_PORT_ID << QNC_MCR_PORT_OFFSET) \
- | (HECREG_OFFSET << QNC_MCR_REG_OFFSET)), %ecx
- leal L15, %esp
- jmp stackless_SideBand_Write
-L15:
-
- /* Open up full 8MB SPI decode */
- movl $(PCI_CFG | ILB_PFA | BDE), %ebx /* PCI config address */
- movl $(DECODE_ALL_REGIONS_ENABLE), %eax
- leal L16, %esp
- jmp stackless_PCIConfig_Write
-L16:
-
- jmp esram_init_done
-
-IssueWarmReset:
- /* Issue Warm Reset request to Remote Management Unit via iLB */
- movw $(CF9_WARM_RESET), %ax
- movw $(ILB_RESET_REG), %dx
- outw %ax, %dx
- jmp . /* Stay here until we are reset. */
-
-IssueColdReset:
- /* Issue Cold Reset request to Remote Management Unit via iLB */
- movw $(CF9_COLD_RESET), %ax
- movw $(ILB_RESET_REG), %dx
- outw %ax, %dx
- jmp . /* Stay here until we are reset. */
-
-/*
- *----------------------------------------------------------------------------
- *
- * Procedure: stackless_SideBand_Read
- *
- * Input: esp - return address
- * ecx[15:8] - Register offset
- * ecx[23:16] - Port ID
- * ecx[31:24] - Opcode
- *
- * Output: eax - Data read
- *
- * Destroys: eax
- * ebx
- * cl
- * esi
- *
- * Description:
- * Perform requested sideband read
- *----------------------------------------------------------------------------
- */
-
-stackless_SideBand_Read:
-
- movl %esp, %esi /* Save the return address */
-
- /* Load the SideBand Packet Register to generate the transaction */
- movl $(PCI_CFG | HOST_BRIDGE_PFA | QNC_ACCESS_PORT_MCR), %ebx
- movb $QNC_MCR_BYTE_ENABLES, %cl /* Set all Byte Enable bits */
- xchgl %ecx, %eax
- leal L17, %esp
- jmp stackless_PCIConfig_Write
-L17:
- xchgl %ecx, %eax
-
- /* Read the SideBand Data Register */
- movl $(PCI_CFG | HOST_BRIDGE_PFA | (QNC_ACCESS_PORT_MDR)), %ebx
- leal L18, %esp
- jmp stackless_PCIConfig_Read
-L18:
-
- movl %esi, %esp /* Restore the return address */
- RET32
-
-/*
- *----------------------------------------------------------------------------
- *
- * Procedure: stackless_SideBand_Write
- *
- * Input: esp - return address
- * eax - Data
- * ecx[15:8] - Register offset
- * ecx[23:16] - Port ID
- * ecx[31:24] - Opcode
- *
- * Output: None
- *
- * Destroys: ebx
- * cl
- * esi
- *
- * Description:
- * Perform requested sideband write
- *
- *----------------------------------------------------------------------------
- */
-
-stackless_SideBand_Write:
-
- movl %esp, %esi /* Save the return address */
-
- /* Load the SideBand Data Register with the data */
- movl $(PCI_CFG | HOST_BRIDGE_PFA | QNC_ACCESS_PORT_MDR), %ebx
- leal L19, %esp
- jmp stackless_PCIConfig_Write
-L19:
-
- /* Load the SideBand Packet Register to generate the transaction */
- movl $(PCI_CFG | HOST_BRIDGE_PFA | QNC_ACCESS_PORT_MCR), %ebx
- movb $QNC_MCR_BYTE_ENABLES, %cl /* Set all Byte Enable bits */
- xchgl %ecx, %eax
- leal L20, %esp
- jmp stackless_PCIConfig_Write
-L20:
- xchgl %ecx, %eax
-
- movl %esi, %esp /* Restore the return address */
- RET32
-
-/*
- *----------------------------------------------------------------------------
- *
- * Procedure: stackless_PCIConfig_Write
- *
- * Input: esp - return address
- * eax - Data to write
- * ebx - PCI Config Address
- *
- * Output: None
- *
- * Destroys: dx
- *
- * Description:
- * Perform a DWORD PCI Configuration write
- *
- *----------------------------------------------------------------------------
- */
-
-stackless_PCIConfig_Write:
-
- /* Write the PCI Config Address to the address port */
- xchgl %ebx, %eax
- movw $(PCI_ADDRESS_PORT), %dx
- outl %eax, %dx
- xchgl %ebx, %eax
-
- /* Write the PCI DWORD Data to the data port */
- movw $(PCI_DATA_PORT), %dx
- outl %eax, %dx
-
- RET32
-
-/*
- *----------------------------------------------------------------------------
- *
- * Procedure: stackless_PCIConfig_Read
- *
- * Input: esp - return address
- * ebx - PCI Config Address
- *
- * Output: eax - Data read
- *
- * Destroys: eax
- * dx
- *
- * Description:
- * Perform a DWORD PCI Configuration read
- *
- *----------------------------------------------------------------------------
- */
-
-stackless_PCIConfig_Read:
-
- /* Write the PCI Config Address to the address port */
- xchgl %ebx, %eax
- movw $(PCI_ADDRESS_PORT), %dx
- outl %eax, %dx
- xchgl %ebx, %eax
-
- /* Read the PCI DWORD Data from the data port */
- movw $(PCI_DATA_PORT), %dx
- inl %dx, %eax
-
- RET32
-
-/*----------------------------------------------------------------------------*/
-
-esram_init_done:
-
-#if CONFIG(ENABLE_DEBUG_LED)
-sd_led:
-
- /* Set the SDIO controller's base address */
- movl $(SD_BASE_ADDR), %eax
- movl $(SD_CFG_ADDR), %ebx
- leal L40, %esp
- jmp stackless_PCIConfig_Write
-
-L40:
- movl $(SD_CFG_ADDR), %ebx
- leal L41, %esp
- jmp stackless_PCIConfig_Read
-
-L41:
- /* Enable the SDIO controller */
- movl $(SD_CFG_CMD), %ebx
- leal L42, %esp
- jmp stackless_PCIConfig_Read
-
-L42:
- orl $2, %eax
- movl $(SD_CFG_CMD), %ebx
- leal L43, %esp
- jmp stackless_PCIConfig_Write
-
-L43:
- movl $(SD_CFG_CMD), %ebx
- leal L44, %esp
- jmp stackless_PCIConfig_Read
-
-L44:
-#if CONFIG(ENABLE_DEBUG_LED_ESRAM)
- jmp light_sd_led
-#endif /* CONFIG_ENABLE_DEBUG_LED_ESRAM */
-#endif /* CONFIG_ENABLE_DEBUG_LED */
-
- /* Registers:
- * ebp: Low 32-bits of timestamp
- * edi: High 32-bits of timestamp
- */
-
- /* Setup bootblock stack */
- movl $_ecar_stack, %esp
-
-before_carstage:
- post_code(0x2b)
-
- /* Get the timestamp passed in bootblock_crt0.S */
- push %edi
- push %ebp
-
- /* We can call into C functions now */
- call bootblock_c_entry
-
- /* Never reached */
-
- .global light_sd_led
-
-light_sd_led:
- /* Turn on SD LED to indicate ESRAM successfully initialized */
- movl $SD_HOST_CTRL, %ebx
- movb 0(%ebx), %al
- orb $1, %al
- movb %al, 0(%ebx)
-
- /* Loop forever */
-die:
- hlt
- jmp die
diff --git a/src/soc/intel/quark/chip.c b/src/soc/intel/quark/chip.c
deleted file mode 100644
index e613ced2cd..0000000000
--- a/src/soc/intel/quark/chip.c
+++ /dev/null
@@ -1,126 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <assert.h>
-#include <device/device.h>
-#include <soc/ramstage.h>
-#include <soc/reg_access.h>
-
-/* Cat Trip Clear value must be less than Cat Trip Set value */
-#define PLATFORM_CATASTROPHIC_TRIP_CELSIUS 105
-#define PLATFORM_CATASTROPHIC_CLEAR_CELSIUS 65
-
-static const struct reg_script thermal_init_script[] = {
-
- /* Setup RMU Thermal sensor registers for Ratiometric mode. */
- REG_SOC_UNIT_RMW(QUARK_SCSS_SOC_UNIT_TSCGF1_CONFIG,
- ~(B_TSCGF1_CONFIG_ISNSCURRENTSEL_MASK
- | B_TSCGF1_CONFIG_ISNSCHOPSEL_MASK
- | B_TSCGF1_CONFIG_ISNSINTERNALVREFEN
- | B_TSCGF1_CONFIG_IBGEN
- | B_TSCGF1_CONFIG_IBGCHOPEN),
- ((V_TSCGF1_CONFIG_ISNSCURRENTSEL_RATIO_MODE
- << B_TSCGF1_CONFIG_ISNSCURRENTSEL_BP)
- | (V_TSCGF1_CONFIG_ISNSCHOPSEL_RATIO_MODE
- << B_TSCGF1_CONFIG_ISNSCHOPSEL_BP)
- | (V_TSCGF1_CONFIG_ISNSINTERNALVREFEN_RATIO_MODE
- << B_TSCGF1_CONFIG_ISNSINTERNALVREFEN_BP)
- | (V_TSCGF1_CONFIG_IBGEN_RATIO_MODE
- << B_TSCGF1_CONFIG_IBGEN_BP)
- | (V_TSCGF1_CONFIG_IBGCHOPEN_RATIO_MODE
- << B_TSCGF1_CONFIG_IBGCHOPEN_BP))),
-
- REG_SOC_UNIT_RMW(QUARK_SCSS_SOC_UNIT_TSCGF2_CONFIG2,
- ~(B_TSCGF2_CONFIG2_ICALCONFIGSEL_MASK
- | B_TSCGF2_CONFIG2_ISPARECTRL_MASK
- | B_TSCGF2_CONFIG2_ICALCOARSETUNE_MASK),
- ((V_TSCGF2_CONFIG2_ICALCONFIGSEL_RATIO_MODE
- << B_TSCGF2_CONFIG2_ICALCONFIGSEL_BP)
- | (V_TSCGF2_CONFIG2_ISPARECTRL_RATIO_MODE
- << B_TSCGF2_CONFIG2_ISPARECTRL_BP)
- | (V_TSCGF2_CONFIG2_ICALCOARSETUNE_RATIO_MODE
- << B_TSCGF2_CONFIG2_ICALCOARSETUNE_BP))),
-
- REG_SOC_UNIT_RMW(QUARK_SCSS_SOC_UNIT_TSCGF2_CONFIG,
- ~(B_TSCGF2_CONFIG_IDSCONTROL_MASK
- | B_TSCGF2_CONFIG_IDSTIMING_MASK),
- ((V_TSCGF2_CONFIG_IDSCONTROL_RATIO_MODE
- << B_TSCGF2_CONFIG_IDSCONTROL_BP)
- | (V_TSCGF2_CONFIG_IDSTIMING_RATIO_MODE
- << B_TSCGF2_CONFIG_IDSTIMING_BP))),
-
- REG_SOC_UNIT_RMW(QUARK_SCSS_SOC_UNIT_TSCGF3_CONFIG,
- ~B_TSCGF3_CONFIG_ITSGAMMACOEFF_MASK,
- V_TSCGF3_CONFIG_ITSGAMMACOEFF_RATIO_MODE
- << B_TSCGF3_CONFIG_ITSGAMMACOEFF_BP),
-
- /* Enable RMU Thermal sensor with a Catastrophic Trip point. */
-
- /* Set up Catastrophic Trip point.
- *
- * Trip Register fields are 8-bit temperature values of granularity 1
- * degree C where 0x00 corresponds to -50 degrees C and 0xFF corresponds
- * to 205 degrees C.
- *
- * Add 50 to Celsius values to get values for register fields.
- */
- REG_RMU_TEMP_RMW(QUARK_NC_RMU_REG_TS_TRIP,
- ~(TS_CAT_TRIP_SET_THOLD_MASK | TS_CAT_TRIP_CLEAR_THOLD_MASK),
- (((PLATFORM_CATASTROPHIC_TRIP_CELSIUS + 50)
- << TS_CAT_TRIP_SET_THOLD_BP)
- | ((PLATFORM_CATASTROPHIC_CLEAR_CELSIUS + 50)
- << TS_CAT_TRIP_CLEAR_THOLD_BP))),
-
- /* To enable the TS do the following:
- * 1) Take the TS out of reset by setting itsrst to 0x0.
- * 2) Enable the TS using RMU Thermal sensor mode register.
- */
- REG_SOC_UNIT_AND(QUARK_SCSS_SOC_UNIT_TSCGF3_CONFIG,
- ~B_TSCGF3_CONFIG_ITSRST),
- REG_RMU_TEMP_OR(QUARK_NC_RMU_REG_TS_MODE, TS_ENABLE),
-
- /* Lock all RMU Thermal sensor control & trip point registers. */
- REG_RMU_TEMP_OR(QUARK_NC_RMU_REG_CONFIG, TS_LOCK_THRM_CTRL_REGS_ENABLE
- | TS_LOCK_AUX_TRIP_PT_REGS_ENABLE),
- REG_SCRIPT_END
-};
-
-static void chip_init(void *chip_info)
-{
- /* Validate the temperature settings */
- ASSERT(PLATFORM_CATASTROPHIC_TRIP_CELSIUS <= 255);
- ASSERT(PLATFORM_CATASTROPHIC_TRIP_CELSIUS
- > PLATFORM_CATASTROPHIC_CLEAR_CELSIUS);
-
- /* Set the temperature settings */
- reg_script_run(thermal_init_script);
-
- /* Verify that the thermal configuration is locked */
- ASSERT((reg_rmu_temp_read(QUARK_NC_RMU_REG_CONFIG)
- & (TS_LOCK_THRM_CTRL_REGS_ENABLE
- | TS_LOCK_AUX_TRIP_PT_REGS_ENABLE))
- == (TS_LOCK_THRM_CTRL_REGS_ENABLE
- | TS_LOCK_AUX_TRIP_PT_REGS_ENABLE));
-
- /* Perform silicon specific init. */
- fsp_silicon_init();
-}
-
-static struct device_operations pci_domain_ops = {
- .read_resources = pci_domain_read_resources,
- .set_resources = pci_domain_set_resources,
- .scan_bus = pci_domain_scan_bus,
-};
-
-static void chip_enable_dev(struct device *dev)
-{
-
- /* Set the operations if it is a special bus type */
- if (dev->path.type == DEVICE_PATH_DOMAIN)
- dev->ops = &pci_domain_ops;
-}
-
-struct chip_operations soc_intel_quark_ops = {
- CHIP_NAME("Intel Quark")
- .init = &chip_init,
- .enable_dev = chip_enable_dev,
-};
diff --git a/src/soc/intel/quark/chip.h b/src/soc/intel/quark/chip.h
deleted file mode 100644
index 7308712180..0000000000
--- a/src/soc/intel/quark/chip.h
+++ /dev/null
@@ -1,101 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#ifndef _SOC_CHIP_H_
-#define _SOC_CHIP_H_
-
-#include <stdint.h>
-#include <fsp/util.h>
-#include <soc/pci_devs.h>
-#include <soc/pm.h>
-
-///
-/// MRC Flags bits
-///
-#define MRC_FLAG_ECC_EN BIT0
-#define MRC_FLAG_SCRAMBLE_EN BIT1
-#define MRC_FLAG_MEMTEST_EN BIT2
-
-/* 0b DDR "fly-by" topology else 1b DDR "tree" topology */
-#define MRC_FLAG_TOP_TREE_EN BIT3
-
-/* If set ODR signal is asserted to DRAM devices on writes */
-#define MRC_FLAG_WR_ODT_EN BIT4
-
-struct soc_intel_quark_config {
- /*
- * MemoryInit:
- *
- * The following fields come from FspUpdVpd.h and are defined as PCDs
- * for the FSP binary. Data for these fields comes from the board's
- * devicetree.cb file which gets processed into static.c and then
- * built into the coreboot image. The fields below contain retain
- * the FSP PCD field name.
- */
-
- uint32_t FspReservedMemoryLength; /* FSP reserved memory in bytes */
-
- uint32_t Flags; /* Bitmap of MRC_FLAG_XXX defs above */
- uint32_t tRAS; /* ACT to PRE command period in picoseconds */
-
- /* Delay from start of internal write transaction to internal read
- * command in picoseconds
- */
- uint32_t tWTR;
-
- /* ACT to ACT command period (JESD79 specific to page size 1K/2K) in
- * picoseconds
- */
- uint32_t tRRD;
-
- /* Four activate window (JESD79 specific to page size 1K/2K) in
- * picoseconds
- */
- uint32_t tFAW;
- uint8_t DramWidth; /* 0=x8, 1=x16, others=RESERVED */
-
- /* 0=DDRFREQ_800, 1=DDRFREQ_1066, others=RESERVED. Only 533MHz SKU
- * support 1066 memory
- */
- uint8_t DramSpeed;
- uint8_t DramType; /* 0=DDR3,1=DDR3L, others=RESERVED */
-
- /* bit[0] RANK0_EN, bit[1] RANK1_EN, others=RESERVED */
- uint8_t RankMask;
- uint8_t ChanMask; /* bit[0] CHAN0_EN, others=RESERVED */
- uint8_t ChanWidth; /* 1=x16, others=RESERVED */
-
- /* 0, 1, 2 (mode 2 forced if ecc enabled), others=RESERVED */
- uint8_t AddrMode;
-
- /* 1=1.95us, 2=3.9us, 3=7.8us, others=RESERVED. REFRESH_RATE */
- uint8_t SrInt;
- uint8_t SrTemp; /* 0=normal, 1=extended, others=RESERVED */
-
- /* 0=34ohm, 1=40ohm, others=RESERVED. RON_VALUE Select MRS1.DIC driver
- * impedance control.
- */
- uint8_t DramRonVal;
- uint8_t DramRttNomVal; /* 0=40ohm, 1=60ohm, 2=120ohm, others=RSVD */
- uint8_t DramRttWrVal; /* 0=off others=RESERVED */
-
- /* 0=off, 1=60ohm, 2=120ohm, 3=180ohm, others=RESERVED */
- uint8_t SocRdOdtVal;
- uint8_t SocWrRonVal; /* 0=27ohm, 1=32ohm, 2=40ohm, others=RESERVED */
- uint8_t SocWrSlewRate; /* 0=2.5V/ns, 1=4V/ns, others=RESERVED */
-
- /* 0=512Mb, 1=1Gb, 2=2Gb, 3=4Gb, others=RESERVED */
- uint8_t DramDensity;
- uint8_t tCL; /* DRAM CAS Latency in clocks */
-
- /* ECC scrub interval in milliseconds 1..255 (0 works as feature
- * disable)
- */
- uint8_t EccScrubInterval;
-
- /* Number of 32B blocks read for ECC scrub 2..16 */
- uint8_t EccScrubBlkSize;
-
- uint8_t SmmTsegSize; /* SMM size in MiB */
-};
-
-#endif
diff --git a/src/soc/intel/quark/ehci.c b/src/soc/intel/quark/ehci.c
deleted file mode 100644
index 3005610439..0000000000
--- a/src/soc/intel/quark/ehci.c
+++ /dev/null
@@ -1,119 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <console/console.h>
-#include <device/pci_ids.h>
-#include <soc/pci_devs.h>
-#include <soc/reg_access.h>
-
-/* USB Phy Registers */
-#define USB2_GLOBAL_PORT 0x4001
-#define USB2_PLL1 0x7F02
-#define USB2_PLL2 0x7F03
-#define USB2_COMPBG 0x7F04
-
-/* EHCI Packet Buffer OUT/IN Thresholds, values in number of DWORDs */
-#define EHCI_OUT_THRESHOLD_VALUE 0x7f
-#define EHCI_IN_THRESHOLD_VALUE 0x7f
-
-/* Platform init USB device interrupt masks */
-#define V_IOH_USBDEVICE_D_INTR_MSK_UDC_REG (0x0000007f)
-#define V_IOH_USBDEVICE_EP_INTR_MSK_UDC_REG \
- (B_IOH_USBDEVICE_EP_INTR_MSK_UDC_REG_OUT_EP_MASK \
- | B_IOH_USBDEVICE_EP_INTR_MSK_UDC_REG_IN_EP_MASK)
-
-/* In order to configure the USB PHY to use clk120 (ickusbcoreclk) as PLL
- * reference clock and Port2 as a USB device port, the following sequence must
- * be followed
- */
-static const struct reg_script ehci_init_script[] = {
-
- /* Set packet buffer OUT/IN thresholds */
- REG_MMIO_RMW32(R_IOH_EHCI_INSNREG01,
- ~(B_IOH_EHCI_INSNREG01_OUT_THRESHOLD_MASK
- | B_IOH_EHCI_INSNREG01_IN_THRESHOLD_MASK),
- (EHCI_OUT_THRESHOLD_VALUE
- << B_IOH_EHCI_INSNREG01_OUT_THRESHOLD_BP)
- | (EHCI_IN_THRESHOLD_VALUE
- << B_IOH_EHCI_INSNREG01_IN_THRESHOLD_BP)),
-
- /* Sighting #4930631 PDNRESCFG [8:7] of USB2_GLOBAL_PORT = 11b.
- * For port 0 & 1 as host and port 2 as device.
- */
- REG_USB_RXW(USB2_GLOBAL_PORT, ~(BIT8 | BIT7 | BIT1), (BIT8 | BIT7)),
-
- /*
- * Sighting #4930653 Required BIOS change on Disconnect vref to change
- * to 600mV.
- */
- REG_USB_RXW(USB2_COMPBG, ~(BIT10 | BIT9 | BIT8 | BIT7),
- (BIT10 | BIT7)),
-
- /* Sideband register write to USB AFE (Phy)
- * (pllbypass) to bypass/Disable PLL before switch
- */
- REG_USB_OR(USB2_PLL2, BIT29),
-
- /* Sideband register write to USB AFE (Phy)
- * (coreclksel) to select 120MHz (ickusbcoreclk) clk source.
- * (Default 0 to select 96MHz (ickusbclk96_npad/ppad))
- */
- REG_USB_OR(USB2_PLL1, BIT1),
-
- /* Sideband register write to USB AFE (Phy)
- * (divide by 8) to achieve internal 480MHz clock
- * for 120MHz input refclk. (Default: 4'b1000 (divide by 10) for 96MHz)
- */
- REG_USB_RXW(USB2_PLL1, ~(BIT6 | BIT5 | BIT4 | BIT3), BIT6),
-
- /* Sideband register write to USB AFE (Phy)
- * Clear (pllbypass)
- */
- REG_USB_AND(USB2_PLL2, ~BIT29),
-
- /* Sideband register write to USB AFE (Phy)
- * Set (startlock) to force the PLL FSM to restart the lock
- * sequence due to input clock/freq switch.
- */
- REG_USB_OR(USB2_PLL2, BIT24),
- REG_SCRIPT_END
-};
-
-static const struct reg_script usb_device_port_init_script[] = {
-
- /* Mask and clear controller interrupts */
- REG_MMIO_WRITE32(R_IOH_USBDEVICE_D_INTR_MSK_UDC_REG,
- V_IOH_USBDEVICE_D_INTR_MSK_UDC_REG),
- REG_MMIO_WRITE32(R_IOH_USBDEVICE_D_INTR_UDC_REG,
- V_IOH_USBDEVICE_D_INTR_MSK_UDC_REG),
-
- /* Mask and clear end point interrupts */
- REG_MMIO_WRITE32(R_IOH_USBDEVICE_EP_INTR_MSK_UDC_REG,
- V_IOH_USBDEVICE_EP_INTR_MSK_UDC_REG),
- REG_MMIO_WRITE32(R_IOH_USBDEVICE_EP_INTR_UDC_REG,
- V_IOH_USBDEVICE_EP_INTR_MSK_UDC_REG),
- REG_SCRIPT_END
-};
-
-static void init(struct device *dev)
-{
- if ((dev->path.pci.devfn & 7) == EHCI_FUNC) {
- printk(BIOS_INFO, "Initializing USB PLLs\n");
- reg_script_run_on_dev(dev, ehci_init_script);
- } else {
- printk(BIOS_INFO, "Initializing USB device port\n");
- reg_script_run_on_dev(dev, usb_device_port_init_script);
- }
-}
-
-static struct device_operations device_ops = {
- .read_resources = pci_dev_read_resources,
- .set_resources = pci_dev_set_resources,
- .enable_resources = pci_dev_enable_resources,
- .init = init,
-};
-
-static const struct pci_driver driver __pci_driver = {
- .ops = &device_ops,
- .vendor = PCI_VID_INTEL,
- .device = EHCI_DEVID,
-};
diff --git a/src/soc/intel/quark/fsp_params.c b/src/soc/intel/quark/fsp_params.c
deleted file mode 100644
index 86fd1e9489..0000000000
--- a/src/soc/intel/quark/fsp_params.c
+++ /dev/null
@@ -1,12 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <fsp/util.h>
-#include <soc/ramstage.h>
-
-void platform_fsp_silicon_init_params_cb(FSPS_UPD *silupd)
-{
-}
-
-asmlinkage void chipset_teardown_car(void)
-{
-}
diff --git a/src/soc/intel/quark/gpio_i2c.c b/src/soc/intel/quark/gpio_i2c.c
deleted file mode 100644
index 4910f1b8c6..0000000000
--- a/src/soc/intel/quark/gpio_i2c.c
+++ /dev/null
@@ -1,29 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <console/console.h>
-#include <device/device.h>
-#include <device/i2c_simple.h>
-#include <device/pci.h>
-#include <device/pci_ids.h>
-#include <soc/i2c.h>
-#include <soc/ramstage.h>
-#include <soc/reg_access.h>
-
-__weak void mainboard_gpio_i2c_init(struct device *dev)
-{
- /* Initialize any of the GPIOs or I2C devices */
- printk(BIOS_SPEW, "WEAK; %s\n", __func__);
-}
-
-static struct device_operations device_ops = {
- .read_resources = pci_dev_read_resources,
- .set_resources = pci_dev_set_resources,
- .enable_resources = pci_dev_enable_resources,
- .init = mainboard_gpio_i2c_init,
-};
-
-static const struct pci_driver gfx_driver __pci_driver = {
- .ops = &device_ops,
- .vendor = PCI_VID_INTEL,
- .device = I2CGPIO_DEVID,
-};
diff --git a/src/soc/intel/quark/i2c.c b/src/soc/intel/quark/i2c.c
deleted file mode 100644
index 42ca25dbd9..0000000000
--- a/src/soc/intel/quark/i2c.c
+++ /dev/null
@@ -1,357 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <assert.h>
-#include <commonlib/helpers.h>
-#include <console/console.h>
-#include <delay.h>
-#include <device/device.h>
-#include <device/i2c_simple.h>
-#include <device/pci.h>
-#include <soc/i2c.h>
-#include <soc/ramstage.h>
-#include <soc/reg_access.h>
-#include <timer.h>
-
-static void i2c_disable(I2C_REGS *regs)
-{
- uint32_t status;
- uint32_t timeout;
-
- /* Disable I2C controller */
- regs->ic_enable = 0;
-
- /* Wait for the enable bit to clear */
- timeout = 1 * 1000 * 1000;
- status = regs->ic_enable_status;
- while (status & IC_ENABLE_CONTROLLER) {
- udelay(1);
- if (--timeout == 0)
- die_with_post_code(POST_HW_INIT_FAILURE,
- "ERROR - I2C failed to disable!\n");
- status = regs->ic_enable_status;
- }
-
- /* Clear any pending interrupts */
- status = regs->ic_clr_intr;
-}
-
-static int platform_i2c_write(uint32_t restart, uint8_t *tx_buffer, int length,
- uint32_t stop, uint8_t *rx_buffer, struct stopwatch *timeout)
-{
- int bytes_transferred;
- uint32_t cmd;
- I2C_REGS *regs;
- uint32_t status;
-
- ASSERT(tx_buffer != NULL);
- ASSERT(timeout != NULL);
- regs = get_i2c_address();
-
- /* Fill the FIFO with the write operation */
- bytes_transferred = 0;
- do {
- status = regs->ic_raw_intr_stat;
-
- /* Check for errors */
- if (status & (IC_INTR_RX_OVER | IC_INTR_RX_UNDER
- | IC_INTR_TX_ABRT | IC_INTR_TX_OVER)) {
- i2c_disable(regs);
- if (CONFIG(I2C_DEBUG))
- printk(BIOS_ERR,
- "0x%08x: ic_raw_intr_stat, I2C write error!\n",
- status);
- return -1;
- }
-
- /* Check for timeout */
- if (stopwatch_expired(timeout)) {
- if (CONFIG(I2C_DEBUG))
- printk(BIOS_ERR,
- "0x%08x: ic_raw_intr_stat, I2C write timeout!\n",
- status);
- return -1;
- }
-
- /* Receive any available data */
- status = regs->ic_status;
- if (rx_buffer != NULL) {
- while (status & IC_STATUS_RFNE) {
- *rx_buffer++ = (uint8_t)regs->ic_data_cmd;
- bytes_transferred++;
- status = regs->ic_status;
- }
- }
-
- /* Determine if space is available in the FIFO */
- if (status & IC_STATUS_TFNF) {
- /* End of the transaction? */
- cmd = IC_DATA_CMD_WRITE | *tx_buffer++ | restart;
- if (length == 1)
- cmd |= stop;
- restart = 0;
-
- /* Place a data byte into the FIFO */
- regs->ic_data_cmd = cmd;
- length--;
- bytes_transferred++;
- } else
- udelay(1);
- } while (length > 0);
- return bytes_transferred;
-}
-
-static int platform_i2c_read(uint32_t restart, uint8_t *rx_buffer, int length,
- uint32_t stop, struct stopwatch *timeout)
-{
- int bytes_transferred;
- uint32_t cmd;
- int fifo_bytes;
- I2C_REGS *regs;
- uint32_t status;
-
- ASSERT(rx_buffer != NULL);
- ASSERT(timeout != NULL);
- regs = get_i2c_address();
-
- /* Empty the FIFO */
- status = regs->ic_status;
- while (status & IC_STATUS_RFNE) {
- (void)regs->ic_data_cmd;
- status = regs->ic_status;
- }
-
- /* Fill the FIFO with read commands */
- fifo_bytes = MIN(length, 16);
- bytes_transferred = 0;
- while (length > 0) {
- status = regs->ic_raw_intr_stat;
-
- /* Check for errors */
- if (status & (IC_INTR_RX_OVER | IC_INTR_RX_UNDER
- | IC_INTR_TX_ABRT | IC_INTR_TX_OVER)) {
- i2c_disable(regs);
- if (CONFIG(I2C_DEBUG))
- printk(BIOS_ERR,
- "0x%08x: ic_raw_intr_stat, I2C read error!\n",
- status);
- return -1;
- }
-
- /* Check for timeout */
- if (stopwatch_expired(timeout)) {
- if (CONFIG(I2C_DEBUG))
- printk(BIOS_ERR,
- "0x%08x: ic_raw_intr_stat, I2C read timeout!\n",
- status);
- return -1;
- }
-
- /* Receive any available data */
- status = regs->ic_status;
- if (status & IC_STATUS_RFNE) {
- /* Save the next data byte, removed from the RX FIFO */
- *rx_buffer++ = (uint8_t)regs->ic_data_cmd;
- bytes_transferred++;
- }
-
- if ((status & IC_STATUS_TFNF)
- || ((status & IC_STATUS_RFNE) && (fifo_bytes > 0))) {
- /* End of the transaction? */
- cmd = IC_DATA_CMD_READ | restart;
- if (length == 1)
- cmd |= stop;
- restart = 0;
-
- /* Place a read command into the TX FIFO */
- regs->ic_data_cmd = cmd;
- if (fifo_bytes > 0)
- fifo_bytes--;
- length--;
- } else
- udelay(1);
- }
- return bytes_transferred;
-}
-
-int platform_i2c_transfer(unsigned int bus, struct i2c_msg *segment,
- int seg_count)
-{
- int bytes_transferred;
- uint8_t chip;
- uint32_t cmd;
- int data_bytes;
- int index;
- int length;
- I2C_REGS *regs;
- uint32_t restart;
- uint8_t *rx_buffer;
- uint32_t status;
- uint32_t stop;
- struct stopwatch timeout;
- int total_bytes;
- uint8_t *tx_buffer;
- int tx_bytes;
-
- if (CONFIG(I2C_DEBUG)) {
- for (index = 0; index < seg_count;) {
- if (index == 0)
- printk(BIOS_ERR, "I2C Start\n");
- printk(BIOS_ERR,
- "I2C segment[%d]: %s 0x%02x %s %p, 0x%08x bytes\n",
- index,
- (segment[index].flags & I2C_M_RD) ? "Read from" : "Write to",
- segment[index].slave,
- (segment[index].flags & I2C_M_RD) ? "to " : "from",
- segment[index].buf,
- segment[index].len);
- printk(BIOS_ERR, "I2C %s\n",
- (++index >= seg_count) ? "Stop" : "Restart");
- }
- }
-
- regs = get_i2c_address();
-
- /* Disable the I2C controller to get access to the registers */
- i2c_disable(regs);
-
- /* Set the slave address */
- ASSERT(seg_count > 0);
- ASSERT(segment != NULL);
-
- /* Clear the start and stop detection */
- status = regs->ic_clr_start_det;
- status = regs->ic_clr_stop_det;
-
- /* Set addressing mode to 7-bit and fast mode */
- cmd = regs->ic_con;
- cmd &= ~(IC_CON_10B | IC_CON_SPEED);
- cmd |= IC_CON_RESTART_EN | IC_CON_7B | IC_CON_SPEED_400_KHz
- | IC_CON_MASTER_MODE;
- regs->ic_con = cmd;
-
- /* Set the target chip address */
- chip = segment->slave;
- regs->ic_tar = chip;
-
- /* Enable the I2C controller */
- regs->ic_enable = IC_ENABLE_CONTROLLER;
-
- /* Clear the interrupts */
- status = regs->ic_clr_rx_under;
- status = regs->ic_clr_rx_over;
- status = regs->ic_clr_tx_over;
- status = regs->ic_clr_tx_abrt;
-
- /* Start the timeout */
- stopwatch_init_usecs_expire(&timeout, CONFIG_I2C_TRANSFER_TIMEOUT_US);
-
- /* Process each of the segments */
- total_bytes = 0;
- tx_bytes = 0;
- bytes_transferred = 0;
- rx_buffer = NULL;
- restart = 0;
- index = 0;
- while (index++ < seg_count) {
- length = segment->len;
- total_bytes += length;
- ASSERT(segment->buf != NULL);
- ASSERT(length >= 1);
- ASSERT(segment->slave == chip);
-
- /* Determine if this is the last segment of the transaction */
- stop = (index == seg_count) ? IC_DATA_CMD_STOP : 0;
-
- /* Fill the FIFO with the necessary command bytes */
- if (segment->flags & I2C_M_RD) {
- /* Place read commands into the FIFO */
- rx_buffer = segment->buf;
- data_bytes = platform_i2c_read(restart, rx_buffer,
- length, stop, &timeout);
-
- /* Return any detected error */
- if (data_bytes < 0) {
- if (CONFIG(I2C_DEBUG))
- printk(BIOS_ERR,
- "I2C segment[%d] failed\n",
- index);
- return data_bytes;
- }
- bytes_transferred += data_bytes;
- } else {
- /* Write the data into the FIFO */
- tx_buffer = segment->buf;
- tx_bytes += length;
- data_bytes = platform_i2c_write(restart, tx_buffer,
- length, stop, rx_buffer, &timeout);
-
- /* Return any detected error */
- if (data_bytes < 0) {
- if (CONFIG(I2C_DEBUG))
- printk(BIOS_ERR,
- "I2C segment[%d] failed\n",
- index);
- return data_bytes;
- }
- bytes_transferred += data_bytes;
- }
- segment++;
- restart = IC_DATA_CMD_RESTART;
- }
-
- /* Wait for the end of the transaction */
- if (rx_buffer != NULL)
- rx_buffer += bytes_transferred - tx_bytes;
- do {
- /* Receive any available data */
- status = regs->ic_status;
- if ((rx_buffer != NULL) && (status & IC_STATUS_RFNE)) {
- *rx_buffer++ = (uint8_t)regs->ic_data_cmd;
- bytes_transferred++;
- } else {
- status = regs->ic_raw_intr_stat;
- if ((total_bytes == bytes_transferred)
- && (status & IC_INTR_STOP_DET))
- break;
-
- /* Check for errors */
- if (status & (IC_INTR_RX_OVER | IC_INTR_RX_UNDER
- | IC_INTR_TX_ABRT | IC_INTR_TX_OVER)) {
- i2c_disable(regs);
- if (CONFIG(I2C_DEBUG)) {
- printk(BIOS_ERR,
- "0x%08x: ic_raw_intr_stat, I2C read error!\n",
- status);
- printk(BIOS_ERR,
- "I2C segment[%d] failed\n",
- seg_count - 1);
- }
- return -1;
- }
-
- /* Check for timeout */
- if (stopwatch_expired(&timeout)) {
- if (CONFIG(I2C_DEBUG)) {
- printk(BIOS_ERR,
- "0x%08x: ic_raw_intr_stat, I2C read timeout!\n",
- status);
- printk(BIOS_ERR,
- "I2C segment[%d] failed\n",
- seg_count - 1);
- }
- return -1;
- }
-
- /* Delay for a while */
- udelay(1);
- }
- } while (1);
- i2c_disable(regs);
- regs->ic_tar = 0;
-
- /* Return the number of bytes transferred */
- if (CONFIG(I2C_DEBUG))
- printk(BIOS_ERR, "0x%08x: bytes transferred\n",
- bytes_transferred);
- return bytes_transferred;
-}
diff --git a/src/soc/intel/quark/include/soc/IntelQNCConfig.h b/src/soc/intel/quark/include/soc/IntelQNCConfig.h
deleted file mode 100644
index 411f75a2ea..0000000000
--- a/src/soc/intel/quark/include/soc/IntelQNCConfig.h
+++ /dev/null
@@ -1,61 +0,0 @@
-/* SPDX-License-Identifier: BSD-2-Clause */
-/* Some configuration of QNC Package */
-
-#ifndef __INTEL_QNC_CONFIG_H__
-#define __INTEL_QNC_CONFIG_H__
-
-//
-// QNC Fixed configurations.
-//
-
-//
-// Memory arbiter fixed config values.
-//
-#define QNC_FIXED_CONFIG_ASTATUS ((UINT32) (\
- (ASTATUS_PRI_NORMAL << ASTATUS0_DEFAULT_BP) | \
- (ASTATUS_PRI_NORMAL << ASTATUS1_DEFAULT_BP) | \
- (ASTATUS_PRI_URGENT << ASTATUS0_RASISED_BP) | \
- (ASTATUS_PRI_URGENT << ASTATUS1_RASISED_BP) \
- ))
-
-//
-// Memory Manager fixed config values.
-//
-#define V_DRAM_NON_HOST_RQ_LIMIT 2
-
-//
-// RMU Thermal config fixed config values for TS in Vref Mode.
-//
-#define V_TSCGF1_CONFIG_ISNSCURRENTSEL_VREF_MODE 0x04
-#define V_TSCGF2_CONFIG2_ISPARECTRL_VREF_MODE 0x01
-#define V_TSCGF1_CONFIG_IBGEN_VREF_MODE 1
-#define V_TSCGF2_CONFIG_IDSCONTROL_VREF_MODE 0x011b
-#define V_TSCGF2_CONFIG2_ICALCOARSETUNE_VREF_MODE 0x34
-
-//
-// RMU Thermal config fixed config values for TS in Ratiometric mode.
-//
-#define V_TSCGF1_CONFIG_ISNSCURRENTSEL_RATIO_MODE 0x04
-#define V_TSCGF1_CONFIG_ISNSCHOPSEL_RATIO_MODE 0x02
-#define V_TSCGF1_CONFIG_ISNSINTERNALVREFEN_RATIO_MODE 1
-#define V_TSCGF2_CONFIG_IDSCONTROL_RATIO_MODE 0x011f
-#define V_TSCGF2_CONFIG_IDSTIMING_RATIO_MODE 0x0001
-#define V_TSCGF2_CONFIG2_ICALCONFIGSEL_RATIO_MODE 0x01
-#define V_TSCGF2_CONFIG2_ISPARECTRL_RATIO_MODE 0x00
-#define V_TSCGF1_CONFIG_IBGEN_RATIO_MODE 0
-#define V_TSCGF1_CONFIG_IBGCHOPEN_RATIO_MODE 0
-#define V_TSCGF3_CONFIG_ITSGAMMACOEFF_RATIO_MODE 0xC8
-#define V_TSCGF2_CONFIG2_ICALCOARSETUNE_RATIO_MODE 0x17
-
-//
-// iCLK fixed config values.
-//
-#define V_MUXTOP_FLEX2 3
-#define V_MUXTOP_FLEX1 1
-
-//
-// PCIe Root Port fixed config values.
-//
-#define V_PCIE_ROOT_PORT_SBIC_VALUE (B_QNC_PCIE_IOSFSBCTL_SBIC_IDLE_NEVER)
-
-#endif
diff --git a/src/soc/intel/quark/include/soc/Ioh.h b/src/soc/intel/quark/include/soc/Ioh.h
deleted file mode 100644
index c3e3350abb..0000000000
--- a/src/soc/intel/quark/include/soc/Ioh.h
+++ /dev/null
@@ -1,244 +0,0 @@
-/* SPDX-License-Identifier: BSD-2-Clause */
-
-#ifndef _IOH_H_
-#define _IOH_H_
-
-#ifndef BIT0
-#define BIT0 0x01
-#define BIT1 0x02
-#define BIT2 0x04
-#define BIT3 0x08
-#define BIT4 0x10
-#define BIT5 0x20
-#define BIT6 0x40
-#define BIT7 0x80
-#define BIT8 0x100
-#define BIT9 0x200
-#define BIT00 0x00000001
-#define BIT01 0x00000002
-#define BIT02 0x00000004
-#define BIT03 0x00000008
-#define BIT04 0x00000010
-#define BIT05 0x00000020
-#define BIT06 0x00000040
-#define BIT07 0x00000080
-#define BIT08 0x00000100
-#define BIT09 0x00000200
-#define BIT10 0x00000400
-#define BIT11 0x00000800
-#define BIT12 0x00001000
-#define BIT13 0x00002000
-#define BIT14 0x00004000
-#define BIT15 0x00008000
-#define BIT16 0x00010000
-#define BIT17 0x00020000
-#define BIT18 0x00040000
-#define BIT19 0x00080000
-#define BIT20 0x00100000
-#define BIT21 0x00200000
-#define BIT22 0x00400000
-#define BIT23 0x00800000
-#define BIT24 0x01000000
-#define BIT25 0x02000000
-#define BIT26 0x04000000
-#define BIT27 0x08000000
-#define BIT28 0x10000000
-#define BIT29 0x20000000
-#define BIT30 0x40000000
-#define BIT31 0x80000000
-#endif
-
-#define IOH_PCI_CFG_ADDRESS(bus, dev, func, reg) \
- (((UINT32) ((((UINTN)bus) << 24) + (((UINTN)dev) << 16) + \
- (((UINTN)func) << 8) + ((UINTN)reg))) & 0x00000000ffffffff)
-
-//----------------------------------------------------------------------------
-
-#define INTEL_VENDOR_ID 0x8086 // Intel Vendor ID
-
-//----------------------------------------------------------------------------
-// Pci Configuration Map Register Offsets
-//----------------------------------------------------------------------------
-#define PCI_REG_VID 0x00 // Vendor ID Register
-#define PCI_REG_DID 0x02 // Device ID Register
-#define PCI_REG_PCICMD 0x04 // PCI Command Register
-#define PCI_REG_PCISTS 0x06 // PCI Status Register
-#define PCI_REG_RID 0x08 // PCI Revision ID Register
-#define PCI_REG_PI 0x09 // Programming Interface
-#define PCI_REG_SCC 0x0a // Sub Class Code Register
-#define PCI_REG_BCC 0x0b // Base Class Code Register
-#define PCI_REG_PMLT 0x0d // Primary Master Latnecy Timer
-#define PCI_REG_HDR 0x0e // Header Type Register
-#define PCI_REG_PBUS 0x18 // Primary Bus Number Register
-#define PCI_REG_SBUS 0x19 // Secondary Bus Number Register
-#define PCI_REG_SUBUS 0x1a // Subordinate Bus Number Register
-#define PCI_REG_SMLT 0x1b // Secondary Master Latnecy Timer
-#define PCI_REG_IOBASE 0x1c // I/O base Register
-#define PCI_REG_IOLIMIT 0x1d // I/O Limit Register
-#define PCI_REG_SECSTATUS 0x1e // Secondary Status Register
-#define PCI_REG_MEMBASE 0x20 // Memory Base Register
-#define PCI_REG_MEMLIMIT 0x22 // Memory Limit Register
-#define PCI_REG_PRE_MEMBASE 0x24 // Prefretchable memory Base register
-#define PCI_REG_PRE_MEMLIMIT 0x26 // Prefretchable memory Limit register
-#define PCI_REG_SVID0 0x2c // Subsystem Vendor ID low byte
-#define PCI_REG_SVID1 0x2d // Subsystem Vendor ID high byte
-#define PCI_REG_SID0 0x2e // Subsystem ID low byte
-#define PCI_REG_SID1 0x2f // Subsystem ID high byte
-#define PCI_REG_IOBASE_U 0x30 // I/O base Upper Register
-#define PCI_REG_IOLIMIT_U 0x32 // I/O Limit Upper Register
-#define PCI_REG_INTLINE 0x3c // Interrupt Line Register
-#define PCI_REG_BRIDGE_CNTL 0x3e // Bridge Control Register
-
-//---------------------------------------------------------------------------
-// QuarkSCSocId Packet Hub definitions
-//---------------------------------------------------------------------------
-
-#define PCIE_BRIDGE_VID_DID 0x88008086
-
-//---------------------------------------------------------------------------
-// Quark South Cluster definitions.
-//---------------------------------------------------------------------------
-
-#define IOH_BUS 0
-#define IOH_PCI_IOSF2AHB_0_DEV_NUM 0x14
-#define IOH_PCI_IOSF2AHB_0_MAX_FUNCS 7
-#define IOH_PCI_IOSF2AHB_1_DEV_NUM 0x15
-#define IOH_PCI_IOSF2AHB_1_MAX_FUNCS 3
-
-//---------------------------------------------------------------------------
-// Quark South Cluster USB definitions.
-//---------------------------------------------------------------------------
-
-#define IOH_USB_BUS_NUMBER IOH_BUS
-#define IOH_USB_CONTROLLER_MMIO_RANGE 0x1000
-#define IOH_MAX_OHCI_USB_CONTROLLERS 1
-#define IOH_MAX_EHCI_USB_CONTROLLERS 1
-#define IOH_MAX_USBDEVICE_USB_CONTROLLERS 1
-
-#define R_IOH_USB_VENDOR_ID 0x00
-#define V_IOH_USB_VENDOR_ID INTEL_VENDOR_ID
-#define R_IOH_USB_DEVICE_ID 0x02
-#define R_IOH_USB_COMMAND 0x04
-#define B_IOH_USB_COMMAND_BME BIT2
-#define B_IOH_USB_COMMAND_MSE BIT1
-#define B_IOH_USB_COMMAND_ISE BIT0
-#define R_IOH_USB_MEMBAR 0x10
-#define B_IOH_USB_MEMBAR_ADDRESS_MASK 0xFFFFF000 // [31:12].
-#define R_IOH_USB_OHCI_HCCABAR 0x18
-
-//---------------------------------------------------------------------------
-// Quark South Cluster OHCI definitions
-//---------------------------------------------------------------------------
-#define IOH_USB_OHCI_DEVICE_NUMBER IOH_PCI_IOSF2AHB_0_DEV_NUM
-#define IOH_OHCI_FUNCTION_NUMBER 0x04
-
-//---------------------------------------------------------------------------
-// Quark South Cluster EHCI definitions
-//---------------------------------------------------------------------------
-#define IOH_USB_EHCI_DEVICE_NUMBER IOH_PCI_IOSF2AHB_0_DEV_NUM
-#define IOH_EHCI_FUNCTION_NUMBER 0x03
-
-//
-// EHCI memory mapped registers offset from memory BAR0.
-//
-#define R_IOH_EHCI_CAPLENGTH 0x00
-#define R_IOH_EHCI_INSNREG01 0x94
-#define B_IOH_EHCI_INSNREG01_OUT_THRESHOLD_BP (16)
-#define B_IOH_EHCI_INSNREG01_OUT_THRESHOLD_MASK \
- (0xff << B_IOH_EHCI_INSNREG01_OUT_THRESHOLD_BP)
-#define B_IOH_EHCI_INSNREG01_IN_THRESHOLD_BP (0)
-#define B_IOH_EHCI_INSNREG01_IN_THRESHOLD_MASK \
- (0xff << B_IOH_EHCI_INSNREG01_IN_THRESHOLD_BP)
-
-//
-// EHCI memory mapped registers offset from memory BAR0 + Cap length value.
-//
-#define R_IOH_EHCI_CONFIGFLAGS 0x40
-
-//---------------------------------------------------------------------------
-// Quark South Cluster USB Device definitions
-//---------------------------------------------------------------------------
-#define IOH_USBDEVICE_DEVICE_NUMBER IOH_PCI_IOSF2AHB_0_DEV_NUM
-#define IOH_USBDEVICE_FUNCTION_NUMBER 0x02
-
-//
-// USB Device memory mapped registers offset from memory BAR0.
-//
-#define R_IOH_USBDEVICE_D_INTR_UDC_REG 0x40c
-#define R_IOH_USBDEVICE_D_INTR_MSK_UDC_REG 0x410
-#define B_IOH_USBDEVICE_D_INTR_MSK_UDC_REG_MASK1_MASK 0xff
-#define R_IOH_USBDEVICE_EP_INTR_UDC_REG 0x414
-#define R_IOH_USBDEVICE_EP_INTR_MSK_UDC_REG 0x418
-#define B_IOH_USBDEVICE_EP_INTR_MSK_UDC_REG_OUT_EP_MASK 0x000f0000
-#define B_IOH_USBDEVICE_EP_INTR_MSK_UDC_REG_IN_EP_MASK 0x0000000f
-
-//---------------------------------------------------------------------------
-// Quark South Cluster 10/100 Mbps Ethernet Device definitions.
-//---------------------------------------------------------------------------
-#define IOH_MAC0_BUS_NUMBER IOH_BUS
-#define IOH_MAC0_DEVICE_NUMBER IOH_PCI_IOSF2AHB_0_DEV_NUM
-#define IOH_MAC0_FUNCTION_NUMBER 0x06
-#define IOH_MAC1_BUS_NUMBER IOH_BUS
-#define IOH_MAC1_DEVICE_NUMBER IOH_PCI_IOSF2AHB_0_DEV_NUM
-#define IOH_MAC1_FUNCTION_NUMBER 0x07
-
-//
-// MAC Device PCI config registers.
-//
-#define R_IOH_MAC_DEVICE_ID 0x02
-#define V_IOH_MAC_VENDOR_ID INTEL_VENDOR_ID
-#define R_IOH_MAC_DEVICE_ID 0x02
-#define V_IOH_MAC_DEVICE_ID 0x0937
-#define R_IOH_MAC_COMMAND 0x04
-#define B_IOH_MAC_COMMAND_BME BIT2
-#define B_IOH_MAC_COMMAND_MSE BIT1
-#define B_IOH_MAC_COMMAND_ISE BIT0
-#define R_IOH_MAC_MEMBAR 0x10
-#define B_IOH_MAC_MEMBAR_ADDRESS_MASK 0xFFFFF000
-
-//
-// LAN Device memory mapped registers offset from memory BAR0.
-//
-#define R_IOH_MAC_GMAC_REG_8 0x20
-#define B_IOH_MAC_USERVER_MASK 0x0000FF00
-#define B_IOH_MAC_SNPSVER_MASK 0x000000FF
-#define R_IOH_MAC_GMAC_REG_16 0x40
-#define B_IOH_MAC_ADDRHI_MASK 0x0000FFFF
-#define B_IOH_MAC_AE BIT31
-#define R_IOH_MAC_GMAC_REG_17 0x44
-#define B_IOH_MAC_ADDRLO_MASK 0xFFFFFFFF
-
-//---------------------------------------------------------------------------
-// Quark I2C / GPIO definitions
-//---------------------------------------------------------------------------
-
-#define V_IOH_I2C_GPIO_VENDOR_ID INTEL_VENDOR_ID
-#define V_IOH_I2C_GPIO_DEVICE_ID 0x0934
-
-#define R_IOH_I2C_MEMBAR 0x10
-#define B_IOH_I2C_GPIO_MEMBAR_ADDR_MASK 0xFFFFF000 // [31:12].
-
-#define GPIO_SWPORTA_DR 0x00
-#define GPIO_SWPORTA_DDR 0x04
-#define GPIO_INTEN 0x30
-#define GPIO_INTMASK 0x34
-#define GPIO_INTTYPE_LEVEL 0x38
-#define GPIO_INT_POLARITY 0x3C
-#define GPIO_INTSTATUS 0x40
-#define GPIO_RAW_INTSTATUS 0x44
-#define GPIO_DEBOUNCE 0x48
-#define GPIO_PORTA_EOI 0x4C
-#define GPIO_EXT_PORTA 0x50
-#define GPIO_EXT_PORTB 0x54
-#define GPIO_LS_SYNC 0x60
-#define GPIO_CONFIG_REG2 0x70
-#define GPIO_CONFIG_REG1 0x74
-
-//---------------------------------------------------------------------------
-// Quark South Cluster UART definitions.
-//---------------------------------------------------------------------------
-
-#define R_IOH_UART_MEMBAR 0x10
-#define B_IOH_UART_MEMBAR_ADDRESS_MASK 0xFFFFF000 // [31:12].
-
-#endif
diff --git a/src/soc/intel/quark/include/soc/QuarkNcSocId.h b/src/soc/intel/quark/include/soc/QuarkNcSocId.h
deleted file mode 100644
index 4a62c04eeb..0000000000
--- a/src/soc/intel/quark/include/soc/QuarkNcSocId.h
+++ /dev/null
@@ -1,826 +0,0 @@
-/* SPDX-License-Identifier: BSD-2-Clause */
-/*
- * QuarkNcSocId Register Definitions
- * Definitions beginning with "R_" are registers
- * Definitions beginning with "B_" are bits within registers
- * Definitions beginning with "V_" are meaningful values of bits within registers
- * Definitions beginning with "S_" are register sizes
- * Definitions beginning with "N_" are the bit position
- *
- */
-
-#ifndef _QUARK_NC_SOC_ID_H_
-#define _QUARK_NC_SOC_ID_H_
-
-//
-// Define the bits
-//
-#ifndef BIT0
-#define BIT0 0x00000001
-#define BIT1 0x00000002
-#define BIT2 0x00000004
-#define BIT3 0x00000008
-#define BIT4 0x00000010
-#define BIT5 0x00000020
-#define BIT6 0x00000040
-#define BIT7 0x00000080
-#define BIT8 0x00000100
-#define BIT9 0x00000200
-#define BIT10 0x00000400
-#define BIT11 0x00000800
-#define BIT12 0x00001000
-#define BIT13 0x00002000
-#define BIT14 0x00004000
-#define BIT15 0x00008000
-#define BIT16 0x00010000
-#define BIT17 0x00020000
-#define BIT18 0x00040000
-#define BIT19 0x00080000
-#define BIT20 0x00100000
-#define BIT21 0x00200000
-#define BIT22 0x00400000
-#define BIT23 0x00800000
-#define BIT24 0x01000000
-#define BIT25 0x02000000
-#define BIT26 0x04000000
-#define BIT27 0x08000000
-#define BIT28 0x10000000
-#define BIT29 0x20000000
-#define BIT30 0x40000000
-#define BIT31 0x80000000
-#endif
-
-//
-// QNC GMCH Equates
-//
-
-//
-// DEVICE 0 (Memory Controller Hub)
-//
-#define MC_BUS PCI_BUS_NUMBER_QNC
-#define MC_DEV 0x00
-#define MC_FUN 0x00
-
-#define QUARK_MC_VENDOR_ID V_INTEL_VENDOR_ID
-#define QUARK_MC_DEVICE_ID 0x0958
-#define QUARK2_MC_DEVICE_ID 0x12C0
-#define QNC_MC_REV_ID_A0 0x00
-
-//
-// MCR - B0:D0:F0:RD0h (WO)- Message control register (Datasheet 12.5)
-// [31:24] Message opcode - D0 read; E0 write;
-// [23:16] Message port
-// [15:8 ] Message target register address
-// [ 7:4 ] Message write byte enable : F is enable
-// [ 3:0 ] Reserved
-//
-#define QNC_ACCESS_PORT_MCR 0xD0 // Message Control Register
-// Always Set to 0xF0
-#define QNC_MCR_MASK 0x000000ff
-#define QNC_MCR_BYTE_ENABLES 0x000000f0
-
-//
-//MDR - B0:D0:F0:RD4h (RW)- Message data register
-//
-#define QNC_ACCESS_PORT_MDR 0xD4 // Message Data Register
-
-//
-//MEA - B0:D0:F0:RD8h (RW)- Message extended address register
-//
-#define QNC_ACCESS_PORT_MEA 0xD8 // Message Extended Addr reg
-#define QNC_MEA_MASK 0xffffff00
-
-#define QNC_MCR_OP_OFFSET 24 // Offset of the opcode field in MCR
-#define QNC_MCR_PORT_OFFSET 16 // Offset of the port field in MCR
-#define QNC_MCR_REG_OFFSET 8 // Offset of the register field in MCR
-
-//
-// Misc Useful Macros
-//
-
-#define LShift16(value) (value << 16)
-
-//
-// QNC Message OpCodes and Attributes
-//
-#define QUARK_OPCODE_READ 0x10 // Message bus "read" opcode
-#define QUARK_OPCODE_WRITE 0x11 // Message bus "write" opcode
-
-//
-// Alternative opcodes for the SCSS block
-//
-#define QUARK_ALT_OPCODE_READ 0x06 // Message bus "read" opcode
-#define QUARK_ALT_OPCODE_WRITE 0x07 // Message bus "write" opcode
-
-//
-// QNC Message OpCodes and Attributes for IO
-//
-#define QUARK_OPCODE_IO_READ 0x02 // Message bus "IO read" opcode
-#define QUARK_OPCODE_IO_WRITE 0x03 // Message bus "IO write" opcode
-
-#define QUARK_DRAM_BASE_ADDR_READY 0x78 // Message bus "RMU Main binary
- // shadow" opcode
-
-#define QUARK_ECC_SCRUB_RESUME 0xC2 // Quark RMU "scrub resume" opcode
-#define QUARK_ECC_SCRUB_PAUSE 0xC3 // Quark RMU "scrub pause" opcode
-
-//
-// QNC Message Ports and Registers
-//
-// Start of SB Port IDs
-#define QUARK_NC_MEMORY_ARBITER_SB_PORT_ID 0x00
-#define QUARK_NC_MEMORY_CONTROLLER_SB_PORT_ID 0x01
-#define QUARK_NC_HOST_BRIDGE_SB_PORT_ID 0x03
-#define QUARK_NC_RMU_SB_PORT_ID 0x04
-#define QUARK_NC_MEMORY_MANAGER_SB_PORT_ID 0x05
-#define QUARK_SC_USB_AFE_SB_PORT_ID 0x14
-#define QUARK_SC_PCIE_AFE_SB_PORT_ID 0x16
-#define QUARK_SCSS_SOC_UNIT_SB_PORT_ID 0x31
-#define QUARK_SCSS_FUSE_SB_PORT_ID 0x33
-#define QUARK_ICLK_SB_PORT_ID 0x32
-#define QUARK_SCSS_CRU_SB_PORT_ID 0x34
-
-//
-// Quark Memory Arbiter Registers.
-//
-#define QUARK_NC_MEMORY_ARBITER_REG_ASTATUS 0x21 // Memory Arbiter PRI
- // Status encodings reg
-#define ASTATUS_PRI_CASUAL 0x0 // Service if convenient
-#define ASTATUS_PRI_IMPENDING 0x1 // DRAM is in Self-Refresh
-#define ASTATUS_PRI_NORMAL 0x2 // Normal request servicing
-#define ASTATUS_PRI_URGENT 0x3 // Urgent request servicing
-#define ASTATUS1_RASISED_BP (10)
-#define ASTATUS1_RASISED_BP_MASK (0x03 << ASTATUS1_RASISED_BP)
-#define ASTATUS0_RASISED_BP (8)
-#define ASTATUS0_RASISED_BP_MASK (0x03 << ASTATUS1_RASISED_BP)
-#define ASTATUS1_DEFAULT_BP (2)
-#define ASTATUS1_DEFAULT_BP_MASK (0x03 << ASTATUS1_RASISED_BP)
-#define ASTATUS0_DEFAULT_BP (0)
-#define ASTATUS0_DEFAULT_BP_MASK (0x03 << ASTATUS1_RASISED_BP)
-
-//
-// Quark Memory Controller Registers.
-//
-#define QUARK_NC_MEMORY_CONTROLLER_REG_DFUSESTAT 0x70 // Fuse status register
-#define B_DFUSESTAT_ECC_DIS (BIT0) // Disable ECC.
-
-//
-// Quark Remote Management Unit Registers.
-//
-#define QNC_MSG_TMPM_REG_PMBA 0x70 // PM I/O Base Address
-
-#define QUARK_NC_RMU_REG_CONFIG 0x71 // RMU configuration reg
-#define TS_LOCK_AUX_TRIP_PT_REGS_ENABLE (BIT6)
-#define TS_LOCK_THRM_CTRL_REGS_ENABLE (BIT5)
-
-#define QUARK_NC_RMU_REG_OPTIONS_1 0x72 // RMU Options register 1
-#define OPTIONS_1_DMA_DISABLE (BIT0)
-
-#define QUARK_NC_RMU_REG_WDT_CONTROL 0x74 // RMU Watchdog control
-#define B_WDT_CONTROL_DBL_ECC_BIT_ERR_MASK (BIT19 | BIT18)
-#define B_WDT_CONTROL_DBL_ECC_BIT_ERR_BP 18
-#define V_WDT_CONTROL_DBL_ECC_BIT_ERR_NONE 0
-#define V_WDT_CONTROL_DBL_ECC_BIT_ERR_CAT \
- (0x1 << B_WDT_CONTROL_DBL_ECC_BIT_ERR_BP)
-#define V_WDT_CONTROL_DBL_ECC_BIT_ERR_WARM \
- (0x2 << B_WDT_CONTROL_DBL_ECC_BIT_ERR_BP)
-#define V_WDT_CONTROL_DBL_ECC_BIT_ERR_SERR \
- (0x3 << B_WDT_CONTROL_DBL_ECC_BIT_ERR_BP)
-
-#define QUARK_NC_RMU_REG_TS_MODE 0xB0 // RMU Thermal sensor mode
-#define TS_ENABLE (BIT15)
-#define QUARK_NC_RMU_REG_TS_TRIP 0xB2 // RMU Thermal sensor
- // programmable trip point
-#define TS_HOT_TRIP_CLEAR_THOLD_BP 24
-#define TS_HOT_TRIP_CLEAR_THOLD_MASK (0xFF << TS_HOT_TRIP_CLEAR_THOLD_BP)
-#define TS_CAT_TRIP_CLEAR_THOLD_BP 16
-#define TS_CAT_TRIP_CLEAR_THOLD_MASK (0xFF << TS_CAT_TRIP_CLEAR_THOLD_BP)
-#define TS_HOT_TRIP_SET_THOLD_BP 8
-#define TS_HOT_TRIP_SET_THOLD_MASK (0xFF << TS_HOT_TRIP_SET_THOLD_BP)
-#define TS_CAT_TRIP_SET_THOLD_BP 0
-#define TS_CAT_TRIP_SET_THOLD_MASK (0xFF << TS_CAT_TRIP_SET_THOLD_BP)
-
-#define QUARK_NC_ECC_SCRUB_CONFIG_REG 0x50
-#define SCRUB_CFG_INTERVAL_SHIFT 0x00
-#define SCRUB_CFG_INTERVAL_MASK 0xFF
-#define SCRUB_CFG_BLOCKSIZE_SHIFT 0x08
-#define SCRUB_CFG_BLOCKSIZE_MASK 0x1F
-#define SCRUB_CFG_ACTIVE (BIT13)
-#define SCRUB_CFG_INVALID 0x00000FFF
-
-#define QUARK_NC_ECC_SCRUB_START_MEM_REG 0x76
-#define QUARK_NC_ECC_SCRUB_END_MEM_REG 0x77
-#define QUARK_NC_ECC_SCRUB_NEXT_READ_REG 0x7C
-
-#define SCRUB_RESUME_MSG() ((UINT32)( \
- (QUARK_ECC_SCRUB_RESUME << QNC_MCR_OP_OFFSET) | \
- (QUARK_NC_RMU_SB_PORT_ID << QNC_MCR_PORT_OFFSET) | \
- 0xF0))
-
-#define SCRUB_PAUSE_MSG() ((UINT32)( \
- (QUARK_ECC_SCRUB_PAUSE << QNC_MCR_OP_OFFSET) | \
- (QUARK_NC_RMU_SB_PORT_ID << QNC_MCR_PORT_OFFSET) | \
- 0xF0))
-
-//
-// Quark Memory Manager Registers
-//
-#define QUARK_NC_MEMORY_MANAGER_ESRAMPGCTRL_BLOCK 0x82
-#define BLOCK_ENABLE_PG (1 << 28)
-#define BLOCK_DISABLE_PG (1 << 29)
-#define QUARK_NC_MEMORY_MANAGER_BIMRVCTL 0x19
-#define EnableIMRInt BIT31
-#define QUARK_NC_MEMORY_MANAGER_BSMMVCTL 0x1C
-#define EnableSMMInt BIT31
-#define QUARK_NC_MEMORY_MANAGER_BTHCTRL 0x20
-#define DRAM_NON_HOST_RQ_LIMIT_BP 0
-#define DRAM_NON_HOST_RQ_LIMIT_MASK (0x3f << DRAM_NON_HOST_RQ_LIMIT_BP)
-
-#define QUARK_NC_TOTAL_IMR_SET 0x8
-#define QUARK_NC_MEMORY_MANAGER_IMR0 0x40
-#define QUARK_NC_MEMORY_MANAGER_IMR1 0x44
-#define QUARK_NC_MEMORY_MANAGER_IMR2 0x48
-#define QUARK_NC_MEMORY_MANAGER_IMR3 0x4C
-#define QUARK_NC_MEMORY_MANAGER_IMR4 0x50
-#define QUARK_NC_MEMORY_MANAGER_IMR5 0x54
-#define QUARK_NC_MEMORY_MANAGER_IMR6 0x58
-#define QUARK_NC_MEMORY_MANAGER_IMR7 0x5C
-#define QUARK_NC_MEMORY_MANAGER_IMRXL 0x00
-#define IMR_LOCK BIT31
-#define IMR_EN BIT30
-#define IMRL_MASK 0x00FFFFFC
-#define IMRL_RESET 0x00000000
-#define QUARK_NC_MEMORY_MANAGER_IMRXH 0x01
-#define IMRH_MASK 0x00FFFFFC
-#define IMRH_RESET 0x00000000
-#define QUARK_NC_MEMORY_MANAGER_IMRXRM 0x02
-#define QUARK_NC_MEMORY_MANAGER_IMRXWM 0x03
-#define IMRX_ALL_ACCESS 0xFFFFFFFF
-#define CPU_SNOOP BIT30
-#define RMU BIT29
-#define CPU0_NON_SMM BIT0
-
-//
-// Quark Host Bridge Registers (Datasheet 12.7.2)
-//
-#define QNC_MSG_FSBIC_REG_HMISC 0x03 // Host Misellaneous Controls
-#define SMI_EN (BIT19) // SMI Global Enable
- // (from Legacy Bridge)
-#define FSEG_RD_DRAM (BIT2) // Enable RAM for 0xf0000
- // - 0xfffff
-#define ESEG_RD_DRAM (BIT1) // Enable RAM for 0xe0000
- // - 0xeffff
-#define QNC_MSG_FSBIC_REG_HSMMC 0x04 // Host SMM Control
-#define NON_HOST_SMM_WR_OPEN (BIT18) // SMM Writes OPEN
-#define NON_HOST_SMM_RD_OPEN (BIT17) // SMM Writes OPEN
-#define SMM_CODE_RD_OPEN (BIT16) // SMM Code read OPEN
-#define SMM_CTL_EN (BIT3) // SMM enable
-#define SMM_WRITE_OPEN (BIT2) // SMM Writes OPEN
-#define SMM_READ_OPEN (BIT1) // SMM Reads OPEN
-#define SMM_LOCKED (BIT0) // SMM Locked
-#define SMM_START_MASK 0x0000FFF0
-#define SMM_END_MASK 0xFFF00000
-#define QUARK_NC_HOST_BRIDGE_HMBOUND_REG 0x08
-#define HMBOUND_MASK 0x0FFFFF000
-#define HMBOUND_LOCK BIT0
-#define QUARK_NC_HOST_BRIDGE_HLEGACY_REG 0x0A
-#define HLEGACY_SMI_PIN_VALUE BIT12
-#define QUARK_NC_HOST_BRIDGE_IA32_MTRR_CAP 0x40
-#define QUARK_NC_HOST_BRIDGE_IA32_MTRR_DEF_TYPE 0x41
-#define QUARK_NC_HOST_BRIDGE_MTRR_FIX64K_00000 0x42
-#define QUARK_NC_HOST_BRIDGE_MTRR_FIX16K_80000 0x44
-#define QUARK_NC_HOST_BRIDGE_MTRR_FIX16K_A0000 0x46
-#define QUARK_NC_HOST_BRIDGE_MTRR_FIX4K_C0000 0x48
-#define QUARK_NC_HOST_BRIDGE_MTRR_FIX4K_C8000 0x4A
-#define QUARK_NC_HOST_BRIDGE_MTRR_FIX4K_D0000 0x4C
-#define QUARK_NC_HOST_BRIDGE_MTRR_FIX4K_D8000 0x4E
-#define QUARK_NC_HOST_BRIDGE_MTRR_FIX4K_E0000 0x50
-#define QUARK_NC_HOST_BRIDGE_MTRR_FIX4K_E8000 0x52
-#define QUARK_NC_HOST_BRIDGE_MTRR_FIX4K_F0000 0x54
-#define QUARK_NC_HOST_BRIDGE_MTRR_FIX4K_F8000 0x56
-#define QUARK_NC_HOST_BRIDGE_IA32_MTRR_SMRR_PHYSBASE 0x58
-#define QUARK_NC_HOST_BRIDGE_IA32_MTRR_SMRR_PHYSMASK 0x59
-#define QUARK_NC_HOST_BRIDGE_IA32_MTRR_PHYSBASE0 0x5A
-#define QUARK_NC_HOST_BRIDGE_IA32_MTRR_PHYSMASK0 0x5B
-#define QUARK_NC_HOST_BRIDGE_IA32_MTRR_PHYSBASE1 0x5C
-#define QUARK_NC_HOST_BRIDGE_IA32_MTRR_PHYSMASK1 0x5D
-#define QUARK_NC_HOST_BRIDGE_IA32_MTRR_PHYSBASE2 0x5E
-#define QUARK_NC_HOST_BRIDGE_IA32_MTRR_PHYSMASK2 0x5F
-#define QUARK_NC_HOST_BRIDGE_IA32_MTRR_PHYSBASE3 0x60
-#define QUARK_NC_HOST_BRIDGE_IA32_MTRR_PHYSMASK3 0x61
-#define QUARK_NC_HOST_BRIDGE_IA32_MTRR_PHYSBASE4 0x62
-#define QUARK_NC_HOST_BRIDGE_IA32_MTRR_PHYSMASK4 0x63
-#define QUARK_NC_HOST_BRIDGE_IA32_MTRR_PHYSBASE5 0x64
-#define QUARK_NC_HOST_BRIDGE_IA32_MTRR_PHYSMASK5 0x65
-#define QUARK_NC_HOST_BRIDGE_IA32_MTRR_PHYSBASE6 0x66
-#define QUARK_NC_HOST_BRIDGE_IA32_MTRR_PHYSMASK6 0x67
-#define QUARK_NC_HOST_BRIDGE_IA32_MTRR_PHYSBASE7 0x68
-#define QUARK_NC_HOST_BRIDGE_IA32_MTRR_PHYSMASK7 0x69
-
-//
-// System On Chip Unit (SOCUnit) Registers.
-//
-#define QUARK_SCSS_SOC_UNIT_STPDDRCFG 0x00
-#define B_STPDDRCFG_FORCE_RECOVERY BIT0
-#define QUARK_SCSS_SOC_UNIT_SPI_ROM_FUSE 0x25
-#define B_ROM_FUSE_IN_SECURE_SKU BIT6
-
-#define QUARK_SCSS_SOC_UNIT_TSCGF1_CONFIG 0x31
-#define B_TSCGF1_CONFIG_ISNSCURRENTSEL_MASK (BIT5 | BIT4 | BIT3)
-#define B_TSCGF1_CONFIG_ISNSCURRENTSEL_BP 3
-#define B_TSCGF1_CONFIG_ISNSCHOPSEL_MASK (BIT12 | BIT11 | BIT10 | BIT9\
- | BIT8)
-#define B_TSCGF1_CONFIG_ISNSCHOPSEL_BP 8
-#define B_TSCGF1_CONFIG_IBGEN BIT17
-#define B_TSCGF1_CONFIG_IBGEN_BP 17
-#define B_TSCGF1_CONFIG_IBGCHOPEN BIT18
-#define B_TSCGF1_CONFIG_IBGCHOPEN_BP 18
-#define B_TSCGF1_CONFIG_ISNSINTERNALVREFEN BIT14
-#define B_TSCGF1_CONFIG_ISNSINTERNALVREFEN_BP 14
-
-#define QUARK_SCSS_SOC_UNIT_TSCGF2_CONFIG 0x32
-#define B_TSCGF2_CONFIG_IDSCONTROL_MASK 0x0000FFFF
-#define B_TSCGF2_CONFIG_IDSCONTROL_BP 0
-#define B_TSCGF2_CONFIG_IDSTIMING_MASK 0xFFFF0000
-#define B_TSCGF2_CONFIG_IDSTIMING_BP 16
-
-#define QUARK_SCSS_SOC_UNIT_TSCGF2_CONFIG2 0x33
-#define B_TSCGF2_CONFIG2_ISPARECTRL_MASK 0xFF000000
-#define B_TSCGF2_CONFIG2_ISPARECTRL_BP 24
-#define B_TSCGF2_CONFIG2_ICALCONFIGSEL_MASK (BIT9 | BIT8)
-#define B_TSCGF2_CONFIG2_ICALCONFIGSEL_BP 8
-#define B_TSCGF2_CONFIG2_ICALCOARSETUNE_MASK 0x000000FF
-#define B_TSCGF2_CONFIG2_ICALCOARSETUNE_BP 0
-
-#define QUARK_SCSS_SOC_UNIT_TSCGF3_CONFIG 0x34
-#define B_TSCGF3_CONFIG_ITSRST BIT0
-#define B_TSCGF3_CONFIG_ITSGAMMACOEFF_BP 11
-#define B_TSCGF3_CONFIG_ITSGAMMACOEFF_MASK \
- (0xFFF << B_TSCGF3_CONFIG_ITSGAMMACOEFF_BP)
-
-#define QUARK_SCSS_SOC_UNIT_SOCCLKEN_CONFIG 0x36
-#define SOCCLKEN_CONFIG_PHY_I_SIDE_RST_L BIT20
-#define SOCCLKEN_CONFIG_PHY_I_CMNRESET_L BIT19
-#define SOCCLKEN_CONFIG_SBI_BB_RST_B BIT18
-#define SOCCLKEN_CONFIG_SBI_RST_100_CORE_B BIT17
-#define SOCCLKEN_CONFIG_BB_RST_B BIT16
-
-#define QUARK_SCSS_SOC_UNIT_SOCCLKEN_CONFIG 0x36
-
-#define QUARK_SCSS_SOC_UNIT_CFG_STICKY_RW 0x51
-#define B_CFG_STICKY_RW_SMM_VIOLATION BIT0
-#define B_CFG_STICKY_RW_HMB_VIOLATION BIT1
-#define B_CFG_STICKY_RW_IMR_VIOLATION BIT2
-#define B_CFG_STICKY_RW_DECC_VIOLATION BIT3
-#define B_CFG_STICKY_RW_WARM_RST BIT4
-#define B_CFG_STICKY_RW_FORCE_RECOVERY BIT9
-#define B_CFG_STICKY_RW_VIOLATION \
- (B_CFG_STICKY_RW_SMM_VIOLATION \
- | B_CFG_STICKY_RW_HMB_VIOLATION \
- | B_CFG_STICKY_RW_IMR_VIOLATION \
- | B_CFG_STICKY_RW_DECC_VIOLATION)
-#define B_CFG_STICKY_RW_ALL (B_CFG_STICKY_RW_VIOLATION \
- | B_CFG_STICKY_RW_WARM_RST)
-
-//
-// iCLK Registers.
-//
-#define QUARK_ICLK_MUXTOP 0x0140
-#define B_MUXTOP_FLEX2_MASK (BIT25 | BIT24 | BIT23)
-#define B_MUXTOP_FLEX2_BP 23
-#define B_MUXTOP_FLEX1_MASK (BIT22 | BIT21 | BIT20)
-#define B_MUXTOP_FLEX1_BP 20
-
-#define QUARK_ICLK_SSC1 0x0314
-#define QUARK_ICLK_SSC2 0x0414
-#define QUARK_ICLK_SSC3 0x0514
-#define QUARK_ICLK_REF2_DBUFF0 0x2000
-
-//
-// PCIe AFE Unit Registers (QUARK_SC_PCIE_AFE_SB_PORT_ID).
-//
-#define QUARK_PCIE_AFE_PCIE_RXPICTRL0_L0 0x2080
-#define QUARK_PCIE_AFE_PCIE_RXPICTRL0_L1 0x2180
-#define OCFGPIMIXLOAD_1_0 BIT6
-#define OCFGPIMIXLOAD_1_0_MASK 0xFFFFFF3F
-
-//
-// QNC ICH Equates
-//
-#define V_INTEL_VENDOR_ID 0x8086
-
-#define PCI_BUS_NUMBER_QNC 0x00
-
-//
-// PCI to LPC Bridge Registers (D31:F0)
-//
-#define PCI_DEVICE_NUMBER_QNC_LPC 31
-#define PCI_FUNCTION_NUMBER_QNC_LPC 0
-
-#define R_QNC_LPC_VENDOR_ID 0x00
-#define V_LPC_VENDOR_ID V_INTEL_VENDOR_ID
-#define R_QNC_LPC_DEVICE_ID 0x02
-#define QUARK_V_LPC_DEVICE_ID_0 0x095E
-#define R_QNC_LPC_REV_ID 0x08
-
-#define R_QNC_LPC_SMBUS_BASE 0x40 //~0x43
-#define B_QNC_LPC_SMBUS_BASE_EN (BIT31)
-#define B_QNC_LPC_SMBUS_BASE_MASK 0x0000FFC0 //[15:6]
-//
-// SMBus register offsets from SMBA - "SMBA" (D31:F0:R40h)
-// Suggested Value for SMBA = 0x1040
-//
-#define R_QNC_SMBUS_HCTL 0x00 // Host Control Register R/W
-#define B_QNC_SMBUS_START (BIT4) // Start/Stop
-#define V_QNC_SMBUS_HCTL_CMD_QUICK 0
-#define V_QNC_SMBUS_HCTL_CMD_BYTE 1
-#define V_QNC_SMBUS_HCTL_CMD_BYTE_DATA 2
-#define V_QNC_SMBUS_HCTL_CMD_WORD_DATA 3
-#define V_QNC_SMBUS_HCTL_CMD_PROCESS_CALL 4
-#define V_QNC_SMBUS_HCTL_CMD_BLOCK 5
-
-#define R_QNC_SMBUS_HSTS 0x01 // Host Status Register R/W
-#define B_QNC_SMBUS_BERR (BIT2) // BUS Error
-#define B_QNC_SMBUS_DERR (BIT1) // Device Error
-#define B_QNC_SMBUS_BYTE_DONE_STS (BIT0) // Completion Status
-#define B_QNC_SMBUS_HSTS_ALL 0x07
-
-#define R_QNC_SMBUS_HCLK 0x02 // Host Clock Divider Register R/W
-#define V_QNC_SMBUS_HCLK_100KHZ 0x0054
-
-#define R_QNC_SMBUS_TSA 0x04 // Tx Slave Address Register R/W
-#define V_QNC_SMBUS_RW_SEL_READ 1
-#define V_QNC_SMBUS_RW_SEL_WRITE 0
-
-#define R_QNC_SMBUS_HCMD 0x05 // Host Command Register R/W
-#define R_QNC_SMBUS_HD0 0x06 // Data 0 Register R/W
-#define R_QNC_SMBUS_HD1 0x07 // Data 1 Register R/W
-#define R_QNC_SMBUS_HBD 0x20 // Host Block Data Register R/W
- // [255:0] ~ 3Fh
-
-#define R_QNC_LPC_GBA_BASE 0x44
-#define B_QNC_LPC_GPA_BASE_MASK 0x0000FFC0
-//
-// GPIO register offsets from GBA - "GPIO" (D31:F0:R44h)
-// Suggested Value for GBA = 0x1080
-//
-#define R_QNC_GPIO_CGEN_CORE_WELL 0x00
-#define R_QNC_GPIO_CGIO_CORE_WELL 0x04
-#define R_QNC_GPIO_CGLVL_CORE_WELL 0x08
-#define R_QNC_GPIO_CGTPE_CORE_WELL 0x0C // CW GPIO Trigger Pos Edge Enable
-#define R_QNC_GPIO_CGTNE_CORE_WELL 0x10 // CW GPIO Trigger Neg Edge Enable
-#define R_QNC_GPIO_CGGPE_CORE_WELL 0x14 // Core well GPIO GPE Enable
-#define R_QNC_GPIO_CGSMI_CORE_WELL 0x18 // Core well GPIO SMI Enable
-#define R_QNC_GPIO_CGTS_CORE_WELL 0x1C // Core well GPIO Trigger Status
-#define R_QNC_GPIO_RGEN_RESUME_WELL 0x20
-#define R_QNC_GPIO_RGIO_RESUME_WELL 0x24
-#define R_QNC_GPIO_RGLVL_RESUME_WELL 0x28
-#define R_QNC_GPIO_RGTPE_RESUME_WELL 0x2C // RW GPIO Trigger Pos Edge Enable
-#define R_QNC_GPIO_RGTNE_RESUME_WELL 0x30 // RW GPIO Trigger Neg Edge Enable
-#define R_QNC_GPIO_RGGPE_RESUME_WELL 0x34 // Resume well GPIO GPE Enable
-#define R_QNC_GPIO_RGSMI_RESUME_WELL 0x38 // Resume well GPIO SMI Enable
-#define R_QNC_GPIO_RGTS_RESUME_WELL 0x3C // Resume well GPIO Trigger Status
-#define R_QNC_GPIO_CNMIEN_CORE_WELL 0x40 // Core well GPIO NMI Enable
-#define R_QNC_GPIO_RNMIEN_RESUME_WELL 0x44 // Resume well GPIO NMI Enable
-
-#define R_QNC_LPC_PM1BLK 0x48
-#define B_QNC_LPC_PM1BLK_MASK 0x0000FFF0
-//
-// ACPI register offsets from PM1BLK - "ACPI PM1 Block" (D31:F0:R48h)
-// Suggested Value for PM1BLK = 0x1000
-//
-#define R_QNC_PM1BLK_PM1S 0x00
-#define S_QNC_PM1BLK_PM1S 2
-#define B_QNC_PM1BLK_PM1S_ALL (BIT15+BIT14+BIT10+BIT5+BIT0)
-#define B_QNC_PM1BLK_PM1S_WAKE (BIT15)
-#define B_QNC_PM1BLK_PM1S_PCIEWSTS (BIT14)
-#define B_QNC_PM1BLK_PM1S_RTC (BIT10)
-#define B_QNC_PM1BLK_PM1S_GLOB (BIT5)
-#define B_QNC_PM1BLK_PM1S_TO (BIT0)
-#define N_QNC_PM1BLK_PM1S_RTC 10
-
-#define R_QNC_PM1BLK_PM1E 0x02
-#define S_QNC_PM1BLK_PM1E 2
-#define B_QNC_PM1BLK_PM1E_PWAKED (BIT14)
-#define B_QNC_PM1BLK_PM1E_RTC (BIT10)
-#define B_QNC_PM1BLK_PM1E_GLOB (BIT5)
-#define N_QNC_PM1BLK_PM1E_RTC 10
-
-#define R_QNC_PM1BLK_PM1C 0x04
-#define B_QNC_PM1BLK_PM1C_SLPEN (BIT13)
-#define B_QNC_PM1BLK_PM1C_SLPTP (BIT12+BIT11+BIT10)
-#define V_S0 0x00000000
-#define V_S3 0x00001400
-#define V_S4 0x00001800
-#define V_S5 0x00001C00
-#define B_QNC_PM1BLK_PM1C_SCIEN (BIT0)
-
-#define R_QNC_PM1BLK_PM1T 0x08
-
-#define R_QNC_LPC_GPE0BLK 0x4C
-#define B_QNC_LPC_GPE0BLK_MASK 0x0000FFC0
-// Suggested Value for GPE0BLK = 0x10C0
-//
-#define R_QNC_GPE0BLK_GPE0S 0x00 // General Purpose Event 0 Status
-#define S_QNC_GPE0BLK_GPE0S 4
-#define B_QNC_GPE0BLK_GPE0S_ALL 0x00003F800 // Clear the status reg
-#define B_QNC_GPE0BLK_GPE0S_PCIE (BIT17) // PCIE
-#define B_QNC_GPE0BLK_GPE0S_GPIO (BIT14) // GPIO
-#define B_QNC_GPE0BLK_GPE0S_EGPE (BIT13) // External GPE
-#define N_QNC_GPE0BLK_GPE0S_THRM 12
-
-#define R_QNC_GPE0BLK_GPE0E 0x04 // General Purpose Event 0 Enable
-#define S_QNC_GPE0BLK_GPE0E 4
-#define B_QNC_GPE0BLK_GPE0E_PCIE (BIT17) // PCIE
-#define B_QNC_GPE0BLK_GPE0E_GPIO (BIT14) // GPIO
-#define B_QNC_GPE0BLK_GPE0E_EGPE (BIT13) // External GPE
-#define N_QNC_GPE0BLK_GPE0E_THRM 12
-
-#define R_QNC_GPE0BLK_SMIE 0x10 // SMI_B Enable
-#define S_QNC_GPE0BLK_SMIE 4
-#define B_QNC_GPE0BLK_SMIE_ALL 0x0003871F
-#define B_QNC_GPE0BLK_SMIE_APM (BIT4) // APM
-#define B_QNC_GPE0BLK_SMIE_SLP (BIT2) // Sleep
-#define B_QNC_GPE0BLK_SMIE_SWT (BIT1) // Software Timer
-#define N_QNC_GPE0BLK_SMIE_GPIO 9
-#define N_QNC_GPE0BLK_SMIE_ESMI 8
-#define N_QNC_GPE0BLK_SMIE_APM 4
-#define N_QNC_GPE0BLK_SMIE_SPI 3
-#define N_QNC_GPE0BLK_SMIE_SLP 2
-#define N_QNC_GPE0BLK_SMIE_SWT 1
-
-#define R_QNC_GPE0BLK_SMIS 0x14 // SMI Status Register.
-#define S_QNC_GPE0BLK_SMIS 4
-#define B_QNC_GPE0BLK_SMIS_ALL 0x0003871F
-#define B_QNC_GPE0BLK_SMIS_EOS (BIT31) // End of SMI
-#define B_QNC_GPE0BLK_SMIS_APM (BIT4) // APM
-#define B_QNC_GPE0BLK_SMIS_SPI (BIT3) // SPI
-#define B_QNC_GPE0BLK_SMIS_SLP (BIT2) // Sleep
-#define B_QNC_GPE0BLK_SMIS_SWT (BIT1) // Software Timer
-#define B_QNC_GPE0BLK_SMIS_BIOS (BIT0) // BIOS
-#define N_QNC_GPE0BLK_SMIS_GPIO 9
-#define N_QNC_GPE0BLK_SMIS_APM 4
-#define N_QNC_GPE0BLK_SMIS_SPI 3
-#define N_QNC_GPE0BLK_SMIS_SLP 2
-#define N_QNC_GPE0BLK_SMIS_SWT 1
-
-#define R_QNC_GPE0BLK_PMCW 0x28 // PM Configuration Core Well
-#define B_QNC_GPE0BLK_PMCW_PSE (BIT31) // Periodic SMI Enable
-
-#define R_QNC_GPE0BLK_PMSW 0x2C // PM Config Suspend/Resume Well
-#define B_QNC_GPE0BLK_PMSW_DRAM_INIT (BIT0) // Dram Init Sctrachpad
-
-#define R_QNC_LPC_ACTL 0x58
-#define V_QNC_LPC_ACTL_SCIS_IRQ9 0x00
-
-//
-// Number of PIRQs supported. PIRQA~PIRQH
-//
-#define QNC_NUMBER_PIRQS 8
-#define R_QNC_LPC_PIRQA_ROUT 0x60
-#define R_QNC_LPC_PIRQB_ROUT 0x61
-#define R_QNC_LPC_PIRQC_ROUT 0x62
-#define R_QNC_LPC_PIRQD_ROUT 0x63
-#define R_QNC_LPC_PIRQE_ROUT 0x64
-#define R_QNC_LPC_PIRQF_ROUT 0x65
-#define R_QNC_LPC_PIRQG_ROUT 0x66
-#define R_QNC_LPC_PIRQH_ROUT 0x67
-
-//
-// Bit values are the same for R_TNC_LPC_PIRQA_ROUT to
-// R_TNC_LPC_PIRQH_ROUT
-#define B_QNC_LPC_PIRQX_ROUT (BIT3+BIT2+BIT1+BIT0)
-
-#define R_QNC_LPC_WDTBA 0x84
-// Watchdog Timer register offsets from WDTBASE (in R_QNC_LPC_WDTBA)-------BEGIN
-#define R_QNC_LPC_WDT_WDTCR 0x10
-#define R_QNC_LPC_WDT_WDTLR 0x18
-// Watchdog Timer register offsets from WDTBASE (in R_QNC_LPC_WDTBA)---------END
-
-#define R_QNC_LPC_FWH_BIOS_DEC 0xD4
-#define B_QNC_LPC_FWH_BIOS_DEC_F8 (BIT31)
-#define B_QNC_LPC_FWH_BIOS_DEC_F0 (BIT30)
-#define B_QNC_LPC_FWH_BIOS_DEC_E8 (BIT29)
-#define B_QNC_LPC_FWH_BIOS_DEC_E0 (BIT28)
-#define B_QNC_LPC_FWH_BIOS_DEC_D8 (BIT27)
-#define B_QNC_LPC_FWH_BIOS_DEC_D0 (BIT26)
-#define B_QNC_LPC_FWH_BIOS_DEC_C8 (BIT25)
-#define B_QNC_LPC_FWH_BIOS_DEC_C0 (BIT24)
-
-#define R_QNC_LPC_BIOS_CNTL 0xD8
-#define S_QNC_LPC_BIOS_CNTL 4
-#define B_QNC_LPC_BIOS_CNTL_PFE (BIT8)
-#define B_QNC_LPC_BIOS_CNTL_SMM_BWP (BIT5)
-#define B_QNC_LPC_BIOS_CNTL_BCD (BIT2)
-#define B_QNC_LPC_BIOS_CNTL_BLE (BIT1)
-#define B_QNC_LPC_BIOS_CNTL_BIOSWE (BIT0)
-#define N_QNC_LPC_BIOS_CNTL_BLE 1
-#define N_QNC_LPC_BIOS_CNTL_BIOSWE 0
-
-#define R_QNC_LPC_RCBA 0xF0
-#define B_QNC_LPC_RCBA_MASK 0xFFFFC000
-#define B_QNC_LPC_RCBA_EN (BIT0)
-
-//---------------------------------------------------------------------------
-// Fixed IO Decode on QuarkNcSocId
-//
-// 20h(2B) 24h(2B) 28h(2B) 2Ch(2B): R/W 8259 master
-// 30h(2B) 34h(2B) 38h(2B) 3Ch(2B): R/W 8259 master
-// 40h(3B): R/W 8254
-// 43h(1B): W 8254
-// 50h(3B): R/W 8254
-// 53h(1B): W 8254
-// 61h(1B): R/W NMI Controller
-// 63h(1B): R/W NMI Controller - can be disabled
-// 65h(1B): R/W NMI Controller - can be disabled
-// 67h(1B): R/W NMI Controller - can be disabled
-// 70h(1B): W NMI & RTC
-// 71h(1B): R/W RTC
-// 72h(1B): R RTC; W NMI&RTC
-// 73h(1B): R/W RTC
-// 74h(1B): R RTC; W NMI&RTC
-// 75h(1B): R/W RTC
-// 76h(1B): R RTC; W NMI&RTC
-// 77h(1B): R/W RTC
-// 84h(3B): R/W Internal/LPC
-// 88h(1B): R/W Internal/LPC
-// 8Ch(3B): R/W Internal/LPC
-// A0h(2B) A4h(2B) A8h(2B) ACh(2B): R/W 8259 slave
-// B0h(2B): R/W 8259 slave
-// B2h(1B) B3h(1B): R/W Power management
-// B4h(2B) B8h(2B) BCh(2B): R/W 8259 slave
-// 3B0h-3BBh: R/W VGA
-// 3C0h-3DFh: R/W VGA
-// CF8h(4B): R/W Internal
-// CF9h(1B): R/W LPC
-// CFCh(4B): R/W Internal
-//---------------------------------------------------------------------------
-
-#define R_APM_CNT 0xB2
-
-//
-// Reset Generator I/O Port
-//
-#define RST_CNT 0xCF9
-#define B_RST_CNT_COLD_RST (BIT3) // Cold reset
-#define B_RST_CNT_WARM_RST (BIT1) // Warm reset
-
-//
-// Processor interface registers (NMI)
-//
-
-#define PCI_DEVICE_NUMBER_QNC_IOSF2AHB_0 20
-#define PCI_DEVICE_NUMBER_QNC_IOSF2AHB_1 21
-#define PCI_FUNCTION_NUMBER_QNC_IOSF2AHB 0
-
-//
-// Pci Express Root Ports (D23:F0/F1)
-//
-#define PCI_DEVICE_NUMBER_PCIE_ROOTPORT 23
-#define PCI_FUNCTION_NUMBER_PCIE_ROOTPORT_0 0
-#define PCI_FUNCTION_NUMBER_PCIE_ROOTPORT_1 1
-
-#define MAX_PCI_EXPRESS_ROOT_PORTS 2
-
-#define R_QNC_PCIE_BNUM 0x18
-#define R_QNC_PCIE_CAP_PTR 0x34
-
-#define PCIE_CAPID 0x10 //PCIE Capability ID
-#define PCIE_CAP_EXT_HEARDER_OFFSET 0x100 //PCIE Capability ID
-#define PCIE_DEV_CAP_OFFSET 0x04 //PCIE Device Capability offset
-#define PCIE_LINK_CAP_OFFSET 0x0C //PCIE Link Capability offset
-#define PCIE_LINK_CNT_OFFSET 0x10 //PCIE Link control reg offset
-#define PCIE_LINK_STS_OFFSET 0x12 //PCIE Link status reg offset
-#define PCIE_SLOT_CAP_OFFSET 0x14 //PCIE Link Capability offset
-
-#define R_QNC_PCIE_XCAP 0x42 //~ 43h
-#define B_QNC_PCIE_XCAP_SI (BIT8) //slot implemented
-#define R_QNC_PCIE_DCAP 0x44 //~ 47h
-// L1 Acceptable exit latency
-#define B_QNC_PCIE_DCAP_E1AL (BIT11 | BIT10 | BIT9)
-// L0 Acceptable exit latency
-#define B_QNC_PCIE_DCAP_E0AL (BIT8 | BIT7 | BIT6)
-#define R_QNC_PCIE_DCTL 0x48 //~ 49h
-// Reporting Enables
-#define B_QNC_PCIE_DCTL_URE (BIT3) //Unsupported Request
-#define B_QNC_PCIE_DCTL_FEE (BIT2) //Fatal error
-#define B_QNC_PCIE_DCTL_NFE (BIT1) //Non Fatal error
-#define B_QNC_PCIE_DCTL_CEE (BIT0) //Correctable error
-#define R_QNC_PCIE_LCAP 0x4C //~ 4Fh
-#define B_QNC_PCIE_LCAP_CPM (BIT18) //clk Pwr Mgmt supported
-// Exit latency mask
-#define B_QNC_PCIE_LCAP_EL1_MASK (BIT17 | BIT16 | BIT15) //L1 ELM
-#define B_QNC_PCIE_LCAP_EL0_MASK (BIT14 | BIT13 | BIT12) //L0 ELM
-// Active state link PM support
-#define B_QNC_PCIE_LCAP_APMS_MASK (BIT11 | BIT10)
-#define V_QNC_PCIE_LCAP_APMS_OFFSET 10
-#define R_QNC_PCIE_LCTL 0x50 //~ 51h
-#define B_QNC_PCIE_LCTL_CCC (BIT6) // Clock clock config
-#define B_QNC_PCIE_LCTL_RL (BIT5) // Retrain link
-#define R_QNC_PCIE_LSTS 0x52 //~ 53h
-#define B_QNC_PCIE_LSTS_SCC (BIT12) //Slot clock configuration
-#define B_QNC_PCIE_LSTS_LT (BIT11) //Link training
-#define R_QNC_PCIE_SLCAP 0x54 //~ 57h
-#define B_QNC_PCIE_SLCAP_MASK_RSV_VALUE 0x0006007F
-// Slot power limit value [14:7]
-#define V_QNC_PCIE_SLCAP_SLV 0x0A //Slot power limit value
-#define V_QNC_PCIE_SLCAP_SLV_OFFSET 7 //Slot power limit offset
-// Slot number is [31:19]
-#define V_QNC_PCIE_SLCAP_PSN_OFFSET 19 //Slot number offset
-#define R_QNC_PCIE_SLCTL 0x58 //~ 59h
-#define B_QNC_PCIE_SLCTL_HPE (BIT5) // Hot plug intr enable
-#define B_QNC_PCIE_SLCTL_PDE (BIT3) // Presence detect enable
-#define B_QNC_PCIE_SLCTL_ABE (BIT0) // Attn Btn Pressed Enable
-#define R_QNC_PCIE_SLSTS 0x5A //~ 5Bh
-#define B_QNC_PCIE_SLSTS_PDS (BIT6) // Present Detect State
-#define B_QNC_PCIE_SLSTS_PDC (BIT3) // Present Detect changed
-#define B_QNC_PCIE_SLSTS_ABP (BIT0) // Attn Button Pressed
-#define R_QNC_PCIE_RCTL 0x5C //~ 5Dh
-// Root PCI-E Interrupt enables
-#define B_QNC_PCIE_RCTL_PIE (BIT3) // PME Interrupt Enable
-#define B_QNC_PCIE_RCTL_SFE (BIT2) // Fatal Error Enable
-#define B_QNC_PCIE_RCTL_SNE (BIT1) // Non-Fatal Error Enable
-#define B_QNC_PCIE_RCTL_SCE (BIT0) // Correctable Error Enbl
-#define R_QNC_PCIE_SVID 0x94 //~ 97h
-#define R_QNC_PCIE_CCFG 0xD0 //~ D3h
-// Upstream
-#define B_QNC_PCIE_CCFG_UPSD (BIT24) // Posted Split Disable
-#define B_QNC_PCIE_CCFG_UNRS (BIT15) // Non-Posted Rqstd Size
-#define B_QNC_PCIE_CCFG_UPRS (BIT14) // Posted Request Size
-#define R_QNC_PCIE_MPC2 0xD4 //~ D7h
-#define B_QNC_PCIE_MPC2_IPF (BIT11) // ISOF Packet Fast Tx Md
-#define R_QNC_PCIE_MPC 0xD8 //~ DBh
-#define B_QNC_PCIE_MPC_PMCE (BIT31) // PM SCI Enable
-#define B_QNC_PCIE_MPC_HPCE (BIT30) // Hot plug SCI enable
-
-#define B_QNC_PCIE_MPC_HPME (BIT1) // Hot plug SMI enable
-#define B_QNC_PCIE_MPC_PMME (BIT0) // PM SMI Enable
-#define R_QNC_PCIE_IOSFSBCTL 0xF6
-// IOSF Sideband ISM Idle Counter.
-#define B_QNC_PCIE_IOSFSBCTL_SBIC_MASK (BIT1 | BIT0)
-// Never transition to IDLE.
-#define B_QNC_PCIE_IOSFSBCTL_SBIC_IDLE_NEVER (BIT1 | BIT0)
-
-#define V_PCIE_MAX_TRY_TIMES 200
-
-//
-// Misc PCI register offsets and sizes
-//
-#define R_EFI_PCI_SVID 0x2C
-
-//
-// IO_APIC
-//
-#define IOAPIC_BASE 0xFEC00000
-#define IOAPIC_SIZE 0x1000
-
-//
-// Chipset configuration registers RCBA - "Root Complex Base Address"
-// (D31:F0:RF0h)
-// Suggested Value for RCBA = 0xFED1C000
-//
-
-#define R_QNC_RCRB_SPIBASE 0x3020 // Serial Peripheral Interface in RCRB
-#define R_QNC_RCRB_SPIS (R_QNC_RCRB_SPIBASE + 0x00) // SPI Status
-#define B_QNC_RCRB_SPIS_SCL (BIT15) // SPI Configuration Lockdown
-#define B_QNC_RCRB_SPIS_BAS (BIT3) // Blocked Access Status
-#define B_QNC_RCRB_SPIS_CDS (BIT2) // Cycle Done Status
-#define B_QNC_RCRB_SPIS_SCIP (BIT0) // SPI Cycle in Progress
-
-#define R_QNC_RCRB_SPIC (R_QNC_RCRB_SPIBASE + 0x02) // SPI Control
-#define B_QNC_RCRB_SPIC_DC (BIT14) // SPI Data Cycle Enable
-#define B_QNC_RCRB_SPIC_DBC 0x3F00 // SPI Data Byte Count (1..8,16,24,
- // 32,40,48,56,64)
-#define B_QNC_RCRB_SPIC_COP (BIT6+BIT5+BIT4) // SPI Cycle Opcode Pointer
-#define B_QNC_RCRB_SPIC_SPOP (BIT3) // Sequence Prefix Opcode Pointer
-#define B_QNC_RCRB_SPIC_ACS (BIT2) // SPI Atomic Cycle Sequence
-#define B_QNC_RCRB_SPIC_SCGO (BIT1) // SPI Cycle Go
-
-#define R_QNC_RCRB_SPIA (R_QNC_RCRB_SPIBASE + 0x04) // SPI Address
-#define B_QNC_RCRB_SPIA_MASK 0x00FFFFFF // SPI Address mask
-#define R_QNC_RCRB_SPID0 (R_QNC_RCRB_SPIBASE + 0x08)
-// SPI Data 0
-#define R_QNC_RCRB_SPIPREOP (R_QNC_RCRB_SPIBASE + 0x54)
-// Prefix Opcode Configuration
-#define R_QNC_RCRB_SPIOPTYPE (R_QNC_RCRB_SPIBASE + 0x56)
-// Opcode Type Configuration
-#define B_QNC_RCRB_SPIOPTYPE_NOADD_READ 0
-#define B_QNC_RCRB_SPIOPTYPE_NOADD_WRITE (BIT0)
-#define B_QNC_RCRB_SPIOPTYPE_ADD_READ (BIT1)
-#define B_QNC_RCRB_SPIOPTYPE_ADD_WRITE (BIT0 | BIT1)
-// Opcode Menu Configuration //R_OPMENU
-#define R_QNC_RCRB_SPIOPMENU (R_QNC_RCRB_SPIBASE + 0x58)
-
-// Protected BIOS Range 0 - 2
-#define R_QNC_RCRB_SPIPBR0 (R_QNC_RCRB_SPIBASE + 0x60)
-#define R_QNC_RCRB_SPIPBR1 (R_QNC_RCRB_SPIBASE + 0x64)
-#define R_QNC_RCRB_SPIPBR2 (R_QNC_RCRB_SPIBASE + 0x68)
-// Write Protection Enable for above 3 registers.
-#define B_QNC_RCRB_SPIPBRn_WPE (BIT31)
-
-#define R_QNC_RCRB_AGENT0IR 0x3140 // AGENT0 interrupt route
-#define R_QNC_RCRB_AGENT1IR 0x3142 // AGENT1 interrupt route
-#define R_QNC_RCRB_AGENT2IR 0x3144 // AGENT2 interrupt route
-#define R_QNC_RCRB_AGENT3IR 0x3146 // AGENT3 interrupt route
-
-#endif
diff --git a/src/soc/intel/quark/include/soc/acpi.h b/src/soc/intel/quark/include/soc/acpi.h
deleted file mode 100644
index 4a6d5c1eb0..0000000000
--- a/src/soc/intel/quark/include/soc/acpi.h
+++ /dev/null
@@ -1,9 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#ifndef _SOC_ACPI_H_
-#define _SOC_ACPI_H_
-
-#include <acpi/acpi.h>
-#include <acpi/acpigen.h>
-
-#endif /* _SOC_ACPI_H_ */
diff --git a/src/soc/intel/quark/include/soc/car.h b/src/soc/intel/quark/include/soc/car.h
deleted file mode 100644
index afa4ffe0e0..0000000000
--- a/src/soc/intel/quark/include/soc/car.h
+++ /dev/null
@@ -1,16 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#ifndef _SOC_CAR_H_
-#define _SOC_CAR_H_
-
-#include <fsp/util.h>
-
-/* Mainboard and SoC initialization prior to console. */
-void car_mainboard_pre_console_init(void);
-void car_soc_pre_console_init(void);
-
-/* Mainboard and SoC initialization post console initialization. */
-void car_mainboard_post_console_init(void);
-void car_soc_post_console_init(void);
-
-#endif /* _SOC_CAR_H_ */
diff --git a/src/soc/intel/quark/include/soc/cpu.h b/src/soc/intel/quark/include/soc/cpu.h
deleted file mode 100644
index e4bcab1b93..0000000000
--- a/src/soc/intel/quark/include/soc/cpu.h
+++ /dev/null
@@ -1,11 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#ifndef _QUARK_CPU_H_
-#define _QUARK_CPU_H_
-
-#include <device/device.h>
-
-/* Supported CPUIDs */
-#define CPUID_QUARK_X1000 0x590
-
-#endif /* _QUARK_CPU_H_ */
diff --git a/src/soc/intel/quark/include/soc/i2c.h b/src/soc/intel/quark/include/soc/i2c.h
deleted file mode 100644
index f490cd2307..0000000000
--- a/src/soc/intel/quark/include/soc/i2c.h
+++ /dev/null
@@ -1,120 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#ifndef _QUARK_I2C_H_
-#define _QUARK_I2C_H_
-
-#include <stdint.h>
-
-typedef volatile struct _I2C_REGS {
- volatile uint32_t ic_con; /* 00: Control Register */
- volatile uint32_t ic_tar; /* 04: Master Target Address */
- uint32_t reserved_08[2];
- volatile uint32_t ic_data_cmd; /* 10: Data Buffer & Command */
- uint32_t ic_ss_scl_hcnt; /* 14: Standard Speed Clock SCL High Count */
- uint32_t ic_ss_scl_lcnt; /* 18: Standard Speed Clock SCL Low Count */
- uint32_t ic_fs_scl_hcnt; /* 1c: Fast Speed Clock SCL High Count */
- uint32_t ic_fs_scl_lcnt; /* 20: Fast Speed Clock SCL Low Count */
- uint32_t reserved_24[2];
- volatile uint32_t ic_intr_stat; /* 2c: Interrupt Status */
- uint32_t ic_intr_mask; /* 30: Interrupt Mask */
- uint32_t ic_raw_intr_stat; /* 34: Raw Interrupt Status */
- uint32_t ic_rx_tl; /* 38: Receive FIFO Threshold Level */
- uint32_t ic_tx_tl; /* 3c: Transmit FIFO Threshold Level */
- uint32_t ic_clr_intr; /* 40: Clear Combined/Individual Interrupt */
- uint32_t ic_clr_rx_under; /* 44: Clear RX_UNDER Interrupt */
- uint32_t ic_clr_rx_over; /* 48: Clear RX_OVER Interrupt */
- uint32_t ic_clr_tx_over; /* 4c: Clear TX_OVER Interrupt */
- uint32_t ic_clr_rd_req; /* 50: Clear RD_REQ Interrupt */
- uint32_t ic_clr_tx_abrt; /* 54: Clear TX_ABRT Interrupt */
- uint32_t reserved_58;
- uint32_t ic_clr_activity; /* 5c: Clear ACTIVITY Interrupt */
- uint32_t ic_clr_stop_det; /* 60: Clear STOP_DET Interrupt */
- uint32_t ic_clr_start_det; /* 64: Clear START_DET Interrupt */
- uint32_t reserved_68;
- volatile uint32_t ic_enable; /* 6c: Enable */
- volatile uint32_t ic_status; /* 70: Status */
- uint32_t ic_txflr; /* 74: Transmit FIFO Level */
- uint32_t ic_rxflr; /* 78: Receive FIFO Level */
- uint32_t ic_sda_hold; /* 7c: SDA Hold */
- volatile uint32_t ic_tx_abrt_source; /* 80: Transmit Abort Source */
- uint32_t reserved_84[6];
- volatile uint32_t ic_enable_status; /* 9c: Enable Status */
- uint32_t ic_fs_spklen; /* a0: SS and FS Spike Suppression Limit */
-} I2C_REGS;
-
-#define IC_CON offsetof(I2C_REGS, ic_con)
-#define IC_TAR offsetof(I2C_REGS, ic_tar)
-#define IC_DATA_CMD offsetof(I2C_REGS, ic_data_cmd)
-#define IC_SS_SCL_HCNT offsetof(I2C_REGS, ic_ss_scl_hcnt)
-#define IC_SS_SCL_LCNT offsetof(I2C_REGS, ic_ss_scl_lcnt)
-#define IC_FS_SCL_HCNT offsetof(I2C_REGS, ic_fs_scl_hcnt)
-#define IC_FS_SCL_LCNT offsetof(I2C_REGS, ic_fs_scl_lcnt)
-#define IC_INTR_STAT offsetof(I2C_REGS, ic_intr_stat)
-#define IC_INTR_MASK offsetof(I2C_REGS, ic_intr_mask)
-#define IC_RAW_INTR_STAT offsetof(I2C_REGS, ic_raw_intr_stat)
-#define IC_RX_TL offsetof(I2C_REGS, ic_rx_tl)
-#define IC_TX_TL offsetof(I2C_REGS, ic_tx_tl)
-#define IC_CLR_INTR offsetof(I2C_REGS, ic_clr_intr)
-#define IC_CLR_RX_UNDER offsetof(I2C_REGS, ic_clr_rx_under)
-#define IC_CLR_RX_OVER offsetof(I2C_REGS, ic_clr_rx_over)
-#define IC_CLR_TX_OVER offsetof(I2C_REGS, ic_clr_tx_over)
-#define IC_CLR_RD_REQ offsetof(I2C_REGS, ic_clr_rd_req)
-#define IC_CLR_TX_ABRT offsetof(I2C_REGS, ic_clr_tx_abrt)
-#define IC_CLR_ACTIVITY offsetof(I2C_REGS, ic_clr_activity)
-#define IC_CLR_STOP_DET offsetof(I2C_REGS, ic_clr_stop_det)
-#define IC_CLR_START_DET offsetof(I2C_REGS, ic_clr_start_det)
-#define IC_ENABLE offsetof(I2C_REGS, ic_enable)
-#define IC_STATUS offsetof(I2C_REGS, ic_status)
-#define IC_TXFLR offsetof(I2C_REGS, ic_txflr)
-#define IC_RXFLR offsetof(I2C_REGS, ic_rxflr)
-#define IC_SDA_HOLD offsetof(I2C_REGS, ic_sda_hold)
-#define IC_TX_ABRT_SOURCE offsetof(I2C_REGS, ic_tx_abrt_source)
-#define IC_ENABLE_STATUS offsetof(I2C_REGS, ic_enable_status)
-#define IC_FS_SPKLEN offsetof(I2C_REGS, ic_fs_spklen)
-
-/* 0x00: ic_con */
-#define IC_CON_RESTART_EN 0x00000020 /* Enable start/restart */
-#define IC_CON_10B 0x00000010 /* 10-bit addressing */
-#define IC_CON_7B 0 /* 7-bit addressing */
-#define IC_CON_SPEED 0x00000006 /* I2C bus speed */
-#define IC_CON_SPEED_400_KHz 0x00000004 /* Fast mode */
-#define IC_CON_SPEED_100_KHz 0x00000002 /* Standard mode */
-#define IC_CON_MASTER_MODE 0x00000001 /* Enable master mode */
-
-/* 0x10: ic_data_cmd */
-#define IC_DATA_CMD_RESTART 0x00000400 /* Send restart before byte */
-#define IC_DATA_CMD_STOP 0x00000200 /* Send stop after byte */
-#define IC_DATA_CMD_CMD 0x00000100 /* Type of transaction */
-#define IC_DATA_CMD_READ IC_DATA_CMD_CMD
-#define IC_DATA_CMD_WRITE 0
-#define IC_DATA_CMD_DATA 0x000000ff /* Data byte */
-
-/* 0x2c: ic_intr_stat
- * 0x30: ic_intr_mask
- * 0x34: ic_raw_intr_stat
- */
-#define IC_INTR_START_DET 0x00000400 /* Start bit detected */
-#define IC_INTR_STOP_DET 0x00000200 /* Stop bit detected */
-#define IC_INTR_ACTIVITY 0x00000100 /* Activity detected */
-#define IC_INTR_TX_ABRT 0x00000040 /* Transmit abort */
-#define IC_INTR_RD_REQ 0x00000020 /* Read request */
-#define IC_INTR_TX_EMPTY 0x00000010 /* TX FIFO is empty */
-#define IC_INTR_TX_OVER 0x00000008 /* TX FIFO overflow */
-#define IC_INTR_RX_FULL 0x00000004 /* Receive FIFO is full */
-#define IC_INTR_RX_OVER 0x00000002 /* Receive FIFO overflow */
-#define IC_INTR_RX_UNDER 0x00000001 /* Receive FIFO underflow */
-
-/* 0x6c: ic_enable
- * 0x9c: ic_enable_status
- */
-#define IC_ENABLE_CONTROLLER 0x00000001 /* Enable the I2C controller */
-
-/* 0x70: ic_status */
-#define IC_STATUS_MST_ACTIVITY 0x00000020 /* Master FSM activity */
-#define IC_STATUS_RFF 0x00000010 /* Receive FIFO completely full */
-#define IC_STATUS_RFNE 0x00000008 /* Receive FIFO not empty */
-#define IC_STATUS_TFE 0x00000004 /* Transmit FIFO completely empty */
-#define IC_STATUS_TFNF 0x00000002 /* Transmit FIFO not full */
-#define IC_STATUS_ACTIVITY 0x00000001 /* Activity */
-
-#endif /* _QUARK_I2C_H_ */
diff --git a/src/soc/intel/quark/include/soc/iomap.h b/src/soc/intel/quark/include/soc/iomap.h
deleted file mode 100644
index 0da34c28b8..0000000000
--- a/src/soc/intel/quark/include/soc/iomap.h
+++ /dev/null
@@ -1,34 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#ifndef _QUARK_IOMAP_H_
-#define _QUARK_IOMAP_H_
-
-/*
- * Memory Mapped IO base addresses.
- */
-
-/* UART MMIO */
-#define UART_BASE_ADDRESS CONFIG_TTYS0_BASE
-
-/* I2C/GPIO Controller */
-#define I2C_BASE_ADDRESS 0xa0020000
-#define GPIO_BASE_ADDRESS 0xa0021000
-
-/* Temporary BAR for SD controller */
-#define SD_BASE_ADDRESS 0xa0022000
-
-/*
- * I/O port address space
- */
-#define GPE0_BASE_ADDRESS 0x2000
-#define GPE0_SIZE 0x40
-
-#define PM1BLK_BASE_ADDRESS 0x2040
-#define PM1BLK_SIZE 0x10
-
-#define LEGACY_GPIO_BASE_ADDRESS 0x2080
-#define LEGACY_GPIO_SIZE 0x80
-
-#define IO_ADDRESS_VALID 0x80000000
-
-#endif /* _QUARK_IOMAP_H_ */
diff --git a/src/soc/intel/quark/include/soc/nvs.h b/src/soc/intel/quark/include/soc/nvs.h
deleted file mode 100644
index 9974d5b5e5..0000000000
--- a/src/soc/intel/quark/include/soc/nvs.h
+++ /dev/null
@@ -1,17 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#ifndef SOC_INTEL_QUARK_NVS_H
-#define SOC_INTEL_QUARK_NVS_H
-
-#include <stdint.h>
-
-struct __packed global_nvs {
- uint32_t cbmc; /* 0x00 - 0x03 - coreboot Memory Console */
- uint8_t unused_was_pwrs; /* 0x4 - Power state (AC = 1) */
-
- /* Required for future unified acpi_save_wake_source. */
- uint32_t pm1i;
- uint32_t gpei;
-};
-
-#endif /* SOC_INTEL_QUARK_NVS_H */
diff --git a/src/soc/intel/quark/include/soc/pci_devs.h b/src/soc/intel/quark/include/soc/pci_devs.h
deleted file mode 100644
index 11594f5148..0000000000
--- a/src/soc/intel/quark/include/soc/pci_devs.h
+++ /dev/null
@@ -1,54 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#ifndef _QUARK_PCI_DEVS_H_
-#define _QUARK_PCI_DEVS_H_
-
-#include <device/pci.h>
-
-/* DEVICE 0 (Memory Controller Hub) */
-#define MC_BDF PCI_DEV(PCI_BUS_NUMBER_QNC, MC_DEV, MC_FUN)
-
-/* Device IDs */
-#define I2CGPIO_DEVID 0x0934
-#define HSUART_DEVID 0x0936
-#define EHCI_DEVID 0x0939
-#define LPC_DEVID 0x095E
-#define PCIE_PORT0_DEVID 0x11c3
-#define PCIE_PORT1_DEVID 0x11c4
-
-/* IO Fabric 1 */
-#define SIO1_DEV 0x14
-#define SD_MMC_DEV SIO1_DEV
-#define HSUART0_DEV SIO1_DEV
-#define HSUART1_DEV SIO1_DEV
-#define SD_MMC_FUNC 0
-#define HSUART0_FUNC 1
-#define USB_DEV_PORT_FUNC 2
-#define EHCI_FUNC 3
-#define OHCI_FUNC 4
-#define HSUART1_FUNC 5
-#define HSUART0_BDF PCI_DEV(PCI_BUS_NUMBER_QNC, HSUART0_DEV, HSUART0_FUNC)
-#define HSUART1_BDF PCI_DEV(PCI_BUS_NUMBER_QNC, HSUART1_DEV, HSUART1_FUNC)
-
-/* IO Fabric 2 */
-#define SIO2_DEV 0x15
-#define I2CGPIO_DEV SIO2_DEV
-#define I2CGPIO_FUNC 2
-#define I2CGPIO_BDF PCI_DEV(PCI_BUS_NUMBER_QNC, I2CGPIO_DEV, I2CGPIO_FUNC)
-
-/* PCIe Ports */
-#define PCIE_DEV 0x17
-#define PCIE_PORT0_DEV PCIE_DEV
-#define PCIE_PORT0_FUNC 0
-#define PCIE_PORT0_BDF PCI_DEV(PCI_BUS_NUMBER_QNC, PCIE_DEV, PCIE_PORT0_FUNC)
-
-#define PCIE_PORT1_DEV PCIE_DEV
-#define PCIE_PORT1_FUNC 1
-#define PCIE_PORT1_BDF PCI_DEV(PCI_BUS_NUMBER_QNC, PCIE_DEV, PCIE_PORT1_FUNC)
-
-/* Platform Controller Unit */
-#define LPC_DEV PCI_DEVICE_NUMBER_QNC_LPC
-#define LPC_FUNC PCI_FUNCTION_NUMBER_QNC_LPC
-#define LPC_BDF PCI_DEV(PCI_BUS_NUMBER_QNC, LPC_DEV, LPC_FUNC)
-
-#endif /* _QUARK_PCI_DEVS_H_ */
diff --git a/src/soc/intel/quark/include/soc/pei_wrapper.h b/src/soc/intel/quark/include/soc/pei_wrapper.h
deleted file mode 100644
index 5c52d3b39b..0000000000
--- a/src/soc/intel/quark/include/soc/pei_wrapper.h
+++ /dev/null
@@ -1,31 +0,0 @@
-/* SPDX-License-Identifier: BSD-3-Clause */
-
-#ifndef _PEI_WRAPPER_H_
-#define _PEI_WRAPPER_H_
-
-#include <types.h>
-
-#define PEI_VERSION 22
-
-#define ABI_X86 __attribute__((regparm(0)))
-
-typedef void ABI_X86(*tx_byte_func)(unsigned char byte);
-
-struct pei_data {
- uint32_t pei_version;
-
- int boot_mode;
-
- /* Data read from flash and passed into MRC */
- const void *saved_data;
- int saved_data_size;
-
- /* Disable use of saved data (can be set by mainboard) */
- int disable_saved_data;
-
- /* Data from MRC that should be saved to flash */
- void *data_to_save;
- int data_to_save_size;
-} __packed;
-
-#endif /* _PEI_WRAPPER_H_ */
diff --git a/src/soc/intel/quark/include/soc/pm.h b/src/soc/intel/quark/include/soc/pm.h
deleted file mode 100644
index 7a08c6ed9a..0000000000
--- a/src/soc/intel/quark/include/soc/pm.h
+++ /dev/null
@@ -1,19 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#ifndef _SOC_PM_H_
-#define _SOC_PM_H_
-
-#include <stdint.h>
-#include <acpi/acpi.h>
-
-struct chipset_power_state {
- uint32_t prev_sleep_state;
-} __packed;
-
-struct chipset_power_state *get_power_state(void);
-int fill_power_state(void);
-
-/* STM Support */
-uint16_t get_pmbase(void);
-
-#endif /* _SOC_PM_H_ */
diff --git a/src/soc/intel/quark/include/soc/ramstage.h b/src/soc/intel/quark/include/soc/ramstage.h
deleted file mode 100644
index 3002322ffb..0000000000
--- a/src/soc/intel/quark/include/soc/ramstage.h
+++ /dev/null
@@ -1,15 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#ifndef _SOC_RAMSTAGE_H_
-#define _SOC_RAMSTAGE_H_
-
-#include <cpu/cpu.h>
-#include <device/device.h>
-#include <soc/QuarkNcSocId.h>
-
-#include "../../chip.h"
-
-void mainboard_gpio_i2c_init(struct device *dev);
-asmlinkage void chipset_teardown_car(void);
-
-#endif /* _SOC_RAMSTAGE_H_ */
diff --git a/src/soc/intel/quark/include/soc/reg_access.h b/src/soc/intel/quark/include/soc/reg_access.h
deleted file mode 100644
index 1f186f781c..0000000000
--- a/src/soc/intel/quark/include/soc/reg_access.h
+++ /dev/null
@@ -1,247 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#ifndef _QUARK_REG_ACCESS_H_
-#define _QUARK_REG_ACCESS_H_
-
-#include <cpu/x86/cr.h>
-#include <fsp/util.h>
-#include <reg_script.h>
-#include <soc/IntelQNCConfig.h>
-#include <soc/Ioh.h>
-#include <soc/QuarkNcSocId.h>
-
-enum {
- USB_PHY_REGS = 1,
- SOC_UNIT_REGS,
- RMU_TEMP_REGS,
- MICROSECOND_DELAY,
- LEG_GPIO_REGS,
- GPIO_REGS,
- PCIE_AFE_REGS,
- PCIE_RESET,
- GPE0_REGS,
- HOST_BRIDGE,
- CPU_CR,
-};
-
-enum {
- SOC_TYPE = REG_SCRIPT_TYPE_SOC_BASE,
- /* Add additional SOC access types here*/
-};
-
-#define SOC_ACCESS(cmd_, reg_, size_, mask_, value_, timeout_, reg_set_) \
- _REG_SCRIPT_ENCODE_RAW(REG_SCRIPT_COMMAND_##cmd_, SOC_TYPE, \
- size_, reg_, mask_, value_, timeout_, reg_set_)
-
-/* CPU CRx register access macros */
-#define REG_CPU_CR_ACCESS(cmd_, reg_, mask_, value_, timeout_) \
- SOC_ACCESS(cmd_, reg_, REG_SCRIPT_SIZE_32, mask_, value_, timeout_, \
- CPU_CR)
-#define REG_CPU_CR_READ(reg_) \
- REG_CPU_CR_ACCESS(READ, reg_, 0, 0, 0)
-#define REG_CPU_CR_WRITE(reg_, value_) \
- REG_CPU_CR_ACCESS(WRITE, reg_, 0, value_, 0)
-#define REG_CPU_CR_AND(reg_, value_) \
- REG_CPU_CR_RMW(reg_, value_, 0)
-#define REG_CPU_CR_RMW(reg_, mask_, value_) \
- REG_CPU_CR_ACCESS(RMW, reg_, mask_, value_, 0)
-#define REG_CPU_CR_RXW(reg_, mask_, value_) \
- REG_CPU_CR_ACCESS(RXW, reg_, mask_, value_, 0)
-#define REG_CPU_CR_OR(reg_, value_) \
- REG_CPU_CR_RMW(reg_, 0xffffffff, value_)
-#define REG_CPU_CR_POLL(reg_, mask_, value_, timeout_) \
- REG_CPU_CR_ACCESS(POLL, reg_, mask_, value_, timeout_)
-#define REG_CPU_CR_XOR(reg_, value_) \
- REG_CPU_CR_RXW(reg_, 0xffffffff, value_)
-
-/* GPE0 controller register access macros */
-#define REG_GPE0_ACCESS(cmd_, reg_, mask_, value_, timeout_) \
- SOC_ACCESS(cmd_, reg_, REG_SCRIPT_SIZE_32, mask_, value_, timeout_, \
- GPE0_REGS)
-#define REG_GPE0_READ(reg_) \
- REG_GPE0_ACCESS(READ, reg_, 0, 0, 0)
-#define REG_GPE0_WRITE(reg_, value_) \
- REG_GPE0_ACCESS(WRITE, reg_, 0, value_, 0)
-#define REG_GPE0_AND(reg_, value_) \
- REG_GPE0_RMW(reg_, value_, 0)
-#define REG_GPE0_RMW(reg_, mask_, value_) \
- REG_GPE0_ACCESS(RMW, reg_, mask_, value_, 0)
-#define REG_GPE0_RXW(reg_, mask_, value_) \
- REG_GPE0_ACCESS(RXW, reg_, mask_, value_, 0)
-#define REG_GPE0_OR(reg_, value_) \
- REG_GPE0_RMW(reg_, 0xffffffff, value_)
-#define REG_GPE0_POLL(reg_, mask_, value_, timeout_) \
- REG_GPE0_ACCESS(POLL, reg_, mask_, value_, timeout_)
-#define REG_GPE0_XOR(reg_, value_) \
- REG_GPE0_RXW(reg_, 0xffffffff, value_)
-
-/* GPIO controller register access macros */
-#define REG_GPIO_ACCESS(cmd_, reg_, mask_, value_, timeout_) \
- SOC_ACCESS(cmd_, reg_, REG_SCRIPT_SIZE_32, mask_, value_, timeout_, \
- GPIO_REGS)
-#define REG_GPIO_READ(reg_) \
- REG_GPIO_ACCESS(READ, reg_, 0, 0, 0)
-#define REG_GPIO_WRITE(reg_, value_) \
- REG_GPIO_ACCESS(WRITE, reg_, 0, value_, 0)
-#define REG_GPIO_AND(reg_, value_) \
- REG_GPIO_RMW(reg_, value_, 0)
-#define REG_GPIO_RMW(reg_, mask_, value_) \
- REG_GPIO_ACCESS(RMW, reg_, mask_, value_, 0)
-#define REG_GPIO_RXW(reg_, mask_, value_) \
- REG_GPIO_ACCESS(RXW, reg_, mask_, value_, 0)
-#define REG_GPIO_OR(reg_, value_) \
- REG_GPIO_RMW(reg_, 0xffffffff, value_)
-#define REG_GPIO_POLL(reg_, mask_, value_, timeout_) \
- REG_GPIO_ACCESS(POLL, reg_, mask_, value_, timeout_)
-#define REG_GPIO_XOR(reg_, value_) \
- REG_GPIO_RXW(reg_, 0xffffffff, value_)
-
-/* Host bridge register access macros */
-#define REG_HOST_BRIDGE_ACCESS(cmd_, reg_, mask_, value_, timeout_) \
- SOC_ACCESS(cmd_, reg_, REG_SCRIPT_SIZE_32, mask_, value_, timeout_, \
- HOST_BRIDGE)
-#define REG_HOST_BRIDGE_READ(reg_) \
- REG_HOST_BRIDGE_ACCESS(READ, reg_, 0, 0, 0)
-#define REG_HOST_BRIDGE_WRITE(reg_, value_) \
- REG_HOST_BRIDGE_ACCESS(WRITE, reg_, 0, value_, 0)
-#define REG_HOST_BRIDGE_AND(reg_, value_) \
- REG_HOST_BRIDGE_RMW(reg_, value_, 0)
-#define REG_HOST_BRIDGE_RMW(reg_, mask_, value_) \
- REG_HOST_BRIDGE_ACCESS(RMW, reg_, mask_, value_, 0)
-#define REG_HOST_BRIDGE_RXW(reg_, mask_, value_) \
- REG_HOST_BRIDGE_ACCESS(RXW, reg_, mask_, value_, 0)
-#define REG_HOST_BRIDGE_OR(reg_, value_) \
- REG_HOST_BRIDGE_RMW(reg_, 0xffffffff, value_)
-#define REG_HOST_BRIDGE_POLL(reg_, mask_, value_, timeout_) \
- REG_HOST_BRIDGE_ACCESS(POLL, reg_, mask_, value_, timeout_)
-#define REG_HOST_BRIDGE_XOR(reg_, value_) \
- REG_HOST_BRIDGE_RXW(reg_, 0xffffffff, value_)
-
-/* Legacy GPIO register access macros */
-#define REG_LEG_GPIO_ACCESS(cmd_, reg_, mask_, value_, timeout_) \
- SOC_ACCESS(cmd_, reg_, REG_SCRIPT_SIZE_32, mask_, value_, timeout_, \
- LEG_GPIO_REGS)
-#define REG_LEG_GPIO_READ(reg_) \
- REG_LEG_GPIO_ACCESS(READ, reg_, 0, 0, 0)
-#define REG_LEG_GPIO_WRITE(reg_, value_) \
- REG_LEG_GPIO_ACCESS(WRITE, reg_, 0, value_, 0)
-#define REG_LEG_GPIO_AND(reg_, value_) \
- REG_LEG_GPIO_RMW(reg_, value_, 0)
-#define REG_LEG_GPIO_RMW(reg_, mask_, value_) \
- REG_LEG_GPIO_ACCESS(RMW, reg_, mask_, value_, 0)
-#define REG_LEG_GPIO_RXW(reg_, mask_, value_) \
- REG_LEG_GPIO_ACCESS(RXW, reg_, mask_, value_, 0)
-#define REG_LEG_GPIO_OR(reg_, value_) \
- REG_LEG_GPIO_RMW(reg_, 0xffffffff, value_)
-#define REG_LEG_GPIO_POLL(reg_, mask_, value_, timeout_) \
- REG_LEG_GPIO_ACCESS(POLL, reg_, mask_, value_, timeout_)
-#define REG_LEG_GPIO_XOR(reg_, value_) \
- REG_LEG_GPIO_RXW(reg_, 0xffffffff, value_)
-
-/* PCIE AFE register access macros */
-#define REG_PCIE_AFE_ACCESS(cmd_, reg_, mask_, value_, timeout_) \
- SOC_ACCESS(cmd_, reg_, REG_SCRIPT_SIZE_32, mask_, value_, timeout_, \
- PCIE_AFE_REGS)
-#define REG_PCIE_AFE_READ(reg_) \
- REG_PCIE_AFE_ACCESS(READ, reg_, 0, 0, 0)
-#define REG_PCIE_AFE_WRITE(reg_, value_) \
- REG_PCIE_AFE_ACCESS(WRITE, reg_, 0, value_, 0)
-#define REG_PCIE_AFE_AND(reg_, value_) \
- REG_PCIE_AFE_RMW(reg_, value_, 0)
-#define REG_PCIE_AFE_RMW(reg_, mask_, value_) \
- REG_PCIE_AFE_ACCESS(RMW, reg_, mask_, value_, 0)
-#define REG_PCIE_AFE_RXW(reg_, mask_, value_) \
- REG_PCIE_AFE_ACCESS(RXW, reg_, mask_, value_, 0)
-#define REG_PCIE_AFE_OR(reg_, value_) \
- REG_PCIE_AFE_RMW(reg_, 0xffffffff, value_)
-#define REG_PCIE_AFE_POLL(reg_, mask_, value_, timeout_) \
- REG_PCIE_AFE_ACCESS(POLL, reg_, mask_, value_, timeout_)
-#define REG_PCIE_AFE_XOR(reg_, value_) \
- REG_PCIE_AFE_RXW(reg_, 0xffffffff, value_)
-
-/* PCIe reset */
-#define MAINBOARD_PCIE_RESET(pin_value_) \
- SOC_ACCESS(WRITE, 0, REG_SCRIPT_SIZE_32, 1, pin_value_, 0, PCIE_RESET)
-
-/* RMU temperature register access macros */
-#define REG_RMU_TEMP_ACCESS(cmd_, reg_, mask_, value_, timeout_) \
- SOC_ACCESS(cmd_, reg_, REG_SCRIPT_SIZE_32, mask_, value_, timeout_, \
- RMU_TEMP_REGS)
-#define REG_RMU_TEMP_READ(reg_) \
- REG_RMU_TEMP_ACCESS(READ, reg_, 0, 0, 0)
-#define REG_RMU_TEMP_WRITE(reg_, value_) \
- REG_RMU_TEMP_ACCESS(WRITE, reg_, 0, value_, 0)
-#define REG_RMU_TEMP_AND(reg_, value_) \
- REG_RMU_TEMP_RMW(reg_, value_, 0)
-#define REG_RMU_TEMP_RMW(reg_, mask_, value_) \
- REG_RMU_TEMP_ACCESS(RMW, reg_, mask_, value_, 0)
-#define REG_RMU_TEMP_RXW(reg_, mask_, value_) \
- REG_RMU_TEMP_ACCESS(RXW, reg_, mask_, value_, 0)
-#define REG_RMU_TEMP_OR(reg_, value_) \
- REG_RMU_TEMP_RMW(reg_, 0xffffffff, value_)
-#define REG_RMU_TEMP_POLL(reg_, mask_, value_, timeout_) \
- REG_RMU_TEMP_ACCESS(POLL, reg_, mask_, value_, timeout_)
-#define REG_RMU_TEMP_XOR(reg_, value_) \
- REG_RMU_TEMP_RXW(reg_, 0xffffffff, value_)
-
-/* Temperature sensor access macros */
-#define REG_SOC_UNIT_ACCESS(cmd_, reg_, mask_, value_, timeout_) \
- SOC_ACCESS(cmd_, reg_, REG_SCRIPT_SIZE_32, mask_, value_, timeout_, \
- SOC_UNIT_REGS)
-#define REG_SOC_UNIT_READ(reg_) \
- REG_SOC_UNIT_ACCESS(READ, reg_, 0, 0, 0)
-#define REG_SOC_UNIT_WRITE(reg_, value_) \
- REG_SOC_UNIT_ACCESS(WRITE, reg_, 0, value_, 0)
-#define REG_SOC_UNIT_AND(reg_, value_) \
- REG_SOC_UNIT_RMW(reg_, value_, 0)
-#define REG_SOC_UNIT_RMW(reg_, mask_, value_) \
- REG_SOC_UNIT_ACCESS(RMW, reg_, mask_, value_, 0)
-#define REG_SOC_UNIT_RXW(reg_, mask_, value_) \
- REG_SOC_UNIT_ACCESS(RXW, reg_, mask_, value_, 0)
-#define REG_SOC_UNIT_OR(reg_, value_) \
- REG_SOC_UNIT_RMW(reg_, 0xffffffff, value_)
-#define REG_SOC_UNIT_POLL(reg_, mask_, value_, timeout_) \
- REG_SOC_UNIT_ACCESS(POLL, reg_, mask_, value_, timeout_)
-#define REG_SOC_UNIT_XOR(reg_, value_) \
- REG_SOC_UNIT_RXW(reg_, 0xffffffff, value_)
-
-/* Time delays */
-#define TIME_DELAY_USEC(value_) \
- SOC_ACCESS(WRITE, 0, REG_SCRIPT_SIZE_32, 0, value_, 0, \
- MICROSECOND_DELAY)
-
-/* USB register access macros */
-#define REG_USB_ACCESS(cmd_, reg_, mask_, value_, timeout_) \
- SOC_ACCESS(cmd_, reg_, REG_SCRIPT_SIZE_32, mask_, value_, timeout_, \
- USB_PHY_REGS)
-#define REG_USB_READ(reg_) \
- REG_USB_ACCESS(READ, reg_, 0, 0, 0)
-#define REG_USB_WRITE(reg_, value_) \
- REG_USB_ACCESS(WRITE, reg_, 0, value_, 0)
-#define REG_USB_AND(reg_, value_) \
- REG_USB_RMW(reg_, value_, 0)
-#define REG_USB_RMW(reg_, mask_, value_) \
- REG_USB_ACCESS(RMW, reg_, mask_, value_, 0)
-#define REG_USB_RXW(reg_, mask_, value_) \
- REG_USB_ACCESS(RXW, reg_, mask_, value_, 0)
-#define REG_USB_OR(reg_, value_) \
- REG_USB_RMW(reg_, 0xffffffff, value_)
-#define REG_USB_POLL(reg_, mask_, value_, timeout_) \
- REG_USB_ACCESS(POLL, reg_, mask_, value_, timeout_)
-#define REG_USB_XOR(reg_, value_) \
- REG_USB_RXW(reg_, 0xffffffff, value_)
-
-void *get_i2c_address(void);
-void mainboard_gpio_pcie_reset(uint32_t pin_value);
-void mcr_write(uint8_t opcode, uint8_t port, uint32_t reg_address);
-uint32_t mdr_read(void);
-void mdr_write(uint32_t value);
-void mea_write(uint32_t reg_address);
-uint32_t port_reg_read(uint8_t port, uint32_t offset);
-void port_reg_write(uint8_t port, uint32_t offset, uint32_t value);
-uint32_t reg_host_bridge_unit_read(uint32_t reg_address);
-uint32_t reg_legacy_gpio_read(uint32_t reg_address);
-void reg_legacy_gpio_write(uint32_t reg_address, uint32_t value);
-uint32_t reg_rmu_temp_read(uint32_t reg_address);
-
-#endif /* _QUARK_REG_ACCESS_H_ */
diff --git a/src/soc/intel/quark/include/soc/romstage.h b/src/soc/intel/quark/include/soc/romstage.h
deleted file mode 100644
index 5e08c4b2af..0000000000
--- a/src/soc/intel/quark/include/soc/romstage.h
+++ /dev/null
@@ -1,16 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#ifndef _QUARK_ROMSTAGE_H_
-#define _QUARK_ROMSTAGE_H_
-
-#include <soc/car.h>
-#include <soc/reg_access.h>
-
-void clear_smi_and_wake_events(void);
-void disable_rom_shadow(void);
-void *locate_rmu_file(size_t *rmu_file_len);
-void report_platform_info(void);
-int set_base_address_and_enable_uart(u8 bus, u8 dev, u8 func, u32 mmio_base);
-void pcie_init(void);
-
-#endif /* _QUARK_ROMSTAGE_H_ */
diff --git a/src/soc/intel/quark/include/soc/sd.h b/src/soc/intel/quark/include/soc/sd.h
deleted file mode 100644
index a59f36dc7c..0000000000
--- a/src/soc/intel/quark/include/soc/sd.h
+++ /dev/null
@@ -1,13 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#ifndef _QUARK_SD_H_
-#define _QUARK_SD_H_
-
-#define SD_PFA (0x14 << 11) /* B0:D20:F0 - SDIO controller */
-#define SD_CFG_BASE (PCI_CFG | SD_PFA) /* SD cntrl base in PCI config space */
-#define SD_CFG_CMD (SD_CFG_BASE+0x04) /* Command reg in PCI config space */
-#define SD_CFG_ADDR (SD_CFG_BASE+0x10) /* Base address in PCI config space */
-#define SD_BASE_ADDR (0xA0018000) /* SD controller's base address */
-#define SD_HOST_CTRL (SD_BASE_ADDR+0x28) /* HOST_CTRL register */
-
-#endif /* _QUARK_SD_H_ */
diff --git a/src/soc/intel/quark/include/soc/spi.h b/src/soc/intel/quark/include/soc/spi.h
deleted file mode 100644
index 505d2d1ad0..0000000000
--- a/src/soc/intel/quark/include/soc/spi.h
+++ /dev/null
@@ -1,82 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#ifndef __SOC_SPI_H__
-#define __SOC_SPI_H__
-
-#include <spi_flash.h>
-#include <spi-generic.h>
-
-#define SPISTS 0x3020 /* Status register */
-#define SPICTL 0x3022 /* Control register */
-#define SPIADDR 0x3024 /* Flash chip select and 24-bit address */
-#define SPIDATA 0x3028 /* 64-byte send/receive data buffer */
-#define SPIBBAR 0x3070 /* BIOS base address */
-#define SPIPREOP 0x3074 /* Prefix opcode table */
-#define SPITYPE 0x3076 /* Opcode type table */
-#define SPIOPMENU 0x3078 /* Opcode table */
-#define SPIPBR0 0x3080 /* Protected BIOS range */
-#define SPIPBR1 0x3084
-#define SPIPBR2 0x3088
-
-struct flash_ctrlr {
- uint8_t rsvd_0x00[0x3020];/* 0x00 */
- uint16_t status; /* 0x3020: Status register */
- uint16_t control; /* 0x3022: Control register */
- uint32_t address; /* 0x3024: Chip select and 24-bit address */
- uint8_t data[64]; /* 0x3028: 64-byte send/receive data buffer */
- uint8_t rsvd_0x68[8]; /* 0x3068 */
- uint32_t bbar; /* 0x3070: BIOS base address */
- uint8_t prefix[2]; /* 0x3074: Prefix opcode table */
- uint16_t type; /* 0x3076: Opcode type table */
- uint8_t opmenu[8]; /* 0x3078: Opcode table */
- uint32_t pbr[3]; /* 0x3080: Protected BIOS range */
-};
-
-/* 0x3020: SPISTS */
-#define SPISTS_CLD 0x8000 /* Lock SPI controller configuration */
-#define SPISTS_BA 0x0008 /* Access is blocked */
-#define SPISTS_CD 0x0004 /* Cycle done */
-#define SPISTS_CIP 0x0001 /* Cycle in progress */
-
-/* 0x3022: SPICTL */
-#define SPICTL_SMIEN 0x8000 /* Assert SMI_B at cycle done */
-#define SPICTL_DC 0x4000 /* Cycle contains data */
-#define SPICTL_DBCNT 0x3f00 /* Data byte count - 1, 1 - 64 bytes */
-#define SPICTL_DBCNT_SHIFT 8
-#define SPICTL_COPTR 0x0070 /* Opcode menu index, 0 - 7 */
-#define SPICTL_COPTR_SHIFT 4
-#define SPICTL_SOPTR 0x0008 /* Prefix index, 0 - 1 */
-#define SPICTL_SOPTR_SHIFT 3
-#define SPICTL_ACS 0x0004 /* Atomic cycle sequence */
-#define SPICTL_CG 0x0002 /* Cycle go */
-#define SPICTL_AR 0x0001 /* Access request */
-
-/* 0x3076: SPITYPE */
-#define SPITYPE_ADDRESS 0x0002 /* 3-byte address required */
-#define SPITYPE_PREFIX 0x0001 /* Prefix required, write/erase cycle */
-
-/*
- * 0x3080: PBR0
- * 0x3084: PBR1
- * 0x3088: PBR2
- */
-#define SPIPBR_WPE 0x80000000 /* Write protect enable */
-#define SPIPBR_PRL 0x00fff000 /* Protected range limit */
-#define SPIPBR_PRB_SHIFT 12
-#define SPIPBR_PRB 0x00000fff /* Protected range base */
-
-struct spi_context {
- volatile struct flash_ctrlr *ctrlr;
- uint16_t control;
- uint16_t prefix;
-};
-
-extern const struct spi_ctrlr spi_driver;
-
-void spi_bios_base(uint32_t bios_base_address);
-void spi_controller_lock(void);
-void spi_display(volatile struct flash_ctrlr *ctrlr);
-const char *spi_opcode_name(int opcode);
-int spi_protection(uint32_t address, uint32_t length);
-
-#endif /* __SOC_SPI_H__ */
diff --git a/src/soc/intel/quark/include/soc/storage_test.h b/src/soc/intel/quark/include/soc/storage_test.h
deleted file mode 100644
index dd602c2d5c..0000000000
--- a/src/soc/intel/quark/include/soc/storage_test.h
+++ /dev/null
@@ -1,37 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#ifndef __STORAGE_TEST_H__
-#define __STORAGE_TEST_H__
-
-#include <commonlib/sd_mmc_ctrlr.h>
-#include <device/device.h>
-#include <device/pci.h>
-#include <timer.h>
-
-#ifdef __SIMPLE_DEVICE__
-uint32_t storage_test_init(pci_devfn_t dev, uint32_t *previous_bar,
- uint16_t *previous_command);
-void storage_test(uint32_t bar, int full_initialization);
-void storage_test_complete(pci_devfn_t dev, uint32_t previous_bar,
- uint16_t previous_command);
-#else
-uint32_t storage_test_init(struct device *dev, uint32_t *previous_bar,
- uint16_t *previous_command);
-void storage_test(uint32_t bar, int full_initialization);
-void storage_test_complete(struct device *dev, uint32_t previous_bar,
- uint16_t previous_command);
-#endif
-
-/* Logging support */
-struct log_entry {
- struct mono_time time;
- struct mmc_command cmd;
- int cmd_issued;
- int ret;
- uint32_t response_entries;
- uint32_t response[4];
-};
-
-#define LOG_ENTRIES 256
-
-#endif /* __STORAGE_TEST_H__ */
diff --git a/src/soc/intel/quark/lpc.c b/src/soc/intel/quark/lpc.c
deleted file mode 100644
index 115a7b9ace..0000000000
--- a/src/soc/intel/quark/lpc.c
+++ /dev/null
@@ -1,56 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <arch/ioapic.h>
-#include <device/pci.h>
-#include <device/pci_ids.h>
-#include <soc/iomap.h>
-#include <soc/pci_devs.h>
-#include <soc/pm.h>
-#include <soc/ramstage.h>
-
-static void pmc_read_resources(struct device *dev)
-{
- unsigned int index = 0;
- struct resource *res;
-
- /* Get the normal PCI resources of this device. */
- pci_dev_read_resources(dev);
-
- /* GPE0 */
- res = new_resource(dev, index++);
- res->base = GPE0_BASE_ADDRESS;
- res->size = GPE0_SIZE;
- res->flags = IORESOURCE_IO | IORESOURCE_ASSIGNED | IORESOURCE_FIXED;
-
- /* PM1BLK */
- res = new_resource(dev, index++);
- res->base = PM1BLK_BASE_ADDRESS;
- res->size = PM1BLK_SIZE;
- res->flags = IORESOURCE_IO | IORESOURCE_ASSIGNED | IORESOURCE_FIXED;
-
- /* Legacy GPIO */
- res = new_resource(dev, index++);
- res->base = LEGACY_GPIO_BASE_ADDRESS;
- res->size = LEGACY_GPIO_SIZE;
- res->flags = IORESOURCE_IO | IORESOURCE_ASSIGNED | IORESOURCE_FIXED;
-}
-
-/* Implemented just to fill FADT SCI_INT as 0. */
-void ioapic_get_sci_pin(u8 *gsi, u8 *irq, u8 *flags)
-{
- *irq = 0;
- *gsi = 0;
-}
-
-static struct device_operations device_ops = {
- .read_resources = pmc_read_resources,
- .set_resources = pci_dev_set_resources,
- .enable_resources = pci_dev_enable_resources,
- .scan_bus = scan_static_bus,
-};
-
-static const struct pci_driver pmc __pci_driver = {
- .ops = &device_ops,
- .vendor = PCI_VID_INTEL,
- .device = QUARK_V_LPC_DEVICE_ID_0,
-};
diff --git a/src/soc/intel/quark/memmap.c b/src/soc/intel/quark/memmap.c
deleted file mode 100644
index 60b79380df..0000000000
--- a/src/soc/intel/quark/memmap.c
+++ /dev/null
@@ -1,31 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <arch/romstage.h>
-#include <cbmem.h>
-#include <cpu/x86/mtrr.h>
-#include <soc/reg_access.h>
-
-void fill_postcar_frame(struct postcar_frame *pcf)
-{
- uintptr_t top_of_ram;
- uintptr_t top_of_low_usable_memory;
-
- /* Locate the top of RAM */
- top_of_low_usable_memory = (uintptr_t)cbmem_top();
- top_of_ram = ALIGN_UP(top_of_low_usable_memory, 16 * MiB);
-
- /* Cache postcar and ramstage */
- postcar_frame_add_mtrr(pcf, top_of_ram - (16 * MiB), 16 * MiB,
- MTRR_TYPE_WRBACK);
-
- /* Cache RMU area */
- postcar_frame_add_mtrr(pcf, (uintptr_t)top_of_low_usable_memory,
- 0x10000, MTRR_TYPE_WRTHROUGH);
-
- /* Cache ESRAM */
- postcar_frame_add_mtrr(pcf, 0x80000000, 0x80000, MTRR_TYPE_WRBACK);
-
- pcf->skip_common_mtrr = 1;
- /* Cache SPI flash - Write protect not supported */
- postcar_frame_add_romcache(pcf, MTRR_TYPE_WRTHROUGH);
-}
diff --git a/src/soc/intel/quark/northcluster.c b/src/soc/intel/quark/northcluster.c
deleted file mode 100644
index f1e5c634f5..0000000000
--- a/src/soc/intel/quark/northcluster.c
+++ /dev/null
@@ -1,50 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <cbmem.h>
-#include <device/pci.h>
-#include <device/pci_ids.h>
-#include <soc/iomap.h>
-#include <soc/ramstage.h>
-
-static void nc_read_resources(struct device *dev)
-{
- int index = 0;
-
- /* Read standard PCI resources. */
- pci_dev_read_resources(dev);
-
- /* 0 -> 0xa0000 */
- ram_from_to(dev, index++, 0, 0xa0000);
-
- /*
- * Reserve everything between A segment and 1MB:
- *
- * 0xa0000 - 0xbffff: legacy VGA
- * 0xc0000 - 0xdffff: RAM
- * 0xe0000 - 0xfffff: ROM shadow
- */
- mmio_from_to(dev, index++, 0xa0000, 0xc0000);
-
- reserved_ram_from_to(dev, index++, 0xc0000, 1 * MiB);
-
- /* 0x100000 -> cbmem_top - cacheable and usable */
- ram_from_to(dev, index++, 1 * MiB, (uintptr_t)cbmem_top());
-
- /* cbmem_top -> 0xc0000000 - reserved */
- reserved_ram_from_to(dev, index++, (uintptr_t)cbmem_top(), 0xc0000000);
-
- /* 0xc0000000 -> 4GiB is mmio. */
- mmio_from_to(dev, index++, 0xc0000000, 4ull * GiB);
-}
-
-static struct device_operations nc_ops = {
- .read_resources = nc_read_resources,
- .set_resources = pci_dev_set_resources,
- .enable_resources = pci_dev_enable_resources,
-};
-
-static const struct pci_driver systemagent_driver __pci_driver = {
- .ops = &nc_ops,
- .vendor = PCI_VID_INTEL,
- .device = QUARK_MC_DEVICE_ID
-};
diff --git a/src/soc/intel/quark/reg_access.c b/src/soc/intel/quark/reg_access.c
deleted file mode 100644
index 14e072541c..0000000000
--- a/src/soc/intel/quark/reg_access.c
+++ /dev/null
@@ -1,478 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#define __SIMPLE_DEVICE__
-
-#include <arch/io.h>
-#include <assert.h>
-#include <cpu/x86/mtrr.h>
-#include <cpu/x86/cr.h>
-#include <console/console.h>
-#include <delay.h>
-#include <device/pci_ops.h>
-#include <soc/pci_devs.h>
-#include <soc/ramstage.h>
-#include <soc/reg_access.h>
-
-static uint16_t get_gpe0_address(uint32_t reg_address)
-{
- uint32_t gpe0_base_address;
-
- /* Get the GPE0 base address */
- gpe0_base_address = pci_read_config32(LPC_BDF, R_QNC_LPC_GPE0BLK);
- ASSERT(gpe0_base_address >= 0x80000000);
- gpe0_base_address &= B_QNC_LPC_GPE0BLK_MASK;
-
- /* Return the GPE0 register address */
- return (uint16_t)(gpe0_base_address + reg_address);
-}
-
-static uint32_t *get_gpio_address(uint32_t reg_address)
-{
- uint32_t gpio_base_address;
-
- /* Get the GPIO base address */
- gpio_base_address = pci_read_config32(I2CGPIO_BDF, PCI_BASE_ADDRESS_1);
- gpio_base_address &= ~PCI_BASE_ADDRESS_MEM_ATTR_MASK;
- ASSERT(gpio_base_address != 0x00000000);
-
- /* Return the GPIO register address */
- return (uint32_t *)(gpio_base_address + reg_address);
-}
-
-void *get_i2c_address(void)
-{
- uint32_t gpio_base_address;
-
- /* Get the GPIO base address */
- gpio_base_address = pci_read_config32(I2CGPIO_BDF, PCI_BASE_ADDRESS_0);
- gpio_base_address &= ~PCI_BASE_ADDRESS_MEM_ATTR_MASK;
- ASSERT(gpio_base_address != 0x00000000);
-
- /* Return the GPIO register address */
- return (void *)gpio_base_address;
-}
-
-static uint16_t get_legacy_gpio_address(uint32_t reg_address)
-{
- uint32_t gpio_base_address;
-
- /* Get the GPIO base address */
- gpio_base_address = pci_read_config32(LPC_BDF, R_QNC_LPC_GBA_BASE);
- ASSERT(gpio_base_address >= 0x80000000);
- gpio_base_address &= B_QNC_LPC_GPA_BASE_MASK;
-
- /* Return the GPIO register address */
- return (uint16_t)(gpio_base_address + reg_address);
-}
-
-static uint32_t mtrr_index_to_host_bridge_register_offset(unsigned long index)
-{
- uint32_t offset;
-
- /* Convert from MTRR index to host bridge offset (Datasheet 12.7.2) */
- if (index == MTRR_CAP_MSR)
- offset = QUARK_NC_HOST_BRIDGE_IA32_MTRR_CAP;
- else if (index == MTRR_DEF_TYPE_MSR)
- offset = QUARK_NC_HOST_BRIDGE_IA32_MTRR_DEF_TYPE;
- else if (index == MTRR_FIX_64K_00000)
- offset = QUARK_NC_HOST_BRIDGE_MTRR_FIX64K_00000;
- else if ((index >= MTRR_FIX_16K_80000) && (index <= MTRR_FIX_16K_A0000))
- offset = ((index - MTRR_FIX_16K_80000) << 1)
- + QUARK_NC_HOST_BRIDGE_MTRR_FIX16K_80000;
- else if ((index >= MTRR_FIX_4K_C0000) && (index <= MTRR_FIX_4K_F8000))
- offset = ((index - MTRR_FIX_4K_C0000) << 1)
- + QUARK_NC_HOST_BRIDGE_IA32_MTRR_PHYSBASE0;
- else if ((index >= MTRR_PHYS_BASE(0)) && (index <= MTRR_PHYS_MASK(7)))
- offset = (index - MTRR_PHYS_BASE(0))
- + QUARK_NC_HOST_BRIDGE_IA32_MTRR_PHYSBASE0;
- else {
- printk(BIOS_SPEW, "index: 0x%08lx\n", index);
- die("Invalid MTRR index specified!\n");
- }
- return offset;
-}
-
-void mcr_write(uint8_t opcode, uint8_t port, uint32_t reg_address)
-{
- pci_write_config32(MC_BDF, QNC_ACCESS_PORT_MCR,
- (opcode << QNC_MCR_OP_OFFSET)
- | ((uint32_t)port << QNC_MCR_PORT_OFFSET)
- | ((reg_address & QNC_MCR_MASK) << QNC_MCR_REG_OFFSET)
- | QNC_MCR_BYTE_ENABLES);
-}
-
-uint32_t mdr_read(void)
-{
- return pci_read_config32(MC_BDF, QNC_ACCESS_PORT_MDR);
-}
-
-void mdr_write(uint32_t value)
-{
- pci_write_config32(MC_BDF, QNC_ACCESS_PORT_MDR, value);
-}
-
-void mea_write(uint32_t reg_address)
-{
- pci_write_config32(MC_BDF, QNC_ACCESS_PORT_MEA, reg_address
- & QNC_MEA_MASK);
-}
-
-uint32_t port_reg_read(uint8_t port, uint32_t offset)
-{
- /* Read the port register */
- mea_write(offset);
- mcr_write(QUARK_OPCODE_READ, port, offset);
- return mdr_read();
-}
-
-void port_reg_write(uint8_t port, uint32_t offset, uint32_t value)
-{
- /* Write the port register */
- mea_write(offset);
- mdr_write(value);
- mcr_write(QUARK_OPCODE_WRITE, port, offset);
-}
-
-static CRx_TYPE reg_cpu_cr_read(uint32_t reg_address)
-{
- /* Read the CPU CRx register */
- switch (reg_address) {
- case 0:
- return read_cr0();
-
- case 4:
- return read_cr4();
- }
- die("ERROR - Unsupported CPU register!\n");
-}
-
-static void reg_cpu_cr_write(uint32_t reg_address, CRx_TYPE value)
-{
- /* Write the CPU CRx register */
- switch (reg_address) {
- default:
- die("ERROR - Unsupported CPU register!\n");
-
- case 0:
- write_cr0(value);
- break;
-
- case 4:
- write_cr4(value);
- break;
- }
-}
-
-static uint32_t reg_gpe0_read(uint32_t reg_address)
-{
- /* Read the GPE0 register */
- return inl(get_gpe0_address(reg_address));
-}
-
-static void reg_gpe0_write(uint32_t reg_address, uint32_t value)
-{
- /* Write the GPE0 register */
- outl(value, get_gpe0_address(reg_address));
-}
-
-static uint32_t reg_gpio_read(uint32_t reg_address)
-{
- /* Read the GPIO register */
- return *get_gpio_address(reg_address);
-}
-
-static void reg_gpio_write(uint32_t reg_address, uint32_t value)
-{
- /* Write the GPIO register */
- *get_gpio_address(reg_address) = value;
-}
-
-uint32_t reg_host_bridge_unit_read(uint32_t reg_address)
-{
- /* Read the host bridge register */
- mea_write(reg_address);
- mcr_write(QUARK_OPCODE_READ, QUARK_NC_HOST_BRIDGE_SB_PORT_ID,
- reg_address);
- return mdr_read();
-}
-
-static void reg_host_bridge_unit_write(uint32_t reg_address, uint32_t value)
-{
- /* Write the host bridge register */
- mea_write(reg_address);
- mdr_write(value);
- mcr_write(QUARK_OPCODE_WRITE, QUARK_NC_HOST_BRIDGE_SB_PORT_ID,
- reg_address);
-}
-
-uint32_t reg_legacy_gpio_read(uint32_t reg_address)
-{
- /* Read the legacy GPIO register */
- return inl(get_legacy_gpio_address(reg_address));
-}
-
-void reg_legacy_gpio_write(uint32_t reg_address, uint32_t value)
-{
- /* Write the legacy GPIO register */
- outl(value, get_legacy_gpio_address(reg_address));
-}
-
-static uint32_t reg_pcie_afe_read(uint32_t reg_address)
-{
- /* Read the PCIE AFE register */
- mea_write(reg_address);
- mcr_write(QUARK_OPCODE_IO_READ, QUARK_SC_PCIE_AFE_SB_PORT_ID,
- reg_address);
- return mdr_read();
-}
-
-static void reg_pcie_afe_write(uint32_t reg_address, uint32_t value)
-{
- /* Write the PCIE AFE register */
- mea_write(reg_address);
- mdr_write(value);
- mcr_write(QUARK_OPCODE_IO_WRITE, QUARK_SC_PCIE_AFE_SB_PORT_ID,
- reg_address);
-}
-
-uint32_t reg_rmu_temp_read(uint32_t reg_address)
-{
- /* Read the RMU temperature register */
- mea_write(reg_address);
- mcr_write(QUARK_OPCODE_READ, QUARK_NC_RMU_SB_PORT_ID, reg_address);
- return mdr_read();
-}
-
-static void reg_rmu_temp_write(uint32_t reg_address, uint32_t value)
-{
- /* Write the RMU temperature register */
- mea_write(reg_address);
- mdr_write(value);
- mcr_write(QUARK_OPCODE_WRITE, QUARK_NC_RMU_SB_PORT_ID, reg_address);
-}
-
-static uint32_t reg_soc_unit_read(uint32_t reg_address)
-{
- /* Read the temperature sensor register */
- mea_write(reg_address);
- mcr_write(QUARK_ALT_OPCODE_READ, QUARK_SCSS_SOC_UNIT_SB_PORT_ID,
- reg_address);
- return mdr_read();
-}
-
-static void reg_soc_unit_write(uint32_t reg_address, uint32_t value)
-{
- /* Write the temperature sensor register */
- mea_write(reg_address);
- mdr_write(value);
- mcr_write(QUARK_ALT_OPCODE_WRITE, QUARK_SCSS_SOC_UNIT_SB_PORT_ID,
- reg_address);
-}
-
-static uint32_t reg_usb_read(uint32_t reg_address)
-{
- /* Read the USB register */
- mea_write(reg_address);
- mcr_write(QUARK_ALT_OPCODE_READ, QUARK_SC_USB_AFE_SB_PORT_ID,
- reg_address);
- return mdr_read();
-}
-
-static void reg_usb_write(uint32_t reg_address, uint32_t value)
-{
- /* Write the USB register */
- mea_write(reg_address);
- mdr_write(value);
- mcr_write(QUARK_ALT_OPCODE_WRITE, QUARK_SC_USB_AFE_SB_PORT_ID,
- reg_address);
-}
-
-static uint64_t reg_read(struct reg_script_context *ctx)
-{
- const struct reg_script *step = ctx->step;
- uint64_t value = 0;
-
- switch (step->id) {
- default:
- printk(BIOS_ERR,
- "ERROR - Unknown register set (0x%08x)!\n",
- step->id);
- ctx->display_features = REG_SCRIPT_DISPLAY_NOTHING;
- return 0;
-
- case CPU_CR:
- ctx->display_prefix = "CPU CR";
- value = reg_cpu_cr_read(step->reg);
- break;
-
- case GPE0_REGS:
- ctx->display_prefix = "GPE0";
- value = reg_gpe0_read(step->reg);
- break;
-
- case GPIO_REGS:
- ctx->display_prefix = "GPIO";
- value = reg_gpio_read(step->reg);
- break;
-
- case HOST_BRIDGE:
- ctx->display_prefix = "Host Bridge";
- value = reg_host_bridge_unit_read(step->reg);
- break;
-
- case LEG_GPIO_REGS:
- ctx->display_prefix = "Legacy GPIO";
- value = reg_legacy_gpio_read(step->reg);
- break;
-
- case PCIE_AFE_REGS:
- ctx->display_prefix = "PCIe AFE";
- value = reg_pcie_afe_read(step->reg);
- break;
-
- case RMU_TEMP_REGS:
- ctx->display_prefix = "RMU TEMP";
- value = reg_rmu_temp_read(step->reg);
- break;
-
- case SOC_UNIT_REGS:
- ctx->display_prefix = "SOC Unit";
- value = reg_soc_unit_read(step->reg);
- break;
-
- case USB_PHY_REGS:
- ctx->display_prefix = "USB PHY";
- value = reg_usb_read(step->reg);
- break;
- }
- return value;
-}
-
-static void reg_write(struct reg_script_context *ctx)
-{
- const struct reg_script *step = ctx->step;
-
- switch (step->id) {
- default:
- printk(BIOS_ERR,
- "ERROR - Unknown register set (0x%08x)!\n",
- step->id);
- ctx->display_features = REG_SCRIPT_DISPLAY_NOTHING;
- return;
-
- case CPU_CR:
- ctx->display_prefix = "CPU CR";
- reg_cpu_cr_write(step->reg, step->value);
- break;
-
- case GPE0_REGS:
- ctx->display_prefix = "GPE0";
- reg_gpe0_write(step->reg, (uint32_t)step->value);
- break;
-
- case GPIO_REGS:
- ctx->display_prefix = "GPIO";
- reg_gpio_write(step->reg, (uint32_t)step->value);
- break;
-
- case HOST_BRIDGE:
- ctx->display_prefix = "Host Bridge";
- reg_host_bridge_unit_write(step->reg, (uint32_t)step->value);
- break;
-
- case LEG_GPIO_REGS:
- ctx->display_prefix = "Legacy GPIO";
- reg_legacy_gpio_write(step->reg, (uint32_t)step->value);
- break;
-
- case PCIE_AFE_REGS:
- ctx->display_prefix = "PCIe AFE";
- reg_pcie_afe_write(step->reg, (uint32_t)step->value);
- break;
-
- case PCIE_RESET:
- if (ctx->display_features) {
- ctx->display_prefix = "PCIe reset";
- ctx->display_features &= ~REG_SCRIPT_DISPLAY_REGISTER;
- }
- mainboard_gpio_pcie_reset(step->value);
- break;
-
- case RMU_TEMP_REGS:
- ctx->display_prefix = "RMU TEMP";
- reg_rmu_temp_write(step->reg, (uint32_t)step->value);
- break;
-
- case SOC_UNIT_REGS:
- ctx->display_prefix = "SOC Unit";
- reg_soc_unit_write(step->reg, (uint32_t)step->value);
- break;
-
- case MICROSECOND_DELAY:
- /* The actual delay is >= the requested delay */
- if (ctx->display_features) {
- /* Higher baud-rates will reduce the impact of
- * displaying this message
- */
- printk(BIOS_INFO, "Delay %lld uSec\n", step->value);
- ctx->display_features = REG_SCRIPT_DISPLAY_NOTHING;
- }
- udelay(step->value);
- break;
-
- case USB_PHY_REGS:
- ctx->display_prefix = "USB PHY";
- reg_usb_write(step->reg, (uint32_t)step->value);
- break;
- }
-}
-
-msr_t soc_msr_read(unsigned int index)
-{
- uint32_t offset;
- union {
- uint64_t u64;
- msr_t msr;
- } value;
-
- /* Read the low 32-bits of the register */
- offset = mtrr_index_to_host_bridge_register_offset(index);
- value.u64 = port_reg_read(QUARK_NC_HOST_BRIDGE_SB_PORT_ID, offset);
-
- /* For 64-bit registers, read the upper 32-bits */
- if ((offset >= QUARK_NC_HOST_BRIDGE_MTRR_FIX64K_00000)
- && (offset <= QUARK_NC_HOST_BRIDGE_MTRR_FIX4K_F8000)) {
- offset += 1;
- value.u64 |= port_reg_read(QUARK_NC_HOST_BRIDGE_SB_PORT_ID,
- offset);
- }
- return value.msr;
-}
-
-void soc_msr_write(unsigned int index, msr_t msr)
-{
- uint32_t offset;
- union {
- uint32_t u32[2];
- msr_t msr;
- } value;
-
- /* Write the low 32-bits of the register */
- value.msr = msr;
- offset = mtrr_index_to_host_bridge_register_offset(index);
- port_reg_write(QUARK_NC_HOST_BRIDGE_SB_PORT_ID, offset, value.u32[0]);
-
- /* For 64-bit registers, write the upper 32-bits */
- if ((offset >= QUARK_NC_HOST_BRIDGE_MTRR_FIX64K_00000)
- && (offset <= QUARK_NC_HOST_BRIDGE_MTRR_FIX4K_F8000)) {
- offset += 1;
- port_reg_write(QUARK_NC_HOST_BRIDGE_SB_PORT_ID, offset,
- value.u32[1]);
- }
-}
-
-const struct reg_script_bus_entry soc_reg_script_bus_table = {
- SOC_TYPE, reg_read, reg_write
-};
-
-REG_SCRIPT_BUS_ENTRY(soc_reg_script_bus_table);
diff --git a/src/soc/intel/quark/reset.c b/src/soc/intel/quark/reset.c
deleted file mode 100644
index 4f8b169a35..0000000000
--- a/src/soc/intel/quark/reset.c
+++ /dev/null
@@ -1,12 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <cf9_reset.h>
-#include <console/console.h>
-#include <fsp/util.h>
-
-void chipset_handle_reset(uint32_t status)
-{
- /* Do a hard reset if Quark FSP ever requests a reset */
- printk(BIOS_ERR, "Unknown reset type %x\n", status);
- full_reset();
-}
diff --git a/src/soc/intel/quark/romstage/Makefile.inc b/src/soc/intel/quark/romstage/Makefile.inc
deleted file mode 100644
index ff9b2b6743..0000000000
--- a/src/soc/intel/quark/romstage/Makefile.inc
+++ /dev/null
@@ -1,9 +0,0 @@
-# SPDX-License-Identifier: GPL-2.0-only
-
-romstage-y += car.c
-romstage-$(CONFIG_DISPLAY_UPD_DATA) += debug.c
-romstage-y += fsp_params.c
-romstage-y += pcie.c
-romstage-y += report_platform.c
-romstage-y += romstage.c
-romstage-y += ../../../../cpu/intel/car/romstage.c
diff --git a/src/soc/intel/quark/romstage/car.c b/src/soc/intel/quark/romstage/car.c
deleted file mode 100644
index 54f6033cfa..0000000000
--- a/src/soc/intel/quark/romstage/car.c
+++ /dev/null
@@ -1,52 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <console/console.h>
-#include <fsp/util.h>
-#include <soc/iomap.h>
-#include <soc/pci_devs.h>
-#include <soc/romstage.h>
-#include <soc/reg_access.h>
-
-static const struct reg_script legacy_gpio_init[] = {
- /* Temporarily enable the legacy GPIO controller */
- REG_PCI_WRITE32(R_QNC_LPC_GBA_BASE, IO_ADDRESS_VALID
- | LEGACY_GPIO_BASE_ADDRESS),
- /* Temporarily enable the GPE controller */
- REG_PCI_WRITE32(R_QNC_LPC_GPE0BLK, IO_ADDRESS_VALID
- | GPE0_BASE_ADDRESS),
- REG_PCI_OR8(PCI_COMMAND, PCI_COMMAND_IO),
- REG_SCRIPT_END
-};
-
-static const struct reg_script i2c_gpio_controller_init[] = {
- /* Temporarily enable the GPIO controller */
- REG_PCI_WRITE32(PCI_BASE_ADDRESS_0, I2C_BASE_ADDRESS),
- REG_PCI_WRITE32(PCI_BASE_ADDRESS_1, GPIO_BASE_ADDRESS),
- REG_PCI_OR8(PCI_COMMAND, PCI_COMMAND_MEMORY),
- REG_SCRIPT_END
-};
-
-static const struct reg_script hsuart_init[] = {
- /* Enable the HSUART */
- REG_PCI_WRITE32(PCI_BASE_ADDRESS_0, UART_BASE_ADDRESS),
- REG_PCI_OR8(PCI_COMMAND, PCI_COMMAND_MEMORY),
- REG_SCRIPT_END
-};
-
-void car_soc_pre_console_init(void)
-{
- /* Initialize the controllers */
- reg_script_run_on_dev(I2CGPIO_BDF, i2c_gpio_controller_init);
- reg_script_run_on_dev(LPC_BDF, legacy_gpio_init);
-
- /* Enable the HSUART */
- if (CONFIG(ENABLE_BUILTIN_HSUART0))
- reg_script_run_on_dev(HSUART0_BDF, hsuart_init);
- if (CONFIG(ENABLE_BUILTIN_HSUART1))
- reg_script_run_on_dev(HSUART1_BDF, hsuart_init);
-}
-
-void car_soc_post_console_init(void)
-{
- report_platform_info();
-};
diff --git a/src/soc/intel/quark/romstage/debug.c b/src/soc/intel/quark/romstage/debug.c
deleted file mode 100644
index bceff7d947..0000000000
--- a/src/soc/intel/quark/romstage/debug.c
+++ /dev/null
@@ -1,78 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <console/console.h>
-#include <fsp/util.h>
-
-void soc_display_fspm_upd_params(const FSPM_UPD *fspm_old_upd,
- const FSPM_UPD *fspm_new_upd)
-{
- const FSP_M_CONFIG *new;
- const FSP_M_CONFIG *old;
-
- old = &fspm_old_upd->FspmConfig;
- new = &fspm_new_upd->FspmConfig;
-
- /* Display the parameters for MemoryInit */
- printk(BIOS_SPEW, "UPD values for MemoryInit at: %p\n", new);
- fsp_display_upd_value("AddrMode", sizeof(old->AddrMode),
- old->AddrMode, new->AddrMode);
- fsp_display_upd_value("ChanMask", sizeof(old->ChanMask),
- old->ChanMask, new->ChanMask);
- fsp_display_upd_value("ChanWidth", sizeof(old->ChanWidth),
- old->ChanWidth, new->ChanWidth);
- fsp_display_upd_value("DramDensity", sizeof(old->DramDensity),
- old->DramDensity, new->DramDensity);
- fsp_display_upd_value("DramRonVal", sizeof(old->DramRonVal),
- old->DramRonVal, new->DramRonVal);
- fsp_display_upd_value("DramRttNomVal", sizeof(old->DramRttNomVal),
- old->DramRttNomVal, new->DramRttNomVal);
- fsp_display_upd_value("DramRttWrVal", sizeof(old->DramRttWrVal),
- old->DramRttWrVal, new->DramRttWrVal);
- fsp_display_upd_value("DramSpeed", sizeof(old->DramSpeed),
- old->DramSpeed, new->DramSpeed);
- fsp_display_upd_value("DramType", sizeof(old->DramType),
- old->DramType, new->DramType);
- fsp_display_upd_value("DramWidth", sizeof(old->DramWidth),
- old->DramWidth, new->DramWidth);
- fsp_display_upd_value("EccScrubBlkSize", sizeof(old->EccScrubBlkSize),
- old->EccScrubBlkSize, new->EccScrubBlkSize);
- fsp_display_upd_value("EccScrubInterval", sizeof(old->EccScrubInterval),
- old->EccScrubInterval, new->EccScrubInterval);
- fsp_display_upd_value("Flags", sizeof(old->Flags), old->Flags,
- new->Flags);
- fsp_display_upd_value("FspReservedMemoryLength",
- sizeof(old->FspReservedMemoryLength),
- old->FspReservedMemoryLength, new->FspReservedMemoryLength);
- fsp_display_upd_value("RankMask", sizeof(old->RankMask), old->RankMask,
- new->RankMask);
- fsp_display_upd_value("RmuBaseAddress", sizeof(old->RmuBaseAddress),
- old->RmuBaseAddress, new->RmuBaseAddress);
- fsp_display_upd_value("RmuLength", sizeof(old->RmuLength),
- old->RmuLength, new->RmuLength);
- fsp_display_upd_value("SerialPortPollForChar",
- sizeof(old->SerialPortPollForChar),
- old->SerialPortPollForChar, new->SerialPortPollForChar);
- fsp_display_upd_value("SerialPortReadChar",
- sizeof(old->SerialPortReadChar),
- old->SerialPortReadChar, new->SerialPortReadChar);
- fsp_display_upd_value("SerialPortWriteChar",
- sizeof(old->SerialPortWriteChar),
- old->SerialPortWriteChar, new->SerialPortWriteChar);
- fsp_display_upd_value("SmmTsegSize", sizeof(old->SmmTsegSize),
- old->SmmTsegSize, new->SmmTsegSize);
- fsp_display_upd_value("SocRdOdtVal", sizeof(old->SocRdOdtVal),
- old->SocRdOdtVal, new->SocRdOdtVal);
- fsp_display_upd_value("SocWrRonVal", sizeof(old->SocWrRonVal),
- old->SocWrRonVal, new->SocWrRonVal);
- fsp_display_upd_value("SocWrSlewRate", sizeof(old->SocWrSlewRate),
- old->SocWrSlewRate, new->SocWrSlewRate);
- fsp_display_upd_value("SrInt", sizeof(old->SrInt), old->SrInt,
- new->SrInt);
- fsp_display_upd_value("SrTemp", sizeof(old->SrTemp), old->SrTemp,
- new->SrTemp);
- fsp_display_upd_value("tCL", sizeof(old->tCL), old->tCL, new->tCL);
- fsp_display_upd_value("tFAW", sizeof(old->tFAW), old->tFAW, new->tFAW);
- fsp_display_upd_value("tRAS", sizeof(old->tRAS), old->tRAS, new->tRAS);
- fsp_display_upd_value("tRRD", sizeof(old->tRRD), old->tRRD, new->tRRD);
- fsp_display_upd_value("tWTR", sizeof(old->tWTR), old->tWTR, new->tWTR);
-}
diff --git a/src/soc/intel/quark/romstage/fsp_params.c b/src/soc/intel/quark/romstage/fsp_params.c
deleted file mode 100644
index 11f70596da..0000000000
--- a/src/soc/intel/quark/romstage/fsp_params.c
+++ /dev/null
@@ -1,146 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <arch/romstage.h>
-#include <arch/symbols.h>
-#include <console/console.h>
-#include <cbmem.h>
-#include "../chip.h"
-#include <fsp/util.h>
-#include <soc/iomap.h>
-#include <soc/pci_devs.h>
-#include <soc/pm.h>
-#include <soc/romstage.h>
-#include <soc/reg_access.h>
-#include <soc/storage_test.h>
-
-void mainboard_romstage_entry(void)
-{
- bool s3wake;
-
- post_code(0x20);
- console_init();
-
- if (CONFIG(STORAGE_TEST)) {
- uint32_t bar;
- pci_devfn_t dev;
- uint32_t previous_bar;
- uint16_t previous_command;
-
- /* Enable the SD/MMC controller and run the test. Restore
- * the BAR and command registers upon completion.
- */
- dev = PCI_DEV(0, SD_MMC_DEV, SD_MMC_FUNC);
- bar = storage_test_init(dev, &previous_bar, &previous_command);
- storage_test(bar, 1);
- storage_test_complete(dev, previous_bar, previous_command);
- }
-
- /* Initialize DRAM */
- s3wake = fill_power_state() == ACPI_S3;
- fsp_memory_init(s3wake);
-
- /* Disable the ROM shadow 0x000e0000 - 0x000fffff */
- disable_rom_shadow();
-
- /* Initialize the PCIe bridges */
- pcie_init();
-}
-
-static struct chipset_power_state power_state;
-
-struct chipset_power_state *get_power_state(void)
-{
- return &power_state;
-}
-
-int fill_power_state(void)
-{
- power_state.prev_sleep_state = 0;
- printk(BIOS_SPEW, "prev_sleep_state %d\n",
- power_state.prev_sleep_state);
- return power_state.prev_sleep_state;
-}
-
-void platform_fsp_memory_init_params_cb(FSPM_UPD *fspm_upd, uint32_t version)
-{
- FSPM_ARCH_UPD *aupd;
- const struct soc_intel_quark_config *config;
- void *rmu_data;
- size_t rmu_data_len;
- FSP_M_CONFIG *upd;
-
- /* Clear SMI and wake events */
- clear_smi_and_wake_events();
-
- /* Locate the RMU data file in flash */
- rmu_data = locate_rmu_file(&rmu_data_len);
- if (!rmu_data)
- die_with_post_code(POST_INVALID_CBFS,
- "Microcode file (rmu.bin) not found.");
-
- /* Locate the configuration data from devicetree.cb */
- config = config_of_soc();
-
- /* Update the architectural UPD values. */
- aupd = &fspm_upd->FspmArchUpd;
- aupd->BootLoaderTolumSize = cbmem_overhead_size();
- aupd->StackBase = (uintptr_t)(CONFIG_FSP_ESRAM_LOC - aupd->StackSize);
- aupd->BootMode = FSP_BOOT_WITH_FULL_CONFIGURATION;
-
- /* Display the ESRAM layout */
- if (CONFIG(DISPLAY_ESRAM_LAYOUT)) {
- printk(BIOS_SPEW, "\nESRAM Layout:\n\n");
- printk(BIOS_SPEW,
- "+-------------------+ 0x80080000 - ESRAM end\n");
- printk(BIOS_SPEW, "| FSP binary |\n");
- printk(BIOS_SPEW,
- "+-------------------+ 0x%08x (CONFIG_FSP_ESRAM_LOC)\n",
- CONFIG_FSP_ESRAM_LOC);
- printk(BIOS_SPEW, "| FSP stack |\n");
- printk(BIOS_SPEW, "+-------------------+ 0x%zx\n",
- (size_t)aupd->StackBase);
- printk(BIOS_SPEW, "| |\n");
- printk(BIOS_SPEW, "+-------------------+ %p\n",
- _car_unallocated_start);
- printk(BIOS_SPEW, "| coreboot data |\n");
- printk(BIOS_SPEW, "+-------------------+ %p\n",
- _ecar_stack);
- printk(BIOS_SPEW, "| coreboot stack |\n");
- printk(BIOS_SPEW,
- "+-------------------+ 0x80000000 - ESRAM start\n\n");
- }
-
- /* Update the UPD data for MemoryInit */
- upd = &fspm_upd->FspmConfig;
- upd->AddrMode = config->AddrMode;
- upd->ChanMask = config->ChanMask;
- upd->ChanWidth = config->ChanWidth;
- upd->DramDensity = config->DramDensity;
- upd->DramRonVal = config->DramRonVal;
- upd->DramRttNomVal = config->DramRttNomVal;
- upd->DramRttWrVal = config->DramRttWrVal;
- upd->DramSpeed = config->DramSpeed;
- upd->DramType = config->DramType;
- upd->DramWidth = config->DramWidth;
- upd->EccScrubBlkSize = config->EccScrubBlkSize;
- upd->EccScrubInterval = config->EccScrubInterval;
- upd->Flags = config->Flags;
- upd->FspReservedMemoryLength = config->FspReservedMemoryLength;
- upd->RankMask = config->RankMask;
- upd->RmuBaseAddress = (uintptr_t)rmu_data;
- upd->RmuLength = rmu_data_len;
- upd->SerialPortWriteChar = !!console_log_level(BIOS_SPEW)
- ? (uintptr_t)fsp_write_line : 0;
- upd->SmmTsegSize = CONFIG(HAVE_SMI_HANDLER) ?
- config->SmmTsegSize : 0;
- upd->SocRdOdtVal = config->SocRdOdtVal;
- upd->SocWrRonVal = config->SocWrRonVal;
- upd->SocWrSlewRate = config->SocWrSlewRate;
- upd->SrInt = config->SrInt;
- upd->SrTemp = config->SrTemp;
- upd->tCL = config->tCL;
- upd->tFAW = config->tFAW;
- upd->tRAS = config->tRAS;
- upd->tRRD = config->tRRD;
- upd->tWTR = config->tWTR;
-}
diff --git a/src/soc/intel/quark/romstage/pcie.c b/src/soc/intel/quark/romstage/pcie.c
deleted file mode 100644
index 393ba4dbd9..0000000000
--- a/src/soc/intel/quark/romstage/pcie.c
+++ /dev/null
@@ -1,90 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <device/device.h>
-#include <soc/pci_devs.h>
-#include <soc/reg_access.h>
-#include <soc/romstage.h>
-
-/* Minimum time in microseconds for assertion of PERST# signal */
-#define PCIEXP_PERST_MIN_ASSERT_US 100
-
-/* Microsecond delay post issuing common lane reset */
-#define PCIEXP_DELAY_US_POST_CMNRESET_RESET 1
-
-/* Microsecond delay to wait for PLL to lock */
-#define PCIEXP_DELAY_US_WAIT_PLL_LOCK 80
-
-/* Microsecond delay post issuing sideband interface reset */
-#define PCIEXP_DELAY_US_POST_SBI_RESET 20
-
-/* Microsecond delay post deasserting PERST# */
-#define PCIEXP_DELAY_US_POST_PERST_DEASSERT 10
-
-const struct reg_script pcie_init_script[] = {
- /* Assert PCIe reset# */
- MAINBOARD_PCIE_RESET(0),
-
- /* PHY Common lane reset */
- REG_SOC_UNIT_OR(QUARK_SCSS_SOC_UNIT_SOCCLKEN_CONFIG,
- SOCCLKEN_CONFIG_PHY_I_CMNRESET_L),
-
- /* Wait post common lane reset */
- TIME_DELAY_USEC(PCIEXP_DELAY_US_POST_CMNRESET_RESET),
-
- /* PHY Sideband interface reset.
- * Controller main reset
- */
- REG_SOC_UNIT_OR(QUARK_SCSS_SOC_UNIT_SOCCLKEN_CONFIG,
- SOCCLKEN_CONFIG_SBI_RST_100_CORE_B
- | SOCCLKEN_CONFIG_PHY_I_SIDE_RST_L),
- TIME_DELAY_USEC(PCIEXP_DELAY_US_WAIT_PLL_LOCK),
-
- /* Controller sideband interface reset */
- REG_SOC_UNIT_OR(QUARK_SCSS_SOC_UNIT_SOCCLKEN_CONFIG,
- SOCCLKEN_CONFIG_SBI_BB_RST_B),
-
- /* Wait post sideband interface reset */
- TIME_DELAY_USEC(PCIEXP_DELAY_US_POST_SBI_RESET),
-
- /* Deassert PCIe reset# */
- MAINBOARD_PCIE_RESET(1),
-
- /* Wait post de assert PERST#. */
- TIME_DELAY_USEC(PCIEXP_DELAY_US_POST_PERST_DEASSERT),
-
- /* Controller primary interface reset */
- REG_SOC_UNIT_OR(QUARK_SCSS_SOC_UNIT_SOCCLKEN_CONFIG,
- SOCCLKEN_CONFIG_BB_RST_B),
-
- /* Set the mixer load resistance */
- REG_PCIE_AFE_AND(QUARK_PCIE_AFE_PCIE_RXPICTRL0_L0,
- OCFGPIMIXLOAD_1_0_MASK),
- REG_PCIE_AFE_AND(QUARK_PCIE_AFE_PCIE_RXPICTRL0_L1,
- OCFGPIMIXLOAD_1_0_MASK),
- REG_SCRIPT_END
-};
-
-static const struct reg_script pcie_bus_init_script[] = {
- /* Setup Message Bus Idle Counter (SBIC) values */
- REG_PCI_RMW8(R_QNC_PCIE_IOSFSBCTL, ~B_QNC_PCIE_IOSFSBCTL_SBIC_MASK,
- V_PCIE_ROOT_PORT_SBIC_VALUE),
- REG_PCI_READ8(R_QNC_PCIE_IOSFSBCTL),
-
- /* Set the IPF bit in MCR2 */
- REG_PCI_OR32(R_QNC_PCIE_MPC2, B_QNC_PCIE_MPC2_IPF),
- REG_PCI_READ32(R_QNC_PCIE_MPC2),
-
- /* Set up the Posted and Non Posted Request sizes for PCIe */
- REG_PCI_RMW32(R_QNC_PCIE_CCFG, ~B_QNC_PCIE_CCFG_UPSD,
- (B_QNC_PCIE_CCFG_UNRS | B_QNC_PCIE_CCFG_UPRS)),
- REG_PCI_READ32(R_QNC_PCIE_CCFG),
- REG_SCRIPT_END
-};
-
-void pcie_init(void)
-{
- /* Initialize the PCIe bridges */
- reg_script_run(pcie_init_script);
- reg_script_run_on_dev(PCIE_PORT0_BDF, pcie_bus_init_script);
- reg_script_run_on_dev(PCIE_PORT1_BDF, pcie_bus_init_script);
-}
diff --git a/src/soc/intel/quark/romstage/report_platform.c b/src/soc/intel/quark/romstage/report_platform.c
deleted file mode 100644
index 7a49148cd0..0000000000
--- a/src/soc/intel/quark/romstage/report_platform.c
+++ /dev/null
@@ -1,113 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <console/console.h>
-#include <cpu/cpu.h>
-#include <device/pci.h>
-#include <device/pci_ops.h>
-#include <soc/cpu.h>
-#include <soc/pci_devs.h>
-#include <soc/romstage.h>
-
-static const struct {
- u32 cpuid;
- u32 extended_temp;
- u32 ecc;
- u32 secure_boot;
- u32 d_variant;
- u32 mm_number;
- const char *name;
-} cpu_table[] = {
- { CPUID_QUARK_X1000, 0, 0, 0, 0, 930237, "Quark X1000" },
- { CPUID_QUARK_X1000, 0, 1, 0, 0, 930239, "Quark X1010" },
- { CPUID_QUARK_X1000, 0, 1, 1, 0, 934775, "Quark X1020" },
- { CPUID_QUARK_X1000, 0, 1, 1, 1, 930236, "Quark X1020D" },
- { CPUID_QUARK_X1000, 1, 0, 0, 0, 934413, "Quark X1001" },
- { CPUID_QUARK_X1000, 1, 1, 0, 0, 934415, "Quark X1011" },
- { CPUID_QUARK_X1000, 1, 1, 1, 0, 934943, "Quark X1021" },
- { CPUID_QUARK_X1000, 1, 1, 1, 1, 934411, "Quark X1021D" },
-};
-
-static struct {
- u8 revision_id;
- const char *stepping;
-} stepping_table[] = {
- { 0, "A0" },
-};
-
-static uint32_t memory_cntrl_read(uint32_t offset)
-{
- /* Read the memory controller register */
- mea_write(offset);
- mcr_write(QUARK_OPCODE_READ, QUARK_NC_MEMORY_CONTROLLER_SB_PORT_ID,
- offset);
- return mdr_read();
-}
-
-static uint32_t fuse_port_read(uint32_t offset)
-{
- /* Read the SoC unit register */
- mea_write(offset);
- mcr_write(QUARK_ALT_OPCODE_READ, QUARK_SCSS_FUSE_SB_PORT_ID, offset);
- return mdr_read();
-}
-
-static void report_cpu_info(void)
-{
- const char *cpu_type = "Unknown";
- u32 d_variant;
- u32 ecc_enabled;
- u32 extended_temp;
- u32 i;
- u8 revision;
- u32 secure_boot, cpu_id;
- const char *stepping = "Unknown";
-
- /* Determine if ECC is enabled */
- ecc_enabled = (0 == (B_DFUSESTAT_ECC_DIS
- & memory_cntrl_read(QUARK_NC_MEMORY_CONTROLLER_REG_DFUSESTAT)));
-
- /* Determine if secure boot is enabled */
- secure_boot = (0 != (fuse_port_read(QUARK_SCSS_SOC_UNIT_SPI_ROM_FUSE)
- & B_ROM_FUSE_IN_SECURE_SKU));
-
- /* TODO: Determine if this is a D variant */
- d_variant = 0;
- if (ecc_enabled && secure_boot)
- d_variant = 0; /* or 1 */
-
- /* TODO: Determine the temperature variant */
- extended_temp = 0;
-
- /* Look for string to match the CPU ID value */
- cpu_id = cpu_get_cpuid();
- for (i = 0; i < ARRAY_SIZE(cpu_table); i++) {
- if ((cpu_table[i].cpuid == cpu_id)
- && (cpu_table[i].extended_temp == extended_temp)
- && (cpu_table[i].ecc == ecc_enabled)
- && (cpu_table[i].secure_boot == secure_boot)
- && (cpu_table[i].d_variant == d_variant)) {
- cpu_type = cpu_table[i].name;
- break;
- }
- }
-
- /*
- * Translate the host bridge revision ID into the stepping
- * Developer's Manual Section C.2
- */
- revision = pci_read_config8(MC_BDF, PCI_REVISION_ID);
- for (i = 0; i < ARRAY_SIZE(stepping_table); i++) {
- if (stepping_table[i].revision_id == revision) {
- stepping = stepping_table[i].stepping;
- break;
- }
- }
-
- printk(BIOS_DEBUG, "CPU: ID %x:%x, %s %s Stepping\n", cpu_id,
- revision, cpu_type, stepping);
-}
-
-void report_platform_info(void)
-{
- report_cpu_info();
-}
diff --git a/src/soc/intel/quark/romstage/romstage.c b/src/soc/intel/quark/romstage/romstage.c
deleted file mode 100644
index 23a551ef57..0000000000
--- a/src/soc/intel/quark/romstage/romstage.c
+++ /dev/null
@@ -1,64 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <cbfs.h>
-#include <console/console.h>
-#include <fsp/util.h>
-#include <soc/pci_devs.h>
-#include <soc/pm.h>
-#include <soc/romstage.h>
-#include <soc/reg_access.h>
-
-static const struct reg_script clear_smi_and_wake_events_script[] = {
- /* Clear any SMI or wake events */
- REG_GPE0_READ(R_QNC_GPE0BLK_GPE0S),
- REG_GPE0_READ(R_QNC_GPE0BLK_SMIS),
- REG_GPE0_OR(R_QNC_GPE0BLK_GPE0S, B_QNC_GPE0BLK_GPE0S_ALL),
- REG_GPE0_OR(R_QNC_GPE0BLK_SMIS, B_QNC_GPE0BLK_SMIS_ALL),
- REG_SCRIPT_END
-};
-
-void clear_smi_and_wake_events(void)
-{
- struct chipset_power_state *ps;
-
- /* Clear SMI and wake events */
- ps = get_power_state();
- if (ps->prev_sleep_state != 3) {
- printk(BIOS_SPEW, "Clearing SMI interrupts and wake events\n");
- reg_script_run_on_dev(LPC_BDF,
- clear_smi_and_wake_events_script);
- }
-}
-
-void disable_rom_shadow(void)
-{
- uint32_t data;
-
- /* Determine if the shadow ROM is enabled */
- data = port_reg_read(QUARK_NC_HOST_BRIDGE_SB_PORT_ID,
- QNC_MSG_FSBIC_REG_HMISC);
- if ((data & (ESEG_RD_DRAM | FSEG_RD_DRAM))
- != (ESEG_RD_DRAM | FSEG_RD_DRAM)) {
-
- /* Disable the ROM shadow 0x000e0000 - 0x000fffff */
- data |= ESEG_RD_DRAM | FSEG_RD_DRAM;
- port_reg_write(QUARK_NC_HOST_BRIDGE_SB_PORT_ID,
- QNC_MSG_FSBIC_REG_HMISC, data);
- }
-}
-
-void *locate_rmu_file(size_t *rmu_file_len)
-{
- size_t fsize;
- void *rmu_data;
-
- /* Locate the rmu.bin file in the read-only region of the flash */
- rmu_data = cbfs_ro_map("rmu.bin", &fsize);
- if (!rmu_data)
- return NULL;
-
- if (rmu_file_len != NULL)
- *rmu_file_len = fsize;
-
- return rmu_data;
-}
diff --git a/src/soc/intel/quark/sd.c b/src/soc/intel/quark/sd.c
deleted file mode 100644
index 2a52ff3da0..0000000000
--- a/src/soc/intel/quark/sd.c
+++ /dev/null
@@ -1,35 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <commonlib/sdhci.h>
-#include <commonlib/storage.h>
-#include <device/device.h>
-#include <device/pci.h>
-#include <device/pci_ids.h>
-#include <soc/storage_test.h>
-
-static void init(struct device *dev)
-{
- /* Run the SD test */
- if (CONFIG(STORAGE_TEST)) {
- uint32_t bar;
- uint32_t previous_bar;
- uint16_t previous_command;
-
- bar = storage_test_init(dev, &previous_bar, &previous_command);
- storage_test(bar, 0);
- storage_test_complete(dev, previous_bar, previous_command);
- }
-}
-
-static const struct device_operations device_ops = {
- .read_resources = pci_dev_read_resources,
- .set_resources = pci_dev_set_resources,
- .enable_resources = pci_dev_enable_resources,
- .init = init,
-};
-
-static const struct pci_driver pmc __pci_driver = {
- .ops = &device_ops,
- .vendor = PCI_VID_INTEL,
- .device = 0x08A7,
-};
diff --git a/src/soc/intel/quark/spi.c b/src/soc/intel/quark/spi.c
deleted file mode 100644
index cc284f33a7..0000000000
--- a/src/soc/intel/quark/spi.c
+++ /dev/null
@@ -1,290 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <device/mmio.h>
-#include <device/pci_ops.h>
-#include <bootstate.h>
-#include <console/console.h>
-#include <device/pci_ids.h>
-#include <device/pci_def.h>
-#include <delay.h>
-#include <soc/pci_devs.h>
-#include <soc/QuarkNcSocId.h>
-#include <soc/spi.h>
-#include <string.h>
-
-struct spi_context spi_driver_context = {
- NULL,
- 0,
- 0
-};
-
-void spi_bios_base(uint32_t bios_base_address)
-{
- uint32_t address;
- volatile struct flash_ctrlr *ctrlr = spi_driver_context.ctrlr;
-
- /* Prevent all SPI operations below this address */
- address = 0xff000000 | bios_base_address;
- ctrlr->bbar = address;
-}
-
-void spi_controller_lock(void)
-{
- volatile struct flash_ctrlr *ctrlr = spi_driver_context.ctrlr;
-
- /* Prevent BIOS and system from changing the SPI controller setup */
- ctrlr->status |= SPISTS_CLD;
-}
-
-int spi_protection(uint32_t address, uint32_t length)
-{
- uint32_t base;
- volatile struct flash_ctrlr *ctrlr = spi_driver_context.ctrlr;
- int index;
- uint32_t limit;
- uint32_t protect;
- uint32_t value;
-
- /* Determine the protection range */
- base = address;
- limit = address + length - 1;
- protect = SPIPBR_WPE | (limit & SPIPBR_PRL)
- | ((base >> SPIPBR_PRB_SHIFT) & SPIPBR_PRB);
-
- /* Walk the list of protected areas */
- for (index = 0; index < ARRAY_SIZE(ctrlr->pbr); index++) {
- value = read32(&ctrlr->pbr[index]);
-
- /* Don't duplicate if the range is already protected */
- if (value == protect)
- return 0;
-
- /* Use the first free register to protect this range */
- if ((value & SPIPBR_WPE) == 0) {
- write32(&ctrlr->pbr[index], protect);
- return 0;
- }
- }
-
- /* No free protection range registers */
- printk(BIOS_ERR,
- "Failed to set protection: 0x%08x - 0x%08x, PRRs full!\n",
- address, address + length - 1);
- return -1;
-}
-
-static int xfer(const struct spi_slave *slave, const void *dout,
- size_t bytesout, void *din, size_t bytesin)
-{
- struct spi_context *context;
- uint16_t control;
- volatile struct flash_ctrlr *ctrlr;
- uint8_t *data;
- int index;
- uint8_t opcode;
- uint32_t status;
- int type;
-
- /* Locate the context structure */
- context = &spi_driver_context;
- ctrlr = context->ctrlr;
-
- /* Validate the buffer sizes */
- if (bytesin > sizeof(ctrlr->data)) {
- printk(BIOS_ERR, "bytesin > %zu\n", sizeof(ctrlr->data));
- goto error;
- }
-
- if (bytesin && (din == NULL)) {
- printk(BIOS_ERR, "din is NULL\n");
- goto error;
- }
-
- if (bytesout == 0) {
- /* Check for a read operation */
- if (bytesin == 0) {
- printk(BIOS_ERR, "bytesout and bytesin == 0\n");
- goto error;
- }
-
- /* Issue the read operation */
- control = context->control;
- control |= SPICTL_DC | ((bytesin - 1) << SPICTL_DBCNT_SHIFT);
- goto start_cycle;
- }
-
- /* Locate the opcode in the opcode table */
- data = (uint8_t *)dout;
- opcode = *data++;
- bytesout -= 1;
- for (index = 0; index < sizeof(ctrlr->opmenu); index++)
- if (opcode == ctrlr->opmenu[index])
- break;
-
- /* Check for a prefix byte */
- if (index == sizeof(ctrlr->opmenu)) {
- for (index = 0; index < sizeof(ctrlr->prefix); index++)
- if (opcode == ctrlr->prefix[index])
- break;
-
- /* Handle the unknown opcode error */
- if (index == sizeof(ctrlr->prefix)) {
- printk(BIOS_ERR, "Unknown SPI flash opcode\n");
- goto error;
- }
-
- /* Save the index for the next operation */
- context->prefix = index;
- return 0;
- }
-
- /* Get the opcode type */
- type = (ctrlr->type >> (index * 2))
- & (SPITYPE_ADDRESS | SPITYPE_PREFIX);
-
- /* Determine if the opcode has an address */
- if (type & SPITYPE_ADDRESS) {
- if (bytesout < 3) {
- printk(BIOS_ERR, "Missing address bytes\n");
- goto error;
- }
-
- /* Use chip select 0 */
- ctrlr->address = (data[0] << 16)
- | (data[1] << 8)
- | data[2];
-
- /* read in order to flush the write buffer */
- status = ctrlr->address;
-
- data += 3;
- bytesout -= 3;
- }
-
- /* Build the control value */
- control = (index << SPICTL_COPTR_SHIFT)
- | (context->prefix << SPICTL_SOPTR_SHIFT)
- | SPICTL_CG | SPICTL_AR;
- if (bytesout) {
- memcpy((void *)&ctrlr->data[0], data, bytesout);
- control |= SPICTL_DC | ((bytesout - 1) << SPICTL_DBCNT_SHIFT);
- }
-
- /* Save the control value for the read operation request */
- if (!(type & SPITYPE_PREFIX)) {
- context->control = control;
- return 0;
- }
-
- /* Write operations require a prefix */
- control |= SPICTL_ACS;
-
-start_cycle:
- /* Start the SPI cycle */
- ctrlr->control = control;
- status = ctrlr->control;
- context->prefix = 0;
-
- /* Wait for the access to complete */
- while ((status = ctrlr->status) & SPISTS_CIP)
- udelay(1);
-
- /* Clear any errors */
- ctrlr->status = status;
-
- /* Handle the blocked access error */
- if (status & SPISTS_BA) {
- printk(BIOS_ERR, "SPI access blocked!\n");
- return -1;
- }
-
- /* Check for done */
- if (status & SPISTS_CD) {
- /* Return any receive data */
- if (bytesin)
- memcpy(din, (void *)&ctrlr->data[0], bytesin);
- return 0;
- }
-
- /* Handle the timeout error */
- printk(BIOS_ERR, "SPI transaction timeout!\n");
-
-error:
- context->prefix = 0;
- return -1;
-}
-
-void spi_init(void)
-{
- uint32_t bios_control;
- struct spi_context *context;
- volatile struct flash_ctrlr *ctrlr;
- struct device *dev;
- uint32_t rcba;
-
- /* Determine the base address of the SPI flash controller */
- context = &spi_driver_context;
- dev = dev_find_device(PCI_VID_INTEL, LPC_DEVID, NULL);
- rcba = pci_read_config32(dev, R_QNC_LPC_RCBA);
- if (!(rcba & B_QNC_LPC_RCBA_EN)) {
- printk(BIOS_ERR, "RBCA not enabled\n");
- return;
- }
- rcba &= B_QNC_LPC_RCBA_MASK;
- ctrlr = (volatile struct flash_ctrlr *)rcba;
-
- /* Enable writes to the SPI flash */
- bios_control = pci_read_config32(dev, R_QNC_LPC_BIOS_CNTL);
- bios_control |= B_QNC_LPC_BIOS_CNTL_BIOSWE;
- pci_write_config32(dev, R_QNC_LPC_BIOS_CNTL, bios_control);
-
- /* Setup the SPI flash controller */
- context->ctrlr = ctrlr;
- ctrlr->opmenu[0] = 0x03; /* Read */
- ctrlr->opmenu[1] = 0x0b; /* Read fast */
- ctrlr->opmenu[2] = 0x05; /* Read status */
- ctrlr->opmenu[3] = 0x9f; /* Read ID */
- ctrlr->opmenu[4] = 0x02; /* Page program */
- ctrlr->opmenu[5] = 0x20; /* Erase 4 KiB */
- ctrlr->opmenu[6] = 0xd8; /* Erase 64 KiB */
- ctrlr->opmenu[7] = 0x01; /* Write status */
- ctrlr->prefix[0] = 0x50; /* Write status enable */
- ctrlr->prefix[1] = 0x06; /* Write enable */
- ctrlr->type = SPITYPE_ADDRESS /* Read */
- | (SPITYPE_ADDRESS << 2) /* Read fast */
- | (0 << 4) /* Read status */
- | (0 << 6) /* Read ID */
- | ((SPITYPE_ADDRESS | SPITYPE_PREFIX) << 8) /* Page program */
- | ((SPITYPE_ADDRESS | SPITYPE_PREFIX) << 10) /* Erase 4 KiB */
- | ((SPITYPE_ADDRESS | SPITYPE_PREFIX) << 12) /* Erase 64 KiB */
- | (SPITYPE_PREFIX << 14); /* Write status */
-}
-
-static void spi_init_cb(void *unused)
-{
- struct spi_flash flash;
-
- spi_init();
- if (spi_flash_probe(0, 0, &flash)) {
- printk(BIOS_DEBUG, "SPI flash failed initialization!\n");
- return;
- }
- printk(BIOS_DEBUG, "SPI flash successfully initialized\n");
-}
-
-BOOT_STATE_INIT_ENTRY(BS_DEV_INIT, BS_ON_ENTRY, spi_init_cb, NULL);
-
-const struct spi_ctrlr spi_driver = {
- .xfer = xfer,
- .max_xfer_size = 64,
-};
-
-const struct spi_ctrlr_buses spi_ctrlr_bus_map[] = {
- {
- .ctrlr = &spi_driver,
- .bus_start = 0,
- .bus_end = 0,
- },
-};
-
-const size_t spi_ctrlr_bus_map_count = ARRAY_SIZE(spi_ctrlr_bus_map);
diff --git a/src/soc/intel/quark/spi_debug.c b/src/soc/intel/quark/spi_debug.c
deleted file mode 100644
index a6b5e692ec..0000000000
--- a/src/soc/intel/quark/spi_debug.c
+++ /dev/null
@@ -1,98 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <console/console.h>
-#include <soc/spi.h>
-
-const char *spi_opcode_name(int opcode)
-{
- const char *op_name;
-
- switch (opcode) {
- default:
- op_name = "Unknown";
- break;
- case 1:
- op_name = "Write Status";
- break;
- case 2:
- op_name = "Page Program";
- break;
- case 3:
- op_name = "Read Data";
- break;
- case 5:
- op_name = "Read Status";
- break;
- case 6:
- op_name = "Write Data Enable";
- break;
- case 0x0b:
- op_name = "Fast Read";
- break;
- case 0x20:
- op_name = "Erase 4 KiB";
- break;
- case 0x50:
- op_name = "Write Status Enable";
- break;
- case 0x9f:
- op_name = "Read ID";
- break;
- case 0xd8:
- op_name = "Erase 64 KiB";
- break;
- }
- return op_name;
-}
-
-void spi_display(volatile struct flash_ctrlr *ctrlr)
-{
- int index;
- int opcode;
- const char *op_name;
- int prefix;
- int status;
- int type;
-
- /* Display the prefixes */
- printk(BIOS_DEBUG, "Prefix Table\n");
- for (index = 0; index < 2; index++) {
- prefix = ctrlr->prefix[index];
- op_name = spi_opcode_name(prefix);
- printk(BIOS_DEBUG, " %d: 0x%02x (%s)\n", index, prefix,
- op_name);
- }
-
- /* Display the opcodes */
- printk(BIOS_DEBUG, "Opcode Menu\n");
- for (index = 0; index < 8; index++) {
- opcode = ctrlr->opmenu[index];
- type = (ctrlr->type >> (index << 1)) & 3;
- op_name = spi_opcode_name(opcode);
- printk(BIOS_DEBUG, " %d: 0x%02x (%s), %s%s\n", index, opcode,
- op_name,
- (type & SPITYPE_PREFIX) ? "Write" : "Read",
- (type & SPITYPE_ADDRESS) ? ", w/3 byte address" : "");
- }
-
- /* Display the BIOS base address */
- printk(BIOS_DEBUG, "0x%08x: BIOS Base Address\n", ctrlr->bbar);
-
- /* Display the protection ranges */
- printk(BIOS_DEBUG, "BIOS Protected Range Registers\n");
- for (index = 0; index < ARRAY_SIZE(ctrlr->pbr); index++) {
- status = ctrlr->pbr[index];
- printk(BIOS_DEBUG, " %d: 0x%08x: 0x%08x - 0x%08x %s\n",
- index, status,
- 0xff000000 | (0x1000000 - CONFIG_ROM_SIZE)
- | ((status & SPIPBR_PRB) << SPIPBR_PRB_SHIFT),
- 0xff800fff | (0x1000000 - CONFIG_ROM_SIZE)
- | (status & SPIPBR_PRL),
- (status & SPIPBR_WPE) ? "Protected" : "Unprotected");
- }
-
- /* Display locked status */
- status = ctrlr->status;
- printk(BIOS_DEBUG, "0x%04x: SPISTS, Tables %s\n", status,
- (status & SPISTS_CLD) ? "Locked" : "Unlocked");
-}
diff --git a/src/soc/intel/quark/storage_test.c b/src/soc/intel/quark/storage_test.c
deleted file mode 100644
index f15d295a61..0000000000
--- a/src/soc/intel/quark/storage_test.c
+++ /dev/null
@@ -1,244 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <device/pci_ops.h>
-#include <assert.h>
-#include <cbmem.h>
-#include <commonlib/sdhci.h>
-#include <commonlib/storage.h>
-#include <console/console.h>
-#include <lib.h>
-#include <soc/iomap.h>
-#include <soc/pci_devs.h>
-#include <soc/storage_test.h>
-#include <timer.h>
-#include <string.h>
-
-#if CONFIG(STORAGE_LOG)
-struct log_entry log[LOG_ENTRIES];
-uint8_t log_index;
-int log_full;
-long log_start_time;
-#endif
-
-static uint8_t drivers_storage[256];
-
-#define STORAGE_DEBUG BIOS_DEBUG
-#define LOG_DEBUG (CONFIG(STORAGE_LOG) ? STORAGE_DEBUG : BIOS_NEVER)
-
-#ifdef __SIMPLE_DEVICE__
-uint32_t storage_test_init(pci_devfn_t dev, uint32_t *previous_bar,
- uint16_t *previous_command)
-#else
-uint32_t storage_test_init(struct device *dev, uint32_t *previous_bar,
- uint16_t *previous_command)
-#endif
-{
- uint32_t bar;
-
- /* Display the vendor/device IDs */
- printk(LOG_DEBUG, "Vendor ID: 0x%04x, Device ID: 0x%04x\n",
- pci_read_config16(dev, PCI_VENDOR_ID),
- pci_read_config16(dev, PCI_DEVICE_ID));
-
- /* Set the temporary base address */
- bar = pci_read_config32(dev, PCI_BASE_ADDRESS_0);
- *previous_bar = bar;
- bar &= ~PCI_BASE_ADDRESS_MEM_ATTR_MASK;
- if (!bar) {
- bar = SD_BASE_ADDRESS;
- pci_write_config32(dev, PCI_BASE_ADDRESS_0, bar);
- }
-
- /* Enable the SD/MMC controller */
- *previous_command = pci_read_config16(dev, PCI_COMMAND);
- pci_write_config16(dev, PCI_COMMAND, *previous_command
- | PCI_COMMAND_MEMORY);
-
- /* Return the controller address */
- return bar;
-}
-
-#ifdef __SIMPLE_DEVICE__
-void storage_test_complete(pci_devfn_t dev, uint32_t previous_bar,
- uint16_t previous_command)
-#else
-void storage_test_complete(struct device *dev, uint32_t previous_bar,
- uint16_t previous_command)
-#endif
-{
- pci_write_config16(dev, PCI_COMMAND, previous_command);
- pci_write_config32(dev, PCI_BASE_ADDRESS_0, previous_bar);
-}
-
-#if !ENV_BOOTBLOCK
-static void display_log(void)
-{
- /* Determine the array bounds */
- if (CONFIG(STORAGE_LOG)) {
- long delta;
- uint8_t end;
- uint8_t index;
- uint8_t start;
-
- end = log_index;
- start = log_full ? log_index : 0;
- for (index = start; (log_full || (index != end)); index++) {
- log_full = 0;
- delta = log[index].time.microseconds - log_start_time;
- printk(BIOS_DEBUG, "%3ld.%03ld mSec, cmd: %2d 0x%08x%s",
- delta / 1000, delta % 1000,
- log[index].cmd.cmdidx,
- log[index].cmd.cmdarg,
- log[index].cmd_issued ? "" : "(not issued)");
- if (log[index].response_entries == 1)
- printk(BIOS_DEBUG, ", rsp: 0x%08x",
- log[index].response[0]);
- else if (log[index].response_entries == 4)
- printk(BIOS_DEBUG,
- ", rsp: 0x%08x.%08x.%08x.%08x",
- log[index].response[3],
- log[index].response[2],
- log[index].response[1],
- log[index].response[0]);
- printk(BIOS_DEBUG, ", ret: %d\n", log[index].ret);
- }
- }
-}
-
-void sdhc_log_command(struct mmc_command *cmd)
-{
- if (CONFIG(STORAGE_LOG)) {
- timer_monotonic_get(&log[log_index].time);
- log[log_index].cmd = *cmd;
- log[log_index].cmd_issued = 0;
- log[log_index].response_entries = 0;
- if ((log_index == 0) && (!log_full))
- log_start_time = log[0].time.microseconds;
- }
-}
-
-void sdhc_log_command_issued(void)
-{
- if (CONFIG(STORAGE_LOG)) {
- log[log_index].cmd_issued = 1;
- }
-}
-
-void sdhc_log_response(uint32_t entries, uint32_t *response)
-{
- unsigned int entry;
-
- if (CONFIG(STORAGE_LOG)) {
- log[log_index].response_entries = entries;
- for (entry = 0; entry < entries; entry++)
- log[log_index].response[entry] = response[entry];
- }
-}
-
-void sdhc_log_ret(int ret)
-{
- if (CONFIG(STORAGE_LOG)) {
- log[log_index].ret = ret;
- if (++log_index == 0)
- log_full = 1;
- }
-}
-
-void storage_test(uint32_t bar, int full_initialization)
-{
- uint64_t blocks_read;
- uint8_t buffer[512];
- int err;
- struct storage_media *media;
- const char *name;
- unsigned int partition;
- unsigned int previous_partition;
- struct sdhci_ctrlr *sdhci_ctrlr;
-
- ASSERT(sizeof(struct sdhci_ctrlr) <= sizeof(drivers_storage));
-
- /* Get the structure addresses */
- media = NULL;
- if (ENV_CREATES_CBMEM)
- media = (struct storage_media *)drivers_storage;
- else
- media = cbmem_find(CBMEM_ID_STORAGE_DATA);
- sdhci_ctrlr = (void *)(((uintptr_t)(media + 1) + 0x7) & ~7);
- media->ctrlr = (struct sd_mmc_ctrlr *)sdhci_ctrlr;
- sdhci_ctrlr->ioaddr = (void *)bar;
-
- /* Initialize the controller */
- if (!full_initialization) {
- /* Perform fast initialization */
- sdhci_update_pointers(sdhci_ctrlr);
- sdhci_display_setup(sdhci_ctrlr);
- storage_display_setup(media);
- } else {
- /* Initialize the log */
- if (CONFIG(STORAGE_LOG)) {
- log_index = 0;
- log_full = 0;
- }
-
- printk(LOG_DEBUG, "Initializing the SD/MMC controller\n");
- err = sdhci_controller_init(sdhci_ctrlr, (void *)bar);
- if (err) {
- display_log();
- printk(BIOS_ERR, "Controller failed to initialize, err = %d\n",
- err);
- return;
- }
-
- /* Initialize the SD/MMC/eMMC card or device */
- printk(LOG_DEBUG, "Initializing the device\n");
- err = storage_setup_media(media, &sdhci_ctrlr->sd_mmc_ctrlr);
- if (err) {
- display_log();
- printk(BIOS_ERR, "Device failed to initialize, err = %d\n",
- err);
- return;
- }
- display_log();
- }
-
- /* Save the current partition */
- previous_partition = storage_get_current_partition(media);
-
- /* Read block 0 from each partition */
- for (partition = 0; partition < ARRAY_SIZE(media->capacity);
- partition++) {
- if (media->capacity[partition] == 0)
- continue;
- name = storage_partition_name(media, partition);
- printk(STORAGE_DEBUG, "%s%sReading block 0\n", name,
- name[0] ? ": " : "");
- err = storage_set_partition(media, partition);
- if (err)
- continue;
- blocks_read = storage_block_read(media, 0, 1, &buffer);
- if (blocks_read)
- hexdump(buffer, sizeof(buffer));
- }
-
- /* Restore the previous partition */
- storage_set_partition(media, previous_partition);
-}
-#endif
-
-static void copy_storage_structures(int is_recovery)
-{
- struct storage_media *media;
- struct sdhci_ctrlr *sdhci_ctrlr;
- size_t size = sizeof(drivers_storage);
-
- /* Locate the data structures in CBMEM */
- media = cbmem_add(CBMEM_ID_STORAGE_DATA, size);
- ASSERT(media != NULL);
- sdhci_ctrlr = (void *)(((uintptr_t)(media + 1) + 0x7) & ~7);
-
- /* Migrate the data into CBMEM */
- memcpy(media, drivers_storage, size);
- media->ctrlr = &sdhci_ctrlr->sd_mmc_ctrlr;
-}
-
-CBMEM_CREATION_HOOK(copy_storage_structures);
diff --git a/src/soc/intel/quark/tsc_freq.c b/src/soc/intel/quark/tsc_freq.c
deleted file mode 100644
index a0a3367809..0000000000
--- a/src/soc/intel/quark/tsc_freq.c
+++ /dev/null
@@ -1,9 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <cpu/x86/tsc.h>
-
-unsigned long tsc_freq_mhz(void)
-{
- /* CPU freq = 400 MHz */
- return 400;
-}
diff --git a/src/soc/intel/quark/uart.c b/src/soc/intel/quark/uart.c
deleted file mode 100644
index 0047664f15..0000000000
--- a/src/soc/intel/quark/uart.c
+++ /dev/null
@@ -1,32 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <console/uart.h>
-#include <device/pci.h>
-#include <device/pci_ids.h>
-#include <soc/pci_devs.h>
-
-static void uart_read_resources(struct device *dev)
-{
- struct resource *res;
-
- /* Read the resources */
- pci_dev_read_resources(dev);
-
- /* Set the debug port configuration */
- res = find_resource(dev, PCI_BASE_ADDRESS_0);
- res->base = uart_platform_base(CONFIG_UART_FOR_CONSOLE);
- res->size = 0x100;
- res->flags = IORESOURCE_MEM | IORESOURCE_ASSIGNED | IORESOURCE_FIXED;
-}
-
-static struct device_operations device_ops = {
- .read_resources = uart_read_resources,
- .set_resources = pci_dev_set_resources,
- .enable_resources = pci_dev_enable_resources,
-};
-
-static const struct pci_driver uart_driver __pci_driver = {
- .ops = &device_ops,
- .vendor = PCI_VID_INTEL,
- .device = HSUART_DEVID,
-};
diff --git a/src/soc/intel/quark/uart_common.c b/src/soc/intel/quark/uart_common.c
deleted file mode 100644
index 19ca745ca1..0000000000
--- a/src/soc/intel/quark/uart_common.c
+++ /dev/null
@@ -1,14 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-
-#include <console/uart.h>
-#include <soc/iomap.h>
-
-unsigned int uart_platform_refclk(void)
-{
- return 44236800;
-}
-
-uintptr_t uart_platform_base(unsigned int idx)
-{
- return UART_BASE_ADDRESS;
-}