1 # Copyright (c) 2008 The Hewlett-Packard Development Company
4 # Redistribution and use in source and binary forms, with or without
5 # modification, are permitted provided that the following conditions are
6 # met: redistributions of source code must retain the above copyright
7 # notice, this list of conditions and the following disclaimer;
8 # redistributions in binary form must reproduce the above copyright
9 # notice, this list of conditions and the following disclaimer in the
10 # documentation and/or other materials provided with the distribution;
11 # neither the name of the copyright holders nor the names of its
12 # contributors may be used to endorse or promote products derived from
13 # this software without specific prior written permission.
15 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16 # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17 # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
18 # A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
19 # OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
20 # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
21 # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22 # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23 # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
25 # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 # Authors: Nathan Binkert
29 from __future__
import print_function
31 from UserDict
import DictMixin
34 from _m5
.debug
import SimpleFlag
, CompoundFlag
35 from _m5
.debug
import schedBreak
, setRemoteGDBPort
36 from m5
.util
import printList
40 for name
in sorted(flags
):
44 children
= [c
for c
in flag
.kids() ]
46 print(" %s: %s" % (name
, flag
.desc()))
48 print("Compound Flags:")
49 for name
in sorted(flags
):
53 children
= [c
for c
in flag
.kids() ]
55 print(" %s: %s" % (name
, flag
.desc()))
56 printList([ c
.name() for c
in children
], indent
=8)
59 class AllFlags(DictMixin
):
65 current_version
= _m5
.debug
.getAllFlagsVersion()
66 if self
._version
== current_version
:
70 for name
, flag
in _m5
.debug
.allFlags().items():
71 self
._dict
[name
] = flag
72 self
._version
= current_version
74 def __contains__(self
, item
):
76 return item
in self
._dict
78 def __getitem__(self
, item
):
80 return self
._dict
[item
]
84 return self
._dict
.keys()
88 return self
._dict
.values()
92 return self
._dict
.items()
96 return self
._dict
.iterkeys()
100 return self
._dict
.itervalues()
104 return self
._dict
.iteritems()