Kerry Sheh | a3f0607 | 2012-02-07 20:32:38 +0800 | [diff] [blame] | 1 | /* |
| 2 | * This file is part of the coreboot project. |
| 3 | * |
| 4 | * Copyright (C) 2011 - 2012 Advanced Micro Devices, Inc. |
| 5 | * |
| 6 | * This program is free software; you can redistribute it and/or modify |
| 7 | * it under the terms of the GNU General Public License as published by |
| 8 | * the Free Software Foundation; version 2 of the License. |
| 9 | * |
| 10 | * This program is distributed in the hope that it will be useful, |
| 11 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 12 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 13 | * GNU General Public License for more details. |
Kerry Sheh | a3f0607 | 2012-02-07 20:32:38 +0800 | [diff] [blame] | 14 | */ |
| 15 | |
Kyösti Mälkki | ef84401 | 2013-06-25 23:17:43 +0300 | [diff] [blame] | 16 | // Use simple device model for this file even in ramstage |
| 17 | #define __SIMPLE_DEVICE__ |
| 18 | |
Stefan Reinauer | 24d1d4b | 2013-03-21 11:51:41 -0700 | [diff] [blame] | 19 | #include <arch/io.h> |
Kerry Sheh | a3f0607 | 2012-02-07 20:32:38 +0800 | [diff] [blame] | 20 | #include <reset.h> |
Kerry Sheh | a3f0607 | 2012-02-07 20:32:38 +0800 | [diff] [blame] | 21 | |
| 22 | #define HT_INIT_CONTROL 0x6C |
| 23 | #define HTIC_BIOSR_Detect (1<<5) |
| 24 | |
Kyösti Mälkki | 29c3e36 | 2014-04-16 16:30:00 +0300 | [diff] [blame] | 25 | #define NODE_PCI(x, fn) (((CONFIG_CDB+x)<32)?(PCI_DEV(CONFIG_CBB,(CONFIG_CDB+x),fn)):(PCI_DEV((CONFIG_CBB-1),(CONFIG_CDB+x-32),fn))) |
Kerry Sheh | a3f0607 | 2012-02-07 20:32:38 +0800 | [diff] [blame] | 26 | |
| 27 | static inline void set_bios_reset(void) |
| 28 | { |
| 29 | u32 nodes; |
| 30 | u32 htic; |
Kyösti Mälkki | 3f9a62e | 2013-06-20 20:25:21 +0300 | [diff] [blame] | 31 | pci_devfn_t dev; |
Kerry Sheh | a3f0607 | 2012-02-07 20:32:38 +0800 | [diff] [blame] | 32 | int i; |
| 33 | |
| 34 | nodes = ((pci_read_config32(PCI_DEV(CONFIG_CBB, CONFIG_CDB, 0), 0x60) >> 4) & 7) + 1; |
Elyes HAOUAS | ba28e8d | 2016-08-31 19:22:16 +0200 | [diff] [blame^] | 35 | for (i = 0; i < nodes; i++) { |
Kerry Sheh | a3f0607 | 2012-02-07 20:32:38 +0800 | [diff] [blame] | 36 | dev = NODE_PCI(i, 0); |
| 37 | htic = pci_read_config32(dev, HT_INIT_CONTROL); |
| 38 | htic &= ~HTIC_BIOSR_Detect; |
| 39 | pci_write_config32(dev, HT_INIT_CONTROL, htic); |
| 40 | } |
| 41 | } |
| 42 | |
| 43 | void hard_reset(void) |
| 44 | { |
| 45 | set_bios_reset(); |
| 46 | /* Try rebooting through port 0xcf9 */ |
| 47 | /* Actually it is not a real hard_reset --- it only reset coherent link table, but not reset link freq and width */ |
| 48 | outb((0 << 3) | (0 << 2) | (1 << 1), 0xcf9); |
| 49 | outb((0 << 3) | (1 << 2) | (1 << 1), 0xcf9); |
| 50 | } |
| 51 | |
| 52 | //SbReset(); |
| 53 | void soft_reset(void) |
| 54 | { |
| 55 | set_bios_reset(); |
| 56 | /* link reset */ |
| 57 | outb(0x06, 0x0cf9); |
| 58 | } |