Remove VertexLoaderBase::IsInitialized
It is no longer relevant for the current set of loaders after 7030542546
. If it becomes relevant again, a static function named IsUsable or IsCompatibleWithCurrentMachine or something would be a better approach.
This commit is contained in:
parent
cafffff75e
commit
fa7077763f
|
@ -22,7 +22,6 @@ public:
|
||||||
VertexLoader(const TVtxDesc& vtx_desc, const VAT& vtx_attr);
|
VertexLoader(const TVtxDesc& vtx_desc, const VAT& vtx_attr);
|
||||||
|
|
||||||
int RunVertices(DataReader src, DataReader dst, int count) override;
|
int RunVertices(DataReader src, DataReader dst, int count) override;
|
||||||
bool IsInitialized() override { return true; } // This vertex loader supports all formats
|
|
||||||
// They are used for the communication with the loader functions
|
// They are used for the communication with the loader functions
|
||||||
float m_posScale;
|
float m_posScale;
|
||||||
float m_tcScale[8];
|
float m_tcScale[8];
|
||||||
|
|
|
@ -53,9 +53,6 @@ alignas(16) static const float scale_factors[] = {
|
||||||
VertexLoaderARM64::VertexLoaderARM64(const TVtxDesc& vtx_desc, const VAT& vtx_att)
|
VertexLoaderARM64::VertexLoaderARM64(const TVtxDesc& vtx_desc, const VAT& vtx_att)
|
||||||
: VertexLoaderBase(vtx_desc, vtx_att), m_float_emit(this)
|
: VertexLoaderBase(vtx_desc, vtx_att), m_float_emit(this)
|
||||||
{
|
{
|
||||||
if (!IsInitialized())
|
|
||||||
return;
|
|
||||||
|
|
||||||
AllocCodeSpace(4096);
|
AllocCodeSpace(4096);
|
||||||
ClearCodeSpace();
|
ClearCodeSpace();
|
||||||
GenerateVertexLoader();
|
GenerateVertexLoader();
|
||||||
|
|
|
@ -19,7 +19,6 @@ public:
|
||||||
VertexLoaderARM64(const TVtxDesc& vtx_desc, const VAT& vtx_att);
|
VertexLoaderARM64(const TVtxDesc& vtx_desc, const VAT& vtx_att);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
bool IsInitialized() override { return true; }
|
|
||||||
int RunVertices(DataReader src, DataReader dst, int count) override;
|
int RunVertices(DataReader src, DataReader dst, int count) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
|
@ -34,31 +34,23 @@ public:
|
||||||
const TVtxDesc& vtx_desc, const VAT& vtx_attr)
|
const TVtxDesc& vtx_desc, const VAT& vtx_attr)
|
||||||
: VertexLoaderBase(vtx_desc, vtx_attr), a(std::move(a_)), b(std::move(b_))
|
: VertexLoaderBase(vtx_desc, vtx_attr), a(std::move(a_)), b(std::move(b_))
|
||||||
{
|
{
|
||||||
m_initialized = a && b && a->IsInitialized() && b->IsInitialized();
|
ASSERT(a && b);
|
||||||
|
if (a->m_VertexSize == b->m_VertexSize && a->m_native_components == b->m_native_components &&
|
||||||
if (m_initialized)
|
a->m_native_vtx_decl.stride == b->m_native_vtx_decl.stride)
|
||||||
{
|
{
|
||||||
m_initialized = a->m_VertexSize == b->m_VertexSize &&
|
m_VertexSize = a->m_VertexSize;
|
||||||
a->m_native_components == b->m_native_components &&
|
m_native_components = a->m_native_components;
|
||||||
a->m_native_vtx_decl.stride == b->m_native_vtx_decl.stride;
|
memcpy(&m_native_vtx_decl, &a->m_native_vtx_decl, sizeof(PortableVertexDeclaration));
|
||||||
|
}
|
||||||
if (m_initialized)
|
else
|
||||||
{
|
{
|
||||||
m_VertexSize = a->m_VertexSize;
|
ERROR_LOG_FMT(VIDEO, "Can't compare vertex loaders that expect different vertex formats!");
|
||||||
m_native_components = a->m_native_components;
|
ERROR_LOG_FMT(VIDEO, "a: m_VertexSize {}, m_native_components {:#010x}, stride {}",
|
||||||
memcpy(&m_native_vtx_decl, &a->m_native_vtx_decl, sizeof(PortableVertexDeclaration));
|
a->m_VertexSize, a->m_native_components, a->m_native_vtx_decl.stride);
|
||||||
}
|
ERROR_LOG_FMT(VIDEO, "b: m_VertexSize {}, m_native_components {:#010x}, stride {}",
|
||||||
else
|
b->m_VertexSize, b->m_native_components, b->m_native_vtx_decl.stride);
|
||||||
{
|
|
||||||
ERROR_LOG_FMT(VIDEO, "Can't compare vertex loaders that expect different vertex formats!");
|
|
||||||
ERROR_LOG_FMT(VIDEO, "a: m_VertexSize {}, m_native_components {:#010x}, stride {}",
|
|
||||||
a->m_VertexSize, a->m_native_components, a->m_native_vtx_decl.stride);
|
|
||||||
ERROR_LOG_FMT(VIDEO, "b: m_VertexSize {}, m_native_components {:#010x}, stride {}",
|
|
||||||
b->m_VertexSize, b->m_native_components, b->m_native_vtx_decl.stride);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
~VertexLoaderTester() override {}
|
|
||||||
int RunVertices(DataReader src, DataReader dst, int count) override
|
int RunVertices(DataReader src, DataReader dst, int count) override
|
||||||
{
|
{
|
||||||
buffer_a.resize(count * a->m_native_vtx_decl.stride + 4);
|
buffer_a.resize(count * a->m_native_vtx_decl.stride + 4);
|
||||||
|
@ -81,21 +73,17 @@ public:
|
||||||
std::min(count_a, count_b) * m_native_vtx_decl.stride))
|
std::min(count_a, count_b) * m_native_vtx_decl.stride))
|
||||||
{
|
{
|
||||||
ERROR_LOG_FMT(VIDEO,
|
ERROR_LOG_FMT(VIDEO,
|
||||||
"The two vertex loaders have loaded different data "
|
"The two vertex loaders have loaded different data. Configuration:"
|
||||||
"(guru meditation {:#010x}, {:#010x}, {:#010x}, {:#010x}, {:#010x}).",
|
"\nVertex desc:\n{}\n\nVertex attr:\n{}",
|
||||||
m_VtxDesc.low.Hex, m_VtxDesc.high.Hex, m_VtxAttr.g0.Hex, m_VtxAttr.g1.Hex,
|
m_VtxDesc, m_VtxAttr);
|
||||||
m_VtxAttr.g2.Hex);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
memcpy(dst.GetPointer(), buffer_a.data(), count_a * m_native_vtx_decl.stride);
|
memcpy(dst.GetPointer(), buffer_a.data(), count_a * m_native_vtx_decl.stride);
|
||||||
m_numLoadedVertices += count;
|
m_numLoadedVertices += count;
|
||||||
return count_a;
|
return count_a;
|
||||||
}
|
}
|
||||||
bool IsInitialized() override { return m_initialized; }
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
bool m_initialized;
|
|
||||||
|
|
||||||
std::unique_ptr<VertexLoaderBase> a;
|
std::unique_ptr<VertexLoaderBase> a;
|
||||||
std::unique_ptr<VertexLoaderBase> b;
|
std::unique_ptr<VertexLoaderBase> b;
|
||||||
|
|
||||||
|
@ -106,33 +94,29 @@ private:
|
||||||
std::unique_ptr<VertexLoaderBase> VertexLoaderBase::CreateVertexLoader(const TVtxDesc& vtx_desc,
|
std::unique_ptr<VertexLoaderBase> VertexLoaderBase::CreateVertexLoader(const TVtxDesc& vtx_desc,
|
||||||
const VAT& vtx_attr)
|
const VAT& vtx_attr)
|
||||||
{
|
{
|
||||||
std::unique_ptr<VertexLoaderBase> loader;
|
std::unique_ptr<VertexLoaderBase> loader = nullptr;
|
||||||
|
|
||||||
//#define COMPARE_VERTEXLOADERS
|
//#define COMPARE_VERTEXLOADERS
|
||||||
|
|
||||||
#if defined(COMPARE_VERTEXLOADERS) && defined(_M_X86_64)
|
#if defined(_M_X86_64)
|
||||||
// first try: Any new VertexLoader vs the old one
|
|
||||||
loader = std::make_unique<VertexLoaderTester>(
|
|
||||||
std::make_unique<VertexLoader>(vtx_desc, vtx_attr), // the software one
|
|
||||||
std::make_unique<VertexLoaderX64>(vtx_desc, vtx_attr), // the new one to compare
|
|
||||||
vtx_desc, vtx_attr);
|
|
||||||
if (loader->IsInitialized())
|
|
||||||
return loader;
|
|
||||||
#elif defined(_M_X86_64)
|
|
||||||
loader = std::make_unique<VertexLoaderX64>(vtx_desc, vtx_attr);
|
loader = std::make_unique<VertexLoaderX64>(vtx_desc, vtx_attr);
|
||||||
if (loader->IsInitialized())
|
|
||||||
return loader;
|
|
||||||
#elif defined(_M_ARM_64)
|
#elif defined(_M_ARM_64)
|
||||||
loader = std::make_unique<VertexLoaderARM64>(vtx_desc, vtx_attr);
|
loader = std::make_unique<VertexLoaderARM64>(vtx_desc, vtx_attr);
|
||||||
if (loader->IsInitialized())
|
|
||||||
return loader;
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// last try: The old VertexLoader
|
// Use the software loader as a fallback
|
||||||
loader = std::make_unique<VertexLoader>(vtx_desc, vtx_attr);
|
// (not currently applicable, as both VertexLoaderX64 and VertexLoaderARM64
|
||||||
if (loader->IsInitialized())
|
// are always usable, but if a loader that only works on some CPUs is created
|
||||||
return loader;
|
// then this fallback would be used)
|
||||||
|
if (!loader)
|
||||||
|
loader = std::make_unique<VertexLoader>(vtx_desc, vtx_attr);
|
||||||
|
|
||||||
PanicAlertFmt("No Vertex Loader found.");
|
#if defined(COMPARE_VERTEXLOADERS)
|
||||||
return nullptr;
|
return std::make_unique<VertexLoaderTester>(
|
||||||
|
std::make_unique<VertexLoader>(vtx_desc, vtx_attr), // the software one
|
||||||
|
std::move(loader), // the new one to compare
|
||||||
|
vtx_desc, vtx_attr);
|
||||||
|
#else
|
||||||
|
return loader;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
|
@ -65,8 +65,6 @@ public:
|
||||||
virtual ~VertexLoaderBase() {}
|
virtual ~VertexLoaderBase() {}
|
||||||
virtual int RunVertices(DataReader src, DataReader dst, int count) = 0;
|
virtual int RunVertices(DataReader src, DataReader dst, int count) = 0;
|
||||||
|
|
||||||
virtual bool IsInitialized() = 0;
|
|
||||||
|
|
||||||
// per loader public state
|
// per loader public state
|
||||||
int m_VertexSize = 0; // number of bytes of a raw GC vertex
|
int m_VertexSize = 0; // number of bytes of a raw GC vertex
|
||||||
PortableVertexDeclaration m_native_vtx_decl{};
|
PortableVertexDeclaration m_native_vtx_decl{};
|
||||||
|
|
|
@ -45,9 +45,6 @@ static OpArg MPIC(const void* ptr)
|
||||||
VertexLoaderX64::VertexLoaderX64(const TVtxDesc& vtx_desc, const VAT& vtx_att)
|
VertexLoaderX64::VertexLoaderX64(const TVtxDesc& vtx_desc, const VAT& vtx_att)
|
||||||
: VertexLoaderBase(vtx_desc, vtx_att)
|
: VertexLoaderBase(vtx_desc, vtx_att)
|
||||||
{
|
{
|
||||||
if (!IsInitialized())
|
|
||||||
return;
|
|
||||||
|
|
||||||
AllocCodeSpace(4096);
|
AllocCodeSpace(4096);
|
||||||
ClearCodeSpace();
|
ClearCodeSpace();
|
||||||
GenerateVertexLoader();
|
GenerateVertexLoader();
|
||||||
|
|
|
@ -18,7 +18,6 @@ public:
|
||||||
VertexLoaderX64(const TVtxDesc& vtx_desc, const VAT& vtx_att);
|
VertexLoaderX64(const TVtxDesc& vtx_desc, const VAT& vtx_att);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
bool IsInitialized() override { return true; }
|
|
||||||
int RunVertices(DataReader src, DataReader dst, int count) override;
|
int RunVertices(DataReader src, DataReader dst, int count) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
Loading…
Reference in New Issue