gzdoom-gles/src/r_drawers.cpp
2016-12-15 23:29:31 +01:00

318 lines
16 KiB
C++

/*
** LLVM code generated drawers
** Copyright (c) 2016 Magnus Norddahl
**
** This software is provided 'as-is', without any express or implied
** warranty. In no event will the authors be held liable for any damages
** arising from the use of this software.
**
** Permission is granted to anyone to use this software for any purpose,
** including commercial applications, and to alter it and redistribute it
** freely, subject to the following restrictions:
**
** 1. The origin of this software must not be misrepresented; you must not
** claim that you wrote the original software. If you use this software
** in a product, an acknowledgment in the product documentation would be
** appreciated but is not required.
** 2. Altered source versions must be plainly marked as such, and must not be
** misrepresented as being the original software.
** 3. This notice may not be removed or altered from any source distribution.
**
*/
#include "i_system.h"
#include "r_drawers.h"
#include "x86.h"
#include "c_cvars.h"
#include "version.h"
#include "m_misc.h"
/////////////////////////////////////////////////////////////////////////////
extern "C"
{
void DrawColumn_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnAdd_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnShaded_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnAddClamp_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnSubClamp_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRevSubClamp_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnTranslated_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnTlatedAdd_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnAddClampTranslated_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnSubClampTranslated_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRevSubClampTranslated_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void FillColumn_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void FillColumnAdd_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void FillColumnAddClamp_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void FillColumnSubClamp_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void FillColumnRevSubClamp_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt1_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt1Copy_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt1Add_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt1Shaded_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt1AddClamp_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt1SubClamp_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt1RevSubClamp_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt1Translated_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt1TlatedAdd_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt1AddClampTranslated_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt1SubClampTranslated_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt1RevSubClampTranslated_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt4_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt4Copy_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt4Add_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt4Shaded_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt4AddClamp_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt4SubClamp_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt4RevSubClamp_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt4Translated_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt4TlatedAdd_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt4AddClampTranslated_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt4SubClampTranslated_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawColumnRt4RevSubClampTranslated_SSE2(const DrawColumnArgs *, const WorkerThreadData *);
void DrawSpan_SSE2(const DrawSpanArgs *);
void DrawSpanMasked_SSE2(const DrawSpanArgs *);
void DrawSpanTranslucent_SSE2(const DrawSpanArgs *);
void DrawSpanMaskedTranslucent_SSE2(const DrawSpanArgs *);
void DrawSpanAddClamp_SSE2(const DrawSpanArgs *);
void DrawSpanMaskedAddClamp_SSE2(const DrawSpanArgs *);
void vlinec1_SSE2(const DrawWallArgs *, const WorkerThreadData *);
void vlinec4_SSE2(const DrawWallArgs *, const WorkerThreadData *);
void mvlinec1_SSE2(const DrawWallArgs *, const WorkerThreadData *);
void mvlinec4_SSE2(const DrawWallArgs *, const WorkerThreadData *);
void tmvline1_add_SSE2(const DrawWallArgs *, const WorkerThreadData *);
void tmvline4_add_SSE2(const DrawWallArgs *, const WorkerThreadData *);
void tmvline1_addclamp_SSE2(const DrawWallArgs *, const WorkerThreadData *);
void tmvline4_addclamp_SSE2(const DrawWallArgs *, const WorkerThreadData *);
void tmvline1_subclamp_SSE2(const DrawWallArgs *, const WorkerThreadData *);
void tmvline4_subclamp_SSE2(const DrawWallArgs *, const WorkerThreadData *);
void tmvline1_revsubclamp_SSE2(const DrawWallArgs *, const WorkerThreadData *);
void tmvline4_revsubclamp_SSE2(const DrawWallArgs *, const WorkerThreadData *);
void DrawSky1_SSE2(const DrawSkyArgs *, const WorkerThreadData *);
void DrawSky4_SSE2(const DrawSkyArgs *, const WorkerThreadData *);
void DrawDoubleSky1_SSE2(const DrawSkyArgs *, const WorkerThreadData *);
void DrawDoubleSky4_SSE2(const DrawSkyArgs *, const WorkerThreadData *);
void TriDraw8_0_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw8_1_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw8_2_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw8_3_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw8_4_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw8_5_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw8_6_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw8_7_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw8_8_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw8_9_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw8_10_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw8_11_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw8_12_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw8_13_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw8_14_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw32_0_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw32_1_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw32_2_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw32_3_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw32_4_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw32_5_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw32_6_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw32_7_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw32_8_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw32_9_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw32_10_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw32_11_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw32_12_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw32_13_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriDraw32_14_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill8_0_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill8_1_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill8_2_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill8_3_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill8_4_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill8_5_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill8_6_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill8_7_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill8_8_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill8_9_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill8_10_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill8_11_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill8_12_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill8_13_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill8_14_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill32_0_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill32_1_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill32_2_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill32_3_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill32_4_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill32_5_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill32_6_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill32_7_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill32_8_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill32_9_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill32_10_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill32_11_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill32_12_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill32_13_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
void TriFill32_14_SSE2(const TriDrawTriangleArgs *, WorkerThreadData *);
}
/////////////////////////////////////////////////////////////////////////////
Drawers::Drawers()
{
DrawColumn = DrawColumn_SSE2;
DrawColumnAdd = DrawColumnAdd_SSE2;
DrawColumnShaded = DrawColumnShaded_SSE2;
DrawColumnAddClamp = DrawColumnAddClamp_SSE2;
DrawColumnSubClamp = DrawColumnSubClamp_SSE2;
DrawColumnRevSubClamp = DrawColumnRevSubClamp_SSE2;
DrawColumnTranslated = DrawColumnTranslated_SSE2;
DrawColumnTlatedAdd = DrawColumnTlatedAdd_SSE2;
DrawColumnAddClampTranslated = DrawColumnAddClampTranslated_SSE2;
DrawColumnSubClampTranslated = DrawColumnSubClampTranslated_SSE2;
DrawColumnRevSubClampTranslated = DrawColumnRevSubClampTranslated_SSE2;
FillColumn = FillColumn_SSE2;
FillColumnAdd = FillColumnAdd_SSE2;
FillColumnAddClamp = FillColumnAddClamp_SSE2;
FillColumnSubClamp = FillColumnSubClamp_SSE2;
FillColumnRevSubClamp = FillColumnRevSubClamp_SSE2;
DrawColumnRt1 = DrawColumnRt1_SSE2;
DrawColumnRt1Copy = DrawColumnRt1Copy_SSE2;
DrawColumnRt1Add = DrawColumnRt1Add_SSE2;
DrawColumnRt1Shaded = DrawColumnRt1Shaded_SSE2;
DrawColumnRt1AddClamp = DrawColumnRt1AddClamp_SSE2;
DrawColumnRt1SubClamp = DrawColumnRt1SubClamp_SSE2;
DrawColumnRt1RevSubClamp = DrawColumnRt1RevSubClamp_SSE2;
DrawColumnRt1Translated = DrawColumnRt1Translated_SSE2;
DrawColumnRt1TlatedAdd = DrawColumnRt1TlatedAdd_SSE2;
DrawColumnRt1AddClampTranslated = DrawColumnRt1AddClampTranslated_SSE2;
DrawColumnRt1SubClampTranslated = DrawColumnRt1SubClampTranslated_SSE2;
DrawColumnRt1RevSubClampTranslated = DrawColumnRt1RevSubClampTranslated_SSE2;
DrawColumnRt4 = DrawColumnRt4_SSE2;
DrawColumnRt4Copy = DrawColumnRt4Copy_SSE2;
DrawColumnRt4Add = DrawColumnRt4Add_SSE2;
DrawColumnRt4Shaded = DrawColumnRt4Shaded_SSE2;
DrawColumnRt4AddClamp = DrawColumnRt4AddClamp_SSE2;
DrawColumnRt4SubClamp = DrawColumnRt4SubClamp_SSE2;
DrawColumnRt4RevSubClamp = DrawColumnRt4RevSubClamp_SSE2;
DrawColumnRt4Translated = DrawColumnRt4Translated_SSE2;
DrawColumnRt4TlatedAdd = DrawColumnRt4TlatedAdd_SSE2;
DrawColumnRt4AddClampTranslated = DrawColumnRt4AddClampTranslated_SSE2;
DrawColumnRt4SubClampTranslated = DrawColumnRt4SubClampTranslated_SSE2;
DrawColumnRt4RevSubClampTranslated = DrawColumnRt4RevSubClampTranslated_SSE2;
DrawSpan = DrawSpan_SSE2;
DrawSpanMasked = DrawSpanMasked_SSE2;
DrawSpanTranslucent = DrawSpanTranslucent_SSE2;
DrawSpanMaskedTranslucent = DrawSpanMaskedTranslucent_SSE2;
DrawSpanAddClamp = DrawSpanAddClamp_SSE2;
DrawSpanMaskedAddClamp = DrawSpanMaskedAddClamp_SSE2;
vlinec1 = vlinec1_SSE2;
vlinec4 = vlinec4_SSE2;
mvlinec1 = mvlinec1_SSE2;
mvlinec4 = mvlinec4_SSE2;
tmvline1_add = tmvline1_add_SSE2;
tmvline4_add = tmvline4_add_SSE2;
tmvline1_addclamp = tmvline1_addclamp_SSE2;
tmvline4_addclamp = tmvline4_addclamp_SSE2;
tmvline1_subclamp = tmvline1_subclamp_SSE2;
tmvline4_subclamp = tmvline4_subclamp_SSE2;
tmvline1_revsubclamp = tmvline1_revsubclamp_SSE2;
tmvline4_revsubclamp = tmvline4_revsubclamp_SSE2;
DrawSky1 = DrawSky1_SSE2;
DrawSky4 = DrawSky4_SSE2;
DrawDoubleSky1 = DrawDoubleSky1_SSE2;
DrawDoubleSky4 = DrawDoubleSky4_SSE2;
TriDraw8.push_back(TriDraw8_0_SSE2);
TriDraw8.push_back(TriDraw8_1_SSE2);
TriDraw8.push_back(TriDraw8_2_SSE2);
TriDraw8.push_back(TriDraw8_3_SSE2);
TriDraw8.push_back(TriDraw8_4_SSE2);
TriDraw8.push_back(TriDraw8_5_SSE2);
TriDraw8.push_back(TriDraw8_6_SSE2);
TriDraw8.push_back(TriDraw8_7_SSE2);
TriDraw8.push_back(TriDraw8_8_SSE2);
TriDraw8.push_back(TriDraw8_9_SSE2);
TriDraw8.push_back(TriDraw8_10_SSE2);
TriDraw8.push_back(TriDraw8_11_SSE2);
TriDraw8.push_back(TriDraw8_12_SSE2);
TriDraw8.push_back(TriDraw8_13_SSE2);
TriDraw8.push_back(TriDraw8_14_SSE2);
TriDraw32.push_back(TriDraw32_0_SSE2);
TriDraw32.push_back(TriDraw32_1_SSE2);
TriDraw32.push_back(TriDraw32_2_SSE2);
TriDraw32.push_back(TriDraw32_3_SSE2);
TriDraw32.push_back(TriDraw32_4_SSE2);
TriDraw32.push_back(TriDraw32_5_SSE2);
TriDraw32.push_back(TriDraw32_6_SSE2);
TriDraw32.push_back(TriDraw32_7_SSE2);
TriDraw32.push_back(TriDraw32_8_SSE2);
TriDraw32.push_back(TriDraw32_9_SSE2);
TriDraw32.push_back(TriDraw32_10_SSE2);
TriDraw32.push_back(TriDraw32_11_SSE2);
TriDraw32.push_back(TriDraw32_12_SSE2);
TriDraw32.push_back(TriDraw32_13_SSE2);
TriDraw32.push_back(TriDraw32_14_SSE2);
TriFill8.push_back(TriFill8_0_SSE2);
TriFill8.push_back(TriFill8_1_SSE2);
TriFill8.push_back(TriFill8_2_SSE2);
TriFill8.push_back(TriFill8_3_SSE2);
TriFill8.push_back(TriFill8_4_SSE2);
TriFill8.push_back(TriFill8_5_SSE2);
TriFill8.push_back(TriFill8_6_SSE2);
TriFill8.push_back(TriFill8_7_SSE2);
TriFill8.push_back(TriFill8_8_SSE2);
TriFill8.push_back(TriFill8_9_SSE2);
TriFill8.push_back(TriFill8_10_SSE2);
TriFill8.push_back(TriFill8_11_SSE2);
TriFill8.push_back(TriFill8_12_SSE2);
TriFill8.push_back(TriFill8_13_SSE2);
TriFill8.push_back(TriFill8_14_SSE2);
TriFill32.push_back(TriFill32_0_SSE2);
TriFill32.push_back(TriFill32_1_SSE2);
TriFill32.push_back(TriFill32_2_SSE2);
TriFill32.push_back(TriFill32_3_SSE2);
TriFill32.push_back(TriFill32_4_SSE2);
TriFill32.push_back(TriFill32_5_SSE2);
TriFill32.push_back(TriFill32_6_SSE2);
TriFill32.push_back(TriFill32_7_SSE2);
TriFill32.push_back(TriFill32_8_SSE2);
TriFill32.push_back(TriFill32_9_SSE2);
TriFill32.push_back(TriFill32_10_SSE2);
TriFill32.push_back(TriFill32_11_SSE2);
TriFill32.push_back(TriFill32_12_SSE2);
TriFill32.push_back(TriFill32_13_SSE2);
TriFill32.push_back(TriFill32_14_SSE2);
}
Drawers *Drawers::Instance()
{
static Drawers drawers;
return &drawers;
}
FString DrawWallArgs::ToString()
{
FString info;
info.Format("dest_y = %i, count = %i, flags = %i, texturefrac[0] = %u, textureheight[0] = %u", dest_y, count, flags, texturefrac[0], textureheight[0]);
return info;
}
FString DrawSpanArgs::ToString()
{
FString info;
info.Format("x1 = %i, x2 = %i, y = %i, flags = %i", x1, x2, y, flags);
return info;
}
FString DrawColumnArgs::ToString()
{
FString info;
info.Format("dest_y = %i, count = %i, flags = %i, iscale = %i (%f), texturefrac = %i (%f)", dest_y, count, flags, iscale, ((fixed_t)iscale) / (float)FRACUNIT, texturefrac, ((fixed_t)texturefrac) / (float)FRACUNIT);
return info;
}
FString DrawSkyArgs::ToString()
{
FString info;
info.Format("dest_y = %i, count = %i", dest_y, count);
return info;
}