wok annotate linld/stuff/src/pipehole.awk @ rev 20630

Up firefox-official (64.0), again
author Pascal Bellard <pascal.bellard@slitaz.org>
date Thu Jan 03 12:04:23 2019 +0100 (2019-01-03)
parents 014e68d6a0ef
children ab907169f156
rev   line source
pascal@20458 1 BEGIN { hold=0 }
pascal@20458 2 function isnum(n) { return match(n,/^[0-9+-]/) }
pascal@20458 3 {
pascal@20458 4 if (hold == 0) {
pascal@20458 5 s=$0
pascal@20534 6 if (/^ mov .[ix],bx$/ || /^ mov .[ix],.i$/) {
pascal@20543 7 r=$2; kept=0
pascal@20458 8 hold=1; split($2,regs,","); next
pascal@20458 9 }
pascal@20458 10 if (/^ inc e?.[ix]/ || /^ dec e?.[ix]/) {
pascal@20458 11 hold=2; r=$2; next
pascal@20458 12 }
pascal@20458 13 if (/^ mov [abcds][ix],/ && ! /,.s/) {
pascal@20458 14 hold=3; split($2,regs,","); next
pascal@20458 15 }
pascal@20458 16 if (/^ movzx eax,ax$/) { hold=4; next }
pascal@20544 17 if (/^ cmp word ptr/ || /^ cmp [bcd]x,/) {
pascal@20543 18 split($0,regs,",")
pascal@20543 19 if (isnum(regs[2]) && regs[2] != 0 &&
pascal@20543 20 (regs[2] % 256) == 0) {
pascal@20549 21 hold=5; next
pascal@20543 22 }
pascal@20543 23 }
pascal@20630 24 if (/^ mov ax,cs$/) { hold=6; kept=0; next }
pascal@20630 25 if (/^ mov cl,4$/) { hold=7; next }
pascal@20630 26 if (/^ cmp word ptr DGROUP:.*,0$/) {
pascal@20630 27 hold=8; split($2,regs,","); next
pascal@20630 28 }
pascal@20458 29 }
pascal@20458 30 else if (hold == 1) {
pascal@20543 31 if (/^ ;/) { line[kept++]=$0; next }
pascal@20458 32 hold=0; split($2,args,","); op=""
pascal@20458 33 if ($1 == "add") op="+"
pascal@20458 34 if ($1 == "sub") op="-"
pascal@20543 35 if (op != "" && regs[1] == args[1]) {
pascal@20543 36 if (isnum(args[2])) {
pascal@20630 37 for (i = kept++; i > 0; i--) line[i] = line[i-1]
pascal@20630 38 line[0] = "\tlea\t" regs[1] ",[" regs[2] op args[2] "]"
pascal@20630 39 hold=10; next
pascal@20543 40 }
pascal@20543 41 line[kept++]=$0
pascal@20543 42 hold=1
pascal@20458 43 next
pascal@20458 44 }
pascal@20520 45 if (/^ pop [ds]i/ && regs[2] ~ /^[ds]i$/) {
pascal@20520 46 print " xchg " r
pascal@20520 47 }
pascal@20543 48 else print s
pascal@20543 49 for (i = 0; i < kept; i++) print line[i]; kept=0
pascal@20458 50 }
pascal@20458 51 else if (hold == 2) {
pascal@20458 52 hold=0; split($2,args,","); print s
pascal@20458 53 if ($1 == "or" && r == args[1] && r == args[2]) next # don't clear C ...
pascal@20458 54 }
pascal@20458 55 else if (hold == 3) {
pascal@20458 56 hold=0
pascal@20542 57 if (/^ add [abcds][ix],/) {
pascal@20458 58 split($2,regs2,",")
pascal@20458 59 if (regs[1] == regs2[1] && (regs2[2] == "offset" || isnum(regs2[2]))) {
pascal@20549 60 t=$0; sub(/mov/,$1,s); sub(/add/,"mov",t)
pascal@20458 61 print t; print s; next
pascal@20458 62 }
pascal@20458 63 }
pascal@20458 64 print s
pascal@20458 65 }
pascal@20458 66 else if (hold == 4) {
pascal@20458 67 hold=0
pascal@20458 68 if (/^ push eax$/) {
pascal@20458 69 print " push 0"; print " push ax"; next
pascal@20458 70 } else { print s }
pascal@20458 71 }
pascal@20543 72 else if (hold == 5) {
pascal@20543 73 hold=0
pascal@20543 74 if ($1 == "jae" || $1 == "jb") {
pascal@20544 75 sub(/word ptr/,"byte ptr",s); sub(/x,/,"h,",s) ||
pascal@20543 76 sub(/\],/,"+1],",s) || sub(/,/,"+1,",s)
pascal@20543 77 s = s "/256"
pascal@20543 78 }
pascal@20543 79 print s
pascal@20543 80 }
pascal@20630 81 else if (hold == 6) {
pascal@20630 82 if (($1 == "and" || $1 == "add") && $2 ~ /^ax,/) {
pascal@20630 83 line[kept++]=$0
pascal@20630 84 next
pascal@20630 85 }
pascal@20630 86 p=$0
pascal@20630 87 if (/^ movzx eax,ax$/) {
pascal@20630 88 s=" mov eax,cs"; p=""
pascal@20630 89 }
pascal@20630 90 print s
pascal@20630 91 for (i = 0; i < kept; i++) print line[i]; kept=0
pascal@20630 92 if (p != "") print p
pascal@20630 93 hold=0; next
pascal@20630 94 }
pascal@20630 95 else if (hold == 7) {
pascal@20458 96 hold=0
pascal@20520 97 if (/^ call near ptr N_LXURSH@$/) {
pascal@20520 98 print " extrn N_LXURSH@4:near"
pascal@20520 99 print " call near ptr N_LXURSH@4"
pascal@20520 100 next
pascal@20520 101 }
pascal@20528 102 if (/^ call near ptr N_LXLSH@$/) {
pascal@20528 103 print " extrn N_LXLSH@4:near"
pascal@20528 104 print " call near ptr N_LXLSH@4"
pascal@20528 105 next
pascal@20528 106 }
pascal@20520 107 print s
pascal@20458 108 }
pascal@20630 109 else if (hold == 8) {
pascal@20630 110 if ($1 == "je" || $1 == "jne") { p=$0; hold=9; next }
pascal@20630 111 hold=0
pascal@20630 112 print s
pascal@20630 113 }
pascal@20630 114 else if (hold == 9) {
pascal@20630 115 hold=0; split($2,args,",")
pascal@20630 116 if (/^ mov ax,/ && args[2] == regs[1]) {
pascal@20630 117 print; print " or ax,ax"; print p; next
pascal@20630 118 }
pascal@20630 119 print s; print p;
pascal@20630 120 }
pascal@20630 121 else if (hold == 10) {
pascal@20630 122 hold=0
pascal@20630 123 if (/^ mov [sd]i,ax$/) {
pascal@20630 124 split($2,args,",")
pascal@20630 125 for (i = 0; i < kept; i++) {
pascal@20630 126 sub(/ax/,args[1],line[i]); print line[i]
pascal@20630 127 }
pascal@20630 128 next
pascal@20630 129 }
pascal@20630 130 for (i = 0; i < kept; i++) print line[i]
pascal@20630 131 }
pascal@20458 132 s=$0
pascal@20458 133 # These optimisation may break ZF or CF
pascal@20485 134 if (/^ sub sp,2$/) { print " push ax"; next }
pascal@20485 135 if (/^ sub sp,4$/) { print " push ax"; print " push ax"; next }
pascal@20485 136 if (/^ add sp,4$/) { print " pop cx"; print " pop cx"; next }
pascal@20458 137 if (/^ mov d*word ptr .*,0$/ || /^ mov dword ptr .*,large 0$/) {
pascal@20458 138 sub(/mov/,"and",s); print s; next # slower
pascal@20458 139 }
pascal@20458 140 if (/^ mov d*word ptr .*,-1$/ || /^ mov dword ptr .*,large -1$/) {
pascal@20458 141 sub(/mov/,"or",s); print s; next # slower
pascal@20458 142 }
pascal@20458 143 if (/^ or .*,0$/ || /^ and .*,-1$/) next
pascal@20458 144 if (/^ or [abcd]x,/) {
pascal@20458 145 split($2,args,",")
pascal@20458 146 if (isnum(args[2]) && args[2] >= 0 && args[2] < 256) {
pascal@20458 147 print " or " substr(args[1],1,1) "l," args[2]; next
pascal@20458 148 }
pascal@20458 149 }
pascal@20458 150 if (/^ and [abcd]x,/) {
pascal@20458 151 split($2,args,",")
pascal@20459 152 if (isnum(args[2]) && args[2] >= -256 && args[2] < 0) {
pascal@20458 153 print " and " substr(args[1],1,1) "l," args[2]; next
pascal@20458 154 }
pascal@20458 155 }
pascal@20458 156 if (/^ or e[abcd]x,/) {
pascal@20458 157 split($2,args,",")
pascal@20458 158 if (args[2] == "large") { args[2] = $3 }
pascal@20458 159 if (isnum(args[2]) && args[2] >= 0 && args[2] < 256) {
pascal@20458 160 print " or " substr(args[1],2,1) "l," args[2]; next
pascal@20458 161 }
pascal@20458 162 }
pascal@20458 163 if (/^ and e[abcd]x,/) {
pascal@20458 164 split($2,args,",")
pascal@20458 165 if (args[2] == "large") { args[2] = $3 }
pascal@20459 166 if (isnum(args[2]) && args[2] >= -256 && args[2] < 0) {
pascal@20458 167 print " and " substr(args[1],2,1) "l," args[2]; next
pascal@20458 168 }
pascal@20458 169 }
pascal@20458 170 if (/^ or e[abcds][ix],/) {
pascal@20458 171 split($2,args,",")
pascal@20458 172 if (args[2] == "large") { args[2] = $3 }
pascal@20458 173 if (isnum(args[2]) && args[2] >= 0 && args[2] < 65536) {
pascal@20458 174 print " or " substr(args[1],2) "," args[2]; next
pascal@20458 175 }
pascal@20458 176 }
pascal@20458 177 if (/^ and e[abcds][ix],/) {
pascal@20458 178 split($2,args,",")
pascal@20458 179 if (args[2] == "large") { args[2] = $3 }
pascal@20459 180 if (isnum(args[2]) && args[2] >= -65536 && args[2] < 0) {
pascal@20458 181 print " and " substr(args[1],2) "," args[2]; next
pascal@20458 182 }
pascal@20458 183 }
pascal@20543 184 if (/^ add word ptr/ || /^ sub word ptr/ ||
pascal@20544 185 /^ add [bcd]x,/ || /^ sub [bcd]x,/) {
pascal@20542 186 split($0,args,",")
pascal@20542 187 if (isnum(args[2]) && (args[2] % 256 == 0)) {
pascal@20544 188 sub(/word ptr/,"byte ptr",s); sub(/x,/,"h,",s) ||
pascal@20543 189 sub(/\],/,"+1],",s) || sub(/,/,"+1,",s)
pascal@20542 190 print s "/256"; next
pascal@20542 191 }
pascal@20542 192 }
pascal@20546 193 if (/^ add dword ptr/ || /^ sub dword ptr/) {
pascal@20458 194 split($0,args,",")
pascal@20543 195 if (args[2] == "large") { args[2] = $3 }
pascal@20458 196 if (isnum(args[2])) {
pascal@20546 197 if (args[2] % 16777216 == 0) {
pascal@20546 198 sub(/dword/,"byte",s)
pascal@20543 199 sub(/\],/,"+3],",s) || sub(/,/,"+3,",s)
pascal@20458 200 print s "/16777216"; next
pascal@20458 201 }
pascal@20458 202 if (args[2] % 65536 == 0) {
pascal@20546 203 sub(/dword/,"word",s)
pascal@20543 204 sub(/\],/,"+2],",s) || sub(/,/,"+2,",s)
pascal@20458 205 print s "/65536"; next
pascal@20458 206 }
pascal@20458 207 }
pascal@20458 208 }
pascal@20458 209 if (/^ mov e.x,/) {
pascal@20458 210 split($2,args,",")
pascal@20458 211 r=args[1]
pascal@20458 212 if (args[2] == "large") { args[2] = $3 }
pascal@20458 213 if (isnum(args[2]) && args[2] % 65536 == args[2]) {
pascal@20458 214 if (args[2] % 256 == args[2] || args[2] % 256 == 0) {
pascal@20458 215 print " xor " r "," r
pascal@20458 216 if (args[2] == 0) next
pascal@20458 217 x=" mov " substr(r,2,1)
pascal@20458 218 if (args[2] % 256 == 0) {
pascal@20458 219 print x "h," args[2] "/256"
pascal@20458 220 }
pascal@20458 221 else { print x "l," args[2] }
pascal@20458 222 next
pascal@20458 223 }
pascal@20458 224 }
pascal@20458 225 }
pascal@20458 226 print
pascal@20458 227 }