Felix Held | 3f3eca9 | 2020-01-23 17:12:32 +0100 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-or-later */ |
Mondrian nuessle | 21da019 | 2009-04-22 20:30:42 +0000 | [diff] [blame] | 2 | |
Uwe Hermann | fff87d3 | 2009-06-01 01:38:29 +0000 | [diff] [blame] | 3 | /* PILOT Super I/O is only based on LPC observation done on factory system. */ |
Mondrian nuessle | 21da019 | 2009-04-22 20:30:42 +0000 | [diff] [blame] | 4 | |
Stefan Reinauer | 24d1d4b | 2013-03-21 11:51:41 -0700 | [diff] [blame] | 5 | #include <arch/io.h> |
Kyösti Mälkki | 3855c01 | 2019-03-03 08:45:19 +0200 | [diff] [blame] | 6 | #include <device/pnp_ops.h> |
Edward O'Callaghan | f18abab | 2014-03-31 21:53:32 +1100 | [diff] [blame] | 7 | #include <device/pnp.h> |
Mondrian nuessle | 21da019 | 2009-04-22 20:30:42 +0000 | [diff] [blame] | 8 | #include "pilot.h" |
| 9 | |
Elyes HAOUAS | e46a415 | 2019-12-05 10:48:17 +0100 | [diff] [blame] | 10 | /* Pilot uses 0x5A/0xA5 pattern to activate deactivate config access. */ |
Edward O'Callaghan | 85836c2 | 2014-07-09 20:26:25 +1000 | [diff] [blame] | 11 | void pnp_enter_ext_func_mode(pnp_devfn_t dev) |
Mondrian nuessle | 21da019 | 2009-04-22 20:30:42 +0000 | [diff] [blame] | 12 | { |
Uwe Hermann | 8c02368 | 2010-11-06 23:36:49 +0000 | [diff] [blame] | 13 | u16 port = dev >> 8; |
Mondrian nuessle | 21da019 | 2009-04-22 20:30:42 +0000 | [diff] [blame] | 14 | outb(0x5A, port); |
| 15 | } |
| 16 | |
Edward O'Callaghan | 85836c2 | 2014-07-09 20:26:25 +1000 | [diff] [blame] | 17 | void pnp_exit_ext_func_mode(pnp_devfn_t dev) |
Mondrian nuessle | 21da019 | 2009-04-22 20:30:42 +0000 | [diff] [blame] | 18 | { |
Uwe Hermann | 8c02368 | 2010-11-06 23:36:49 +0000 | [diff] [blame] | 19 | u16 port = dev >> 8; |
Mondrian nuessle | 21da019 | 2009-04-22 20:30:42 +0000 | [diff] [blame] | 20 | outb(0xA5, port); |
| 21 | } |
| 22 | |
Uwe Hermann | fff87d3 | 2009-06-01 01:38:29 +0000 | [diff] [blame] | 23 | /* Serial config is a fairly standard procedure. */ |
Edward O'Callaghan | 85836c2 | 2014-07-09 20:26:25 +1000 | [diff] [blame] | 24 | void pilot_enable_serial(pnp_devfn_t dev, u16 iobase) |
Mondrian nuessle | 21da019 | 2009-04-22 20:30:42 +0000 | [diff] [blame] | 25 | { |
| 26 | pnp_enter_ext_func_mode(dev); |
| 27 | pnp_set_logical_device(dev); |
| 28 | pnp_set_iobase(dev, PNP_IDX_IO0, iobase); |
| 29 | pnp_set_enable(dev, 1); |
| 30 | pnp_exit_ext_func_mode(dev); |
| 31 | } |
| 32 | |
Edward O'Callaghan | 85836c2 | 2014-07-09 20:26:25 +1000 | [diff] [blame] | 33 | void pilot_disable_serial(pnp_devfn_t dev) |
Mondrian nuessle | 21da019 | 2009-04-22 20:30:42 +0000 | [diff] [blame] | 34 | { |
| 35 | pnp_enter_ext_func_mode(dev); |
| 36 | pnp_set_logical_device(dev); |
Uwe Hermann | 8c02368 | 2010-11-06 23:36:49 +0000 | [diff] [blame] | 37 | pnp_set_iobase(dev, PNP_IDX_IO0, 0x0000); |
Mondrian nuessle | 21da019 | 2009-04-22 20:30:42 +0000 | [diff] [blame] | 38 | pnp_set_enable(dev, 0); |
| 39 | pnp_exit_ext_func_mode(dev); |
| 40 | } |