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:
parent
44976a0461
commit
87d3f32be1
@ -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 */
|
||||||
|
@ -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;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user