mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-08 14:13:53 +00:00
83b716d1fe
Add the Device Feature List (DFL) feature id for the High Speed Serial Interface (HSSI) Subsystem to the table of ids supported by the uio_dfl driver. The HSSI Subsystem is a configurable set of IP blocks to be used as part of a Ethernet or PCS/FEC/PMA pipeline. Like the Ethernet group used by the N3000 card, the HSSI Subsystem does not fully implement a network device from a Linux netdev perspective and is controlled and monitored from user space software via the uio interface. The Feature ID table of DFL can be found: https://github.com/OPAE/dfl-feature-id Reviewed-by: Tom Rix <trix@redhat.com> Acked-by: Xu Yilun <yilun.xu@intel.com> Signed-off-by: Matthew Gerlach <matthew.gerlach@linux.intel.com> Signed-off-by: Tianfei Zhang <tianfei.zhang@intel.com> Link: https://lore.kernel.org/r/20220505094129.686535-1-tianfei.zhang@intel.com Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
69 lines
1.6 KiB
C
69 lines
1.6 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
/*
|
|
* Generic DFL driver for Userspace I/O devicess
|
|
*
|
|
* Copyright (C) 2021 Intel Corporation, Inc.
|
|
*/
|
|
#include <linux/dfl.h>
|
|
#include <linux/errno.h>
|
|
#include <linux/module.h>
|
|
#include <linux/uio_driver.h>
|
|
|
|
#define DRIVER_NAME "uio_dfl"
|
|
|
|
static int uio_dfl_probe(struct dfl_device *ddev)
|
|
{
|
|
struct resource *r = &ddev->mmio_res;
|
|
struct device *dev = &ddev->dev;
|
|
struct uio_info *uioinfo;
|
|
struct uio_mem *uiomem;
|
|
int ret;
|
|
|
|
uioinfo = devm_kzalloc(dev, sizeof(struct uio_info), GFP_KERNEL);
|
|
if (!uioinfo)
|
|
return -ENOMEM;
|
|
|
|
uioinfo->name = DRIVER_NAME;
|
|
uioinfo->version = "0";
|
|
|
|
uiomem = &uioinfo->mem[0];
|
|
uiomem->memtype = UIO_MEM_PHYS;
|
|
uiomem->addr = r->start & PAGE_MASK;
|
|
uiomem->offs = r->start & ~PAGE_MASK;
|
|
uiomem->size = (uiomem->offs + resource_size(r)
|
|
+ PAGE_SIZE - 1) & PAGE_MASK;
|
|
uiomem->name = r->name;
|
|
|
|
/* Irq is yet to be supported */
|
|
uioinfo->irq = UIO_IRQ_NONE;
|
|
|
|
ret = devm_uio_register_device(dev, uioinfo);
|
|
if (ret)
|
|
dev_err(dev, "unable to register uio device\n");
|
|
|
|
return ret;
|
|
}
|
|
|
|
#define FME_FEATURE_ID_ETH_GROUP 0x10
|
|
#define FME_FEATURE_ID_HSSI_SUBSYS 0x15
|
|
|
|
static const struct dfl_device_id uio_dfl_ids[] = {
|
|
{ FME_ID, FME_FEATURE_ID_ETH_GROUP },
|
|
{ FME_ID, FME_FEATURE_ID_HSSI_SUBSYS },
|
|
{ }
|
|
};
|
|
MODULE_DEVICE_TABLE(dfl, uio_dfl_ids);
|
|
|
|
static struct dfl_driver uio_dfl_driver = {
|
|
.drv = {
|
|
.name = DRIVER_NAME,
|
|
},
|
|
.id_table = uio_dfl_ids,
|
|
.probe = uio_dfl_probe,
|
|
};
|
|
module_dfl_driver(uio_dfl_driver);
|
|
|
|
MODULE_DESCRIPTION("Generic DFL driver for Userspace I/O devices");
|
|
MODULE_AUTHOR("Intel Corporation");
|
|
MODULE_LICENSE("GPL v2");
|