etherdevice.hh revision 5999
113820Sgabeblack@google.com/*
213820Sgabeblack@google.com * Copyright (c) 2007 The Regents of The University of Michigan
313820Sgabeblack@google.com * All rights reserved.
413820Sgabeblack@google.com *
513820Sgabeblack@google.com * Redistribution and use in source and binary forms, with or without
613820Sgabeblack@google.com * modification, are permitted provided that the following conditions are
713820Sgabeblack@google.com * met: redistributions of source code must retain the above copyright
813820Sgabeblack@google.com * notice, this list of conditions and the following disclaimer;
913820Sgabeblack@google.com * redistributions in binary form must reproduce the above copyright
1013820Sgabeblack@google.com * notice, this list of conditions and the following disclaimer in the
1113820Sgabeblack@google.com * documentation and/or other materials provided with the distribution;
1213820Sgabeblack@google.com * neither the name of the copyright holders nor the names of its
1313820Sgabeblack@google.com * contributors may be used to endorse or promote products derived from
1413820Sgabeblack@google.com * this software without specific prior written permission.
1513820Sgabeblack@google.com *
1613820Sgabeblack@google.com * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
1713820Sgabeblack@google.com * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
1813820Sgabeblack@google.com * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
1913820Sgabeblack@google.com * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
2013820Sgabeblack@google.com * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
2113820Sgabeblack@google.com * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
2213820Sgabeblack@google.com * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
2313820Sgabeblack@google.com * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
2413820Sgabeblack@google.com * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
2513820Sgabeblack@google.com * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
2613820Sgabeblack@google.com * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
2713820Sgabeblack@google.com *
2813820Sgabeblack@google.com * Authors: Ali Saidi
2913820Sgabeblack@google.com */
3013820Sgabeblack@google.com
3113820Sgabeblack@google.com/**
3213820Sgabeblack@google.com * @file
3313820Sgabeblack@google.com * Base Ethernet Device declaration.
3413820Sgabeblack@google.com */
3513820Sgabeblack@google.com
3613820Sgabeblack@google.com#ifndef __DEV_ETHERDEVICE_HH__
3713820Sgabeblack@google.com#define __DEV_ETHERDEVICE_HH__
3813820Sgabeblack@google.com
3913820Sgabeblack@google.com#include "base/statistics.hh"
4013820Sgabeblack@google.com#include "dev/pcidev.hh"
4113820Sgabeblack@google.com#include "params/EtherDevice.hh"
4213820Sgabeblack@google.com#include "sim/sim_object.hh"
4313820Sgabeblack@google.com
4413820Sgabeblack@google.comclass EtherInt;
4513820Sgabeblack@google.com
4613820Sgabeblack@google.com/**
4713820Sgabeblack@google.com * The base EtherObject class, allows for an accesor function to a
4813820Sgabeblack@google.com * simobj that returns the Port.
4913820Sgabeblack@google.com */
5013820Sgabeblack@google.comclass EtherDevice : public PciDev
5113820Sgabeblack@google.com{
5213820Sgabeblack@google.com  public:
5313820Sgabeblack@google.com    typedef EtherDeviceParams Params;
5413820Sgabeblack@google.com    EtherDevice(const Params *params)
5513820Sgabeblack@google.com        : PciDev(params)
5613820Sgabeblack@google.com    {}
5713820Sgabeblack@google.com
5813820Sgabeblack@google.com    const Params *
5913820Sgabeblack@google.com    params() const
6013820Sgabeblack@google.com    {
6113820Sgabeblack@google.com        return dynamic_cast<const Params *>(_params);
6213820Sgabeblack@google.com    }
6313820Sgabeblack@google.com
6413820Sgabeblack@google.com  public:
6513820Sgabeblack@google.com    /** Additional function to return the Port of a memory object. */
6613820Sgabeblack@google.com    virtual EtherInt *getEthPort(const std::string &if_name, int idx = -1) = 0;
6713820Sgabeblack@google.com
6813820Sgabeblack@google.com  public:
6913820Sgabeblack@google.com    void regStats();
7013820Sgabeblack@google.com
7113820Sgabeblack@google.com  protected:
7213820Sgabeblack@google.com    Stats::Scalar txBytes;
73    Stats::Scalar rxBytes;
74    Stats::Scalar txPackets;
75    Stats::Scalar rxPackets;
76    Stats::Scalar txIpChecksums;
77    Stats::Scalar rxIpChecksums;
78    Stats::Scalar txTcpChecksums;
79    Stats::Scalar rxTcpChecksums;
80    Stats::Scalar txUdpChecksums;
81    Stats::Scalar rxUdpChecksums;
82    Stats::Scalar descDmaReads;
83    Stats::Scalar descDmaWrites;
84    Stats::Scalar descDmaRdBytes;
85    Stats::Scalar descDmaWrBytes;
86    Stats::Formula totBandwidth;
87    Stats::Formula totPackets;
88    Stats::Formula totBytes;
89    Stats::Formula totPacketRate;
90    Stats::Formula txBandwidth;
91    Stats::Formula rxBandwidth;
92    Stats::Formula txPacketRate;
93    Stats::Formula rxPacketRate;
94    Stats::Scalar postedSwi;
95    Stats::Formula coalescedSwi;
96    Stats::Scalar totalSwi;
97    Stats::Scalar postedRxIdle;
98    Stats::Formula coalescedRxIdle;
99    Stats::Scalar totalRxIdle;
100    Stats::Scalar postedRxOk;
101    Stats::Formula coalescedRxOk;
102    Stats::Scalar totalRxOk;
103    Stats::Scalar postedRxDesc;
104    Stats::Formula coalescedRxDesc;
105    Stats::Scalar totalRxDesc;
106    Stats::Scalar postedTxOk;
107    Stats::Formula coalescedTxOk;
108    Stats::Scalar totalTxOk;
109    Stats::Scalar postedTxIdle;
110    Stats::Formula coalescedTxIdle;
111    Stats::Scalar totalTxIdle;
112    Stats::Scalar postedTxDesc;
113    Stats::Formula coalescedTxDesc;
114    Stats::Scalar totalTxDesc;
115    Stats::Scalar postedRxOrn;
116    Stats::Formula coalescedRxOrn;
117    Stats::Scalar totalRxOrn;
118    Stats::Formula coalescedTotal;
119    Stats::Scalar postedInterrupts;
120    Stats::Scalar droppedPackets;
121};
122
123#endif //__DEV_ETHERDEVICE_HH__
124