diff options
author | Matthew Wilcox <willy@linux.intel.com> | 2009-03-17 13:54:09 +0100 |
---|---|---|
committer | Jesse Barnes <jbarnes@virtuousgeek.org> | 2009-03-20 18:48:13 +0100 |
commit | f2440d9acbe866b917b16cc0f927366341ce9215 (patch) | |
tree | ed868ca5b61fcadaf782f85c9a900b06e77fc3ce /Documentation | |
parent | PCI MSI: Use mask_pos instead of mask_base when appropriate (diff) | |
download | linux-f2440d9acbe866b917b16cc0f927366341ce9215.tar.xz linux-f2440d9acbe866b917b16cc0f927366341ce9215.zip |
PCI MSI: Refactor interrupt masking code
Since most of the callers already know whether they have an MSI or
an MSI-X capability, split msi_set_mask_bits() into msi_mask_irq()
and msix_mask_irq(). The only callers which don't (mask_msi_irq()
and unmask_msi_irq()) can share code in msi_set_mask_bit(). This then
becomes the only caller of msix_flush_writes(), so we can inline it.
The flushing read can be to any address that belongs to the device,
so we can eliminate the calculation too.
We can also get rid of maskbits_mask from struct msi_desc and simply
recalculate it on the rare occasion that we need it. The single-bit
'masked' element is replaced by a copy of the 32-bit 'masked' register,
so this patch does not affect the size of msi_desc.
Signed-off-by: Matthew Wilcox <willy@linux.intel.com>
Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
Diffstat (limited to 'Documentation')
0 files changed, 0 insertions, 0 deletions