soc/amd/stoney: clean up and update reset.c

- Move #defines to soc/northbridge.h, add other reset definitions to
soc/southbridge.h.
- Clean up file to use definitions instead of magic numbers.
- Add do_soft_reset()

BUG=b:69224851
TEST=Build gardenia; Build & boot Kahlee

Change-Id: I0cc4c04b53b7fec38d45e962ff1292d8c717269c
Signed-off-by: Martin Roth <martinroth@google.com>
Reviewed-on: https://review.coreboot.org/22439
Reviewed-by: Aaron Durbin <adurbin@chromium.org>
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Marshall Dawson <marshalldawson3rd@gmail.com>
This commit is contained in:
Martin Roth 2017-11-12 14:54:09 -07:00
parent 88a61bbd00
commit 48e44eecc7
4 changed files with 37 additions and 20 deletions

View file

@ -42,6 +42,8 @@ bootblock-y += BiosCallOuts.c
bootblock-y += bootblock/bootblock.c bootblock-y += bootblock/bootblock.c
bootblock-y += early_setup.c bootblock-y += early_setup.c
bootblock-y += pmutil.c bootblock-y += pmutil.c
bootblock-y += reset.c
bootblock-y += sb_util.c
bootblock-y += tsc_freq.c bootblock-y += tsc_freq.c
romstage-y += BiosCallOuts.c romstage-y += BiosCallOuts.c
@ -51,6 +53,8 @@ romstage-$(CONFIG_USBDEBUG_IN_ROMSTAGE) += enable_usbdebug.c
romstage-y += gpio.c romstage-y += gpio.c
romstage-$(CONFIG_STONEYRIDGE_IMC_FWM) += imc.c romstage-$(CONFIG_STONEYRIDGE_IMC_FWM) += imc.c
romstage-y += pmutil.c romstage-y += pmutil.c
romstage-y += reset.c
romstage-y += sb_util.c
romstage-y += smbus.c romstage-y += smbus.c
romstage-y += smbus_spd.c romstage-y += smbus_spd.c
romstage-y += ramtop.c romstage-y += ramtop.c

View file

@ -24,6 +24,8 @@
#define D18F0_NODE_ID 0x60 #define D18F0_NODE_ID 0x60
#define D18F0_CPU_CNT 0x62 /* BKDG defines as a field in DWORD 0x60 */ #define D18F0_CPU_CNT 0x62 /* BKDG defines as a field in DWORD 0x60 */
# define CPU_CNT_MASK 0x1f /* CpuCnt + 1 = no. CPUs */ # define CPU_CNT_MASK 0x1f /* CpuCnt + 1 = no. CPUs */
#define HT_INIT_CONTROL 0x6c
# define HTIC_BIOSR_DETECT ((1 << 5) | (1 << 9) | (1 << 10))
/* D18F1 - Address Map Registers */ /* D18F1 - Address Map Registers */

View file

@ -259,6 +259,15 @@
#define FCH_MISC_REG40_OSCOUT1_EN BIT(2) #define FCH_MISC_REG40_OSCOUT1_EN BIT(2)
/* IO 0xcf9 - Reset control port*/
#define FULL_RST BIT(3)
#define RST_CMD BIT(2)
#define SYS_RST BIT(1)
/* PMx10 - Power Reset Config */
#define PWR_RESET_CFG 0x10
#define TOGGLE_ALL_PWR_GOOD BIT(1)
static inline int sb_sata_enable(void) static inline int sb_sata_enable(void)
{ {
/* True if IDE or AHCI. */ /* True if IDE or AHCI. */

View file

@ -2,6 +2,7 @@
* This file is part of the coreboot project. * This file is part of the coreboot project.
* *
* Copyright (C) 2010 Advanced Micro Devices, Inc. * Copyright (C) 2010 Advanced Micro Devices, Inc.
* Copyright (C) 2017 Google, Inc.
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
@ -13,34 +14,35 @@
* GNU General Public License for more details. * GNU General Public License for more details.
*/ */
// Use simple device model for this file even in ramstage
#define __SIMPLE_DEVICE__
#include <arch/io.h> #include <arch/io.h>
#include <reset.h> #include <reset.h>
#include <soc/northbridge.h>
#include <soc/pci_devs.h>
#include <soc/southbridge.h> #include <soc/southbridge.h>
#define HT_INIT_CONTROL 0x6c /* Clear bits 5, 9 & 10, used to signal the reset type */
#define HTIC_BIOSR_Detect (1 << 5) static void clear_bios_reset(void)
static void set_bios_reset(void)
{ {
u32 htic; u32 htic;
htic = pci_io_read_config32(PCI_DEV(0, 0x18, 0), HT_INIT_CONTROL); htic = pci_read_config32(SOC_HT_DEV, HT_INIT_CONTROL);
htic &= ~HTIC_BIOSR_Detect; htic &= ~HTIC_BIOSR_DETECT;
pci_io_write_config32(PCI_DEV(0, 0x18, 0), HT_INIT_CONTROL, htic); pci_write_config32(SOC_HT_DEV, HT_INIT_CONTROL, htic);
} }
void do_hard_reset(void) void do_hard_reset(void)
{ {
set_bios_reset(); clear_bios_reset();
/* Try rebooting through port 0xcf9 */
/* /* De-assert and then assert all PwrGood signals on CF9 reset. */
* Actually it is not a real hard_reset pm_write16(PWR_RESET_CFG, pm_read16(PWR_RESET_CFG) |
* --- it only reset coherent link table, TOGGLE_ALL_PWR_GOOD);
* but not reset link freq and width outb(RST_CMD | SYS_RST, SYS_RESET);
*/ }
outb((0 << 3) | (0 << 2) | (1 << 1), SYS_RESET);
outb((0 << 3) | (1 << 2) | (1 << 1), SYS_RESET); void do_soft_reset(void)
{
clear_bios_reset();
/* Assert reset signals only. */
outb(RST_CMD | SYS_RST, SYS_RESET);
} }