CheckTable.hh revision 7454
112854Sgabeblack@google.com/*
212854Sgabeblack@google.com * Copyright (c) 1999-2008 Mark D. Hill and David A. Wood
312854Sgabeblack@google.com * Copyright (c) 2009 Advanced Micro Devices, Inc.
412854Sgabeblack@google.com * All rights reserved.
512854Sgabeblack@google.com *
612854Sgabeblack@google.com * Redistribution and use in source and binary forms, with or without
712854Sgabeblack@google.com * modification, are permitted provided that the following conditions are
812854Sgabeblack@google.com * met: redistributions of source code must retain the above copyright
912854Sgabeblack@google.com * notice, this list of conditions and the following disclaimer;
1012854Sgabeblack@google.com * redistributions in binary form must reproduce the above copyright
1112854Sgabeblack@google.com * notice, this list of conditions and the following disclaimer in the
1212854Sgabeblack@google.com * documentation and/or other materials provided with the distribution;
1312854Sgabeblack@google.com * neither the name of the copyright holders nor the names of its
1412854Sgabeblack@google.com * contributors may be used to endorse or promote products derived from
1512854Sgabeblack@google.com * this software without specific prior written permission.
1612854Sgabeblack@google.com *
1712854Sgabeblack@google.com * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
1812854Sgabeblack@google.com * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
1912854Sgabeblack@google.com * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
2012854Sgabeblack@google.com * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
2112854Sgabeblack@google.com * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
2212854Sgabeblack@google.com * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
2312854Sgabeblack@google.com * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
2412854Sgabeblack@google.com * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
2512854Sgabeblack@google.com * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
2612854Sgabeblack@google.com * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
2712854Sgabeblack@google.com * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
2812854Sgabeblack@google.com */
2912854Sgabeblack@google.com
3012854Sgabeblack@google.com#ifndef __CPU_RUBYTEST_CHECKTABLE_HH__
3112854Sgabeblack@google.com#define __CPU_RUBYTEST_CHECKTABLE_HH__
3212854Sgabeblack@google.com
3312854Sgabeblack@google.com#include <iostream>
3412854Sgabeblack@google.com#include <vector>
3512854Sgabeblack@google.com
3612854Sgabeblack@google.com#include "mem/ruby/common/Global.hh"
3712854Sgabeblack@google.com
3812854Sgabeblack@google.comclass Address;
3912854Sgabeblack@google.comclass Check;
4012854Sgabeblack@google.comclass RubyTester;
4112854Sgabeblack@google.comtemplate <class KEY_TYPE, class VALUE_TYPE> class Map;
4212854Sgabeblack@google.com
4312854Sgabeblack@google.comclass CheckTable
4412854Sgabeblack@google.com{
4512854Sgabeblack@google.com  public:
4612854Sgabeblack@google.com    CheckTable(int _num_cpu_sequencers, RubyTester* _tester);
4712854Sgabeblack@google.com    ~CheckTable();
4812854Sgabeblack@google.com
4912854Sgabeblack@google.com    Check* getRandomCheck();
5012854Sgabeblack@google.com    Check* getCheck(const Address& address);
5112854Sgabeblack@google.com
5212854Sgabeblack@google.com    //  bool isPresent(const Address& address) const;
5312854Sgabeblack@google.com    //  void removeCheckFromTable(const Address& address);
5412854Sgabeblack@google.com    //  bool isTableFull() const;
5512854Sgabeblack@google.com    // Need a method to select a check or retrieve a check
5612854Sgabeblack@google.com
5712854Sgabeblack@google.com    void print(std::ostream& out) const;
5812854Sgabeblack@google.com
5912854Sgabeblack@google.com  private:
6012854Sgabeblack@google.com    void addCheck(const Address& address);
6112854Sgabeblack@google.com
6212854Sgabeblack@google.com    // Private copy constructor and assignment operator
6312854Sgabeblack@google.com    CheckTable(const CheckTable& obj);
6412854Sgabeblack@google.com    CheckTable& operator=(const CheckTable& obj);
6512854Sgabeblack@google.com
6612854Sgabeblack@google.com    std::vector<Check*> m_check_vector;
6712854Sgabeblack@google.com    Map<Address, Check*>* m_lookup_map_ptr;
6812854Sgabeblack@google.com
6912854Sgabeblack@google.com    int m_num_cpu_sequencers;
7012854Sgabeblack@google.com    RubyTester* m_tester_ptr;
7112854Sgabeblack@google.com};
7212854Sgabeblack@google.com
7312854Sgabeblack@google.cominline std::ostream&
7412854Sgabeblack@google.comoperator<<(std::ostream& out, const CheckTable& obj)
7512854Sgabeblack@google.com{
7612854Sgabeblack@google.com    obj.print(out);
7712854Sgabeblack@google.com    out << std::flush;
7812854Sgabeblack@google.com    return out;
7912854Sgabeblack@google.com}
8012854Sgabeblack@google.com
8112854Sgabeblack@google.com#endif // __CPU_RUBYTEST_CHECKTABLE_HH__
8212854Sgabeblack@google.com