mirror of https://github.com/PCSX2/pcsx2.git
vifUnpack: Made V3_## Unpacks work the same as V4_32, this is how legacy did it to, for some reason i made it copy the 3rd vector in to the fourth >.<
git-svn-id: http://pcsx2.googlecode.com/svn/trunk@3516 96395faa-99c1-11dd-bbfe-3dabce05a288
This commit is contained in:
parent
8e7a7cf5fe
commit
6fdfdf604f
|
@ -98,27 +98,31 @@ void VifUnpackSSE_Base::xUPK_S_32() const {
|
||||||
}
|
}
|
||||||
|
|
||||||
void VifUnpackSSE_Base::xUPK_S_16() const {
|
void VifUnpackSSE_Base::xUPK_S_16() const {
|
||||||
if (x86caps.hasStreamingSIMD4Extensions) {
|
if (x86caps.hasStreamingSIMD4Extensions)
|
||||||
|
{
|
||||||
xPMOVXX16 (workReg);
|
xPMOVXX16 (workReg);
|
||||||
}
|
}
|
||||||
else {
|
else
|
||||||
|
{
|
||||||
xMOV16 (workReg, ptr32[srcIndirect]);
|
xMOV16 (workReg, ptr32[srcIndirect]);
|
||||||
xPUNPCK.LWD(workReg, workReg);
|
xPUNPCK.LWD(workReg, workReg);
|
||||||
xShiftR (workReg, 16);
|
xShiftR (workReg, 16);
|
||||||
}
|
}
|
||||||
xPSHUF.D (destReg, workReg, _v0);
|
xPSHUF.D (destReg, workReg, _v0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void VifUnpackSSE_Base::xUPK_S_8() const {
|
void VifUnpackSSE_Base::xUPK_S_8() const {
|
||||||
if (x86caps.hasStreamingSIMD4Extensions) {
|
if (x86caps.hasStreamingSIMD4Extensions)
|
||||||
|
{
|
||||||
xPMOVXX8 (workReg);
|
xPMOVXX8 (workReg);
|
||||||
}
|
}
|
||||||
else {
|
else
|
||||||
|
{
|
||||||
xMOV8 (workReg, ptr32[srcIndirect]);
|
xMOV8 (workReg, ptr32[srcIndirect]);
|
||||||
xPUNPCK.LBW(workReg, workReg);
|
xPUNPCK.LBW(workReg, workReg);
|
||||||
xPUNPCK.LWD(workReg, workReg);
|
xPUNPCK.LWD(workReg, workReg);
|
||||||
xShiftR (workReg, 24);
|
xShiftR (workReg, 24);
|
||||||
}
|
}
|
||||||
xPSHUF.D (destReg, workReg, _v0);
|
xPSHUF.D (destReg, workReg, _v0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -133,58 +137,63 @@ void VifUnpackSSE_Base::xUPK_V2_32() const {
|
||||||
}
|
}
|
||||||
|
|
||||||
void VifUnpackSSE_Base::xUPK_V2_16() const {
|
void VifUnpackSSE_Base::xUPK_V2_16() const {
|
||||||
if (x86caps.hasStreamingSIMD4Extensions) {
|
if (x86caps.hasStreamingSIMD4Extensions)
|
||||||
|
{
|
||||||
xPMOVXX16 (destReg);
|
xPMOVXX16 (destReg);
|
||||||
}
|
}
|
||||||
else {
|
else
|
||||||
|
{
|
||||||
xMOV32 (destReg, ptr32[srcIndirect]);
|
xMOV32 (destReg, ptr32[srcIndirect]);
|
||||||
xPUNPCK.LWD(destReg, destReg);
|
xPUNPCK.LWD(destReg, destReg);
|
||||||
xShiftR (destReg, 16);
|
xShiftR (destReg, 16);
|
||||||
}
|
}
|
||||||
xPSHUF.D (destReg, destReg, 0x44); //v1v0v1v0
|
xPSHUF.D (destReg, destReg, 0x44); //v1v0v1v0
|
||||||
}
|
}
|
||||||
|
|
||||||
void VifUnpackSSE_Base::xUPK_V2_8() const {
|
void VifUnpackSSE_Base::xUPK_V2_8() const {
|
||||||
if (x86caps.hasStreamingSIMD4Extensions) {
|
if (x86caps.hasStreamingSIMD4Extensions)
|
||||||
|
{
|
||||||
xPMOVXX8 (destReg);
|
xPMOVXX8 (destReg);
|
||||||
}
|
}
|
||||||
else {
|
else
|
||||||
|
{
|
||||||
xMOV16 (destReg, ptr32[srcIndirect]);
|
xMOV16 (destReg, ptr32[srcIndirect]);
|
||||||
xPUNPCK.LBW(destReg, destReg);
|
xPUNPCK.LBW(destReg, destReg);
|
||||||
xPUNPCK.LWD(destReg, destReg);
|
xPUNPCK.LWD(destReg, destReg);
|
||||||
xShiftR (destReg, 24);
|
xShiftR (destReg, 24);
|
||||||
}
|
}
|
||||||
xPSHUF.D (destReg, destReg, 0x44); //v1v0v1v0
|
xPSHUF.D (destReg, destReg, 0x44); //v1v0v1v0
|
||||||
}
|
}
|
||||||
|
|
||||||
void VifUnpackSSE_Base::xUPK_V3_32() const {
|
void VifUnpackSSE_Base::xUPK_V3_32() const {
|
||||||
xMOV128 (destReg, ptr32[srcIndirect]);
|
xMOV128 (destReg, ptr32[srcIndirect]);
|
||||||
xPSHUF.D (destReg, destReg, 0xA4); //v2v2v1v0
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void VifUnpackSSE_Base::xUPK_V3_16() const {
|
void VifUnpackSSE_Base::xUPK_V3_16() const {
|
||||||
if (x86caps.hasStreamingSIMD4Extensions) {
|
if (x86caps.hasStreamingSIMD4Extensions)
|
||||||
|
{
|
||||||
xPMOVXX16 (destReg);
|
xPMOVXX16 (destReg);
|
||||||
}
|
}
|
||||||
else {
|
else
|
||||||
|
{
|
||||||
xMOV64 (destReg, ptr32[srcIndirect]);
|
xMOV64 (destReg, ptr32[srcIndirect]);
|
||||||
xPUNPCK.LWD(destReg, destReg);
|
xPUNPCK.LWD(destReg, destReg);
|
||||||
xShiftR (destReg, 16);
|
xShiftR (destReg, 16);
|
||||||
}
|
}
|
||||||
xPSHUF.D (destReg, destReg, 0xA4); //v2v2v1v0
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void VifUnpackSSE_Base::xUPK_V3_8() const {
|
void VifUnpackSSE_Base::xUPK_V3_8() const {
|
||||||
if (x86caps.hasStreamingSIMD4Extensions) {
|
if (x86caps.hasStreamingSIMD4Extensions)
|
||||||
|
{
|
||||||
xPMOVXX8 (destReg);
|
xPMOVXX8 (destReg);
|
||||||
}
|
}
|
||||||
else {
|
else
|
||||||
|
{
|
||||||
xMOV32 (destReg, ptr32[srcIndirect]);
|
xMOV32 (destReg, ptr32[srcIndirect]);
|
||||||
xPUNPCK.LBW(destReg, destReg);
|
xPUNPCK.LBW(destReg, destReg);
|
||||||
xPUNPCK.LWD(destReg, destReg);
|
xPUNPCK.LWD(destReg, destReg);
|
||||||
xShiftR (destReg, 24);
|
xShiftR (destReg, 24);
|
||||||
}
|
}
|
||||||
xPSHUF.D (destReg, destReg, 0xA4); //v2v2v1v0
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void VifUnpackSSE_Base::xUPK_V4_32() const {
|
void VifUnpackSSE_Base::xUPK_V4_32() const {
|
||||||
|
@ -192,26 +201,30 @@ void VifUnpackSSE_Base::xUPK_V4_32() const {
|
||||||
}
|
}
|
||||||
|
|
||||||
void VifUnpackSSE_Base::xUPK_V4_16() const {
|
void VifUnpackSSE_Base::xUPK_V4_16() const {
|
||||||
if (x86caps.hasStreamingSIMD4Extensions) {
|
if (x86caps.hasStreamingSIMD4Extensions)
|
||||||
|
{
|
||||||
xPMOVXX16 (destReg);
|
xPMOVXX16 (destReg);
|
||||||
}
|
}
|
||||||
else {
|
else
|
||||||
|
{
|
||||||
xMOV64 (destReg, ptr32[srcIndirect]);
|
xMOV64 (destReg, ptr32[srcIndirect]);
|
||||||
xPUNPCK.LWD(destReg, destReg);
|
xPUNPCK.LWD(destReg, destReg);
|
||||||
xShiftR (destReg, 16);
|
xShiftR (destReg, 16);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void VifUnpackSSE_Base::xUPK_V4_8() const {
|
void VifUnpackSSE_Base::xUPK_V4_8() const {
|
||||||
if (x86caps.hasStreamingSIMD4Extensions) {
|
if (x86caps.hasStreamingSIMD4Extensions)
|
||||||
|
{
|
||||||
xPMOVXX8 (destReg);
|
xPMOVXX8 (destReg);
|
||||||
}
|
}
|
||||||
else {
|
else
|
||||||
|
{
|
||||||
xMOV32 (destReg, ptr32[srcIndirect]);
|
xMOV32 (destReg, ptr32[srcIndirect]);
|
||||||
xPUNPCK.LBW(destReg, destReg);
|
xPUNPCK.LBW(destReg, destReg);
|
||||||
xPUNPCK.LWD(destReg, destReg);
|
xPUNPCK.LWD(destReg, destReg);
|
||||||
xShiftR (destReg, 24);
|
xShiftR (destReg, 24);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void VifUnpackSSE_Base::xUPK_V4_5() const {
|
void VifUnpackSSE_Base::xUPK_V4_5() const {
|
||||||
|
|
Loading…
Reference in New Issue