Skip to content

Commit 3272460

Browse files
Fixed disruptive optimization rule under 6809.
1 parent 5fcdcd1 commit 3272460

File tree

1 file changed

+80
-1
lines changed

1 file changed

+80
-1
lines changed

ugbc/src/targets/d32/_optimizer.c

Lines changed: 80 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2121,6 +2121,85 @@ static void optim_remove_unused_temporary( Environment * _environment ) {
21212121
optim( buf[2], RULE "unused temporary", "\tTST%s", v1->str );
21222122
++_environment->removedAssemblyLines;
21232123
}
2124+
2125+
} else if (
2126+
( ( po_buf_match( buf[0], " LDA #*", v1 ) || po_buf_match( buf[0], " CLRA") ) && po_buf_match( buf[1], " STA *", v2 ) && po_buf_match( buf[2], " STD *", v3 ) ) ||
2127+
( ( po_buf_match( buf[0], " LDB #*", v1 ) || po_buf_match( buf[0], " CLRB") ) && po_buf_match( buf[1], " STB *", v2 ) && po_buf_match( buf[2], " STD *", v3 ) )
2128+
) {
2129+
2130+
char * realVarName = strdup( v2->str );
2131+
char * c = strstr( realVarName, "+" );
2132+
if ( c ) {
2133+
*c = 0;
2134+
}
2135+
c = strstr( realVarName, "<(" );
2136+
if ( c ) {
2137+
strcpy( c, c+2 );
2138+
}
2139+
c = strstr( realVarName, ")" );
2140+
if ( c ) {
2141+
*c = 0;
2142+
}
2143+
2144+
// printf(" RULE #2 for [%s]\n", realVarName );
2145+
2146+
UnusedSymbol * tmp = currentlyUnusedSymbols;
2147+
while( tmp ) {
2148+
// printf(" - compare %s = %s\n", realVarName, tmp->realName );
2149+
if ( strcmp( realVarName, tmp->realName ) == 0 ) {
2150+
// printf(" > found!\n" );
2151+
break;
2152+
}
2153+
tmp = tmp->next;
2154+
}
2155+
// printf( "\n" );
2156+
if ( tmp ) {
2157+
// printf(" APPLIED #2\n");
2158+
// optim( buf[0], RULE "unused temporary bug", NULL );
2159+
optim( buf[1], RULE "unused temporary", NULL );
2160+
++_environment->removedAssemblyLines;
2161+
++_environment->removedAssemblyLines;
2162+
}
2163+
} else if (
2164+
po_buf_match( buf[0], " DEC*", v1 ) &&
2165+
po_buf_match( buf[1], "_*", v4 ) &&
2166+
po_buf_match( buf[2], " ST* *", v3, v2 ) &&
2167+
(po_buf_cmp( v1, v3 ) == 0)
2168+
) {
2169+
2170+
char * realVarName = strdup( v2->str );
2171+
char * c = strstr( realVarName, "+" );
2172+
if ( c ) {
2173+
*c = 0;
2174+
}
2175+
c = strstr( realVarName, "<(" );
2176+
if ( c ) {
2177+
strcpy( c, c+2 );
2178+
}
2179+
c = strstr( realVarName, ")" );
2180+
if ( c ) {
2181+
*c = 0;
2182+
}
2183+
2184+
// printf(" RULE #2 for [%s]\n", realVarName );
2185+
2186+
UnusedSymbol * tmp = currentlyUnusedSymbolsQ;
2187+
while( tmp ) {
2188+
// printf(" - compare %s = %s\n", realVarName, tmp->realName );
2189+
if ( strcmp( realVarName, tmp->realName ) == 0 ) {
2190+
// printf(" > found!\n" );
2191+
break;
2192+
}
2193+
tmp = tmp->next;
2194+
}
2195+
// printf( "\n" );
2196+
if ( tmp ) {
2197+
// printf(" APPLIED #2\n");
2198+
// optim( buf[0], RULE "unused temporary", NULL );
2199+
optim( buf[2], RULE "unused temporary", "\tTST%s", v1->str );
2200+
++_environment->removedAssemblyLines;
2201+
}
2202+
21242203
} else if (
21252204
( ( po_buf_match( buf[0], " LDA #*", v1 ) || po_buf_match( buf[0], " CLRA") ) && po_buf_match( buf[1], " STA *", v2 ) ) ||
21262205
( ( po_buf_match( buf[0], " LDB #*", v1 ) || po_buf_match( buf[0], " CLRB") ) && po_buf_match( buf[1], " STB *", v2 ) ) ||
@@ -2155,7 +2234,7 @@ static void optim_remove_unused_temporary( Environment * _environment ) {
21552234
// printf( "\n" );
21562235
if ( tmp ) {
21572236
// printf(" APPLIED #2\n");
2158-
// optim( buf[0], RULE "unused temporary", NULL );
2237+
optim( buf[0], RULE "unused temporary bug", NULL );
21592238
optim( buf[1], RULE "unused temporary", NULL );
21602239
++_environment->removedAssemblyLines;
21612240
++_environment->removedAssemblyLines;

0 commit comments

Comments
 (0)