]> git.sur5r.net Git - cc65/blob - src/cc65/asmcode.c
Cleanup in ShiftExpr.
[cc65] / src / cc65 / asmcode.c
1 /*****************************************************************************/
2 /*                                                                           */
3 /*                                 asmcode.c                                 */
4 /*                                                                           */
5 /*          Assembler output code handling for the cc65 C compiler           */
6 /*                                                                           */
7 /*                                                                           */
8 /*                                                                           */
9 /* (C) 2000-2004 Ullrich von Bassewitz                                       */
10 /*               Römerstraße 52                                              */
11 /*               D-70794 Filderstadt                                         */
12 /* EMail:        uz@cc65.org                                                 */
13 /*                                                                           */
14 /*                                                                           */
15 /* This software is provided 'as-is', without any expressed or implied       */
16 /* warranty.  In no event will the authors be held liable for any damages    */
17 /* arising from the use of this software.                                    */
18 /*                                                                           */
19 /* Permission is granted to anyone to use this software for any purpose,     */
20 /* including commercial applications, and to alter it and redistribute it    */
21 /* freely, subject to the following restrictions:                            */
22 /*                                                                           */
23 /* 1. The origin of this software must not be misrepresented; you must not   */
24 /*    claim that you wrote the original software. If you use this software   */
25 /*    in a product, an acknowledgment in the product documentation would be  */
26 /*    appreciated but is not required.                                       */
27 /* 2. Altered source versions must be plainly marked as such, and must not   */
28 /*    be misrepresented as being the original software.                      */
29 /* 3. This notice may not be removed or altered from any source              */
30 /*    distribution.                                                          */
31 /*                                                                           */
32 /*****************************************************************************/
33
34
35
36 /* common */
37 #include "check.h"
38
39 /* cc65 */
40 #include "asmcode.h"
41 #include "codeopt.h"
42 #include "codeseg.h"
43 #include "dataseg.h"
44 #include "segments.h"
45 #include "stackptr.h"
46 #include "symtab.h"
47
48
49
50 /*****************************************************************************/
51 /*                                   Code                                    */
52 /*****************************************************************************/
53
54
55
56 void GetCodePos (CodeMark* M)
57 /* Get a marker pointing to the current output position */
58 {
59     M->Pos = CS_GetEntryCount (CS->Code);
60     M->SP  = StackPtr;
61 }
62
63
64
65 void RemoveCode (const CodeMark* M)
66 /* Remove all code after the given code marker */
67 {
68     CS_DelCodeAfter (CS->Code, M->Pos);
69     StackPtr = M->SP;
70 }
71
72
73
74 void MoveCode (const CodeMark* Start, const CodeMark* End, const CodeMark* Target)
75 /* Move the code between Start (inclusive) and End (exclusive) to
76  * (before) Target. The code marks aren't updated.
77  */
78 {
79     CS_MoveEntries (CS->Code, Start->Pos, End->Pos - Start->Pos, Target->Pos);
80 }
81
82
83
84 int CodeRangeIsEmpty (const CodeMark* Start, const CodeMark* End)
85 /* Return true if the given code range is empty (no code between Start and End) */
86 {   
87     int Empty;
88     PRECONDITION (Start->Pos >= End->Pos);
89     Empty = (Start->Pos == End->Pos);
90     if (Empty) {
91         /* Safety */
92         CHECK (Start->SP == End->SP);
93     }
94     return Empty;
95 }
96
97
98
99 void WriteOutput (FILE* F)
100 /* Write the final output to a file */
101 {
102     SymTable* SymTab;
103     SymEntry* Entry;
104
105     /* Output the global data segment */
106     CHECK (!HaveGlobalCode ());
107     OutputSegments (CS, F);
108
109     /* Output all global or referenced functions */
110     SymTab = GetGlobalSymTab ();
111     Entry  = SymTab->SymHead;
112     while (Entry) {
113         if (IsTypeFunc (Entry->Type)            &&
114             SymIsDef (Entry)                    &&
115             (Entry->Flags & (SC_REF | SC_EXTERN)) != 0) {
116             /* Function which is defined and referenced or extern */
117             CS_MergeLabels (Entry->V.F.Seg->Code);
118             RunOpt (Entry->V.F.Seg->Code);
119             OutputSegments (Entry->V.F.Seg, F);
120         }
121         Entry = Entry->NextSym;
122     }
123 }
124
125
126