Commit 458e1f7d authored by Johannes Berg's avatar Johannes Berg Committed by Richard Weinberger

um: irq: Clean up and rename struct irq_fd

This really shouldn't be called "irq_fd" since it doesn't
carry an fd. Well, it used to, apparently, but that struct
member is unused.

Rename it to "irq_reg" since it more accurately reflects a
registered interrupt, and remove the unused 'next' and 'fd'
members from the struct as well.

While at it, also move it to the implementation, it's not
used anywhere else, and the header file is shared with the
userspace components.
Acked-By: default avatarAnton Ivanov <anton.ivanov@cambridgegreys.com>
Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
Acked-By: default avatarAnton Ivanov <anton.ivanov@cambridgegreys.com>
Signed-off-by: default avatarRichard Weinberger <richard@nod.at>
parent 0ede3c05
...@@ -9,25 +9,11 @@ ...@@ -9,25 +9,11 @@
#include <sysdep/ptrace.h> #include <sysdep/ptrace.h>
#include <stdbool.h> #include <stdbool.h>
struct irq_fd {
struct irq_fd *next;
void *id;
int fd;
int type;
int irq;
int events;
bool active;
bool pending;
bool purge;
};
#define IRQ_READ 0 #define IRQ_READ 0
#define IRQ_WRITE 1 #define IRQ_WRITE 1
#define IRQ_NONE 2 #define IRQ_NONE 2
#define MAX_IRQ_TYPE (IRQ_NONE + 1) #define MAX_IRQ_TYPE (IRQ_NONE + 1)
struct siginfo; struct siginfo;
extern void sigio_handler(int sig, struct siginfo *unused_si, struct uml_pt_regs *regs); extern void sigio_handler(int sig, struct siginfo *unused_si, struct uml_pt_regs *regs);
extern void free_irq_by_fd(int fd); extern void free_irq_by_fd(int fd);
......
...@@ -26,14 +26,24 @@ extern void free_irqs(void); ...@@ -26,14 +26,24 @@ extern void free_irqs(void);
/* When epoll triggers we do not know why it did so /* When epoll triggers we do not know why it did so
* we can also have different IRQs for read and write. * we can also have different IRQs for read and write.
* This is why we keep a small irq_fd array for each fd - * This is why we keep a small irq_reg array for each fd -
* one entry per IRQ type * one entry per IRQ type
*/ */
struct irq_reg {
void *id;
int type;
int irq;
int events;
bool active;
bool pending;
bool purge;
};
struct irq_entry { struct irq_entry {
struct irq_entry *next; struct irq_entry *next;
int fd; int fd;
struct irq_fd *irq_array[MAX_IRQ_TYPE + 1]; struct irq_reg *irq_array[MAX_IRQ_TYPE + 1];
}; };
static struct irq_entry *active_fds; static struct irq_entry *active_fds;
...@@ -41,7 +51,7 @@ static struct irq_entry *active_fds; ...@@ -41,7 +51,7 @@ static struct irq_entry *active_fds;
static DEFINE_SPINLOCK(irq_lock); static DEFINE_SPINLOCK(irq_lock);
static DECLARE_BITMAP(irqs_allocated, NR_IRQS); static DECLARE_BITMAP(irqs_allocated, NR_IRQS);
static void irq_io_loop(struct irq_fd *irq, struct uml_pt_regs *regs) static void irq_io_loop(struct irq_reg *irq, struct uml_pt_regs *regs)
{ {
/* /*
* irq->active guards against reentry * irq->active guards against reentry
...@@ -65,7 +75,7 @@ static void irq_io_loop(struct irq_fd *irq, struct uml_pt_regs *regs) ...@@ -65,7 +75,7 @@ static void irq_io_loop(struct irq_fd *irq, struct uml_pt_regs *regs)
void sigio_handler(int sig, struct siginfo *unused_si, struct uml_pt_regs *regs) void sigio_handler(int sig, struct siginfo *unused_si, struct uml_pt_regs *regs)
{ {
struct irq_entry *irq_entry; struct irq_entry *irq_entry;
struct irq_fd *irq; struct irq_reg *irq;
int n, i, j; int n, i, j;
...@@ -86,7 +96,7 @@ void sigio_handler(int sig, struct siginfo *unused_si, struct uml_pt_regs *regs) ...@@ -86,7 +96,7 @@ void sigio_handler(int sig, struct siginfo *unused_si, struct uml_pt_regs *regs)
} }
for (i = 0; i < n ; i++) { for (i = 0; i < n ; i++) {
/* Epoll back reference is the entry with 3 irq_fd /* Epoll back reference is the entry with 3 irq_reg
* leaves - one for each irq type. * leaves - one for each irq type.
*/ */
irq_entry = (struct irq_entry *) irq_entry = (struct irq_entry *)
...@@ -112,7 +122,7 @@ static int assign_epoll_events_to_irq(struct irq_entry *irq_entry) ...@@ -112,7 +122,7 @@ static int assign_epoll_events_to_irq(struct irq_entry *irq_entry)
{ {
int i; int i;
int events = 0; int events = 0;
struct irq_fd *irq; struct irq_reg *irq;
for (i = 0; i < MAX_IRQ_TYPE ; i++) { for (i = 0; i < MAX_IRQ_TYPE ; i++) {
irq = irq_entry->irq_array[i]; irq = irq_entry->irq_array[i];
...@@ -131,7 +141,7 @@ static int assign_epoll_events_to_irq(struct irq_entry *irq_entry) ...@@ -131,7 +141,7 @@ static int assign_epoll_events_to_irq(struct irq_entry *irq_entry)
static int activate_fd(int irq, int fd, int type, void *dev_id) static int activate_fd(int irq, int fd, int type, void *dev_id)
{ {
struct irq_fd *new_fd; struct irq_reg *new_fd;
struct irq_entry *irq_entry; struct irq_entry *irq_entry;
int i, err, events; int i, err, events;
unsigned long flags; unsigned long flags;
...@@ -182,13 +192,13 @@ static int activate_fd(int irq, int fd, int type, void *dev_id) ...@@ -182,13 +192,13 @@ static int activate_fd(int irq, int fd, int type, void *dev_id)
/* New entry for this fd */ /* New entry for this fd */
err = -ENOMEM; err = -ENOMEM;
new_fd = kmalloc(sizeof(struct irq_fd), GFP_ATOMIC); new_fd = kmalloc(sizeof(struct irq_reg), GFP_ATOMIC);
if (new_fd == NULL) if (new_fd == NULL)
goto out_unlock; goto out_unlock;
events = os_event_mask(type); events = os_event_mask(type);
*new_fd = ((struct irq_fd) { *new_fd = ((struct irq_reg) {
.id = dev_id, .id = dev_id,
.irq = irq, .irq = irq,
.type = type, .type = type,
...@@ -273,8 +283,8 @@ static struct irq_entry *get_irq_entry_by_fd(int fd) ...@@ -273,8 +283,8 @@ static struct irq_entry *get_irq_entry_by_fd(int fd)
/* /*
* Walk the IRQ list and dispose of an entry for a specific * Walk the IRQ list and dispose of an entry for a specific
* device, fd and number. Note - if sharing an IRQ for read * device and number. Note - if sharing an IRQ for read
* and writefor the same FD it will be disposed in either case. * and write for the same FD it will be disposed in either case.
* If this behaviour is undesirable use different IRQ ids. * If this behaviour is undesirable use different IRQ ids.
*/ */
...@@ -289,7 +299,7 @@ static void do_free_by_irq_and_dev( ...@@ -289,7 +299,7 @@ static void do_free_by_irq_and_dev(
) )
{ {
int i; int i;
struct irq_fd *to_free; struct irq_reg *to_free;
for (i = 0; i < MAX_IRQ_TYPE ; i++) { for (i = 0; i < MAX_IRQ_TYPE ; i++) {
if (irq_entry->irq_array[i] != NULL) { if (irq_entry->irq_array[i] != NULL) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment