1 /*------------------------------------------------------------------------- 2 * Vulkan CTS Framework 3 * -------------------- 4 * 5 * Copyright (c) 2015 Google Inc. 6 * 7 * Licensed under the Apache License, Version 2.0 (the "License"); 8 * you may not use this file except in compliance with the License. 9 * You may obtain a copy of the License at 10 * 11 * http://www.apache.org/licenses/LICENSE-2.0 12 * 13 * Unless required by applicable law or agreed to in writing, software 14 * distributed under the License is distributed on an "AS IS" BASIS, 15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 16 * See the License for the specific language governing permissions and 17 * limitations under the License. 18 * 19 *//*! 20 * \file 21 * \brief Spirv program and binary info. 22 *//*--------------------------------------------------------------------*/ 23 24 #include "vkSpirVProgram.hpp" 25 26 #include "tcuTestLog.hpp" 27 28 namespace vk 29 { 30 31 tcu::TestLog& operator<< (tcu::TestLog& log, const SpirVProgramInfo& shaderInfo) 32 { 33 log << tcu::TestLog::ShaderProgram(shaderInfo.compileOk , shaderInfo.infoLog) 34 << tcu::TestLog::SpirVAssemblySource(shaderInfo.source) 35 << tcu::TestLog::EndShaderProgram; 36 37 // Write statistics 38 log << tcu::TestLog::Float( "SpirVAssemblyTime", 39 "SpirV assembly time", 40 "ms", QP_KEY_TAG_TIME, (float)shaderInfo.compileTimeUs / 1000.0f); 41 return log; 42 } 43 44 tcu::TestLog& operator<< (tcu::TestLog& log, const SpirVAsmSource& source) 45 { 46 log << tcu::TestLog::ShaderProgram(true , "") 47 << tcu::TestLog::SpirVAssemblySource(source.source) 48 << tcu::TestLog::EndShaderProgram; 49 50 return log; 51 } 52 53 } // vk 54