[PATCH 03/12] userspace-header-gen: Special case for Yacc / Lex.

Christian Mauderer christian.mauderer at embedded-brains.de
Wed Aug 1 08:04:45 UTC 2018


Some variables generated by Yacc / Lex need a special treatment. That
had been done by manual editing of the generated headers in the past.
This patch integrate these changes into the generator.
---
 userspace-header-gen.py | 32 +++++++++++++++++++++++++++++++-
 1 file changed, 31 insertions(+), 1 deletion(-)

diff --git a/userspace-header-gen.py b/userspace-header-gen.py
index cd50c1ef..f41feb4a 100755
--- a/userspace-header-gen.py
+++ b/userspace-header-gen.py
@@ -81,6 +81,25 @@ class HeaderGenCU:
         self._rtems_port_names.append("_Linker_set_bsd_prog_%s_end" % progname)
         self._rtems_port_names.append("rtems_bsd_command_%s" % progname)
 
+        self._filter_special_vars = []
+        # Take some special care for some yacc variables. This matches the yyval
+        # and yylval. These two always make trouble in the generated headers.
+        # yyval is initialized by Yacc generated code so it's not
+        # necessary to move them into the copy back region. yylval is used only
+        # for transporting a value. It will be set when used.
+        self._filter_special_vars.append({
+            "re":re.compile('extern YYSTYPE .*val'),
+            "reason":"Lex / Yacc variable initialized by generated code",
+            "action":"no_section"
+            })
+        # Lex generates an external variable that shouldn't be extern. Move it
+        # to the current data header file.
+        self._filter_special_vars.append({
+            "re":re.compile('extern yy_size_t .*len'),
+            "reason":"Lex adds an extern to this variable that is not necessary.",
+            "action":"ignore_extern"
+            })
+
         self._err = err
         self._verbose = verbose
         self._cu = cu
@@ -381,6 +400,17 @@ class HeaderGenCU:
                     var_with_type = "extern " + var_with_type
                     outfile = glob_data_out
 
+                for flt in self._filter_special_vars:
+                    if flt["re"].match(var_with_type) is not None:
+                        if flt["action"] == "no_section":
+                            self._err.write('Don\'t put "%s" into section. Reason: %s.\n' % \
+                                            (var_with_type, flt["reason"]))
+                            outfile = None
+                        if flt["action"] == "ignore_extern":
+                            self._err.write('Ignore extern of variable "%s". Reason: %s.\n' % \
+                                            (var_with_type, flt["reason"]))
+                            outfile = data_out
+
             # write output
             if self._verbose >= VERBOSE_SOME:
                 if not is_function:
@@ -389,7 +419,7 @@ class HeaderGenCU:
                 else:
                     self._err.write('Found a function "%s" at %s (DIE offset %s); extern: %r\n' % \
                                     (varname, var_decl, child.offset, is_extern))
-            if not is_function:
+            if (not is_function) and (outfile is not None):
                 outfile.write("RTEMS_LINKER_RWSET_CONTENT(bsd_prog_%s, %s);\n" % \
                         (self._progname, var_with_type))
             if is_extern:
-- 
2.13.7




More information about the devel mailing list