blob: bda064f1365b39b01ca2bdcf3f39b08c36f2220c [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Bin Menga2927e02014-12-12 21:05:25 +08002/*
3 * Copyright (C) 2014, Bin Meng <bmeng.cn@gmail.com>
Bin Menga2927e02014-12-12 21:05:25 +08004 */
5
Tom Rinid678a592024-05-18 20:20:43 -06006#include <common.h>
Bin Menga2927e02014-12-12 21:05:25 +08007#include <asm/io.h>
8#include <asm/pnp_def.h>
9
10static void pnp_enter_conf_state(u16 dev)
11{
12 u16 port = dev >> 8;
13
14 outb(0x55, port);
15}
16
17static void pnp_exit_conf_state(u16 dev)
18{
19 u16 port = dev >> 8;
20
21 outb(0xaa, port);
22}
23
Bin Mengc78dfb42015-08-21 00:18:51 -070024void lpc47m_enable_serial(uint dev, uint iobase, uint irq)
Bin Menga2927e02014-12-12 21:05:25 +080025{
26 pnp_enter_conf_state(dev);
27 pnp_set_logical_device(dev);
28 pnp_set_enable(dev, 0);
29 pnp_set_iobase(dev, PNP_IDX_IO0, iobase);
Bin Meng19268832015-03-31 11:25:03 +080030 pnp_set_irq(dev, PNP_IDX_IRQ0, irq);
Bin Menga2927e02014-12-12 21:05:25 +080031 pnp_set_enable(dev, 1);
32 pnp_exit_conf_state(dev);
33}
Bin Mengc78dfb42015-08-21 00:18:51 -070034
35void lpc47m_enable_kbc(uint dev, uint irq0, uint irq1)
36{
37 pnp_enter_conf_state(dev);
38 pnp_set_logical_device(dev);
39 pnp_set_enable(dev, 0);
40 pnp_set_irq(dev, PNP_IDX_IRQ0, irq0);
41 pnp_set_irq(dev, PNP_IDX_IRQ1, irq1);
42 pnp_set_enable(dev, 1);
43 pnp_exit_conf_state(dev);
44}