mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-07 14:24:18 +08:00
74ba9207e1
Based on 1 normalized pattern(s): this program is free software you can redistribute it and or modify it under the terms of the gnu general public license as published by the free software foundation either version 2 of the license or at your option any later version this program is distributed in the hope that it will be useful but without any warranty without even the implied warranty of merchantability or fitness for a particular purpose see the gnu general public license for more details you should have received a copy of the gnu general public license along with this program if not write to the free software foundation inc 675 mass ave cambridge ma 02139 usa extracted by the scancode license scanner the SPDX license identifier GPL-2.0-or-later has been chosen to replace the boilerplate/reference in 441 file(s). Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Michael Ellerman <mpe@ellerman.id.au> (powerpc) Reviewed-by: Richard Fontana <rfontana@redhat.com> Reviewed-by: Allison Randal <allison@lohutok.net> Reviewed-by: Kate Stewart <kstewart@linuxfoundation.org> Cc: linux-spdx@vger.kernel.org Link: https://lkml.kernel.org/r/20190520071858.739733335@linutronix.de Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
97 lines
2.3 KiB
C
97 lines
2.3 KiB
C
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
/*
|
|
* RDC321x MFD southbridge driver
|
|
*
|
|
* Copyright (C) 2007-2010 Florian Fainelli <florian@openwrt.org>
|
|
* Copyright (C) 2010 Bernhard Loos <bernhardloos@googlemail.com>
|
|
*/
|
|
#include <linux/module.h>
|
|
#include <linux/kernel.h>
|
|
#include <linux/platform_device.h>
|
|
#include <linux/pci.h>
|
|
#include <linux/mfd/core.h>
|
|
#include <linux/mfd/rdc321x.h>
|
|
|
|
static struct rdc321x_wdt_pdata rdc321x_wdt_pdata;
|
|
|
|
static struct resource rdc321x_wdt_resource[] = {
|
|
{
|
|
.name = "wdt-reg",
|
|
.start = RDC321X_WDT_CTRL,
|
|
.end = RDC321X_WDT_CTRL + 0x3,
|
|
.flags = IORESOURCE_IO,
|
|
}
|
|
};
|
|
|
|
static struct rdc321x_gpio_pdata rdc321x_gpio_pdata = {
|
|
.max_gpios = RDC321X_NUM_GPIO,
|
|
};
|
|
|
|
static struct resource rdc321x_gpio_resources[] = {
|
|
{
|
|
.name = "gpio-reg1",
|
|
.start = RDC321X_GPIO_CTRL_REG1,
|
|
.end = RDC321X_GPIO_CTRL_REG1 + 0x7,
|
|
.flags = IORESOURCE_IO,
|
|
}, {
|
|
.name = "gpio-reg2",
|
|
.start = RDC321X_GPIO_CTRL_REG2,
|
|
.end = RDC321X_GPIO_CTRL_REG2 + 0x7,
|
|
.flags = IORESOURCE_IO,
|
|
}
|
|
};
|
|
|
|
static const struct mfd_cell rdc321x_sb_cells[] = {
|
|
{
|
|
.name = "rdc321x-wdt",
|
|
.resources = rdc321x_wdt_resource,
|
|
.num_resources = ARRAY_SIZE(rdc321x_wdt_resource),
|
|
.platform_data = &rdc321x_wdt_pdata,
|
|
.pdata_size = sizeof(rdc321x_wdt_pdata),
|
|
}, {
|
|
.name = "rdc321x-gpio",
|
|
.resources = rdc321x_gpio_resources,
|
|
.num_resources = ARRAY_SIZE(rdc321x_gpio_resources),
|
|
.platform_data = &rdc321x_gpio_pdata,
|
|
.pdata_size = sizeof(rdc321x_gpio_pdata),
|
|
},
|
|
};
|
|
|
|
static int rdc321x_sb_probe(struct pci_dev *pdev,
|
|
const struct pci_device_id *ent)
|
|
{
|
|
int err;
|
|
|
|
err = pci_enable_device(pdev);
|
|
if (err) {
|
|
dev_err(&pdev->dev, "failed to enable device\n");
|
|
return err;
|
|
}
|
|
|
|
rdc321x_gpio_pdata.sb_pdev = pdev;
|
|
rdc321x_wdt_pdata.sb_pdev = pdev;
|
|
|
|
return devm_mfd_add_devices(&pdev->dev, -1,
|
|
rdc321x_sb_cells,
|
|
ARRAY_SIZE(rdc321x_sb_cells),
|
|
NULL, 0, NULL);
|
|
}
|
|
|
|
static const struct pci_device_id rdc321x_sb_table[] = {
|
|
{ PCI_DEVICE(PCI_VENDOR_ID_RDC, PCI_DEVICE_ID_RDC_R6030) },
|
|
{}
|
|
};
|
|
MODULE_DEVICE_TABLE(pci, rdc321x_sb_table);
|
|
|
|
static struct pci_driver rdc321x_sb_driver = {
|
|
.name = "RDC321x Southbridge",
|
|
.id_table = rdc321x_sb_table,
|
|
.probe = rdc321x_sb_probe,
|
|
};
|
|
|
|
module_pci_driver(rdc321x_sb_driver);
|
|
|
|
MODULE_AUTHOR("Florian Fainelli <florian@openwrt.org>");
|
|
MODULE_LICENSE("GPL");
|
|
MODULE_DESCRIPTION("RDC R-321x MFD southbridge driver");
|