MachineAST.py revision 7542:49327b849c7f
16112SN/A# Copyright (c) 1999-2008 Mark D. Hill and David A. Wood
211570SCurtis.Dunham@arm.com# Copyright (c) 2009 The Hewlett-Packard Development Company
311570SCurtis.Dunham@arm.com# All rights reserved.
411570SCurtis.Dunham@arm.com#
511570SCurtis.Dunham@arm.com# Redistribution and use in source and binary forms, with or without
611960Sgabeblack@google.com# modification, are permitted provided that the following conditions are
711570SCurtis.Dunham@arm.com# met: redistributions of source code must retain the above copyright
8# notice, this list of conditions and the following disclaimer;
9# redistributions in binary form must reproduce the above copyright
10# notice, this list of conditions and the following disclaimer in the
11# documentation and/or other materials provided with the distribution;
12# neither the name of the copyright holders nor the names of its
13# contributors may be used to endorse or promote products derived from
14# this software without specific prior written permission.
15#
16# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
19# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
20# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
28from slicc.ast.DeclAST import DeclAST
29from slicc.symbols import StateMachine, Type
30
31class MachineAST(DeclAST):
32    def __init__(self, slicc, ident, pairs_ast, config_parameters, decls):
33        super(MachineAST, self).__init__(slicc, pairs_ast)
34
35        self.ident = ident
36        self.pairs_ast = pairs_ast
37        self.config_parameters = config_parameters
38        self.decls = decls
39
40    def __repr__(self):
41        return "[Machine: %r]" % self.ident
42
43    def files(self, parent=None):
44        s = set(('%s_Controller.cc' % self.ident,
45                 '%s_Controller.hh' % self.ident,
46                 '%s_Controller.py' % self.ident,
47                 '%s_Profiler.cc' % self.ident,
48                 '%s_Profiler.hh' % self.ident,
49                 '%s_ProfileDumper.cc' % self.ident,
50                 '%s_ProfileDumper.hh' % self.ident,
51                 '%s_Transitions.cc' % self.ident,
52                 '%s_Wakeup.cc' % self.ident))
53
54        s |= self.decls.files(self.ident)
55        return s
56
57    def generate(self):
58        # Make a new frame
59        self.symtab.pushFrame()
60
61        # Create a new machine
62        machine = StateMachine(self.symtab, self.ident, self.location,
63                               self.pairs, self.config_parameters)
64
65        self.symtab.newCurrentMachine(machine)
66
67        # Generate code for all the internal decls
68        self.decls.generate()
69
70        # Build the transition table
71        machine.buildTable()
72
73        # Pop the frame
74        self.symtab.popFrame()
75
76    def findMachines(self):
77        # Add to MachineType enumeration
78        machine_type = self.symtab.find("MachineType", Type)
79        if not machine_type.enumAdd(self.ident, self.pairs_ast.pairs):
80            self.error("Duplicate machine name: %s:%s" % (machine_type,
81                                                          self.ident))
82
83        # Generate code for all the internal decls
84        self.decls.findMachines()
85