]> git.sur5r.net Git - cc65/blob - src/cc65/coptind.h
More optimization
[cc65] / src / cc65 / coptind.h
1 /*****************************************************************************/
2 /*                                                                           */
3 /*                                 coptind.h                                 */
4 /*                                                                           */
5 /*              Environment independent low level optimizations              */
6 /*                                                                           */
7 /*                                                                           */
8 /*                                                                           */
9 /* (C) 2001      Ullrich von Bassewitz                                       */
10 /*               Wacholderweg 14                                             */
11 /*               D-70597 Stuttgart                                           */
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 #ifndef COPTIND_H
37 #define COPTIND_H
38
39
40
41 #include "codeseg.h"
42
43
44
45 /*****************************************************************************/
46 /*                                   Code                                    */
47 /*****************************************************************************/
48
49
50
51 unsigned OptRTSJumps (CodeSeg* S);
52 /* Replace jumps to RTS by RTS */
53
54 unsigned OptDeadJumps (CodeSeg* S);
55 /* Remove dead jumps (jumps to the next instruction) */
56
57 unsigned OptDeadCode (CodeSeg* S);
58 /* Remove dead code (code that follows an unconditional jump or an rts/rti
59  * and has no label)
60  */
61
62 unsigned OptJumpCascades (CodeSeg* S);
63 /* Optimize jump cascades (jumps to jumps). In such a case, the jump is
64  * replaced by a jump to the final location. This will in some cases produce
65  * worse code, because some jump targets are no longer reachable by short
66  * branches, but this is quite rare, so there are more advantages than
67  * disadvantages.
68  */
69
70 unsigned OptRTS (CodeSeg* S);
71 /* Optimize subroutine calls followed by an RTS. The subroutine call will get
72  * replaced by a jump. Don't bother to delete the RTS if it does not have a
73  * label, the dead code elimination should take care of it.
74  */
75
76 unsigned OptJumpTarget (CodeSeg* S);
77 /* If the instruction preceeding an unconditional branch is the same as the
78  * instruction preceeding the jump target, the jump target may be moved
79  * one entry back. This is a size optimization, since the instruction before
80  * the branch gets removed.
81  */
82
83 unsigned OptCondBranches (CodeSeg* S);
84 /* If an immidiate load of a register is followed by a conditional jump that
85  * is never taken because the load of the register sets the flags in such a
86  * manner, remove the conditional branch.
87  */
88
89 unsigned OptUnusedLoads (CodeSeg* S);
90 /* Remove loads of registers where the value loaded is not used later. */
91
92 unsigned OptDuplicateLoads (CodeSeg* S);
93 /* Remove loads of registers where the value loaded is already in the register. */
94
95 unsigned OptStoreLoad (CodeSeg* S);
96 /* Remove a store followed by a load from the same location. */
97
98 unsigned OptTransfers (CodeSeg* S);
99 /* Remove transfers from one register to another and back */
100
101 unsigned OptBranchDist (CodeSeg* S);
102 /* Change branches for the distance needed. */
103
104
105
106 /* End of coptind.h */
107 #endif
108
109
110