Equalizer
1.2.1
|
00001 00002 /* Copyright (c) 2007-2010, Stefan Eilemann <eile@equalizergraphics.com> 00003 * 00004 * Redistribution and use in source and binary forms, with or without 00005 * modification, are permitted provided that the following conditions are met: 00006 * 00007 * - Redistributions of source code must retain the above copyright notice, this 00008 * list of conditions and the following disclaimer. 00009 * - Redistributions in binary form must reproduce the above copyright notice, 00010 * this list of conditions and the following disclaimer in the documentation 00011 * and/or other materials provided with the distribution. 00012 * - Neither the name of Eyescale Software GmbH nor the names of its 00013 * contributors may be used to endorse or promote products derived from this 00014 * software without specific prior written permission. 00015 * 00016 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 00017 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00018 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00019 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE 00020 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 00021 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 00022 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 00023 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 00024 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 00025 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 00026 * POSSIBILITY OF SUCH DAMAGE. 00027 */ 00028 00029 #include "configEvent.h" 00030 00031 namespace eqPixelBench 00032 { 00033 std::ostream& operator << ( std::ostream& os, const ConfigEvent* event ) 00034 { 00035 switch( event->data.type ) 00036 { 00037 case ConfigEvent::READBACK: 00038 os << "readback"; 00039 break; 00040 00041 case ConfigEvent::ASSEMBLE: 00042 os << "assemble"; 00043 break; 00044 case ConfigEvent::START_LATENCY: 00045 os << " "; 00046 break; 00047 default: 00048 os << static_cast< const eq::ConfigEvent* >( event ); 00049 return os; 00050 } 00051 00052 00053 os << " \"" << event->data.user.data << "\" " << event->formatType 00054 << std::string( 32-strlen( event->formatType ), ' ' ) << event->area.x() 00055 << "x" << event->area.y() << ": "; 00056 00057 if( event->msec < 0.0f ) 00058 os << "error 0x" << std::hex << static_cast< int >( -event->msec ) 00059 << std::dec; 00060 else 00061 os << static_cast< uint32_t >( event->area.x() * event->area.y() / 00062 event->msec / 1048.576f ) 00063 << "MPix/sec (" << event->msec << "ms, " << 00064 unsigned(1000.0f / event->msec) << "FPS)"; 00065 00066 #if 0 00067 if ( event->data.type == ConfigEvent::READBACK ) 00068 { 00069 os << event->area << "( size GPU : " << event->dataSizeGPU << " bytes "; 00070 os << "/ size CPU : " << event->dataSizeCPU << " bytes "; 00071 os << "/ time : " << event->msec << "ms )"; 00072 } 00073 else if ( event->data.type == ConfigEvent::ASSEMBLE ) 00074 { 00075 os << event->area << "( size CPU : " << event->dataSizeCPU << " bytes "; 00076 os << "/ time : " << event->msec << "ms )"; 00077 } 00078 #endif 00079 return os; 00080 } 00081 }