mirror of
				https://github.com/AxioDL/metaforce.git
				synced 2025-10-25 08:50:25 +00:00 
			
		
		
		
	Changes to support new boo object tracker API
This commit is contained in:
		
							parent
							
								
									f9a431d62c
								
							
						
					
					
						commit
						d2fda8a373
					
				
							
								
								
									
										2
									
								
								hecl/extern/boo
									
									
									
									
										vendored
									
									
								
							
							
								
								
								
								
								
								
									
									
								
							
						
						
									
										2
									
								
								hecl/extern/boo
									
									
									
									
										vendored
									
									
								
							| @ -1 +1 @@ | ||||
| Subproject commit 10364557b99f0b48d1ab61ed02355f61c8fdbac1 | ||||
| Subproject commit 3a7987bb21b0db3873948e82520fa88c6981f436 | ||||
| @ -91,7 +91,7 @@ public: | ||||
|     uint64_t getMetaData() const {return m_meta;} | ||||
| 
 | ||||
|     /* For shader constructors that require vertex format up-front (HLSL) */ | ||||
|     boo::IVertexFormat* newVertexFormat(boo::IGraphicsDataFactory::Context& ctx) const; | ||||
|     boo::ObjToken<boo::IVertexFormat> newVertexFormat(boo::IGraphicsDataFactory::Context& ctx) const; | ||||
| }; | ||||
| 
 | ||||
| /**
 | ||||
| @ -196,14 +196,14 @@ class IShaderBackendFactory | ||||
|     friend class ShaderCacheManager; | ||||
| protected: | ||||
|     unsigned m_rtHint = 1; | ||||
|     using FReturnExtensionShader = std::function<void(boo::IShaderPipeline*)>; | ||||
|     using FReturnExtensionShader = std::function<void(const boo::ObjToken<boo::IShaderPipeline>&)>; | ||||
|     virtual ShaderCachedData buildShaderFromIR(const ShaderTag& tag, | ||||
|                                                const hecl::Frontend::IR& ir, | ||||
|                                                hecl::Frontend::Diagnostics& diag, | ||||
|                                                boo::IGraphicsDataFactory::Context& ctx, | ||||
|                                                boo::IShaderPipeline*& objOut)=0; | ||||
|     virtual boo::IShaderPipeline* buildShaderFromCache(const ShaderCachedData& data, | ||||
|                                                        boo::IGraphicsDataFactory::Context& ctx)=0; | ||||
|                                                boo::ObjToken<boo::IShaderPipeline>& objOut)=0; | ||||
|     virtual boo::ObjToken<boo::IShaderPipeline> buildShaderFromCache(const ShaderCachedData& data, | ||||
|                                                                      boo::IGraphicsDataFactory::Context& ctx)=0; | ||||
|     virtual ShaderCachedData buildExtendedShaderFromIR(const ShaderTag& tag, | ||||
|                                                        const hecl::Frontend::IR& ir, | ||||
|                                                        hecl::Frontend::Diagnostics& diag, | ||||
| @ -215,7 +215,7 @@ protected: | ||||
|                                               boo::IGraphicsDataFactory::Context& ctx, | ||||
|                                               FReturnExtensionShader returnFunc)=0; | ||||
| public: | ||||
|     virtual ~IShaderBackendFactory() {} | ||||
|     virtual ~IShaderBackendFactory() = default; | ||||
| }; | ||||
| 
 | ||||
| /**
 | ||||
| @ -223,8 +223,7 @@ public: | ||||
|  */ | ||||
| struct ShaderPipelines | ||||
| { | ||||
|     boo::GraphicsDataToken m_token; | ||||
|     std::vector<boo::IShaderPipeline*> m_pipelines; | ||||
|     std::vector<boo::ObjToken<boo::IShaderPipeline>> m_pipelines; | ||||
| }; | ||||
| 
 | ||||
| /**
 | ||||
| @ -256,10 +255,10 @@ class ShaderCacheManager | ||||
|     void bootstrapIndex(); | ||||
|     ShaderCachedData lookupData(const Hash& hash); | ||||
|     bool addData(const ShaderCachedData& data); | ||||
|     boo::IShaderPipeline* buildFromCache(const ShaderCachedData& foundData, | ||||
|                                          boo::IGraphicsDataFactory::Context& ctx); | ||||
|     std::vector<boo::IShaderPipeline*> buildExtendedFromCache(const ShaderCachedData& foundData, | ||||
|                                                               boo::IGraphicsDataFactory::Context& ctx); | ||||
|     boo::ObjToken<boo::IShaderPipeline> buildFromCache(const ShaderCachedData& foundData, | ||||
|                                                        boo::IGraphicsDataFactory::Context& ctx); | ||||
|     std::vector<boo::ObjToken<boo::IShaderPipeline>> buildExtendedFromCache(const ShaderCachedData& foundData, | ||||
|                                                                             boo::IGraphicsDataFactory::Context& ctx); | ||||
| public: | ||||
|     ShaderCacheManager(const FileStoreManager& storeMgr, | ||||
|                        boo::IGraphicsDataFactory* gfxFactory, | ||||
| @ -293,23 +292,26 @@ public: | ||||
|  */ | ||||
| struct HMDLData | ||||
| { | ||||
|     boo::IGraphicsBufferS* m_vbo; | ||||
|     boo::IGraphicsBufferS* m_ibo; | ||||
|     boo::IVertexFormat* m_vtxFmt = nullptr; | ||||
|     boo::ObjToken<boo::IGraphicsBufferS> m_vbo; | ||||
|     boo::ObjToken<boo::IGraphicsBufferS> m_ibo; | ||||
|     boo::ObjToken<boo::IVertexFormat> m_vtxFmt; | ||||
| 
 | ||||
|     HMDLData(boo::IGraphicsDataFactory::Context& ctx, | ||||
|              const void* metaData, const void* vbo, const void* ibo); | ||||
| 
 | ||||
|     /* For binding constructors that require vertex format up front (GLSL) */ | ||||
|     static boo::IVertexFormat* NewVertexFormat(boo::IGraphicsDataFactory::Context& ctx, const HMDLMeta& meta, | ||||
|                                                boo::IGraphicsBuffer* vbo=nullptr, boo::IGraphicsBuffer* ibo=nullptr); | ||||
|     static boo::ObjToken<boo::IVertexFormat> | ||||
|     NewVertexFormat(boo::IGraphicsDataFactory::Context& ctx, const HMDLMeta& meta, | ||||
|                     const boo::ObjToken<boo::IGraphicsBuffer>& vbo={}, | ||||
|                     const boo::ObjToken<boo::IGraphicsBuffer>& ibo={}); | ||||
| 
 | ||||
|     boo::IShaderDataBinding* newShaderDataBindng(boo::IGraphicsDataFactory::Context& ctx, | ||||
|                                                  boo::IShaderPipeline* shader, | ||||
|                                                  size_t ubufCount, boo::IGraphicsBuffer** ubufs, | ||||
|                                                  const boo::PipelineStage* ubufStages, | ||||
|                                                  size_t texCount, boo::ITexture** texs) | ||||
|     {return ctx.newShaderDataBinding(shader, m_vtxFmt, m_vbo, nullptr, m_ibo, | ||||
|     boo::ObjToken<boo::IShaderDataBinding> | ||||
|     newShaderDataBindng(boo::IGraphicsDataFactory::Context& ctx, | ||||
|                         const boo::ObjToken<boo::IShaderPipeline>& shader, | ||||
|                         size_t ubufCount, const boo::ObjToken<boo::IGraphicsBuffer>* ubufs, | ||||
|                         const boo::PipelineStage* ubufStages, | ||||
|                         size_t texCount, const boo::ObjToken<boo::ITexture>* texs) | ||||
|     {return ctx.newShaderDataBinding(shader, m_vtxFmt, m_vbo.get(), nullptr, m_ibo.get(), | ||||
|                                      ubufCount, ubufs, ubufStages, nullptr, nullptr, | ||||
|                                      texCount, texs, nullptr, nullptr);} | ||||
| }; | ||||
|  | ||||
| @ -51,13 +51,13 @@ private: | ||||
|     /** Efficient way to get bucket and block simultaneously */ | ||||
|     DivTp getBucketDiv(IndexTp idx) const { return std::div(idx, m_countPerBucket); } | ||||
| 
 | ||||
|     /** Buffer pool token */ | ||||
|     boo::GraphicsBufferPoolToken m_token; | ||||
|     /** Factory pointer for building additional buffers */ | ||||
|     boo::IGraphicsDataFactory* m_factory = nullptr; | ||||
| 
 | ||||
|     /** Private bucket info */ | ||||
|     struct Bucket | ||||
|     { | ||||
|         boo::IGraphicsBufferD* buffer; | ||||
|         boo::ObjToken<boo::IGraphicsBufferD> buffer; | ||||
|         uint8_t* cpuBuffer = nullptr; | ||||
|         std::atomic_size_t useCount = {}; | ||||
|         bool dirty = false; | ||||
| @ -80,8 +80,8 @@ private: | ||||
|         void increment(UniformBufferPool& pool) | ||||
|         { | ||||
|             if (useCount.fetch_add(1) == 0) | ||||
|                 buffer = pool.m_token.newPoolBuffer(boo::BufferUse::Uniform, | ||||
|                                                     pool.m_stride, pool.m_countPerBucket); | ||||
|                 buffer = pool.m_factory->newPoolBuffer(boo::BufferUse::Uniform, | ||||
|                                                        pool.m_stride, pool.m_countPerBucket); | ||||
|         } | ||||
| 
 | ||||
|         void decrement(UniformBufferPool& pool) | ||||
| @ -93,8 +93,7 @@ private: | ||||
|                     buffer->unmap(); | ||||
|                     cpuBuffer = nullptr; | ||||
|                 } | ||||
|                 pool.m_token.deletePoolBuffer(buffer); | ||||
|                 buffer = nullptr; | ||||
|                 buffer.reset(); | ||||
|             } | ||||
|         } | ||||
|     }; | ||||
| @ -168,7 +167,7 @@ public: | ||||
|             return reinterpret_cast<UniformStruct&>(bucket.cpuBuffer[m_div.rem * m_pool->m_stride]); | ||||
|         } | ||||
| 
 | ||||
|         std::pair<boo::IGraphicsBufferD*, IndexTp> getBufferInfo() const | ||||
|         std::pair<boo::ObjToken<boo::IGraphicsBufferD>, IndexTp> getBufferInfo() const | ||||
|         { | ||||
|             Bucket& bucket = *m_pool->m_buckets[m_div.quot]; | ||||
|             return {bucket.buffer, m_div.rem * m_pool->m_stride}; | ||||
| @ -192,12 +191,15 @@ public: | ||||
|     /** Allocate free block into client-owned Token */ | ||||
|     Token allocateBlock(boo::IGraphicsDataFactory* factory) | ||||
|     { | ||||
|         if (!m_token) | ||||
|             m_token = factory->newBufferPool(); | ||||
|         m_factory = factory; | ||||
|         return Token(this); | ||||
|     } | ||||
| 
 | ||||
|     void doDestroy() { m_token.doDestroy(); } | ||||
|     void doDestroy() | ||||
|     { | ||||
|         for (auto& bucket : m_buckets) | ||||
|             bucket->buffer.reset(); | ||||
|     } | ||||
| }; | ||||
| 
 | ||||
| } | ||||
|  | ||||
| @ -51,13 +51,13 @@ private: | ||||
|     /** Efficient way to get bucket and element simultaneously */ | ||||
|     DivTp getBucketDiv(IndexTp idx) const { return std::div(idx, m_countPerBucket); } | ||||
| 
 | ||||
|     /** Buffer pool token */ | ||||
|     boo::GraphicsBufferPoolToken m_token; | ||||
|     /** Factory pointer for building additional buffers */ | ||||
|     boo::IGraphicsDataFactory* m_factory = nullptr; | ||||
| 
 | ||||
|     /** Private bucket info */ | ||||
|     struct Bucket | ||||
|     { | ||||
|         boo::IGraphicsBufferD* buffer; | ||||
|         boo::ObjToken<boo::IGraphicsBufferD> buffer; | ||||
|         uint8_t* cpuBuffer = nullptr; | ||||
|         std::atomic_size_t useCount = {}; | ||||
|         bool dirty = false; | ||||
| @ -80,8 +80,8 @@ private: | ||||
|         void increment(VertexBufferPool& pool) | ||||
|         { | ||||
|             if (useCount.fetch_add(1) == 0) | ||||
|                 buffer = pool.m_token.newPoolBuffer(boo::BufferUse::Vertex, | ||||
|                                                     pool.m_stride, pool.m_countPerBucket); | ||||
|                 buffer = pool.m_factory->newPoolBuffer(boo::BufferUse::Vertex, | ||||
|                                                        pool.m_stride, pool.m_countPerBucket); | ||||
|         } | ||||
| 
 | ||||
|         void decrement(VertexBufferPool& pool) | ||||
| @ -93,8 +93,7 @@ private: | ||||
|                     buffer->unmap(); | ||||
|                     cpuBuffer = nullptr; | ||||
|                 } | ||||
|                 pool.m_token.deletePoolBuffer(buffer); | ||||
|                 buffer = nullptr; | ||||
|                 buffer.reset(); | ||||
|             } | ||||
|         } | ||||
|     }; | ||||
| @ -170,7 +169,7 @@ public: | ||||
|             return reinterpret_cast<VertStruct*>(&bucket.cpuBuffer[m_div.rem * m_pool->m_stride]); | ||||
|         } | ||||
| 
 | ||||
|         std::pair<boo::IGraphicsBufferD*, IndexTp> getBufferInfo() const | ||||
|         std::pair<boo::ObjToken<boo::IGraphicsBufferD>, IndexTp> getBufferInfo() const | ||||
|         { | ||||
|             Bucket& bucket = *m_pool->m_buckets[m_div.quot]; | ||||
|             return {bucket.buffer, m_div.rem}; | ||||
| @ -194,12 +193,15 @@ public: | ||||
|     /** Allocate free block into client-owned Token */ | ||||
|     Token allocateBlock(boo::IGraphicsDataFactory* factory, IndexTp count) | ||||
|     { | ||||
|         if (!m_token) | ||||
|             m_token = factory->newBufferPool(); | ||||
|         m_factory = factory; | ||||
|         return Token(this, count); | ||||
|     } | ||||
| 
 | ||||
|     void doDestroy() { m_token.doDestroy(); } | ||||
|     void doDestroy() | ||||
|     { | ||||
|         for (auto& bucket : m_buckets) | ||||
|             bucket->buffer.reset(); | ||||
|     } | ||||
| 
 | ||||
|     static constexpr IndexTp bucketCapacity() { return m_countPerBucket; } | ||||
| }; | ||||
|  | ||||
| @ -390,7 +390,7 @@ struct GLSLBackendFactory : IShaderBackendFactory | ||||
|                                        const hecl::Frontend::IR& ir, | ||||
|                                        hecl::Frontend::Diagnostics& diag, | ||||
|                                        boo::IGraphicsDataFactory::Context& ctx, | ||||
|                                        boo::IShaderPipeline*& objOut) | ||||
|                                        boo::ObjToken<boo::IShaderPipeline>& objOut) | ||||
|     { | ||||
|         m_backend.reset(ir, diag); | ||||
|         size_t cachedSz = 3; | ||||
| @ -433,8 +433,8 @@ struct GLSLBackendFactory : IShaderBackendFactory | ||||
|         return dataOut; | ||||
|     } | ||||
| 
 | ||||
|     boo::IShaderPipeline* buildShaderFromCache(const ShaderCachedData& data, | ||||
|                                                boo::IGraphicsDataFactory::Context& ctx) | ||||
|     boo::ObjToken<boo::IShaderPipeline> buildShaderFromCache(const ShaderCachedData& data, | ||||
|                                                              boo::IGraphicsDataFactory::Context& ctx) | ||||
|     { | ||||
|         const ShaderTag& tag = data.m_tag; | ||||
|         athena::io::MemoryReader r(data.m_data.get(), data.m_sz, false, false); | ||||
| @ -450,7 +450,7 @@ struct GLSLBackendFactory : IShaderBackendFactory | ||||
|         if (texMapEnd > 8) | ||||
|             Log.report(logvisor::Fatal, "maximum of 8 texture maps supported"); | ||||
| 
 | ||||
|         boo::IShaderPipeline* ret = | ||||
|         auto ret = | ||||
|         static_cast<boo::GLDataFactory::Context&>(ctx). | ||||
|                 newShaderPipeline(vertSource.c_str(), fragSource.c_str(), | ||||
|                                   texMapEnd, STD_TEXNAMES, | ||||
| @ -520,7 +520,7 @@ struct GLSLBackendFactory : IShaderBackendFactory | ||||
|                 break; | ||||
|             } | ||||
| 
 | ||||
|             boo::IShaderPipeline* ret = | ||||
|             auto ret = | ||||
|             static_cast<boo::GLDataFactory::Context&>(ctx). | ||||
|                     newShaderPipeline(sources.back().first.c_str(), sources.back().second.c_str(), | ||||
|                                       8, STD_TEXNAMES, bc, bn, | ||||
| @ -602,7 +602,7 @@ struct GLSLBackendFactory : IShaderBackendFactory | ||||
|                 break; | ||||
|             } | ||||
| 
 | ||||
|             boo::IShaderPipeline* ret = | ||||
|             auto ret = | ||||
|             static_cast<boo::GLDataFactory::Context&>(ctx). | ||||
|                     newShaderPipeline(vertSource.c_str(), fragSource.c_str(), | ||||
|                                       8, STD_TEXNAMES, bc, bn, | ||||
|  | ||||
| @ -443,7 +443,7 @@ struct MetalBackendFactory : IShaderBackendFactory | ||||
|                                        const hecl::Frontend::IR& ir, | ||||
|                                        hecl::Frontend::Diagnostics& diag, | ||||
|                                        boo::IGraphicsDataFactory::Context& ctx, | ||||
|                                        boo::IShaderPipeline*& objOut) | ||||
|                                        boo::ObjToken<boo::IShaderPipeline>& objOut) | ||||
|     { | ||||
|         if (!m_rtHint) | ||||
|             Log.report(logvisor::Fatal, | ||||
| @ -455,15 +455,17 @@ struct MetalBackendFactory : IShaderBackendFactory | ||||
|         std::string vertSource = | ||||
|         m_backend.makeVert(tag.getColorCount(), tag.getUvCount(), tag.getWeightCount(), | ||||
|                            tag.getSkinSlotCount(), tag.getTexMtxCount(), 0, nullptr, tag.getReflectionType()); | ||||
|         cachedSz += vertSource.size() + 1; | ||||
| 
 | ||||
|         std::string fragSource = m_backend.makeFrag(0, nullptr, | ||||
|             tag.getDepthWrite() && m_backend.m_blendDst == hecl::Backend::BlendFactor::InvSrcAlpha, | ||||
|             tag.getReflectionType()); | ||||
|         cachedSz += fragSource.size() + 1; | ||||
| 
 | ||||
|         std::vector<uint8_t> vertBlob; | ||||
|         std::vector<uint8_t> fragBlob; | ||||
|         objOut = | ||||
|         static_cast<boo::MetalDataFactory::Context&>(ctx). | ||||
|             newShaderPipeline(vertSource.c_str(), fragSource.c_str(), | ||||
|                               &vertBlob, &fragBlob, | ||||
|                               tag.newVertexFormat(ctx), m_rtHint, | ||||
|                               boo::BlendFactor(m_backend.m_blendSrc), | ||||
|                               boo::BlendFactor(m_backend.m_blendDst), | ||||
| @ -473,18 +475,23 @@ struct MetalBackendFactory : IShaderBackendFactory | ||||
|         if (!objOut) | ||||
|             Log.report(logvisor::Fatal, "unable to build shader"); | ||||
| 
 | ||||
|         cachedSz += vertBlob.size() + 4; | ||||
|         cachedSz += fragBlob.size() + 4; | ||||
| 
 | ||||
|         ShaderCachedData dataOut(tag, cachedSz); | ||||
|         athena::io::MemoryWriter w(dataOut.m_data.get(), dataOut.m_sz); | ||||
|         w.writeUByte(atUint8(m_backend.m_blendSrc)); | ||||
|         w.writeUByte(atUint8(m_backend.m_blendDst)); | ||||
|         w.writeString(vertSource); | ||||
|         w.writeString(fragSource); | ||||
|         w.writeUint32Big(vertBlob.size()); | ||||
|         w.writeUBytes(vertBlob.data(), vertBlob.size()); | ||||
|         w.writeUint32Big(fragBlob.size()); | ||||
|         w.writeUBytes(fragBlob.data(), fragBlob.size()); | ||||
| 
 | ||||
|         return dataOut; | ||||
|     } | ||||
| 
 | ||||
|     boo::IShaderPipeline* buildShaderFromCache(const ShaderCachedData& data, | ||||
|                                                boo::IGraphicsDataFactory::Context& ctx) | ||||
|     boo::ObjToken<boo::IShaderPipeline> buildShaderFromCache(const ShaderCachedData& data, | ||||
|                                                              boo::IGraphicsDataFactory::Context& ctx) | ||||
|     { | ||||
|         if (!m_rtHint) | ||||
|             Log.report(logvisor::Fatal, | ||||
| @ -494,15 +501,28 @@ struct MetalBackendFactory : IShaderBackendFactory | ||||
|         athena::io::MemoryReader r(data.m_data.get(), data.m_sz, false, false); | ||||
|         boo::BlendFactor blendSrc = boo::BlendFactor(r.readUByte()); | ||||
|         boo::BlendFactor blendDst = boo::BlendFactor(r.readUByte()); | ||||
|         std::string vertSource = r.readString(); | ||||
|         std::string fragSource = r.readString(); | ||||
|         std::vector<uint8_t> vertBlob; | ||||
|         std::vector<uint8_t> fragBlob; | ||||
|         atUint32 vertLen = r.readUint32Big(); | ||||
|         if (vertLen) | ||||
|         { | ||||
|             vertBlob.resize(vertLen); | ||||
|             r.readUBytesToBuf(&vertBlob[0], vertLen); | ||||
|         } | ||||
|         atUint32 fragLen = r.readUint32Big(); | ||||
|         if (fragLen) | ||||
|         { | ||||
|             fragBlob.resize(fragLen); | ||||
|             r.readUBytesToBuf(&fragBlob[0], fragLen); | ||||
|         } | ||||
| 
 | ||||
|         if (r.hasError()) | ||||
|             return nullptr; | ||||
| 
 | ||||
|         boo::IShaderPipeline* ret = | ||||
|         auto ret = | ||||
|         static_cast<boo::MetalDataFactory::Context&>(ctx). | ||||
|             newShaderPipeline(vertSource.c_str(), fragSource.c_str(), | ||||
|             newShaderPipeline(nullptr, nullptr, | ||||
|                               &vertBlob, &fragBlob, | ||||
|                               tag.newVertexFormat(ctx), m_rtHint, | ||||
|                               blendSrc, blendDst, tag.getPrimType(), | ||||
|                               tag.getDepthTest() ? boo::ZTest::LEqual : boo::ZTest::None, tag.getDepthWrite(), true, true, | ||||
| @ -526,19 +546,19 @@ struct MetalBackendFactory : IShaderBackendFactory | ||||
|         m_backend.reset(ir, diag); | ||||
|         size_t cachedSz = 2; | ||||
| 
 | ||||
|         std::vector<std::pair<std::string, std::string>> sources; | ||||
|         sources.reserve(extensionSlots.size()); | ||||
|         std::vector<std::pair<std::vector<uint8_t>, std::vector<uint8_t>>> blobs; | ||||
|         blobs.reserve(extensionSlots.size()); | ||||
|         for (const ShaderCacheExtensions::ExtensionSlot& slot : extensionSlots) | ||||
|         { | ||||
|             sources.emplace_back(m_backend.makeVert(tag.getColorCount(), tag.getUvCount(), tag.getWeightCount(), | ||||
|                                                     tag.getSkinSlotCount(), tag.getTexMtxCount(), slot.texCount, slot.texs, | ||||
|                                                     slot.noReflection ? Backend::ReflectionType::None : tag.getReflectionType()), | ||||
|                                  m_backend.makeFrag(slot.blockCount, slot.blockNames, | ||||
|                                                     tag.getDepthWrite() && m_backend.m_blendDst == hecl::Backend::BlendFactor::InvSrcAlpha, | ||||
|                                                     slot.noReflection ? Backend::ReflectionType::None : tag.getReflectionType(), | ||||
|                                                     slot.lighting, slot.post, slot.texCount, slot.texs)); | ||||
|             cachedSz += sources.back().first.size() + 1; | ||||
|             cachedSz += sources.back().second.size() + 1; | ||||
|             std::string vertSource = | ||||
|                 m_backend.makeVert(tag.getColorCount(), tag.getUvCount(), tag.getWeightCount(), | ||||
|                                    tag.getSkinSlotCount(), tag.getTexMtxCount(), slot.texCount, slot.texs, | ||||
|                                    slot.noReflection ? Backend::ReflectionType::None : tag.getReflectionType()); | ||||
|             std::string fragSource = | ||||
|                 m_backend.makeFrag(slot.blockCount, slot.blockNames, | ||||
|                                    tag.getDepthWrite() && m_backend.m_blendDst == hecl::Backend::BlendFactor::InvSrcAlpha, | ||||
|                                    slot.noReflection ? Backend::ReflectionType::None : tag.getReflectionType(), | ||||
|                                    slot.lighting, slot.post, slot.texCount, slot.texs); | ||||
| 
 | ||||
|             boo::ZTest zTest; | ||||
|             switch (slot.depthTest) | ||||
| @ -561,9 +581,11 @@ struct MetalBackendFactory : IShaderBackendFactory | ||||
|                 break; | ||||
|             } | ||||
| 
 | ||||
|             boo::IShaderPipeline* ret = | ||||
|             blobs.emplace_back(); | ||||
|             auto ret = | ||||
|             static_cast<boo::MetalDataFactory::Context&>(ctx). | ||||
|                 newShaderPipeline(sources.back().first.c_str(), sources.back().second.c_str(), | ||||
|                 newShaderPipeline(vertSource.c_str(), fragSource.c_str(), | ||||
|                                   &blobs.back().first, &blobs.back().second, | ||||
|                                   tag.newVertexFormat(ctx), m_rtHint, | ||||
|                                   boo::BlendFactor((slot.srcFactor == hecl::Backend::BlendFactor::Original) ? m_backend.m_blendSrc : slot.srcFactor), | ||||
|                                   boo::BlendFactor((slot.dstFactor == hecl::Backend::BlendFactor::Original) ? m_backend.m_blendDst : slot.dstFactor), | ||||
| @ -573,6 +595,9 @@ struct MetalBackendFactory : IShaderBackendFactory | ||||
|                                   (tag.getBackfaceCulling() ? boo::CullMode::Backface : boo::CullMode::None)); | ||||
|             if (!ret) | ||||
|                 Log.report(logvisor::Fatal, "unable to build shader"); | ||||
| 
 | ||||
|             cachedSz += blobs.back().first.size() + 4; | ||||
|             cachedSz += blobs.back().second.size() + 4; | ||||
|             returnFunc(ret); | ||||
|         } | ||||
| 
 | ||||
| @ -580,10 +605,12 @@ struct MetalBackendFactory : IShaderBackendFactory | ||||
|         athena::io::MemoryWriter w(dataOut.m_data.get(), dataOut.m_sz); | ||||
|         w.writeUByte(atUint8(m_backend.m_blendSrc)); | ||||
|         w.writeUByte(atUint8(m_backend.m_blendDst)); | ||||
|         for (auto& src : sources) | ||||
|         for (auto& blob : blobs) | ||||
|         { | ||||
|             w.writeString(src.first); | ||||
|             w.writeString(src.second); | ||||
|             w.writeUint32Big(blob.first.size()); | ||||
|             w.writeUBytes(blob.first.data(), blob.first.size()); | ||||
|             w.writeUint32Big(blob.second.size()); | ||||
|             w.writeUBytes(blob.second.data(), blob.second.size()); | ||||
|         } | ||||
| 
 | ||||
|         return dataOut; | ||||
| @ -608,8 +635,20 @@ struct MetalBackendFactory : IShaderBackendFactory | ||||
| 
 | ||||
|         for (const ShaderCacheExtensions::ExtensionSlot& slot : extensionSlots) | ||||
|         { | ||||
|             std::string vertSource = r.readString(); | ||||
|             std::string fragSource = r.readString(); | ||||
|             std::vector<uint8_t> vertBlob; | ||||
|             std::vector<uint8_t> fragBlob; | ||||
|             atUint32 vertLen = r.readUint32Big(); | ||||
|             if (vertLen) | ||||
|             { | ||||
|                 vertBlob.resize(vertLen); | ||||
|                 r.readUBytesToBuf(&vertBlob[0], vertLen); | ||||
|             } | ||||
|             atUint32 fragLen = r.readUint32Big(); | ||||
|             if (fragLen) | ||||
|             { | ||||
|                 fragBlob.resize(fragLen); | ||||
|                 r.readUBytesToBuf(&fragBlob[0], fragLen); | ||||
|             } | ||||
| 
 | ||||
|             if (r.hasError()) | ||||
|                 return false; | ||||
| @ -635,9 +674,10 @@ struct MetalBackendFactory : IShaderBackendFactory | ||||
|                 break; | ||||
|             } | ||||
| 
 | ||||
|             boo::IShaderPipeline* ret = | ||||
|             auto ret = | ||||
|             static_cast<boo::MetalDataFactory::Context&>(ctx). | ||||
|                 newShaderPipeline(vertSource.c_str(), fragSource.c_str(), | ||||
|                 newShaderPipeline(nullptr, nullptr, | ||||
|                                   &vertBlob, &fragBlob, | ||||
|                                   tag.newVertexFormat(ctx), m_rtHint, | ||||
|                                   boo::BlendFactor((slot.srcFactor == hecl::Backend::BlendFactor::Original) ? blendSrc : slot.srcFactor), | ||||
|                                   boo::BlendFactor((slot.dstFactor == hecl::Backend::BlendFactor::Original) ? blendDst : slot.dstFactor), | ||||
|  | ||||
| @ -419,6 +419,7 @@ BlenderConnection::BlenderConnection(int verbosityLevel) | ||||
|                 int devNull = open("/dev/null", O_WRONLY); | ||||
|                 dup2(devNull, STDOUT_FILENO); | ||||
|                 dup2(devNull, STDERR_FILENO); | ||||
|                 close(devNull); | ||||
|             } | ||||
| 
 | ||||
|             char errbuf[256]; | ||||
|  | ||||
| @ -23,12 +23,14 @@ HMDLData::HMDLData(boo::IGraphicsDataFactory::Context& ctx, | ||||
|     m_ibo = ctx.newStaticBuffer(boo::BufferUse::Index, ibo, 4, meta.indexCount); | ||||
| 
 | ||||
|     if (ctx.bindingNeedsVertexFormat()) | ||||
|         m_vtxFmt = NewVertexFormat(ctx, meta, m_vbo, m_ibo); | ||||
|         m_vtxFmt = NewVertexFormat(ctx, meta, m_vbo.get(), m_ibo.get()); | ||||
| } | ||||
| 
 | ||||
| /* For binding constructors that require vertex format up front (GLSL) */ | ||||
| boo::IVertexFormat* HMDLData::NewVertexFormat(boo::IGraphicsDataFactory::Context& ctx, const HMDLMeta& meta, | ||||
|                                               boo::IGraphicsBuffer* vbo, boo::IGraphicsBuffer* ibo) | ||||
| boo::ObjToken<boo::IVertexFormat> | ||||
| HMDLData::NewVertexFormat(boo::IGraphicsDataFactory::Context& ctx, const HMDLMeta& meta, | ||||
|                           const boo::ObjToken<boo::IGraphicsBuffer>& vbo, | ||||
|                           const boo::ObjToken<boo::IGraphicsBuffer>& ibo) | ||||
| { | ||||
|     size_t elemCount = 2 + meta.colorCount + meta.uvCount + meta.weightCount; | ||||
|     std::unique_ptr<boo::VertexElementDescriptor[]> vdescs(new boo::VertexElementDescriptor[elemCount]); | ||||
| @ -64,7 +66,7 @@ boo::IVertexFormat* HMDLData::NewVertexFormat(boo::IGraphicsDataFactory::Context | ||||
| } | ||||
| 
 | ||||
| /* For shader constructors that require vertex format up-front (HLSL/Metal/Vulkan) */ | ||||
| boo::IVertexFormat* ShaderTag::newVertexFormat(boo::IGraphicsDataFactory::Context& ctx) const | ||||
| boo::ObjToken<boo::IVertexFormat> ShaderTag::newVertexFormat(boo::IGraphicsDataFactory::Context& ctx) const | ||||
| { | ||||
|     size_t elemCount = 2 + m_colorCount + m_uvCount + m_weightCount; | ||||
|     std::unique_ptr<boo::VertexElementDescriptor[]> vdescs(new boo::VertexElementDescriptor[elemCount]); | ||||
|  | ||||
| @ -370,7 +370,7 @@ bool ShaderCacheManager::addData(const ShaderCachedData& data) | ||||
|     return true; | ||||
| } | ||||
| 
 | ||||
| boo::IShaderPipeline* | ||||
| boo::ObjToken<boo::IShaderPipeline> | ||||
| ShaderCacheManager::buildFromCache(const ShaderCachedData& foundData, | ||||
|                                    boo::IGraphicsDataFactory::Context& ctx) | ||||
| { | ||||
| @ -390,10 +390,10 @@ ShaderCacheManager::buildShader(const ShaderTag& tag, const std::string& source, | ||||
|     ShaderCachedData foundData = lookupData(tag); | ||||
|     if (foundData) | ||||
|     { | ||||
|         ret->m_token = factory.commitTransaction([&](boo::IGraphicsDataFactory::Context& ctx) -> bool | ||||
|         factory.commitTransaction([&](boo::IGraphicsDataFactory::Context& ctx) -> bool | ||||
|         { | ||||
|             Log.report(logvisor::Info, "building cached shader '%s' %016llX", diagName.c_str(), tag.val64()); | ||||
|             boo::IShaderPipeline* build = buildFromCache(foundData, ctx); | ||||
|             boo::ObjToken<boo::IShaderPipeline> build = buildFromCache(foundData, ctx); | ||||
|             if (build) | ||||
|             { | ||||
|                 ret->m_pipelines.push_back(build); | ||||
| @ -402,7 +402,7 @@ ShaderCacheManager::buildShader(const ShaderTag& tag, const std::string& source, | ||||
|             return false; | ||||
|         }); | ||||
| 
 | ||||
|         if (ret->m_token) | ||||
|         if (ret->m_pipelines.size()) | ||||
|         { | ||||
|             m_pipelineLookup[tag] = ret; | ||||
|             return ret; | ||||
| @ -410,12 +410,12 @@ ShaderCacheManager::buildShader(const ShaderTag& tag, const std::string& source, | ||||
|         Log.report(logvisor::Warning, "invalid cache read, rebuilding shader '%s'", diagName.c_str()); | ||||
|     } | ||||
| 
 | ||||
|     ret->m_token = factory.commitTransaction([&](boo::IGraphicsDataFactory::Context& ctx) -> bool | ||||
|     factory.commitTransaction([&](boo::IGraphicsDataFactory::Context& ctx) -> bool | ||||
|     { | ||||
|         hecl::Frontend::IR ir = FE.compileSource(source, diagName); | ||||
|         Log.report(logvisor::Info, "building shader '%s' %016llX", diagName.c_str(), tag.val64()); | ||||
|         FE.getDiagnostics().reset(diagName); | ||||
|         boo::IShaderPipeline* build; | ||||
|         boo::ObjToken<boo::IShaderPipeline> build; | ||||
|         addData(m_factory->buildShaderFromIR(tag, ir, FE.getDiagnostics(), ctx, build)); | ||||
|         ret->m_pipelines.push_back(build); | ||||
|         return true; | ||||
| @ -437,10 +437,10 @@ ShaderCacheManager::buildShader(const ShaderTag& tag, const hecl::Frontend::IR& | ||||
|     ShaderCachedData foundData = lookupData(tag); | ||||
|     if (foundData) | ||||
|     { | ||||
|         ret->m_token = factory.commitTransaction([&](boo::IGraphicsDataFactory::Context& ctx) -> bool | ||||
|         factory.commitTransaction([&](boo::IGraphicsDataFactory::Context& ctx) -> bool | ||||
|         { | ||||
|             Log.report(logvisor::Info, "building cached shader '%s' %016llX", diagName.c_str(), tag.val64()); | ||||
|             boo::IShaderPipeline* build = buildFromCache(foundData, ctx); | ||||
|             boo::ObjToken<boo::IShaderPipeline> build = buildFromCache(foundData, ctx); | ||||
|             if (build) | ||||
|             { | ||||
|                 ret->m_pipelines.push_back(build); | ||||
| @ -449,7 +449,7 @@ ShaderCacheManager::buildShader(const ShaderTag& tag, const hecl::Frontend::IR& | ||||
|             return false; | ||||
|         }); | ||||
| 
 | ||||
|         if (ret->m_token) | ||||
|         if (ret->m_pipelines.size()) | ||||
|         { | ||||
|             m_pipelineLookup[tag] = ret; | ||||
|             return ret; | ||||
| @ -457,11 +457,11 @@ ShaderCacheManager::buildShader(const ShaderTag& tag, const hecl::Frontend::IR& | ||||
|         Log.report(logvisor::Warning, "invalid cache read, rebuilding shader '%s'", diagName.c_str()); | ||||
|     } | ||||
| 
 | ||||
|     ret->m_token = factory.commitTransaction([&](boo::IGraphicsDataFactory::Context& ctx) -> bool | ||||
|     factory.commitTransaction([&](boo::IGraphicsDataFactory::Context& ctx) -> bool | ||||
|     { | ||||
|         Log.report(logvisor::Info, "building shader '%s' %016llX", diagName.c_str(), tag.val64()); | ||||
|         FE.getDiagnostics().reset(diagName); | ||||
|         boo::IShaderPipeline* build; | ||||
|         boo::ObjToken<boo::IShaderPipeline> build; | ||||
|         addData(m_factory->buildShaderFromIR(tag, ir, FE.getDiagnostics(), ctx, build)); | ||||
|         ret->m_pipelines.push_back(build); | ||||
|         return true; | ||||
| @ -470,14 +470,14 @@ ShaderCacheManager::buildShader(const ShaderTag& tag, const hecl::Frontend::IR& | ||||
|     return ret; | ||||
| } | ||||
| 
 | ||||
| std::vector<boo::IShaderPipeline*> | ||||
| std::vector<boo::ObjToken<boo::IShaderPipeline>> | ||||
| ShaderCacheManager::buildExtendedFromCache(const ShaderCachedData& foundData, | ||||
|                                            boo::IGraphicsDataFactory::Context& ctx) | ||||
| { | ||||
|     std::vector<boo::IShaderPipeline*> shaders; | ||||
|     std::vector<boo::ObjToken<boo::IShaderPipeline>> shaders; | ||||
|     shaders.reserve(m_extensions.m_extensionSlots.size()); | ||||
|     if (!m_factory->buildExtendedShaderFromCache(foundData, m_extensions.m_extensionSlots, ctx, | ||||
|     [&](boo::IShaderPipeline* shader){shaders.push_back(shader);})) | ||||
|     [&](const boo::ObjToken<boo::IShaderPipeline>& shader){shaders.push_back(shader);})) | ||||
|         return {}; | ||||
|     if (shaders.size() != m_extensions.m_extensionSlots.size()) | ||||
|         Log.report(logvisor::Fatal, "buildShaderFromCache returned %" PRISize " times, expected %" PRISize, | ||||
| @ -498,16 +498,14 @@ ShaderCacheManager::buildExtendedShader(const ShaderTag& tag, const std::string& | ||||
|     ShaderCachedData foundData = lookupData(tag); | ||||
|     if (foundData) | ||||
|     { | ||||
|         ret->m_token = factory.commitTransaction([&](boo::IGraphicsDataFactory::Context& ctx) -> bool | ||||
|         factory.commitTransaction([&](boo::IGraphicsDataFactory::Context& ctx) -> bool | ||||
|         { | ||||
|             Log.report(logvisor::Info, "building cached shader '%s' %016llX", diagName.c_str(), tag.val64()); | ||||
|             ret->m_pipelines = buildExtendedFromCache(foundData, ctx); | ||||
|             if (ret->m_pipelines.size()) | ||||
|                 return true; | ||||
|             return false; | ||||
|             return ret->m_pipelines.size() != 0; | ||||
|         }); | ||||
| 
 | ||||
|         if (ret->m_token) | ||||
|         if (ret->m_pipelines.size()) | ||||
|         { | ||||
|             m_pipelineLookup[tag] = ret; | ||||
|             return ret; | ||||
| @ -517,14 +515,14 @@ ShaderCacheManager::buildExtendedShader(const ShaderTag& tag, const std::string& | ||||
| 
 | ||||
|     hecl::Frontend::IR ir = FE.compileSource(source, diagName); | ||||
| 
 | ||||
|     ret->m_token = factory.commitTransaction([&](boo::IGraphicsDataFactory::Context& ctx) -> bool | ||||
|     factory.commitTransaction([&](boo::IGraphicsDataFactory::Context& ctx) -> bool | ||||
|     { | ||||
|         ret->m_pipelines.reserve(m_extensions.m_extensionSlots.size()); | ||||
|         FE.getDiagnostics().reset(diagName); | ||||
|         Log.report(logvisor::Info, "building shader '%s' %016llX", diagName.c_str(), tag.val64()); | ||||
|         ShaderCachedData data = | ||||
|         m_factory->buildExtendedShaderFromIR(tag, ir, FE.getDiagnostics(), m_extensions.m_extensionSlots, ctx, | ||||
|         [&](boo::IShaderPipeline* shader){ret->m_pipelines.push_back(shader);}); | ||||
|         [&](const boo::ObjToken<boo::IShaderPipeline>& shader){ret->m_pipelines.push_back(shader);}); | ||||
|         if (ret->m_pipelines.size() != m_extensions.m_extensionSlots.size()) | ||||
|             Log.report(logvisor::Fatal, "buildShaderFromIR returned %" PRISize " times, expected %" PRISize, | ||||
|                        ret->m_pipelines.size(), m_extensions.m_extensionSlots.size()); | ||||
| @ -548,16 +546,14 @@ ShaderCacheManager::buildExtendedShader(const ShaderTag& tag, const hecl::Fronte | ||||
|     ShaderCachedData foundData = lookupData(tag); | ||||
|     if (foundData) | ||||
|     { | ||||
|         ret->m_token = factory.commitTransaction([&](boo::IGraphicsDataFactory::Context& ctx) -> bool | ||||
|         factory.commitTransaction([&](boo::IGraphicsDataFactory::Context& ctx) -> bool | ||||
|         { | ||||
|             Log.report(logvisor::Info, "building cached shader '%s' %016llX", diagName.c_str(), tag.val64()); | ||||
|             ret->m_pipelines = buildExtendedFromCache(foundData, ctx); | ||||
|             if (ret->m_pipelines.size()) | ||||
|                 return true; | ||||
|             return false; | ||||
|             return ret->m_pipelines.size() != 0; | ||||
|         }); | ||||
| 
 | ||||
|         if (ret->m_token) | ||||
|         if (ret->m_pipelines.size() != 0) | ||||
|         { | ||||
|             m_pipelineLookup[tag] = ret; | ||||
|             return ret; | ||||
| @ -565,14 +561,14 @@ ShaderCacheManager::buildExtendedShader(const ShaderTag& tag, const hecl::Fronte | ||||
|         Log.report(logvisor::Warning, "invalid cache read, rebuilding shader '%s'", diagName.c_str()); | ||||
|     } | ||||
| 
 | ||||
|     ret->m_token = factory.commitTransaction([&](boo::IGraphicsDataFactory::Context& ctx) -> bool | ||||
|     factory.commitTransaction([&](boo::IGraphicsDataFactory::Context& ctx) -> bool | ||||
|     { | ||||
|         ret->m_pipelines.reserve(m_extensions.m_extensionSlots.size()); | ||||
|         FE.getDiagnostics().reset(diagName); | ||||
|         Log.report(logvisor::Info, "building shader '%s' %016llX", diagName.c_str(), tag.val64()); | ||||
|         ShaderCachedData data = | ||||
|         m_factory->buildExtendedShaderFromIR(tag, ir, FE.getDiagnostics(), m_extensions.m_extensionSlots, ctx, | ||||
|         [&](boo::IShaderPipeline* shader){ret->m_pipelines.push_back(shader);}); | ||||
|         [&](const boo::ObjToken<boo::IShaderPipeline>& shader){ret->m_pipelines.push_back(shader);}); | ||||
|         if (ret->m_pipelines.size() != m_extensions.m_extensionSlots.size()) | ||||
|             Log.report(logvisor::Fatal, "buildShaderFromIR returned %" PRISize " times, expected %" PRISize, | ||||
|                        ret->m_pipelines.size(), m_extensions.m_extensionSlots.size()); | ||||
|  | ||||
| @ -46,9 +46,9 @@ struct HECLApplicationCallback : boo::IApplicationCallback | ||||
|         m_mainWindow = app->newWindow(_S("HECL Test"), 1); | ||||
|         m_mainWindow->setCallback(&m_windowCb); | ||||
| 
 | ||||
|         boo::ITextureR* renderTex = nullptr; | ||||
|         boo::IGraphicsBufferD* vubo = nullptr; | ||||
|         boo::IShaderDataBinding* binding = nullptr; | ||||
|         boo::ObjToken<boo::ITextureR> renderTex; | ||||
|         boo::ObjToken<boo::IGraphicsBuffer> vubo; | ||||
|         boo::ObjToken<boo::IShaderDataBinding> binding; | ||||
| 
 | ||||
|         struct VertexUBO | ||||
|         { | ||||
| @ -94,7 +94,6 @@ struct HECLApplicationCallback : boo::IApplicationCallback | ||||
|             std::shared_ptr<hecl::Runtime::ShaderPipelines> testShaderObj = | ||||
|             shaderMgr.buildShader(testShaderTag, testShader, "testShader", *gfxF); | ||||
| 
 | ||||
|             boo::GraphicsDataToken data = | ||||
|             gfxF->commitTransaction([&](boo::IGraphicsDataFactory::Context& ctx) -> bool | ||||
|             { | ||||
|                 boo::SWindowRect mainWindowRect = m_mainWindow->getWindowFrame(); | ||||
| @ -149,14 +148,14 @@ struct HECLApplicationCallback : boo::IApplicationCallback | ||||
|                         tex[i][j][2] = 0; | ||||
|                         tex[i][j][3] = 0xff; | ||||
|                     } | ||||
|                 boo::ITexture* texture = | ||||
|                 ctx.newStaticTexture(256, 256, 1, boo::TextureFormat::RGBA8, boo::TextureClampMode::Repeat, tex, 256*256*4); | ||||
|                 boo::ObjToken<boo::ITexture> texture = | ||||
|                 ctx.newStaticTexture(256, 256, 1, boo::TextureFormat::RGBA8, boo::TextureClampMode::Repeat, tex, 256*256*4).get(); | ||||
| 
 | ||||
|                 /* Make vertex uniform buffer */ | ||||
|                 vubo = ctx.newDynamicBuffer(boo::BufferUse::Uniform, sizeof(VertexUBO), 1); | ||||
|                 vubo = ctx.newDynamicBuffer(boo::BufferUse::Uniform, sizeof(VertexUBO), 1).get(); | ||||
| 
 | ||||
|                 /* Assemble data binding */ | ||||
|                 binding = testData.newShaderDataBindng(ctx, testShaderObj->m_pipelines[0], 1, (boo::IGraphicsBuffer**)&vubo, nullptr, 1, &texture); | ||||
|                 binding = testData.newShaderDataBindng(ctx, testShaderObj->m_pipelines[0], 1, &vubo, nullptr, 1, &texture); | ||||
|                 return true; | ||||
|             }); | ||||
| 
 | ||||
| @ -209,7 +208,7 @@ struct HECLApplicationCallback : boo::IApplicationCallback | ||||
| 
 | ||||
|             vuboData.modelview[3][0] = sinf(frameIdx / 60.0) * 0.5; | ||||
|             vuboData.modelview[3][1] = cosf(frameIdx / 60.0) * 0.5; | ||||
|             vubo->load(&vuboData, sizeof(vuboData)); | ||||
|             vubo.cast<boo::IGraphicsBufferD>()->load(&vuboData, sizeof(vuboData)); | ||||
| 
 | ||||
|             gfxQ->setShaderDataBinding(binding); | ||||
|             gfxQ->drawIndexed(0, 4); | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user