blob: b5e0cbb34382845056c9d4c8625212122b79c81e [file] [log] [blame]
Jeff Dike8e367062006-03-27 01:14:32 -08001/*
Jeff Dikec5d4bb12008-02-04 22:31:14 -08002 * Copyright (C) 2002 - 2007 Jeff Dike (jdike@{linux.intel,addtoit}.com)
Linus Torvalds1da177e2005-04-16 15:20:36 -07003 * Licensed under the GPL
4 */
5
Jeff Dikec5d4bb12008-02-04 22:31:14 -08006#include <linux/interrupt.h>
Al Viro37185b32012-10-08 03:27:32 +01007#include <irq_kern.h>
8#include <os.h>
9#include <sigio.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070010
11/* Protected by sigio_lock() called from write_sigio_workaround */
12static int sigio_irq_fd = -1;
13
Al Viro7bea96f2006-10-08 22:49:34 +010014static irqreturn_t sigio_interrupt(int irq, void *data)
Linus Torvalds1da177e2005-04-16 15:20:36 -070015{
Jeff Dike8e367062006-03-27 01:14:32 -080016 char c;
17
Jeff Dikea6ea4cc2007-05-06 14:51:43 -070018 os_read_file(sigio_irq_fd, &c, sizeof(c));
Linus Torvalds1da177e2005-04-16 15:20:36 -070019 reactivate_fd(sigio_irq_fd, SIGIO_WRITE_IRQ);
Jeff Dike4cffb7f2007-02-10 01:44:24 -080020 return IRQ_HANDLED;
Linus Torvalds1da177e2005-04-16 15:20:36 -070021}
22
23int write_sigio_irq(int fd)
24{
25 int err;
26
27 err = um_request_irq(SIGIO_WRITE_IRQ, fd, IRQ_READ, sigio_interrupt,
Theodore Ts'oaab94462012-07-17 14:18:23 -040028 0, "write sigio", NULL);
Jeff Dikec5d4bb12008-02-04 22:31:14 -080029 if (err) {
30 printk(KERN_ERR "write_sigio_irq : um_request_irq failed, "
31 "err = %d\n", err);
Jeff Dike4cffb7f2007-02-10 01:44:24 -080032 return -1;
Linus Torvalds1da177e2005-04-16 15:20:36 -070033 }
34 sigio_irq_fd = fd;
Jeff Dike4cffb7f2007-02-10 01:44:24 -080035 return 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -070036}
37
Jeff Diked9f9d312007-02-10 01:44:23 -080038/* These are called from os-Linux/sigio.c to protect its pollfds arrays. */
Linus Torvalds1da177e2005-04-16 15:20:36 -070039static DEFINE_SPINLOCK(sigio_spinlock);
40
41void sigio_lock(void)
42{
43 spin_lock(&sigio_spinlock);
44}
45
46void sigio_unlock(void)
47{
48 spin_unlock(&sigio_spinlock);
49}