VirtualBox

Changeset 96995 in vbox for trunk/src/VBox


Ignore:
Timestamp:
Oct 5, 2022 8:01:58 AM (2 years ago)
Author:
vboxsync
svn:sync-xref-src-repo-rev:
153927
Message:

VMM/APIC: Fix pointer alignment for ASMBitTest, ASMAtomicBit[Set|Clear].

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/VMM/VMMAll/APICAll.cpp

    r96926 r96995  
    8686{
    8787    const volatile uint8_t *pbBitmap = (const volatile uint8_t *)&pApicReg->u[0];
    88     return ASMBitTest(pbBitmap + XAPIC_REG256_VECTOR_OFF(uVector), XAPIC_REG256_VECTOR_BIT(uVector));
     88    return ASMBitTest(pbBitmap, (XAPIC_REG256_VECTOR_OFF(uVector) << 3) + XAPIC_REG256_VECTOR_BIT(uVector));
    8989}
    9090
     
    9999{
    100100    volatile uint8_t *pbBitmap = (volatile uint8_t *)&pApicReg->u[0];
    101     ASMAtomicBitSet(pbBitmap + XAPIC_REG256_VECTOR_OFF(uVector), XAPIC_REG256_VECTOR_BIT(uVector));
     101    ASMAtomicBitSet(pbBitmap, (XAPIC_REG256_VECTOR_OFF(uVector) << 3) + XAPIC_REG256_VECTOR_BIT(uVector));
    102102}
    103103
     
    112112{
    113113    volatile uint8_t *pbBitmap = (volatile uint8_t *)&pApicReg->u[0];
    114     ASMAtomicBitClear(pbBitmap + XAPIC_REG256_VECTOR_OFF(uVector), XAPIC_REG256_VECTOR_BIT(uVector));
     114    ASMAtomicBitClear(pbBitmap, (XAPIC_REG256_VECTOR_OFF(uVector) << 3) + XAPIC_REG256_VECTOR_BIT(uVector));
    115115}
    116116
Note: See TracChangeset for help on using the changeset viewer.

© 2025 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette