* symbols.c (define_sym_at_dot): New function, extracted from..
authorAlan Modra <amodra@gmail.com>
Wed, 23 Sep 2009 06:10:08 +0000 (06:10 +0000)
committerAlan Modra <amodra@gmail.com>
Wed, 23 Sep 2009 06:10:08 +0000 (06:10 +0000)
(colon): ..here.  Define error case cloned symbol.

gas/ChangeLog
gas/symbols.c

index 0f4d02456ad59e801b372acd8029b6990953818f..28099ba6a13a68428f40f3d863ff4d26bda8603d 100644 (file)
@@ -1,3 +1,8 @@
+2009-09-23  Alan Modra  <amodra@bigpond.net.au>
+
+       * symbols.c (define_sym_at_dot): New function, extracted from..
+       (colon): ..here.  Define error case cloned symbol.
+
 2009-09-21  H.J. Lu  <hongjiu.lu@intel.com>
 
        * config/tc-i386.c: Remove white spaces.
index 61623189cbf4ef5ec2ea1c7bdaf33b3123e66ed2..304a1eeb6e85c9de2d8b6a17d1a51d893f5507c6 100644 (file)
@@ -246,6 +246,17 @@ local_symbol_convert (struct local_symbol *locsym)
   return ret;
 }
 \f
+static void
+define_sym_at_dot (symbolS *symbolP)
+{
+  symbolP->sy_frag = frag_now;
+#ifdef OBJ_VMS
+  S_SET_OTHER (symbolP, const_flag);
+#endif
+  S_SET_VALUE (symbolP, (valueT) frag_now_fix ());
+  S_SET_SEGMENT (symbolP, now_seg);
+}
+
 /* We have just seen "<name>:".
    Creates a struct symbol unless it already exists.
 
@@ -343,12 +354,7 @@ colon (/* Just seen "x:" - rattle symbols & frags.  */
            }
          if (S_GET_VALUE (symbolP) == 0)
            {
-             symbolP->sy_frag = frag_now;
-#ifdef OBJ_VMS
-             S_SET_OTHER (symbolP, const_flag);
-#endif
-             S_SET_VALUE (symbolP, (valueT) frag_now_fix ());
-             S_SET_SEGMENT (symbolP, now_seg);
+             define_sym_at_dot (symbolP);
 #ifdef N_UNDF
              know (N_UNDF == 0);
 #endif /* if we have one, it better be zero.  */
@@ -393,12 +399,7 @@ colon (/* Just seen "x:" - rattle symbols & frags.  */
                    {
                      /* It is a .comm/.lcomm being converted to initialized
                         data.  */
-                     symbolP->sy_frag = frag_now;
-#ifdef OBJ_VMS
-                     S_SET_OTHER (symbolP, const_flag);
-#endif
-                     S_SET_VALUE (symbolP, (valueT) frag_now_fix ());
-                     S_SET_SEGMENT (symbolP, now_seg); /* Keep N_EXT bit.  */
+                     define_sym_at_dot (symbolP);
                    }
                }
              else
@@ -431,6 +432,7 @@ colon (/* Just seen "x:" - rattle symbols & frags.  */
            {
              as_bad (_("symbol `%s' is already defined"), sym_name);
              symbolP = symbol_clone (symbolP, 0);
+             define_sym_at_dot (symbolP);
            }
        }