pktfifo.hh revision 1154
111515Sandreas.sandberg@arm.com/* 211515Sandreas.sandberg@arm.com * Copyright (c) 2002-2004 The Regents of The University of Michigan 38721SN/A * All rights reserved. 48721SN/A * 57513SN/A * Redistribution and use in source and binary forms, with or without 611960Sgabeblack@google.com * modification, are permitted provided that the following conditions are 711960Sgabeblack@google.com * met: redistributions of source code must retain the above copyright 811960Sgabeblack@google.com * notice, this list of conditions and the following disclaimer; 911960Sgabeblack@google.com * redistributions in binary form must reproduce the above copyright 1011219Snilay@cs.wisc.edu * notice, this list of conditions and the following disclaimer in the 1111570SCurtis.Dunham@arm.com * documentation and/or other materials provided with the distribution; 1211570SCurtis.Dunham@arm.com * neither the name of the copyright holders nor the names of its 137513SN/A * contributors may be used to endorse or promote products derived from 147513SN/A * this software without specific prior written permission. 157513SN/A * 167513SN/A * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 177513SN/A * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 187513SN/A * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 197513SN/A * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 207513SN/A * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 217513SN/A * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 227513SN/A * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 237513SN/A * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 247513SN/A * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 257513SN/A * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 267513SN/A * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 2711960Sgabeblack@google.com */ 28 29#ifndef __DEV_PKTFIFO_HH__ 30#define __DEV_PKTFIFO_HH__ 31 32#include <iosfwd> 33#include <list> 34#include <string> 35 36#include "dev/etherpkt.hh" 37#include "sim/serialize.hh" 38 39class Checkpoint; 40class PacketFifo 41{ 42 protected: 43 std::list<PacketPtr> fifo; 44 int _maxsize; 45 int _size; 46 47 public: 48 explicit PacketFifo(int max) : _maxsize(max), _size(0) {} 49 virtual ~PacketFifo() {} 50 51 int maxsize() const { return _maxsize; } 52 int packets() const { return fifo.size(); } 53 int size() const { return _size; } 54 int avail() const { return _maxsize - _size; } 55 bool empty() const { return _size == 0; } 56 bool full() const { return _size >= _maxsize; } 57 58 bool push(PacketPtr ptr) 59 { 60 if (avail() < ptr->length) 61 return false; 62 63 _size += ptr->length; 64 fifo.push_back(ptr); 65 return true; 66 } 67 68 PacketPtr front() { return fifo.front(); } 69 70 void pop() 71 { 72 if (empty()) 73 return; 74 75 _size -= fifo.front()->length; 76 fifo.front() = NULL; 77 fifo.pop_front(); 78 } 79 80 void clear() 81 { 82 fifo.clear(); 83 _size = 0; 84 } 85 86/** 87 * Serialization stuff 88 */ 89 public: 90 void serialize(const std::string &base, std::ostream &os); 91 void unserialize(const std::string &base, 92 Checkpoint *cp, const std::string §ion); 93}; 94 95#endif // __DEV_PKTFIFO_HH__ 96