mirror of
https://github.com/KarolS/millfork.git
synced 2024-10-25 05:24:11 +00:00
Optimize more pointless loads from the same memory/register
This commit is contained in:
parent
beef56cdab
commit
0c50c4562a
@ -34,6 +34,7 @@ object OptimizationPresets {
|
|||||||
AlwaysGoodOptimizations.PointlessOperationAfterLoad,
|
AlwaysGoodOptimizations.PointlessOperationAfterLoad,
|
||||||
AlwaysGoodOptimizations.PointlessLoadBeforeTransfer,
|
AlwaysGoodOptimizations.PointlessLoadBeforeTransfer,
|
||||||
VariableToRegisterOptimization,
|
VariableToRegisterOptimization,
|
||||||
|
AlwaysGoodOptimizations.RearrangableLoadFromTheSameLocation,
|
||||||
AlwaysGoodOptimizations.PoinlessLoadBeforeAnotherLoad,
|
AlwaysGoodOptimizations.PoinlessLoadBeforeAnotherLoad,
|
||||||
AlwaysGoodOptimizations.CommonIndexSubexpressionElimination,
|
AlwaysGoodOptimizations.CommonIndexSubexpressionElimination,
|
||||||
AlwaysGoodOptimizations.PointlessOperationPairRemoval,
|
AlwaysGoodOptimizations.PointlessOperationPairRemoval,
|
||||||
@ -218,6 +219,7 @@ object OptimizationPresets {
|
|||||||
AlwaysGoodOptimizations.ReverseFlowAnalysis,
|
AlwaysGoodOptimizations.ReverseFlowAnalysis,
|
||||||
AlwaysGoodOptimizations.SimplifiableCondition,
|
AlwaysGoodOptimizations.SimplifiableCondition,
|
||||||
VariableToRegisterOptimization,
|
VariableToRegisterOptimization,
|
||||||
|
AlwaysGoodOptimizations.PointlessLoadAfterLoadOrStore,
|
||||||
LaterOptimizations.DoubleLoadToTheSameRegister
|
LaterOptimizations.DoubleLoadToTheSameRegister
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
@ -766,6 +766,12 @@ object AlwaysGoodOptimizations {
|
|||||||
HasOpcode(TAX) ~ (Elidable & Set(TXA, TAX)) ~~> (_.init),
|
HasOpcode(TAX) ~ (Elidable & Set(TXA, TAX)) ~~> (_.init),
|
||||||
HasOpcode(TSX) ~ (Elidable & Set(TXS, TSX)) ~~> (_.init),
|
HasOpcode(TSX) ~ (Elidable & Set(TXS, TSX)) ~~> (_.init),
|
||||||
HasOpcode(TXS) ~ (Elidable & Set(TXS, TSX)) ~~> (_.init),
|
HasOpcode(TXS) ~ (Elidable & Set(TXS, TSX)) ~~> (_.init),
|
||||||
|
HasOpcodeIn(Set(TXA, TAX)) ~
|
||||||
|
(Linear & Not(ChangesNAndZ) & Not(ChangesA) & Not(ChangesX)).* ~
|
||||||
|
(Elidable & HasOpcodeIn(Set(TXA, TAX))) ~~> (_.init),
|
||||||
|
HasOpcodeIn(Set(TYA, TAY)) ~
|
||||||
|
(Linear & Not(ChangesNAndZ) & Not(ChangesA) & Not(ChangesX)).* ~
|
||||||
|
(Elidable & HasOpcodeIn(Set(TYA, TAY))) ~~> (_.init),
|
||||||
HasOpcode(TSX) ~ (Not(ChangesX) & Not(ChangesS) & Linear).* ~ (Elidable & Set(TXS, TSX)) ~~> (_.init),
|
HasOpcode(TSX) ~ (Not(ChangesX) & Not(ChangesS) & Linear).* ~ (Elidable & Set(TXS, TSX)) ~~> (_.init),
|
||||||
HasOpcode(TXS) ~ (Not(ChangesX) & Not(ChangesS) & Linear).* ~ (Elidable & Set(TXS, TSX)) ~~> (_.init),
|
HasOpcode(TXS) ~ (Not(ChangesX) & Not(ChangesS) & Linear).* ~ (Elidable & Set(TXS, TSX)) ~~> (_.init),
|
||||||
)
|
)
|
||||||
@ -999,6 +1005,14 @@ object AlwaysGoodOptimizations {
|
|||||||
(Linear & Not(ChangesA) & Not(HasOpcode(DISCARD_AF)) & DoesntChangeIndexingInAddrMode(0) & DoesntChangeMemoryAt(0, 1)).* ~
|
(Linear & Not(ChangesA) & Not(HasOpcode(DISCARD_AF)) & DoesntChangeIndexingInAddrMode(0) & DoesntChangeMemoryAt(0, 1)).* ~
|
||||||
(HasOpcode(LABEL) & MatchParameter(3) & HasCallerCount(1)) ~
|
(HasOpcode(LABEL) & MatchParameter(3) & HasCallerCount(1)) ~
|
||||||
(Elidable & HasOpcode(LDA) & MatchAddrMode(0) & MatchParameter(1) & DoesntMatterWhatItDoesWith(State.N, State.Z)) ~~> (_.init),
|
(Elidable & HasOpcode(LDA) & MatchAddrMode(0) & MatchParameter(1) & DoesntMatterWhatItDoesWith(State.N, State.Z)) ~~> (_.init),
|
||||||
|
|
||||||
|
HasOpcodeIn(Set(TXA, TAX)) ~
|
||||||
|
(Not(Set(TXA, TAX)) & Linear & Not(ChangesA) & Not(ChangesX)).* ~
|
||||||
|
(Elidable & HasOpcodeIn(Set(TXA, TAX)) & DoesntMatterWhatItDoesWith(State.N, State.Z)) ~~> (_.init),
|
||||||
|
|
||||||
|
HasOpcodeIn(Set(TYA, TAY)) ~
|
||||||
|
(Not(Set(TYA, TAY)) & Linear & Not(ChangesA) & Not(ChangesY)).* ~
|
||||||
|
(Elidable & HasOpcodeIn(Set(TYA, TAY)) & DoesntMatterWhatItDoesWith(State.N, State.Z)) ~~> (_.init),
|
||||||
)
|
)
|
||||||
|
|
||||||
val RearrangableLoadFromTheSameLocation = new RuleBasedAssemblyOptimization("Rearrangable load from the same location",
|
val RearrangableLoadFromTheSameLocation = new RuleBasedAssemblyOptimization("Rearrangable load from the same location",
|
||||||
@ -1024,6 +1038,21 @@ object AlwaysGoodOptimizations {
|
|||||||
(Elidable & HasOpcode(LDY) & MatchAddrMode(0) & MatchParameter(1)) ~~> {code =>
|
(Elidable & HasOpcode(LDY) & MatchAddrMode(0) & MatchParameter(1)) ~~> {code =>
|
||||||
List(code.head, AssemblyLine.implied(TAY), code(1))
|
List(code.head, AssemblyLine.implied(TAY), code(1))
|
||||||
},
|
},
|
||||||
|
(HasOpcode(LDA) & MatchAddrMode(0) & MatchParameter(1)) ~
|
||||||
|
(Linear & Not(ChangesA) & Not(ChangesNAndZ) & DoesntChangeMemoryAt(0, 1)).* ~
|
||||||
|
(Elidable & HasOpcode(LDA) & MatchAddrMode(0) & MatchParameter(1)) ~~> {code =>
|
||||||
|
code.init
|
||||||
|
},
|
||||||
|
(HasOpcode(LDX) & MatchAddrMode(0) & MatchParameter(1)) ~
|
||||||
|
(Linear & Not(ChangesX) & Not(ChangesNAndZ) & DoesntChangeMemoryAt(0, 1)).* ~
|
||||||
|
(Elidable & HasOpcode(LDX) & MatchAddrMode(0) & MatchParameter(1)) ~~> {code =>
|
||||||
|
code.init
|
||||||
|
},
|
||||||
|
(HasOpcode(LDY) & MatchAddrMode(0) & MatchParameter(1)) ~
|
||||||
|
(Linear & Not(ChangesY) & Not(ChangesNAndZ) & DoesntChangeMemoryAt(0, 1)).* ~
|
||||||
|
(Elidable & HasOpcode(LDY) & MatchAddrMode(0) & MatchParameter(1)) ~~> {code =>
|
||||||
|
code.init
|
||||||
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
val PointlessOperationAfterLoad = new RuleBasedAssemblyOptimization("Pointless operation after load",
|
val PointlessOperationAfterLoad = new RuleBasedAssemblyOptimization("Pointless operation after load",
|
||||||
|
Loading…
Reference in New Issue
Block a user