summaryrefslogtreecommitdiff
path: root/src/mem/slicc/ast/OutPortDeclAST.py
diff options
context:
space:
mode:
Diffstat (limited to 'src/mem/slicc/ast/OutPortDeclAST.py')
-rw-r--r--src/mem/slicc/ast/OutPortDeclAST.py5
1 files changed, 5 insertions, 0 deletions
diff --git a/src/mem/slicc/ast/OutPortDeclAST.py b/src/mem/slicc/ast/OutPortDeclAST.py
index e6ef31928..a387f6d91 100644
--- a/src/mem/slicc/ast/OutPortDeclAST.py
+++ b/src/mem/slicc/ast/OutPortDeclAST.py
@@ -30,6 +30,7 @@ from m5.util import code_formatter
from slicc.ast.DeclAST import DeclAST
from slicc.ast.TypeAST import TypeAST
from slicc.symbols import Var
+from slicc.symbols import Type
class OutPortDeclAST(DeclAST):
def __init__(self, slicc, ident, msg_type, var_expr, pairs):
@@ -52,6 +53,10 @@ class OutPortDeclAST(DeclAST):
"attribute. Type '%s' does not have this attribute.",
(queue_type))
+ if not self.symtab.find(self.msg_type.ident, Type):
+ self.error("The message type '%s' does not exist.",
+ self.msg_type.ident)
+
var = Var(self.symtab, self.ident, self.location, self.queue_type.type,
str(code), self.pairs)
self.symtab.newSymbol(var)