mirror of
https://github.com/torvalds/linux.git
synced 2024-12-25 12:21:37 +00:00
ee2d64f5cc
A major rewrite of interrupt handling for incoming mailbox processing, to split the timing critical steps from the the deferrable steps as the sending XPU on the CX23418 will time out and overwrite our incoming mailboxes rather quickly. Setup a pool of work "order forms" for the irq handler to send jobs to the new work handler routine which uses the kernel default work queue to do the deferrable work. Started optimizing some of the cx18-io calls as they are now the low hanging fruit for recoving microseconds back from the timeline. Future optimizations will get rid of mmio read retries, mmio stats logging, and combine smaller functions in the irq path into the larger ones to save ~2 us each. Signed-off-by: Andy Walls <awalls@radix.net> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
35 lines
1.3 KiB
C
35 lines
1.3 KiB
C
/*
|
|
* cx18 interrupt handling
|
|
*
|
|
* Copyright (C) 2007 Hans Verkuil <hverkuil@xs4all.nl>
|
|
*
|
|
* 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., 59 Temple Place, Suite 330, Boston, MA
|
|
* 02111-1307 USA
|
|
*/
|
|
|
|
#define HW2_I2C1_INT (1 << 22)
|
|
#define HW2_I2C2_INT (1 << 23)
|
|
#define HW2_INT_CLR_STATUS 0xc730c4
|
|
#define HW2_INT_MASK5_PCI 0xc730e4
|
|
#define SW1_INT_SET 0xc73100
|
|
#define SW1_INT_STATUS 0xc73104
|
|
#define SW1_INT_ENABLE_PCI 0xc7311c
|
|
#define SW2_INT_SET 0xc73140
|
|
#define SW2_INT_STATUS 0xc73144
|
|
#define SW2_INT_ENABLE_CPU 0xc73158
|
|
#define SW2_INT_ENABLE_PCI 0xc7315c
|
|
|
|
irqreturn_t cx18_irq_handler(int irq, void *dev_id);
|