1
0
mirror of https://github.com/cc65/cc65.git synced 2025-01-11 11:30:13 +00:00

More work on address sizes

git-svn-id: svn://svn.cc65.org/cc65/trunk@2622 b7a2c559-68d2-44c3-8de9-860c34a00d81
This commit is contained in:
cuz 2003-11-08 23:13:02 +00:00
parent 44976a0461
commit 87d3f32be1
2 changed files with 22 additions and 21 deletions

View File

@ -58,8 +58,6 @@
#define SF_EXPORT 0x0004 /* Export this symbol */ #define SF_EXPORT 0x0004 /* Export this symbol */
#define SF_IMPORT 0x0008 /* Import this symbol */ #define SF_IMPORT 0x0008 /* Import this symbol */
#define SF_GLOBAL 0x0010 /* Global symbol */ #define SF_GLOBAL 0x0010 /* Global symbol */
#define SF_ZP 0x0020 /* Declared as zeropage symbol */
#define SF_ABS 0x0040 /* Declared as absolute symbol */
#define SF_LABEL 0x0080 /* Used as a label */ #define SF_LABEL 0x0080 /* Used as a label */
#define SF_FORCED 0x0100 /* Forced import, SF_IMPORT also set */ #define SF_FORCED 0x0100 /* Forced import, SF_IMPORT also set */
#define SF_FINALIZED 0x0200 /* Symbol is finalized */ #define SF_FINALIZED 0x0200 /* Symbol is finalized */

View File

@ -7,7 +7,7 @@
/* */ /* */
/* */ /* */
/* (C) 1998-2003 Ullrich von Bassewitz */ /* (C) 1998-2003 Ullrich von Bassewitz */
/* Römerstrasse 52 */ /* Römerstraße 52 */
/* D-70794 Filderstadt */ /* D-70794 Filderstadt */
/* EMail: uz@cc65.org */ /* EMail: uz@cc65.org */
/* */ /* */
@ -152,9 +152,6 @@ static SymTable* NewSymTable (SymTable* Parent, const char* Name)
} }
} }
} }
} else {
/* This is the root table */
RootScope = S;
} }
/* Return the prepared struct */ /* Return the prepared struct */
@ -215,12 +212,18 @@ void SymEnterLevel (const char* ScopeName, unsigned AddrSize)
AddrSize = GetCurrentSegAddrSize (); AddrSize = GetCurrentSegAddrSize ();
} }
/* Search for an existing table/create a new one */ /* If we have a current scope, search for the given name and create a
CurrentScope = SymFindScope (CurrentScope, ScopeName, SYM_ALLOC_NEW); * new one if it doesn't exist. If this is the root scope, just create it.
*/
/* Check if the scope has been defined before */ if (CurrentScope) {
if (CurrentScope->Flags & ST_DEFINED) { CurrentScope = SymFindScope (CurrentScope, ScopeName, SYM_ALLOC_NEW);
Error ("Duplicate scope `%s'", ScopeName);
/* Check if the scope has been defined before */
if (CurrentScope->Flags & ST_DEFINED) {
Error ("Duplicate scope `%s'", ScopeName);
}
} else {
CurrentScope = RootScope = NewSymTable (0, ScopeName);
} }
/* Mark the scope as defined */ /* Mark the scope as defined */
@ -467,21 +470,20 @@ int SymIsZP (SymEntry* S)
* enclosing scope for a symbol with the same name, and return the ZP * enclosing scope for a symbol with the same name, and return the ZP
* attribute of this symbol if we find one. * attribute of this symbol if we find one.
*/ */
if (!IsLocalNameId (S->Name) && if (!IsLocalNameId (S->Name) && (S->Flags & (SF_DEFINED | SF_IMPORT)) == 0 &&
(S->Flags & (SF_ZP | SF_ABS | SF_DEFINED | SF_IMPORT)) == 0 &&
S->SymTab->Parent != 0) { S->SymTab->Parent != 0) {
/* Try to find a symbol with the same name in the enclosing scope */ /* Try to find a symbol with the same name in the enclosing scope */
SymEntry* E = SymFindAny (S->SymTab->Parent, GetString (S->Name)); SymEntry* E = SymFindAny (S->SymTab->Parent, GetString (S->Name));
/* If we found one, use the ZP flag */ /* If we found one, use the ZP flag */
if (E && (E->Flags & SF_ZP) != 0) { if (E && E->AddrSize == ADDR_SIZE_ZP) {
S->Flags |= SF_ZP; S->AddrSize = ADDR_SIZE_ZP;
} }
} }
/* Check the ZP flag */ /* Check the ZP flag */
return (S->Flags & SF_ZP) != 0; return (S->AddrSize == ADDR_SIZE_ZP);
} }
@ -537,7 +539,8 @@ static void SymCheckUndefined (SymEntry* S)
/* The symbol is already marked as imported external symbol */ /* The symbol is already marked as imported external symbol */
PError (&S->Pos, "Symbol `%s' is already an import", GetString (S->Name)); PError (&S->Pos, "Symbol `%s' is already an import", GetString (S->Name));
} }
Sym->Flags |= S->Flags & (SF_EXPORT | SF_ZP); Sym->Flags |= (S->Flags & SF_EXPORT);
Sym->ExportSize = S->ExportSize;
} }
/* Transfer the referenced flag */ /* Transfer the referenced flag */
@ -655,7 +658,7 @@ void SymDump (FILE* F)
(S->Flags & SF_REFERENCED)? "REF" : "---", (S->Flags & SF_REFERENCED)? "REF" : "---",
(S->Flags & SF_IMPORT)? "IMP" : "---", (S->Flags & SF_IMPORT)? "IMP" : "---",
(S->Flags & SF_EXPORT)? "EXP" : "---", (S->Flags & SF_EXPORT)? "EXP" : "---",
(S->Flags & SF_ZP)? "ZP" : "--"); AddrSizeToStr (S->AddrSize));
} }
/* Next symbol */ /* Next symbol */
S = S->List; S = S->List;
@ -685,7 +688,7 @@ void WriteImports (void)
if ((S->Flags & (SF_TRAMPOLINE | SF_IMPORT)) == SF_IMPORT && if ((S->Flags & (SF_TRAMPOLINE | SF_IMPORT)) == SF_IMPORT &&
(S->Flags & (SF_REFERENCED | SF_FORCED)) != 0) { (S->Flags & (SF_REFERENCED | SF_FORCED)) != 0) {
if (S->Flags & SF_ZP) { if (S->AddrSize == ADDR_SIZE_ZP) {
ObjWrite8 (IMP_ZP); ObjWrite8 (IMP_ZP);
} else { } else {
ObjWrite8 (IMP_ABS); ObjWrite8 (IMP_ABS);
@ -711,7 +714,7 @@ static unsigned char GetExprMask (SymEntry* S)
ExprMask = (SymIsConst (S))? EXP_CONST : EXP_EXPR; ExprMask = (SymIsConst (S))? EXP_CONST : EXP_EXPR;
/* Add zeropage/abs bits */ /* Add zeropage/abs bits */
ExprMask |= (S->Flags & SF_ZP)? EXP_ZP : EXP_ABS; ExprMask |= (S->AddrSize == ADDR_SIZE_ZP)? EXP_ZP : EXP_ABS;
/* Add the label/equate bits */ /* Add the label/equate bits */
ExprMask |= (S->Flags & SF_LABEL)? EXP_LABEL : EXP_EQUATE; ExprMask |= (S->Flags & SF_LABEL)? EXP_LABEL : EXP_EQUATE;