2024-07-30 11:42:36 +00:00
|
|
|
// SPDX-FileCopyrightText: 2002-2024 PCSX2 Dev Team
|
|
|
|
// SPDX-License-Identifier: GPL-3.0+
|
2009-04-21 05:29:14 +00:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
// MMX / SSE Helper Functions!
|
|
|
|
|
|
|
|
// ------------------------------------------------------------------------
|
|
|
|
// For implementing SSE-only logic operations that have xmmreg,xmmreg/rm forms only,
|
|
|
|
// like ANDPS/ANDPD
|
|
|
|
//
|
2016-11-12 15:28:37 +00:00
|
|
|
template <u8 Prefix, u16 Opcode>
|
2009-04-21 05:29:14 +00:00
|
|
|
class SimdImpl_DestRegSSE
|
|
|
|
{
|
|
|
|
public:
|
2021-09-06 18:28:26 +00:00
|
|
|
__forceinline void operator()(const xRegisterSSE& to, const xRegisterSSE& from) const { xOpWrite0F(Prefix, Opcode, to, from); }
|
|
|
|
__forceinline void operator()(const xRegisterSSE& to, const ModSibBase& from) const
|
|
|
|
{
|
|
|
|
bool isReallyAligned = ((from.Displacement & 0x0f) == 0) && from.Index.IsEmpty() && from.Base.IsEmpty();
|
2023-12-22 10:30:31 +00:00
|
|
|
pxAssertMsg(isReallyAligned, "Alignment check failed on SSE indirect load.");
|
2021-09-06 18:28:26 +00:00
|
|
|
xOpWrite0F(Prefix, Opcode, to, from);
|
|
|
|
}
|
2009-04-21 05:29:14 +00:00
|
|
|
|
2021-09-06 18:28:26 +00:00
|
|
|
SimdImpl_DestRegSSE() {} //GCWho?
|
2009-04-21 05:29:14 +00:00
|
|
|
};
|