Embedded Linux development
 help / color / mirror / Atom feed
From: Neil Armstrong <narmstrong@neotion.com>
To: Embedded Linux mailing list <linux-embedded@vger.kernel.org>
Subject: [PATCH] uio: add ioctl callback
Date: Wed, 12 Nov 2008 15:11:03 +0100	[thread overview]
Message-ID: <491AE3F7.4050202@neotion.com> (raw)


[-- Attachment #1.1: Type: text/plain, Size: 1638 bytes --]

Add an ioctl callback to the UIO device class.
This can be useful when status and data are needed after an interrupt
occurs.

Changes :
 - Add an uio_ioctl method
 - Add en ioctl entry in uio_info

Neil Armstrong <narmstrong@neotion.com>

Index: drivers/uio/uio.c
===================================================================
--- drivers/uio/uio.c    (revision 80)
+++ drivers/uio/uio.c    (working copy)
@@ -378,6 +378,17 @@
     return 0;
 }
 
+static int uio_ioctl(struct inode *inode, struct file *filep, unsigned
int cmd, unsigned long arg)
+{
+    struct uio_listener *listener = filep->private_data;
+    struct uio_device *idev = listener->dev;
+   
+    if (idev->info->ioctl)
+        return idev->info->ioctl(idev->info, cmd, arg);
+   
+    return -ENOSYS;
+}
+
 static ssize_t uio_read(struct file *filep, char __user *buf,
             size_t count, loff_t *ppos)
 {
@@ -575,6 +586,7 @@
     .mmap        = uio_mmap,
     .poll        = uio_poll,
     .fasync        = uio_fasync,
+   .ioctl      = uio_ioctl,
 };
 
 static int uio_major_init(void)
Index: include/linux/uio_driver.h
===================================================================
--- include/linux/uio_driver.h    (revision 80)
+++ include/linux/uio_driver.h    (working copy)
@@ -68,6 +68,7 @@
     int (*open)(struct uio_info *info, struct inode *inode);
     int (*release)(struct uio_info *info, struct inode *inode);
     int (*irqcontrol)(struct uio_info *info, s32 irq_on);
+    int (*ioctl)(struct uio_info *info, unsigned int cmd, unsigned long
arg);
 };
 
 extern int __must_check


[-- Attachment #1.2: narmstrong.vcf --]
[-- Type: text/x-vcard, Size: 319 bytes --]

begin:vcard
fn:Neil Armstrong
n:Armstrong;Neil
org:Neotion;Neotion Sophia Antipolis
adr:;;;Sophia Antipolis;;;France
email;internet:narmstrong@neotion.com
title:Embedded Linux Software Engineer
tel;cell:0667474169
note:PGP 0x1166F485
x-mozilla-html:FALSE
url:http://www.neotion.com
version:2.1
end:vcard


[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 252 bytes --]

             reply	other threads:[~2008-11-12 14:11 UTC|newest]

Thread overview: 2+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2008-11-12 14:11 Neil Armstrong [this message]
2008-11-12 14:33 ` [PATCH] uio: add ioctl callback Marco Stornelli

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=491AE3F7.4050202@neotion.com \
    --to=narmstrong@neotion.com \
    --cc=linux-embedded@vger.kernel.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox