1. 19 2月, 2011 24 次提交
    • T
      genirq: Implement handle_irq_event() · 4912609f
      Thomas Gleixner 提交于
      Core code replacement for the ugly camel case. It contains all the
      code which is shared in all handlers.
      
           clear status flags
           set INPROGRESS flag
           unlock
           call action chain
           note_interrupt
           lock
           clr INPROGRESS flag
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      4912609f
    • T
      genirq: Do not fiddle with IRQ_MASKED in handle_edge_irq() · d78f8dd3
      Thomas Gleixner 提交于
      IRQ_MASKED is set in mask_ack_irq() anyway. Remove it from
      handle_edge_irq() to allow simpler ab^HHreuse of that function.
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      Cc: Peter Zijlstra <peterz@infradead.org>
      LKML-Reference: <20110202212551.918484270@linutronix.de>
      d78f8dd3
    • T
      genirq: Consolidate IRQ_DISABLED · 3aae994f
      Thomas Gleixner 提交于
      Handle IRQ_DISABLED consistent.
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      3aae994f
    • T
      genirq: Remove default magic · 50f7c032
      Thomas Gleixner 提交于
      Now that everything uses the wrappers, we can remove the default
      functions. None of those functions is performance critical.
      
      That makes the IRQ_MASKED flag tracking fully consistent.
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      50f7c032
    • T
      genirq: Consolidate disable/enable · 87923470
      Thomas Gleixner 提交于
      Create irq_disable/enable and use them to keep the flags consistent.
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      87923470
    • T
      genirq: Consolidate startup/shutdown of interrupts · 46999238
      Thomas Gleixner 提交于
      Aside of duplicated code some of the startup/shutdown sites do not
      handle the MASKED/DISABLED flags and the depth field at all. Move that
      to a helper function and take care of it there.
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      Cc: Peter Zijlstra <peterz@infradead.org>
      LKML-Reference: <20110202212551.787481468@linutronix.de>
      46999238
    • T
      genirq: Remove bogus conditional · 3b56f058
      Thomas Gleixner 提交于
      The if (chip->irq_shutdown) check will always evaluate to true, as we
      fill in chip->irq_shutdown with default_shutdown in
      irq_chip_set_defaults() if the chip does not provide its own function.
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      Cc: Peter Zijlstra <peterz@infradead.org>
      LKML-Reference: <20110202212551.667607458@linutronix.de>
      3b56f058
    • T
      genirq: Move irq thread flags to core · 1535dfac
      Thomas Gleixner 提交于
      Soleley used in core code.
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      1535dfac
    • T
      genirq: Mark polled irqs and defer the real handler · fe200ae4
      Thomas Gleixner 提交于
      With the chip.end() function gone we might run into a situation where
      a poll call runs and the real interrupt comes in, sees IRQ_INPROGRESS
      and disables the line. That might be a perfect working one, which will
      then be masked forever.
      
      So mark them polled while the poll runs. When the real handler sees
      IRQ_INPROGRESS it checks the poll flag and waits for the polling to
      complete. Add the necessary amount of sanity checks to it to avoid
      deadlocks.
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      fe200ae4
    • T
      genirq: spurious: Run only one poller at a time · d05c65ff
      Thomas Gleixner 提交于
      No point in running concurrent pollers which confuse each other by
      setting PENDING.
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      d05c65ff
    • T
      genirq: Do not poll disabled, percpu and timer interrupts · c7259cd7
      Thomas Gleixner 提交于
      There is no point in polling disabled lines.
      
      percpu does not make sense at all because we only poll on the cpu
      we're currently running on. Also polling per_cpu interrupts is racy as
      hell. The handler runs without locking so we might get a huge
      surprise.
      
      If the timer interrupt needs polling, then we wont get there anyway.
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      c7259cd7
    • T
      genirq: Fixup poll handling · fa27271b
      Thomas Gleixner 提交于
      try_one_irq() contains redundant code and lots of useless checks for
      shared interrupts. Check for shared before setting IRQ_INPROGRESS and
      then call handle_IRQ_event() while pending. Shorter version with the
      same functionality.
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      fa27271b
    • T
      genirq: Warn when handler enables interrupts · b738a50a
      Thomas Gleixner 提交于
      We run all handlers with interrupts disabled and expect them not to
      enable them. Warn when we catch one who does.
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      b738a50a
    • T
      genirq: Plug race in report_bad_irq() · 1082687e
      Thomas Gleixner 提交于
      We cannot walk the action chain unlocked. Even if IRQ_INPROGRESS is
      set an action can be removed and we follow a null pointer. It's safe
      to take the lock there, because the code which removes the action will
      call synchronize_irq() which waits unlocked for IRQ_INPROGRESS going
      away.
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      1082687e
    • T
      genirq: Remove redundant thread affinity setting · 2b879eaf
      Thomas Gleixner 提交于
      Thread affinity is already set by setup_affinity().
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      2b879eaf
    • T
      genirq: Do not copy affinity before set · 3b8249e7
      Thomas Gleixner 提交于
      While rumaging through arch code I found that there are a few
      workarounds which deal with the fact that the initial affinity setting
      from request_irq() copies the mask into irq_data->affinity before the
      chip code is called. In the normal path we unconditionally copy the
      mask when the chip code returns 0.
      
      Copy after the code is called and add a return code
      IRQ_SET_MASK_OK_NOCOPY for the chip functions, which prevents the
      copy. That way we see the real mask when the chip function decided to
      truncate it further as some arches do. IRQ_SET_MASK_OK is 0, which is
      the current behaviour.
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      3b8249e7
    • T
      genirq: Always apply cpu online mask · 569bda8d
      Thomas Gleixner 提交于
      If the affinity had been set by the user, then a later request_irq()
      will honour that setting. But online cpus can have changed. So apply
      the online mask and for this case as well.
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      569bda8d
    • T
      genirq: Rremove redundant check · b008207c
      Thomas Gleixner 提交于
      IRQ_NO_BALANCING is already checked in irq_can_set_affinity() above,
      no need to check it again.
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      b008207c
    • T
      genirq: Simplify affinity related code · 1fa46f1f
      Thomas Gleixner 提交于
      There is lot of #ifdef CONFIG_GENERIC_PENDING_IRQ along with
      duplicated code in the irq core. Move the #ifdeffery into one place
      and cleanup the code so it's readable. No functional change.
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      1fa46f1f
    • T
      genirq: Namespace cleanup · a0cd9ca2
      Thomas Gleixner 提交于
      The irq namespace has become quite convoluted. My bad.  Clean it up
      and deprecate the old functions. All new functions follow the scheme:
      
      irq number based:
          irq_set/get/xxx/_xxx(unsigned int irq, ...)
      
      irq_data based:
      	 irq_data_set/get/xxx/_xxx(struct irq_data *d, ....)
      
      irq_desc based:
      	 irq_desc_get_xxx(struct irq_desc *desc)
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      a0cd9ca2
    • T
      genirq: Add missing buslock to set_irq_type(), set_irq_wake() · 43abe43c
      Thomas Gleixner 提交于
      chips behind a slow bus cannot update the chip under desc->lock, but
      we miss the chip_buslock/chip_bus_sync_unlock() calls around the set
      type and set wake functions.
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      43abe43c
    • T
      genirq: Make nr_irqs runtime expandable · e7bcecb7
      Thomas Gleixner 提交于
      We face more and more the requirement to expand nr_irqs at
      runtime. The reason are irq expanders which can not be detected in the
      early boot stage. So we speculate nr_irqs to have enough room. Further
      Xen needs extra irq numbers and we really want to avoid adding more
      "detection" code into the early boot. There is no real good reason why
      we need to limit nr_irqs at early boot.
      
      Allow the allocation code to expand nr_irqs. We have already 8k extra
      number space in the allocation bitmap, so lets use it.
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      e7bcecb7
    • T
      genirq: Disable the SHIRQ_DEBUG call in request_threaded_irq for now · 6d83f94d
      Thomas Gleixner 提交于
      With CONFIG_SHIRQ_DEBUG=y we call a newly installed interrupt handler
      in request_threaded_irq().
      
      The original implementation (commit a304e1b8) called the handler
      _BEFORE_ it was installed, but that caused problems with handlers
      calling disable_irq_nosync(). See commit 377bf1e4.
      
      It's braindead in the first place to call disable_irq_nosync in shared
      handlers, but ....
      
      Moving this call after we installed the handler looks innocent, but it
      is very subtle broken on SMP.
      
      Interrupt handlers rely on the fact, that the irq core prevents
      reentrancy.
      
      Now this debug call violates that promise because we run the handler
      w/o the IRQ_INPROGRESS protection - which we cannot apply here because
      that would result in a possibly forever masked interrupt line.
      
      A concurrent real hardware interrupt on a different CPU results in
      handler reentrancy and can lead to complete wreckage, which was
      unfortunately observed in reality and took a fricking long time to
      debug.
      
      Leave the code here for now. We want this debug feature, but that's
      not easy to fix. We really should get rid of those
      disable_irq_nosync() abusers and remove that function completely.
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      Cc: Anton Vorontsov <avorontsov@ru.mvista.com>
      Cc: David Woodhouse <dwmw2@infradead.org>
      Cc: Arjan van de Ven <arjan@infradead.org>
      Cc: stable@kernel.org # .28 -> .37
      6d83f94d
    • T
      genirq: Prevent access beyond allocated_irqs bitmap · c1ee6264
      Thomas Gleixner 提交于
      Lars-Peter Clausen pointed out:
      
         I stumbled upon this while looking through the existing archs using
         SPARSE_IRQ.  Even with SPARSE_IRQ the NR_IRQS is still the upper
         limit for the number of IRQs.
      
         Both PXA and MMP set NR_IRQS to IRQ_BOARD_START, with
         IRQ_BOARD_START being the number of IRQs used by the core.
      
         In various machine files the nr_irqs field of the ARM machine
         defintion struct is then set to "IRQ_BOARD_START + NR_BOARD_IRQS".
      
         As a result "nr_irqs" will greater then NR_IRQS which then again
         causes the "allocated_irqs" bitmap in the core irq code to be
         accessed beyond its size overwriting unrelated data.
      
      The core code really misses a sanity check there.
      
      This went unnoticed so far as by chance the compiler/linker places
      data behind that bitmap which gets initialized later on those affected
      platforms.
      
      So the obvious fix would be to add a sanity check in early_irq_init()
      and break all affected platforms. Though that check wants to be
      backported to stable as well, which will require to fix all known
      problematic platforms and probably some more yet not known ones as
      well. Lots of churn.
      
      A way simpler solution is to allocate a slightly larger bitmap and
      avoid the whole churn w/o breaking anything. Add a few warnings when
      an arch returns utter crap.
      Reported-by: NLars-Peter Clausen <lars@metafoo.de>
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      Cc: stable@kernel.org # .37
      Cc: Haojian Zhuang <haojian.zhuang@marvell.com>
      Cc: Eric Miao <eric.y.miao@gmail.com>
      Cc: Peter Zijlstra <peterz@infradead.org>
      c1ee6264
  2. 11 2月, 2011 1 次提交
    • D
      genirq: Call bus_lock/unlock functions in setup_irq() · 986c011d
      David Daney 提交于
      irq_chips that supply .irq_bus_lock/.irq_bus_sync_unlock functions,
      expect that the other chip methods will be called inside of calls to
      the pair.  If this expectation is not met, things tend to not work.
      
      Make setup_irq() call chip_bus_lock()/chip_bus_sync_unlock() too.
      
      For the vast majority of irq_chips, this will be a NOP as most don't
      have these bus lock functions.
      
      [ tglx: No we don't want to call that in __setup_irq(). Way too many
        	error exit pathes. ]
      Signed-off-by: NDavid Daney <ddaney@caviumnetworks.com>
      LKML-Reference: <1297296265-18680-1-git-send-email-ddaney@caviumnetworks.com>
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      986c011d
  3. 09 2月, 2011 1 次提交
  4. 08 2月, 2011 1 次提交
  5. 03 2月, 2011 1 次提交
    • T
      genirq: Prevent irq storm on migration · f1a06390
      Thomas Gleixner 提交于
      move_native_irq() masks and unmasks the interrupt line
      unconditionally, but the interrupt line might be masked due to a
      threaded oneshot handler in progress. Unmasking the line in that case
      can lead to interrupt storms. Observed on PREEMPT_RT.
      
      Originally-from: Ingo Molnar <mingo@elte.hu>
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      Cc: stable@kernel.org
      f1a06390
  6. 31 1月, 2011 1 次提交
  7. 23 1月, 2011 1 次提交
    • B
      genirq: Add IRQ affinity notifiers · cd7eab44
      Ben Hutchings 提交于
      When initiating I/O on a multiqueue and multi-IRQ device, we may want
      to select a queue for which the response will be handled on the same
      or a nearby CPU.  This requires a reverse-map of IRQ affinity.  Add a
      notification mechanism to support this.
      
      This is based closely on work by Thomas Gleixner <tglx@linutronix.de>.
      Signed-off-by: NBen Hutchings <bhutchings@solarflare.com>
      Cc: linux-net-drivers@solarflare.com
      Cc: Tom Herbert <therbert@google.com>
      Cc: David Miller <davem@davemloft.net>
      LKML-Reference: <1295470904.11126.84.camel@bwh-desktop>
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      cd7eab44
  8. 21 1月, 2011 1 次提交
  9. 14 1月, 2011 1 次提交
    • E
      irq: use per_cpu kstat_irqs · 6c9ae009
      Eric Dumazet 提交于
      Use modern per_cpu API to increment {soft|hard}irq counters, and use
      per_cpu allocation for (struct irq_desc)->kstats_irq instead of an array.
      
      This gives better SMP/NUMA locality and saves few instructions per irq.
      
      With small nr_cpuids values (8 for example), kstats_irq was a small array
      (less than L1_CACHE_BYTES), potentially source of false sharing.
      
      In the !CONFIG_SPARSE_IRQ case, remove the huge, NUMA/cache unfriendly
      kstat_irqs_all[NR_IRQS][NR_CPUS] array.
      
      Note: we still populate kstats_irq for all possible irqs in
      early_irq_init().  We probably could use on-demand allocations.  (Code
      included in alloc_descs()).  Problem is not all IRQS are used with a prior
      alloc_descs() call.
      
      kstat_irqs_this_cpu() is not used anymore, remove it.
      Signed-off-by: NEric Dumazet <eric.dumazet@gmail.com>
      Reviewed-by: NChristoph Lameter <cl@linux.com>
      Cc: Ingo Molnar <mingo@elte.hu>
      Cc: Andi Kleen <andi@firstfloor.org>
      Cc: Tejun Heo <tj@kernel.org>
      Cc: Thomas Gleixner <tglx@linutronix.de>
      Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      6c9ae009
  10. 07 1月, 2011 1 次提交
  11. 01 12月, 2010 1 次提交
  12. 28 10月, 2010 1 次提交
    • K
      /proc/stat: fix scalability of irq sum of all cpu · 478735e3
      KAMEZAWA Hiroyuki 提交于
      In /proc/stat, the number of per-IRQ event is shown by making a sum each
      irq's events on all cpus.  But we can make use of kstat_irqs().
      
      kstat_irqs() do the same calculation, If !CONFIG_GENERIC_HARDIRQ,
      it's not a big cost. (Both of the number of cpus and irqs are small.)
      
      If a system is very big and CONFIG_GENERIC_HARDIRQ, it does
      
      	for_each_irq()
      		for_each_cpu()
      			- look up a radix tree
      			- read desc->irq_stat[cpu]
      This seems not efficient. This patch adds kstat_irqs() for
      CONFIG_GENRIC_HARDIRQ and change the calculation as
      
      	for_each_irq()
      		look up radix tree
      		for_each_cpu()
      			- read desc->irq_stat[cpu]
      
      This reduces cost.
      
      A test on (4096cpusp, 256 nodes, 4592 irqs) host (by Jack Steiner)
      
      %time cat /proc/stat > /dev/null
      
      Before Patch:	 2.459 sec
      After Patch :	  .561 sec
      
      [akpm@linux-foundation.org: unexport kstat_irqs, coding-style tweaks]
      [akpm@linux-foundation.org: fix unused variable 'per_irq_sum']
      Signed-off-by: NKAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
      Tested-by: NJack Steiner <steiner@sgi.com>
      Acked-by: NJack Steiner <steiner@sgi.com>
      Cc: Yinghai Lu <yinghai@kernel.org>
      Cc: Ingo Molnar <mingo@elte.hu>
      Cc: Thomas Gleixner <tglx@linutronix.de>
      Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      478735e3
  13. 23 10月, 2010 1 次提交
  14. 22 10月, 2010 1 次提交
  15. 13 10月, 2010 1 次提交
  16. 12 10月, 2010 2 次提交
反馈
建议
客服 返回
顶部