Felix Held | 3f3eca9 | 2020-01-23 17:12:32 +0100 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-or-later */ |
Zheng Bao | 9db833b | 2009-12-28 09:59:44 +0000 | [diff] [blame] | 2 | |
Stefan Reinauer | 24d1d4b | 2013-03-21 11:51:41 -0700 | [diff] [blame] | 3 | #include <arch/io.h> |
Kyösti Mälkki | 3855c01 | 2019-03-03 08:45:19 +0200 | [diff] [blame] | 4 | #include <device/pnp_ops.h> |
Edward O'Callaghan | b8f05d4 | 2015-01-04 16:17:54 +1100 | [diff] [blame] | 5 | #include <device/pnp.h> |
| 6 | #include <stdint.h> |
Ronald G. Minnich | 1cf26a8 | 2005-10-19 17:35:18 +0000 | [diff] [blame] | 7 | #include "pc87417.h" |
| 8 | |
Edward O'Callaghan | b8f05d4 | 2015-01-04 16:17:54 +1100 | [diff] [blame] | 9 | void pc87417_disable_dev(pnp_devfn_t dev) |
Ronald G. Minnich | 1cf26a8 | 2005-10-19 17:35:18 +0000 | [diff] [blame] | 10 | { |
| 11 | pnp_set_logical_device(dev); |
| 12 | pnp_set_enable(dev, 0); |
| 13 | } |
Zheng Bao | 9db833b | 2009-12-28 09:59:44 +0000 | [diff] [blame] | 14 | |
Edward O'Callaghan | b8f05d4 | 2015-01-04 16:17:54 +1100 | [diff] [blame] | 15 | void pc87417_enable_dev(pnp_devfn_t dev) |
Ronald G. Minnich | 1cf26a8 | 2005-10-19 17:35:18 +0000 | [diff] [blame] | 16 | { |
| 17 | pnp_set_logical_device(dev); |
Ronald G. Minnich | 1cf26a8 | 2005-10-19 17:35:18 +0000 | [diff] [blame] | 18 | pnp_set_enable(dev, 1); |
| 19 | } |
Zheng Bao | 9db833b | 2009-12-28 09:59:44 +0000 | [diff] [blame] | 20 | |
Edward O'Callaghan | b8f05d4 | 2015-01-04 16:17:54 +1100 | [diff] [blame] | 21 | void xbus_cfg(pnp_devfn_t dev) |
Ronald G. Minnich | 1cf26a8 | 2005-10-19 17:35:18 +0000 | [diff] [blame] | 22 | { |
Edward O'Callaghan | b8f05d4 | 2015-01-04 16:17:54 +1100 | [diff] [blame] | 23 | u8 i; |
Uwe Hermann | a69d978 | 2010-11-15 19:35:14 +0000 | [diff] [blame] | 24 | u16 xbus_index; |
Ronald G. Minnich | 1cf26a8 | 2005-10-19 17:35:18 +0000 | [diff] [blame] | 25 | |
| 26 | pnp_set_logical_device(dev); |
Uwe Hermann | a69d978 | 2010-11-15 19:35:14 +0000 | [diff] [blame] | 27 | /* Select proper BIOS size (4MB). */ |
| 28 | pnp_write_config(dev, PC87417_XMEMCNF2, |
| 29 | (pnp_read_config(dev, PC87417_XMEMCNF2)) | 0x04); |
Elyes HAOUAS | 9b54dfa | 2020-08-26 18:36:13 +0200 | [diff] [blame] | 30 | xbus_index = pnp_read_iobase(dev, PNP_IDX_IO0); |
Ronald G. Minnich | 1cf26a8 | 2005-10-19 17:35:18 +0000 | [diff] [blame] | 31 | |
Uwe Hermann | a69d978 | 2010-11-15 19:35:14 +0000 | [diff] [blame] | 32 | /* Enable writes to devices attached to XCS0 (XBUS Chip Select 0). */ |
| 33 | for (i = 0; i <= 0xf; i++) |
| 34 | outb((i << 4), xbus_index + PC87417_HAP0); |
Zheng Bao | 9db833b | 2009-12-28 09:59:44 +0000 | [diff] [blame] | 35 | } |