blob: b3e2c0e44976ec13acde177d644e0f8ecadbf3cf [file] [log] [blame]
Morgan Tsai1602dd52007-10-29 21:00:14 +00001/*
2 * This file is part of the LinuxBIOS project.
3 *
4 * Copyright (C) 2007 AMD
5 * Written by Yinghai Lu <yinghai.lu@amd.com> for AMD.
6 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
20 */
21
22static unsigned get_sbdn(unsigned bus)
23{
24 device_t dev;
25
Carl-Daniel Hailfingera3588922007-11-05 22:21:27 +000026 /* Find the device. */
Morgan Tsai1602dd52007-10-29 21:00:14 +000027 dev = pci_locate_device_on_bus(
Morgan Tsai31e805d2007-11-14 01:34:02 +000028 PCI_ID(PCI_VENDOR_ID_SIS, PCI_DEVICE_ID_SIS_SIS761),
Morgan Tsai1602dd52007-10-29 21:00:14 +000029 bus);
30
31 return (dev>>15) & 0x1f;
Morgan Tsai1602dd52007-10-29 21:00:14 +000032}
33
34static void hard_reset(void)
35{
36 set_bios_reset();
37
38 /* full reset */
39 outb(0x0a, 0x0cf9);
40 outb(0x0e, 0x0cf9);
41}
Carl-Daniel Hailfingera3588922007-11-05 22:21:27 +000042
Morgan Tsai1602dd52007-10-29 21:00:14 +000043static void enable_fid_change_on_sb(unsigned sbbusn, unsigned sbdn)
44{
45/* default value for sis966 is good */
46 /* set VFSMAF ( VID/FID System Management Action Field) to 2 */
47
48}
49
50static void soft_reset(void)
51{
52 set_bios_reset();
Morgan Tsai218c2652007-11-02 16:09:58 +000053
Morgan Tsai1602dd52007-10-29 21:00:14 +000054 /* link reset */
55 outb(0x02, 0x0cf9);
56 outb(0x06, 0x0cf9);
Morgan Tsai218c2652007-11-02 16:09:58 +000057
Morgan Tsai1602dd52007-10-29 21:00:14 +000058}
59