Use normal pointer for VA addresses
As VA addresses are used as pointers there's no need to handle them as 64-bit integer (which make the code more complicated) Signed-off-by: Frediano Ziglio <fziglio@redhat.com> Acked-by: Yuri Benditovich <yuri.benditovich@daynix.com>
This commit is contained in:
parent
6ec0533a7d
commit
53fb38c92f
@ -3596,10 +3596,10 @@ _inline QXLPHYSICAL QxlDevice::PA(PVOID virt, UINT8 slot_id)
|
||||
PAGED_CODE();
|
||||
DbgPrint(TRACE_LEVEL_VERBOSE, ("<--> %s\n", __FUNCTION__));
|
||||
MemSlot *pSlot = &m_MemSlots[slot_id];
|
||||
return pSlot->high_bits | ((UINT64)virt - pSlot->start_virt_addr);
|
||||
return pSlot->high_bits | ((UINT8*)virt - pSlot->start_virt_addr);
|
||||
}
|
||||
|
||||
_inline UINT64 QxlDevice::VA(QXLPHYSICAL paddr, UINT8 slot_id)
|
||||
_inline UINT8 *QxlDevice::VA(QXLPHYSICAL paddr, UINT8 slot_id)
|
||||
{
|
||||
PAGED_CODE();
|
||||
UINT64 virt;
|
||||
@ -3607,9 +3607,7 @@ _inline UINT64 QxlDevice::VA(QXLPHYSICAL paddr, UINT8 slot_id)
|
||||
|
||||
DbgPrint(TRACE_LEVEL_VERBOSE, ("---> %s\n", __FUNCTION__));
|
||||
virt = paddr & m_VaSlotMask;
|
||||
virt += pSlot->start_virt_addr;;
|
||||
|
||||
return virt;
|
||||
return pSlot->start_virt_addr + virt;
|
||||
}
|
||||
|
||||
void QxlDevice::SetupHWSlot(UINT8 Idx, MemSlot *pSlot)
|
||||
@ -3683,7 +3681,7 @@ void QxlDevice::SyncIo(UCHAR Port, UCHAR Value)
|
||||
ReleaseMutex(&m_IoLock, locked);
|
||||
}
|
||||
|
||||
void QxlDevice::SetupMemSlot(UINT8 Idx, UINT64 pastart, UINT64 paend, UINT64 vastart, UINT64 vaend)
|
||||
void QxlDevice::SetupMemSlot(UINT8 Idx, UINT64 pastart, UINT64 paend, UINT8 *vastart, UINT8 *valast)
|
||||
{
|
||||
PAGED_CODE();
|
||||
UINT64 high_bits;
|
||||
@ -3696,7 +3694,7 @@ void QxlDevice::SetupMemSlot(UINT8 Idx, UINT64 pastart, UINT64 paend, UINT64 vas
|
||||
pSlot->start_phys_addr = pastart;
|
||||
pSlot->end_phys_addr = paend;
|
||||
pSlot->start_virt_addr = vastart;
|
||||
pSlot->end_virt_addr = vaend;
|
||||
pSlot->last_virt_addr = valast;
|
||||
|
||||
SetupHWSlot(Idx + 1, pSlot);
|
||||
|
||||
@ -3716,14 +3714,14 @@ BOOL QxlDevice::CreateMemSlots(void)
|
||||
SetupMemSlot(m_MainMemSlot,
|
||||
(UINT64)m_RamPA.QuadPart,
|
||||
(UINT64)(m_RamPA.QuadPart + len),
|
||||
(UINT64)m_RamStart,
|
||||
(UINT64)(m_RamStart + len));
|
||||
m_RamStart,
|
||||
m_RamStart + len - 1);
|
||||
len = m_VRamSize;
|
||||
SetupMemSlot(m_SurfaceMemSlot,
|
||||
(UINT64)m_VRamPA.QuadPart,
|
||||
(UINT64)(m_VRamPA.QuadPart + len),
|
||||
(UINT64)m_VRamStart,
|
||||
(UINT64)(m_VRamStart + len));
|
||||
m_VRamStart,
|
||||
m_VRamStart + len - 1);
|
||||
DbgPrint(TRACE_LEVEL_VERBOSE, ("<--- %s\n", __FUNCTION__));
|
||||
return TRUE;
|
||||
}
|
||||
|
@ -364,8 +364,8 @@ typedef struct _MemSlot {
|
||||
UINT8 generation;
|
||||
UINT64 start_phys_addr;
|
||||
UINT64 end_phys_addr;
|
||||
UINT64 start_virt_addr;
|
||||
UINT64 end_virt_addr;
|
||||
UINT8 *start_virt_addr;
|
||||
UINT8 *last_virt_addr;
|
||||
QXLPHYSICAL high_bits;
|
||||
} MemSlot;
|
||||
|
||||
@ -581,10 +581,10 @@ private:
|
||||
void CreatePrimarySurface(PVIDEO_MODE_INFORMATION pModeInfo);
|
||||
void DestroyPrimarySurface(void);
|
||||
void SetupHWSlot(UINT8 Idx, MemSlot *pSlot);
|
||||
void SetupMemSlot(UINT8 Idx, UINT64 pastart, UINT64 paend, UINT64 vastart, UINT64 vaend);
|
||||
void SetupMemSlot(UINT8 Idx, UINT64 pastart, UINT64 paend, UINT8 *vastart, UINT8 *valast);
|
||||
BOOL CreateEvents(void);
|
||||
BOOL CreateRings(void);
|
||||
UINT64 VA(QXLPHYSICAL paddr, UINT8 slot_id);
|
||||
UINT8 *VA(QXLPHYSICAL paddr, UINT8 slot_id);
|
||||
QXLPHYSICAL PA(PVOID virt, UINT8 slot_id);
|
||||
void InitDeviceMemoryResources(void);
|
||||
NTSTATUS InitMonitorConfig();
|
||||
|
Loading…
Reference in New Issue
Block a user