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 &section);
93};
94
95#endif // __DEV_PKTFIFO_HH__
96