2019-05-29 23:57:21 +00:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
2006-12-07 09:58:29 +00:00
|
|
|
/*
|
|
|
|
* include/linux/uio_driver.h
|
|
|
|
*
|
|
|
|
* Copyright(C) 2005, Benedikt Spranger <b.spranger@linutronix.de>
|
|
|
|
* Copyright(C) 2005, Thomas Gleixner <tglx@linutronix.de>
|
2010-10-29 22:36:47 +00:00
|
|
|
* Copyright(C) 2006, Hans J. Koch <hjk@hansjkoch.de>
|
2006-12-07 09:58:29 +00:00
|
|
|
* Copyright(C) 2006, Greg Kroah-Hartman <greg@kroah.com>
|
|
|
|
*
|
|
|
|
* Userspace IO driver.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _UIO_DRIVER_H_
|
|
|
|
#define _UIO_DRIVER_H_
|
|
|
|
|
2018-05-14 01:32:23 +00:00
|
|
|
#include <linux/device.h>
|
2006-12-07 09:58:29 +00:00
|
|
|
#include <linux/fs.h>
|
|
|
|
#include <linux/interrupt.h>
|
|
|
|
|
2011-05-26 17:46:22 +00:00
|
|
|
struct module;
|
2007-12-04 22:41:54 +00:00
|
|
|
struct uio_map;
|
|
|
|
|
2006-12-07 09:58:29 +00:00
|
|
|
/**
|
|
|
|
* struct uio_mem - description of a UIO memory region
|
2009-01-06 23:15:39 +00:00
|
|
|
* @name: name of the memory region for identification
|
2017-03-16 13:50:08 +00:00
|
|
|
* @addr: address of the device's memory rounded to page
|
2020-03-06 07:03:59 +00:00
|
|
|
* size (phys_addr is used since addr can be
|
|
|
|
* logical, virtual, or physical & phys_addr_t
|
|
|
|
* should always be large enough to handle any of
|
|
|
|
* the address types)
|
2024-02-05 20:01:37 +00:00
|
|
|
* @dma_addr: DMA handle set by dma_alloc_coherent, used with
|
|
|
|
* UIO_MEM_DMA_COHERENT only (@addr should be the
|
|
|
|
* void * returned from the same dma_alloc_coherent call)
|
2017-03-16 13:50:08 +00:00
|
|
|
* @offs: offset of device memory within the page
|
|
|
|
* @size: size of IO (multiple of page size)
|
2006-12-07 09:58:29 +00:00
|
|
|
* @memtype: type of memory addr points to
|
|
|
|
* @internal_addr: ioremap-ped version of addr, for driver internal use
|
2024-02-05 20:01:37 +00:00
|
|
|
* @dma_device: device struct that was passed to dma_alloc_coherent,
|
|
|
|
* used with UIO_MEM_DMA_COHERENT only
|
2007-12-04 22:41:54 +00:00
|
|
|
* @map: for use by the UIO core only.
|
2006-12-07 09:58:29 +00:00
|
|
|
*/
|
|
|
|
struct uio_mem {
|
2009-01-06 23:15:39 +00:00
|
|
|
const char *name;
|
2011-10-17 18:50:20 +00:00
|
|
|
phys_addr_t addr;
|
2024-02-05 20:01:37 +00:00
|
|
|
dma_addr_t dma_addr;
|
2017-03-16 13:50:08 +00:00
|
|
|
unsigned long offs;
|
2014-10-09 12:00:27 +00:00
|
|
|
resource_size_t size;
|
2006-12-07 09:58:29 +00:00
|
|
|
int memtype;
|
|
|
|
void __iomem *internal_addr;
|
2024-02-05 20:01:37 +00:00
|
|
|
struct device *dma_device;
|
2007-12-04 22:41:54 +00:00
|
|
|
struct uio_map *map;
|
2006-12-07 09:58:29 +00:00
|
|
|
};
|
|
|
|
|
2008-06-10 07:14:48 +00:00
|
|
|
#define MAX_UIO_MAPS 5
|
2006-12-07 09:58:29 +00:00
|
|
|
|
UIO: Pass information about ioports to userspace (V2)
Devices sometimes have memory where all or parts of it can not be mapped to
userspace. But it might still be possible to access this memory from
userspace by other means. An example are PCI cards that advertise not only
mappable memory but also ioport ranges. On x86 architectures, these can be
accessed with ioperm, iopl, inb, outb, and friends. Mike Frysinger (CCed)
reported a similar problem on Blackfin arch where it doesn't seem to be easy
to mmap non-cached memory but it can still be accessed from userspace.
This patch allows kernel drivers to pass information about such ports to
userspace. Similar to the existing mem[] array, it adds a port[] array to
struct uio_info. Each port range is described by start, size, and porttype.
If a driver fills in at least one such port range, the UIO core will simply
pass this information to userspace by creating a new directory "portio"
underneath /sys/class/uio/uioN/. Similar to the "mem" directory, it will
contain a subdirectory (portX) for each port range given.
Note that UIO simply passes this information to userspace, it performs no
action whatsoever with this data. It's userspace's responsibility to obtain
access to these ports and to solve arch dependent issues. The "porttype"
attribute tells userspace what kind of port it is dealing with.
This mechanism could also be used to give userspace information about GPIOs
related to a device. You frequently find such hardware in embedded devices,
so I added a UIO_PORT_GPIO definition. I'm not really sure if this is a good
idea since there are other solutions to this problem, but it won't hurt much
anyway.
Signed-off-by: Hans J. Koch <hjk@linutronix.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2008-12-06 01:23:13 +00:00
|
|
|
struct uio_portio;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* struct uio_port - description of a UIO port region
|
2009-01-06 23:15:39 +00:00
|
|
|
* @name: name of the port region for identification
|
UIO: Pass information about ioports to userspace (V2)
Devices sometimes have memory where all or parts of it can not be mapped to
userspace. But it might still be possible to access this memory from
userspace by other means. An example are PCI cards that advertise not only
mappable memory but also ioport ranges. On x86 architectures, these can be
accessed with ioperm, iopl, inb, outb, and friends. Mike Frysinger (CCed)
reported a similar problem on Blackfin arch where it doesn't seem to be easy
to mmap non-cached memory but it can still be accessed from userspace.
This patch allows kernel drivers to pass information about such ports to
userspace. Similar to the existing mem[] array, it adds a port[] array to
struct uio_info. Each port range is described by start, size, and porttype.
If a driver fills in at least one such port range, the UIO core will simply
pass this information to userspace by creating a new directory "portio"
underneath /sys/class/uio/uioN/. Similar to the "mem" directory, it will
contain a subdirectory (portX) for each port range given.
Note that UIO simply passes this information to userspace, it performs no
action whatsoever with this data. It's userspace's responsibility to obtain
access to these ports and to solve arch dependent issues. The "porttype"
attribute tells userspace what kind of port it is dealing with.
This mechanism could also be used to give userspace information about GPIOs
related to a device. You frequently find such hardware in embedded devices,
so I added a UIO_PORT_GPIO definition. I'm not really sure if this is a good
idea since there are other solutions to this problem, but it won't hurt much
anyway.
Signed-off-by: Hans J. Koch <hjk@linutronix.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2008-12-06 01:23:13 +00:00
|
|
|
* @start: start of port region
|
|
|
|
* @size: size of port region
|
|
|
|
* @porttype: type of port (see UIO_PORT_* below)
|
|
|
|
* @portio: for use by the UIO core only.
|
|
|
|
*/
|
|
|
|
struct uio_port {
|
2009-01-06 23:15:39 +00:00
|
|
|
const char *name;
|
UIO: Pass information about ioports to userspace (V2)
Devices sometimes have memory where all or parts of it can not be mapped to
userspace. But it might still be possible to access this memory from
userspace by other means. An example are PCI cards that advertise not only
mappable memory but also ioport ranges. On x86 architectures, these can be
accessed with ioperm, iopl, inb, outb, and friends. Mike Frysinger (CCed)
reported a similar problem on Blackfin arch where it doesn't seem to be easy
to mmap non-cached memory but it can still be accessed from userspace.
This patch allows kernel drivers to pass information about such ports to
userspace. Similar to the existing mem[] array, it adds a port[] array to
struct uio_info. Each port range is described by start, size, and porttype.
If a driver fills in at least one such port range, the UIO core will simply
pass this information to userspace by creating a new directory "portio"
underneath /sys/class/uio/uioN/. Similar to the "mem" directory, it will
contain a subdirectory (portX) for each port range given.
Note that UIO simply passes this information to userspace, it performs no
action whatsoever with this data. It's userspace's responsibility to obtain
access to these ports and to solve arch dependent issues. The "porttype"
attribute tells userspace what kind of port it is dealing with.
This mechanism could also be used to give userspace information about GPIOs
related to a device. You frequently find such hardware in embedded devices,
so I added a UIO_PORT_GPIO definition. I'm not really sure if this is a good
idea since there are other solutions to this problem, but it won't hurt much
anyway.
Signed-off-by: Hans J. Koch <hjk@linutronix.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2008-12-06 01:23:13 +00:00
|
|
|
unsigned long start;
|
|
|
|
unsigned long size;
|
|
|
|
int porttype;
|
|
|
|
struct uio_portio *portio;
|
|
|
|
};
|
|
|
|
|
|
|
|
#define MAX_UIO_PORT_REGIONS 5
|
|
|
|
|
2014-10-01 23:07:03 +00:00
|
|
|
struct uio_device {
|
2020-03-06 07:03:59 +00:00
|
|
|
struct module *owner;
|
2018-05-14 01:32:23 +00:00
|
|
|
struct device dev;
|
2020-03-06 07:03:59 +00:00
|
|
|
int minor;
|
|
|
|
atomic_t event;
|
|
|
|
struct fasync_struct *async_queue;
|
|
|
|
wait_queue_head_t wait;
|
|
|
|
struct uio_info *info;
|
2018-07-07 02:05:38 +00:00
|
|
|
struct mutex info_lock;
|
2020-03-06 07:03:59 +00:00
|
|
|
struct kobject *map_dir;
|
|
|
|
struct kobject *portio_dir;
|
2014-10-01 23:07:03 +00:00
|
|
|
};
|
2006-12-07 09:58:29 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* struct uio_info - UIO device capabilities
|
|
|
|
* @uio_dev: the UIO device this info belongs to
|
|
|
|
* @name: device name
|
|
|
|
* @version: device driver version
|
|
|
|
* @mem: list of mappable memory regions, size==0 for end of list
|
UIO: Pass information about ioports to userspace (V2)
Devices sometimes have memory where all or parts of it can not be mapped to
userspace. But it might still be possible to access this memory from
userspace by other means. An example are PCI cards that advertise not only
mappable memory but also ioport ranges. On x86 architectures, these can be
accessed with ioperm, iopl, inb, outb, and friends. Mike Frysinger (CCed)
reported a similar problem on Blackfin arch where it doesn't seem to be easy
to mmap non-cached memory but it can still be accessed from userspace.
This patch allows kernel drivers to pass information about such ports to
userspace. Similar to the existing mem[] array, it adds a port[] array to
struct uio_info. Each port range is described by start, size, and porttype.
If a driver fills in at least one such port range, the UIO core will simply
pass this information to userspace by creating a new directory "portio"
underneath /sys/class/uio/uioN/. Similar to the "mem" directory, it will
contain a subdirectory (portX) for each port range given.
Note that UIO simply passes this information to userspace, it performs no
action whatsoever with this data. It's userspace's responsibility to obtain
access to these ports and to solve arch dependent issues. The "porttype"
attribute tells userspace what kind of port it is dealing with.
This mechanism could also be used to give userspace information about GPIOs
related to a device. You frequently find such hardware in embedded devices,
so I added a UIO_PORT_GPIO definition. I'm not really sure if this is a good
idea since there are other solutions to this problem, but it won't hurt much
anyway.
Signed-off-by: Hans J. Koch <hjk@linutronix.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2008-12-06 01:23:13 +00:00
|
|
|
* @port: list of port regions, size==0 for end of list
|
2006-12-07 09:58:29 +00:00
|
|
|
* @irq: interrupt number or UIO_IRQ_CUSTOM
|
|
|
|
* @irq_flags: flags for request_irq()
|
|
|
|
* @priv: optional private data
|
|
|
|
* @handler: the device's irq handler
|
|
|
|
* @mmap: mmap operation for this uio device
|
|
|
|
* @open: open operation for this uio device
|
|
|
|
* @release: release operation for this uio device
|
2008-05-23 11:50:14 +00:00
|
|
|
* @irqcontrol: disable/enable irqs when 0/1 is written to /dev/uioX
|
2006-12-07 09:58:29 +00:00
|
|
|
*/
|
|
|
|
struct uio_info {
|
|
|
|
struct uio_device *uio_dev;
|
2008-12-12 10:44:21 +00:00
|
|
|
const char *name;
|
|
|
|
const char *version;
|
2006-12-07 09:58:29 +00:00
|
|
|
struct uio_mem mem[MAX_UIO_MAPS];
|
UIO: Pass information about ioports to userspace (V2)
Devices sometimes have memory where all or parts of it can not be mapped to
userspace. But it might still be possible to access this memory from
userspace by other means. An example are PCI cards that advertise not only
mappable memory but also ioport ranges. On x86 architectures, these can be
accessed with ioperm, iopl, inb, outb, and friends. Mike Frysinger (CCed)
reported a similar problem on Blackfin arch where it doesn't seem to be easy
to mmap non-cached memory but it can still be accessed from userspace.
This patch allows kernel drivers to pass information about such ports to
userspace. Similar to the existing mem[] array, it adds a port[] array to
struct uio_info. Each port range is described by start, size, and porttype.
If a driver fills in at least one such port range, the UIO core will simply
pass this information to userspace by creating a new directory "portio"
underneath /sys/class/uio/uioN/. Similar to the "mem" directory, it will
contain a subdirectory (portX) for each port range given.
Note that UIO simply passes this information to userspace, it performs no
action whatsoever with this data. It's userspace's responsibility to obtain
access to these ports and to solve arch dependent issues. The "porttype"
attribute tells userspace what kind of port it is dealing with.
This mechanism could also be used to give userspace information about GPIOs
related to a device. You frequently find such hardware in embedded devices,
so I added a UIO_PORT_GPIO definition. I'm not really sure if this is a good
idea since there are other solutions to this problem, but it won't hurt much
anyway.
Signed-off-by: Hans J. Koch <hjk@linutronix.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2008-12-06 01:23:13 +00:00
|
|
|
struct uio_port port[MAX_UIO_PORT_REGIONS];
|
2006-12-07 09:58:29 +00:00
|
|
|
long irq;
|
|
|
|
unsigned long irq_flags;
|
|
|
|
void *priv;
|
|
|
|
irqreturn_t (*handler)(int irq, struct uio_info *dev_info);
|
|
|
|
int (*mmap)(struct uio_info *info, struct vm_area_struct *vma);
|
|
|
|
int (*open)(struct uio_info *info, struct inode *inode);
|
|
|
|
int (*release)(struct uio_info *info, struct inode *inode);
|
2008-05-23 11:50:14 +00:00
|
|
|
int (*irqcontrol)(struct uio_info *info, s32 irq_on);
|
2006-12-07 09:58:29 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
extern int __must_check
|
|
|
|
__uio_register_device(struct module *owner,
|
|
|
|
struct device *parent,
|
|
|
|
struct uio_info *info);
|
2011-05-27 13:02:11 +00:00
|
|
|
|
|
|
|
/* use a define to avoid include chaining to get THIS_MODULE */
|
2020-10-23 16:33:17 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* uio_register_device - register a new userspace IO device
|
|
|
|
* @parent: parent device
|
|
|
|
* @info: UIO device capabilities
|
|
|
|
*
|
|
|
|
* returns zero on success or a negative error code.
|
|
|
|
*/
|
2011-05-27 13:02:11 +00:00
|
|
|
#define uio_register_device(parent, info) \
|
|
|
|
__uio_register_device(THIS_MODULE, parent, info)
|
|
|
|
|
2006-12-07 09:58:29 +00:00
|
|
|
extern void uio_unregister_device(struct uio_info *info);
|
|
|
|
extern void uio_event_notify(struct uio_info *info);
|
|
|
|
|
2020-03-06 16:18:52 +00:00
|
|
|
extern int __must_check
|
|
|
|
__devm_uio_register_device(struct module *owner,
|
|
|
|
struct device *parent,
|
|
|
|
struct uio_info *info);
|
|
|
|
|
|
|
|
/* use a define to avoid include chaining to get THIS_MODULE */
|
2020-10-23 16:33:17 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* devm_uio_register_device - Resource managed uio_register_device()
|
|
|
|
* @parent: parent device
|
|
|
|
* @info: UIO device capabilities
|
|
|
|
*
|
|
|
|
* returns zero on success or a negative error code.
|
|
|
|
*/
|
2020-03-06 16:18:52 +00:00
|
|
|
#define devm_uio_register_device(parent, info) \
|
|
|
|
__devm_uio_register_device(THIS_MODULE, parent, info)
|
|
|
|
|
2008-06-10 07:14:48 +00:00
|
|
|
/* defines for uio_info->irq */
|
2006-12-07 09:58:29 +00:00
|
|
|
#define UIO_IRQ_CUSTOM -1
|
2010-09-14 18:37:36 +00:00
|
|
|
#define UIO_IRQ_NONE 0
|
2006-12-07 09:58:29 +00:00
|
|
|
|
2008-06-10 07:14:48 +00:00
|
|
|
/* defines for uio_mem->memtype */
|
2006-12-07 09:58:29 +00:00
|
|
|
#define UIO_MEM_NONE 0
|
|
|
|
#define UIO_MEM_PHYS 1
|
|
|
|
#define UIO_MEM_LOGICAL 2
|
|
|
|
#define UIO_MEM_VIRTUAL 3
|
2018-09-14 16:10:18 +00:00
|
|
|
#define UIO_MEM_IOVA 4
|
2024-02-05 20:01:37 +00:00
|
|
|
/*
|
|
|
|
* UIO_MEM_DMA_COHERENT exists for legacy drivers that had been getting by with
|
|
|
|
* improperly mapping DMA coherent allocations through the other modes.
|
|
|
|
* Do not use in new drivers.
|
|
|
|
*/
|
|
|
|
#define UIO_MEM_DMA_COHERENT 5
|
2006-12-07 09:58:29 +00:00
|
|
|
|
UIO: Pass information about ioports to userspace (V2)
Devices sometimes have memory where all or parts of it can not be mapped to
userspace. But it might still be possible to access this memory from
userspace by other means. An example are PCI cards that advertise not only
mappable memory but also ioport ranges. On x86 architectures, these can be
accessed with ioperm, iopl, inb, outb, and friends. Mike Frysinger (CCed)
reported a similar problem on Blackfin arch where it doesn't seem to be easy
to mmap non-cached memory but it can still be accessed from userspace.
This patch allows kernel drivers to pass information about such ports to
userspace. Similar to the existing mem[] array, it adds a port[] array to
struct uio_info. Each port range is described by start, size, and porttype.
If a driver fills in at least one such port range, the UIO core will simply
pass this information to userspace by creating a new directory "portio"
underneath /sys/class/uio/uioN/. Similar to the "mem" directory, it will
contain a subdirectory (portX) for each port range given.
Note that UIO simply passes this information to userspace, it performs no
action whatsoever with this data. It's userspace's responsibility to obtain
access to these ports and to solve arch dependent issues. The "porttype"
attribute tells userspace what kind of port it is dealing with.
This mechanism could also be used to give userspace information about GPIOs
related to a device. You frequently find such hardware in embedded devices,
so I added a UIO_PORT_GPIO definition. I'm not really sure if this is a good
idea since there are other solutions to this problem, but it won't hurt much
anyway.
Signed-off-by: Hans J. Koch <hjk@linutronix.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
2008-12-06 01:23:13 +00:00
|
|
|
/* defines for uio_port->porttype */
|
|
|
|
#define UIO_PORT_NONE 0
|
|
|
|
#define UIO_PORT_X86 1
|
|
|
|
#define UIO_PORT_GPIO 2
|
|
|
|
#define UIO_PORT_OTHER 3
|
|
|
|
|
2006-12-07 09:58:29 +00:00
|
|
|
#endif /* _LINUX_UIO_DRIVER_H_ */
|