This should only cover bits 12-19, in line with MSI_ADDR_DEST_ID_SHIFT.
Also replace a couple of open-coded uses of this shift and mask.
Signed-off-by: Jan Beulich <jbeulich@suse.com>
if ( !vector )
{
- int pirq = ((addr >> 32) & 0xffffff00) | ((addr >> 12) & 0xff);
+ int pirq = ((addr >> 32) & 0xffffff00) | dest;
+
if ( pirq > 0 )
{
struct pirq *info = pirq_info(d, pirq);
msg->dest32 = iremap_entry->lo.dst;
else
msg->dest32 = (iremap_entry->lo.dst >> 8) & 0xff;
- msg->address_lo |= (msg->dest32 & 0xff) << MSI_ADDR_DEST_ID_SHIFT;
+ msg->address_lo |= MSI_ADDR_DEST_ID(msg->dest32);
msg->data =
MSI_DATA_TRIGGER_EDGE |
if (x2apic_enabled)
msg.address_hi = dest & 0xFFFFFF00;
msg.address_lo &= ~MSI_ADDR_DEST_ID_MASK;
- msg.address_lo |= MSI_ADDR_DEST_ID(dest & 0xff);
+ msg.address_lo |= MSI_ADDR_DEST_ID(dest);
iommu->msi.msg = msg;
spin_lock_irqsave(&iommu->register_lock, flags);
#define MSI_ADDR_REDIRECTION_LOWPRI (1 << MSI_ADDR_REDIRECTION_SHIFT)
#define MSI_ADDR_DEST_ID_SHIFT 12
-#define MSI_ADDR_DEST_ID_MASK 0x00ffff0
+#define MSI_ADDR_DEST_ID_MASK 0x00ff000
#define MSI_ADDR_DEST_ID(dest) (((dest) << MSI_ADDR_DEST_ID_SHIFT) & MSI_ADDR_DEST_ID_MASK)
/* MAX fixed pages reserved for mapping MSIX tables. */