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 28namespace vk 29{ 30 31tcu::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 44tcu::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