From: David Schleef Date: Wed, 9 Feb 2000 06:43:52 +0000 (+0000) Subject: This file somehow disappeared from the repository X-Git-Tag: r0_7_39~6 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=5b22490ecfe3c0b6b86704715c02632c23159be1;p=comedi.git This file somehow disappeared from the repository --- diff --git a/comedi/rt.c b/comedi/rt.c new file mode 100644 index 00000000..9be02eb8 --- /dev/null +++ b/comedi/rt.c @@ -0,0 +1,129 @@ +/* + comedi/rt.c + comedi kernel module + + COMEDI - Linux Control and Measurement Device Interface + Copyright (C) 1997-2000 David A. Schleef + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + +*/ + +#undef DEBUG + +#include + +#include +#include +#include +#include +#include +#include +#include +#include +#include + + + +static struct comedi_irq_struct *comedi_irqs; + +int comedi_request_irq(unsigned irq,void (*handler)(int, void *,struct pt_regs *), + unsigned long flags,const char *device,void *dev_id) +{ + struct comedi_irq_struct *it; + int ret; + + it=kmalloc(sizeof(*it),GFP_KERNEL); + if(!it) + return -ENOMEM; + + it->handler=handler; + it->irq=irq; + it->dev_id=dev_id; + it->flags=flags; + + ret=request_irq(irq,handler,flags&~SA_PRIORITY,device,dev_id); + if(ret<0){ + kfree(it); + return ret; + } + + if(flags&SA_PRIORITY){ + get_priority_irq(it); + } + + it->next=comedi_irqs; + comedi_irqs=it; + + return 0; +} + +int comedi_change_irq_flags(unsigned int irq,void *dev_id,unsigned long flags) +{ + struct comedi_irq_struct *it; + + it=get_irq_struct(irq); + if(it){ + if((it->flags&~SA_PRIORITY)!=(flags&~SA_PRIORITY)) + return -EINVAL; + + if((it->flags&SA_PRIORITY)==(flags&SA_PRIORITY)) + return 0; + + it->flags=flags; + if(flags&SA_PRIORITY){ + return get_priority_irq(it); + }else{ + return free_priority_irq(it); + } + } + + return -EINVAL; +} + +void comedi_free_irq(unsigned int irq,void *dev_id) +{ + struct comedi_irq_struct *it,*prev; + + prev=NULL; + for(it=comedi_irqs;it;it=it->next){ + if(it->irq==irq){ + break; + } + prev=it; + } + if(it->flags&SA_PRIORITY) + free_priority_irq(it); + + free_irq(it->irq,it->dev_id); + + if(prev) prev->next=it->next; + else comedi_irqs=it->next; + + kfree(it); +} + +struct comedi_irq_struct *get_irq_struct(unsigned int irq) +{ + struct comedi_irq_struct *it; + + for(it=comedi_irqs;it;it=it->next){ + if(it->irq==irq){ + return it; + } + } + return NULL; +} +