00001 /*******************************************************************\ 00002 00003 SESAME project software license 00004 00005 Copyright (C) 2002, 2003 University of Amsterdam 00006 00007 This program is free software; you can redistribute it and/or 00008 modify it under the terms of the GNU General Public License 00009 as published by the Free Software Foundation; either version 2 00010 of the License, or (at your option) any later version. 00011 00012 This program is distributed in the hope that it will be useful, 00013 but WITHOUT ANY WARRANTY; without even the implied warranty of 00014 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00015 GNU General Public License for more details. 00016 00017 You should have received a copy of the GNU General Public License 00018 along with this program; if not, write to the Free Software 00019 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 00020 02111-1307, USA. 00021 00022 For information regarding the SESAME software project see 00023 http://sesamesim.sourceforge.net or email 00024 jcofflan@users.sourceforge.net 00025 00026 \*******************************************************************/ 00027 00038 #ifndef TRACECHANNEL_H 00039 #define TRACECHANNEL_H 00040 00041 #include "tracedefs.h" 00042 00043 class TraceChannel { 00044 public: 00045 00052 virtual int getId() = 0; 00053 00061 virtual int getPortId(const char *name) = 0; 00062 00071 virtual int getInstructionId(const char *name) = 0; 00072 00073 00080 virtual void send(trace_event_t &event) = 0; 00081 00088 virtual trace_event_t next() = 0; 00089 00090 00095 virtual void sendQuit(); 00096 00097 00104 virtual void sendExec(int operId); 00105 00113 virtual void sendRead(int portId, int size, int commChannelId); 00114 00122 virtual void sendWrite(int portId, int size, int commChannelId); 00123 }; 00124 #endif