blob: 13604769ab107681887cc2e09296e93d1c966a68 [file] [log] [blame]
Felix Held3f3eca92020-01-23 17:12:32 +01001/* SPDX-License-Identifier: GPL-2.0-or-later */
Stefan Reinauer474ff3d2015-11-04 22:41:47 +02002
Stefan Reinauer474ff3d2015-11-04 22:41:47 +02003#include <device/device.h>
4#include <device/pnp.h>
5#include <pc80/keyboard.h>
Stefan Reinauer474ff3d2015-11-04 22:41:47 +02006#include <superio/conf_mode.h>
7
8#include "nct6779d.h"
9
Stefan Reinauer474ff3d2015-11-04 22:41:47 +020010static void nct6779d_init(struct device *dev)
11{
12 if (!dev->enabled)
13 return;
14
Elyes HAOUAS0ce41f12018-11-13 10:03:31 +010015 switch (dev->path.pnp.device) {
Stefan Reinauer474ff3d2015-11-04 22:41:47 +020016 /* TODO: Might potentially need code for HWM or FDC etc. */
17 case NCT6779D_KBC:
Timothy Pearson448e3862015-11-24 14:12:01 -060018 pc_keyboard_init(NO_AUX_DEVICE);
Stefan Reinauer474ff3d2015-11-04 22:41:47 +020019 break;
20 }
21}
22
23static struct device_operations ops = {
24 .read_resources = pnp_read_resources,
25 .set_resources = pnp_set_resources,
26 .enable_resources = pnp_enable_resources,
27 .enable = pnp_alt_enable,
28 .init = nct6779d_init,
29 .ops_pnp_mode = &pnp_conf_mode_8787_aa,
30};
31
32static struct pnp_info pnp_dev_info[] = {
Felix Held9911d642018-07-06 20:55:53 +020033 { NULL, NCT6779D_PP, PNP_IO0 | PNP_IRQ0 | PNP_DRQ0, 0x0ff8, },
34 { NULL, NCT6779D_SP1, PNP_IO0 | PNP_IRQ0, 0x0ff8, },
35 { NULL, NCT6779D_SP2, PNP_IO0 | PNP_IRQ0, 0x0ff8, },
36 { NULL, NCT6779D_KBC, PNP_IO0 | PNP_IO1 | PNP_IRQ0 | PNP_IRQ1,
37 0x0fff, 0x0fff, },
38 { NULL, NCT6779D_CIR, PNP_IO0 | PNP_IRQ0, 0x0ff8, },
Keith Hui1f572b92020-05-10 23:00:16 -040039 { NULL, NCT6779D_ACPI, PNP_MSC2,},
40 { NULL, NCT6779D_HWM_FPLED, PNP_IO0 | PNP_IO1 | PNP_IRQ0 | PNP_MSC0,
Felix Held9911d642018-07-06 20:55:53 +020041 0x0ffe, 0x0ffe, },
42 { NULL, NCT6779D_WDT1},
43 { NULL, NCT6779D_CIRWKUP, PNP_IO0 | PNP_IRQ0, 0x0ff8, },
44 { NULL, NCT6779D_GPIO_PP_OD},
45 { NULL, NCT6779D_PRT80},
46 { NULL, NCT6779D_DSLP},
47 { NULL, NCT6779D_GPIOBASE, PNP_IO0, 0x0ff8, },
48 { NULL, NCT6779D_GPIO0},
49 { NULL, NCT6779D_GPIO1},
50 { NULL, NCT6779D_GPIO2},
51 { NULL, NCT6779D_GPIO3},
52 { NULL, NCT6779D_GPIO4},
Keith Hui1f572b92020-05-10 23:00:16 -040053 { NULL, NCT6779D_GPIO5, PNP_MSC4 | PNP_MSC5},
54 { NULL, NCT6779D_GPIO6, PNP_MSC4 | PNP_MSC5},
Felix Held9911d642018-07-06 20:55:53 +020055 { NULL, NCT6779D_GPIO7},
56 { NULL, NCT6779D_GPIO8},
Stefan Reinauer474ff3d2015-11-04 22:41:47 +020057};
58
59static void enable_dev(struct device *dev)
60{
61 pnp_enable_devices(dev, &ops, ARRAY_SIZE(pnp_dev_info), pnp_dev_info);
62}
63
64struct chip_operations superio_nuvoton_nct6779d_ops = {
Nicholas Sudsgaardbfb11be2024-01-30 09:53:46 +090065 .name = "NUVOTON NCT6779D Super I/O",
Stefan Reinauer474ff3d2015-11-04 22:41:47 +020066 .enable_dev = enable_dev,
67};