diff --git a/src/base/stl_helpers.hh b/src/base/stl_helpers.hh new file mode 100644 index 000000000..740bd1b48 --- /dev/null +++ b/src/base/stl_helpers.hh @@ -0,0 +1,97 @@ +/* + * Copyright (c) 2010 The Hewlett-Packard Development Company + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are + * met: redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer; + * redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution; + * neither the name of the copyright holders nor the names of its + * contributors may be used to endorse or promote products derived from + * this software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR + * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT + * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT + * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + * + * Authors: Nathan Binkert + */ + +#ifndef __BASE_STL_HELPERS_HH__ +#define __BASE_STL_HELPERS_HH__ + +#include +#include + +namespace m5 { +namespace stl_helpers { + +template +void +deletePointer(T &ptr) +{ + delete ptr; + ptr = NULL; +} + +template +class ContainerPrint +{ + private: + std::ostream &out; + bool first; + + public: + ContainerPrint(std::ostream &out) + : out(out), first(true) + {} + + void + operator()(const T &elem) + { + out << elem; + // First one doesn't get a space before it. The rest do. + if (first) + first = false; + else + out << " "; + } +}; + +// Treat all objects in an stl container as pointers to heap objects, +// calling delete on each one and zeroing the pointers along the way +template class C, typename A> +void +deletePointers(C &container) +{ + std::for_each(container.begin(), container.end(), deletePointer); +} + +// Write out all elements in an stl container as a space separated +// list enclosed in square brackets +template class C, typename A> +std::ostream & +operator<<(std::ostream& out, const C &vec) +{ + out << "[ "; + std::for_each(vec.begin(), vec.end(), ContainerPrint(out)); + out << " ]"; + out << std::flush; + return out; +} + +/* namespace stl_helpers */ } +/* namespace m5 */ } + +#endif // __BASE_STL_HELPERS_HH__ diff --git a/src/cpu/rubytest/CheckTable.cc b/src/cpu/rubytest/CheckTable.cc index 3b94de315..7588007c9 100644 --- a/src/cpu/rubytest/CheckTable.cc +++ b/src/cpu/rubytest/CheckTable.cc @@ -102,7 +102,7 @@ CheckTable::addCheck(const Address& address) // Insert it once per byte m_lookup_map_ptr->add(Address(address.getAddress() + i), check_ptr); } - m_check_vector.insertAtBottom(check_ptr); + m_check_vector.push_back(check_ptr); } Check* diff --git a/src/cpu/rubytest/CheckTable.hh b/src/cpu/rubytest/CheckTable.hh index a22fa7f73..117fb1276 100644 --- a/src/cpu/rubytest/CheckTable.hh +++ b/src/cpu/rubytest/CheckTable.hh @@ -31,8 +31,8 @@ #define __CPU_RUBYTEST_CHECKTABLE_HH__ #include +#include -#include "mem/gems_common/Vector.hh" #include "mem/ruby/common/Global.hh" class Address; @@ -63,7 +63,7 @@ class CheckTable CheckTable(const CheckTable& obj); CheckTable& operator=(const CheckTable& obj); - Vector m_check_vector; + std::vector m_check_vector; Map* m_lookup_map_ptr; int m_num_cpu_sequencers; diff --git a/src/cpu/rubytest/RubyTester.cc b/src/cpu/rubytest/RubyTester.cc index 3ad977b42..036e511bc 100644 --- a/src/cpu/rubytest/RubyTester.cc +++ b/src/cpu/rubytest/RubyTester.cc @@ -59,7 +59,7 @@ RubyTester::init() { assert(ports.size() > 0); - m_last_progress_vector.setSize(ports.size()); + m_last_progress_vector.resize(ports.size()); for (int i = 0; i < m_last_progress_vector.size(); i++) { m_last_progress_vector[i] = 0; } diff --git a/src/cpu/rubytest/RubyTester.hh b/src/cpu/rubytest/RubyTester.hh index 634e61f88..2726a50d6 100644 --- a/src/cpu/rubytest/RubyTester.hh +++ b/src/cpu/rubytest/RubyTester.hh @@ -31,6 +31,7 @@ #define __CPU_RUBYTEST_RUBYTESTER_HH__ #include +#include #include #include "cpu/rubytest/CheckTable.hh" @@ -126,7 +127,7 @@ class RubyTester : public MemObject RubyTester& operator=(const RubyTester& obj); CheckTable* m_checkTable_ptr; - Vector