aboutsummaryrefslogtreecommitdiff
path: root/src/cmd/compile/internal/ssa/rewriteAMD64splitload.go
diff options
context:
space:
mode:
authorJosh Bleecher Snyder <josharian@gmail.com>2020-01-21 20:53:30 -0800
committerJosh Bleecher Snyder <josharian@gmail.com>2020-02-21 02:29:11 +0000
commit6dd11bcb35cba37f5994c1b9aaaf7d2dc13fd7cf (patch)
treec04ec9e31fdca65416943a63fe70437abc674264 /src/cmd/compile/internal/ssa/rewriteAMD64splitload.go
parent1bc116b73ced8ec1ddc46f59acc75c89e5642607 (diff)
downloadgo-6dd11bcb35cba37f5994c1b9aaaf7d2dc13fd7cf.tar.gz
go-6dd11bcb35cba37f5994c1b9aaaf7d2dc13fd7cf.zip
cmd/compile: remove chunking of rewrite rules
We added chunking of rewrite rules to speed up compiling package SSA. This series of changes has significantly shrunk the number of rewrite rules, and they are no longer being added nearly as fast. Now that we are sharing v.Args across multiple rewrite rules, there is additional benefit to having more rules in a single function. Removing chunking now has an incidental impact on compiling package SSA, marginally speeds up other compilation, shrinks the cmd/compile binary, and simplifies the code. name old time/op new time/op delta Template 211ms ± 2% 210ms ± 2% -0.50% (p=0.000 n=91+97) Unicode 81.9ms ± 3% 81.8ms ± 3% ~ (p=0.179 n=96+91) GoTypes 731ms ± 2% 731ms ± 1% ~ (p=0.442 n=94+96) Compiler 3.43s ± 2% 3.41s ± 2% -0.36% (p=0.001 n=98+94) SSA 8.30s ± 2% 8.32s ± 2% +0.19% (p=0.034 n=94+95) Flate 135ms ± 2% 134ms ± 1% -0.30% (p=0.006 n=98+94) GoParser 167ms ± 1% 167ms ± 1% -0.22% (p=0.001 n=92+94) Reflect 453ms ± 2% 453ms ± 3% ~ (p=0.306 n=98+97) Tar 184ms ± 2% 183ms ± 2% -0.31% (p=0.012 n=94+94) XML 249ms ± 2% 248ms ± 1% -0.26% (p=0.002 n=96+92) [Geo mean] 419ms 418ms -0.21% name old user-time/op new user-time/op delta Template 273ms ± 2% 272ms ± 2% -0.46% (p=0.000 n=93+96) Unicode 116ms ± 4% 117ms ± 4% ~ (p=0.433 n=98+98) GoTypes 977ms ± 2% 977ms ± 1% ~ (p=0.971 n=92+99) Compiler 4.56s ± 6% 4.53s ± 6% ~ (p=0.081 n=100+100) SSA 11.1s ± 2% 11.1s ± 2% ~ (p=0.064 n=99+96) Flate 167ms ± 2% 167ms ± 1% -0.24% (p=0.004 n=95+96) GoParser 203ms ± 1% 203ms ± 2% -0.14% (p=0.049 n=96+97) Reflect 595ms ± 2% 595ms ± 2% ~ (p=0.544 n=95+92) Tar 225ms ± 2% 224ms ± 2% ~ (p=0.562 n=99+99) XML 312ms ± 2% 311ms ± 1% ~ (p=0.050 n=97+93) [Geo mean] 543ms 542ms -0.13% Change-Id: I8d34ab59f154b28f20c6f9e416b976bfce339baa Reviewed-on: https://go-review.googlesource.com/c/go/+/216220 Run-TryBot: Josh Bleecher Snyder <josharian@gmail.com> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Keith Randall <khr@golang.org>
Diffstat (limited to 'src/cmd/compile/internal/ssa/rewriteAMD64splitload.go')
-rw-r--r--src/cmd/compile/internal/ssa/rewriteAMD64splitload.go32
1 files changed, 16 insertions, 16 deletions
diff --git a/src/cmd/compile/internal/ssa/rewriteAMD64splitload.go b/src/cmd/compile/internal/ssa/rewriteAMD64splitload.go
index ec7d2270b3..69df3f7a1e 100644
--- a/src/cmd/compile/internal/ssa/rewriteAMD64splitload.go
+++ b/src/cmd/compile/internal/ssa/rewriteAMD64splitload.go
@@ -6,25 +6,25 @@ package ssa
func rewriteValueAMD64splitload(v *Value) bool {
switch v.Op {
case OpAMD64CMPBconstload:
- return rewriteValueAMD64splitload_OpAMD64CMPBconstload_0(v)
+ return rewriteValueAMD64splitload_OpAMD64CMPBconstload(v)
case OpAMD64CMPBload:
- return rewriteValueAMD64splitload_OpAMD64CMPBload_0(v)
+ return rewriteValueAMD64splitload_OpAMD64CMPBload(v)
case OpAMD64CMPLconstload:
- return rewriteValueAMD64splitload_OpAMD64CMPLconstload_0(v)
+ return rewriteValueAMD64splitload_OpAMD64CMPLconstload(v)
case OpAMD64CMPLload:
- return rewriteValueAMD64splitload_OpAMD64CMPLload_0(v)
+ return rewriteValueAMD64splitload_OpAMD64CMPLload(v)
case OpAMD64CMPQconstload:
- return rewriteValueAMD64splitload_OpAMD64CMPQconstload_0(v)
+ return rewriteValueAMD64splitload_OpAMD64CMPQconstload(v)
case OpAMD64CMPQload:
- return rewriteValueAMD64splitload_OpAMD64CMPQload_0(v)
+ return rewriteValueAMD64splitload_OpAMD64CMPQload(v)
case OpAMD64CMPWconstload:
- return rewriteValueAMD64splitload_OpAMD64CMPWconstload_0(v)
+ return rewriteValueAMD64splitload_OpAMD64CMPWconstload(v)
case OpAMD64CMPWload:
- return rewriteValueAMD64splitload_OpAMD64CMPWload_0(v)
+ return rewriteValueAMD64splitload_OpAMD64CMPWload(v)
}
return false
}
-func rewriteValueAMD64splitload_OpAMD64CMPBconstload_0(v *Value) bool {
+func rewriteValueAMD64splitload_OpAMD64CMPBconstload(v *Value) bool {
v_1 := v.Args[1]
v_0 := v.Args[0]
b := v.Block
@@ -47,7 +47,7 @@ func rewriteValueAMD64splitload_OpAMD64CMPBconstload_0(v *Value) bool {
return true
}
}
-func rewriteValueAMD64splitload_OpAMD64CMPBload_0(v *Value) bool {
+func rewriteValueAMD64splitload_OpAMD64CMPBload(v *Value) bool {
v_2 := v.Args[2]
v_1 := v.Args[1]
v_0 := v.Args[0]
@@ -72,7 +72,7 @@ func rewriteValueAMD64splitload_OpAMD64CMPBload_0(v *Value) bool {
return true
}
}
-func rewriteValueAMD64splitload_OpAMD64CMPLconstload_0(v *Value) bool {
+func rewriteValueAMD64splitload_OpAMD64CMPLconstload(v *Value) bool {
v_1 := v.Args[1]
v_0 := v.Args[0]
b := v.Block
@@ -95,7 +95,7 @@ func rewriteValueAMD64splitload_OpAMD64CMPLconstload_0(v *Value) bool {
return true
}
}
-func rewriteValueAMD64splitload_OpAMD64CMPLload_0(v *Value) bool {
+func rewriteValueAMD64splitload_OpAMD64CMPLload(v *Value) bool {
v_2 := v.Args[2]
v_1 := v.Args[1]
v_0 := v.Args[0]
@@ -120,7 +120,7 @@ func rewriteValueAMD64splitload_OpAMD64CMPLload_0(v *Value) bool {
return true
}
}
-func rewriteValueAMD64splitload_OpAMD64CMPQconstload_0(v *Value) bool {
+func rewriteValueAMD64splitload_OpAMD64CMPQconstload(v *Value) bool {
v_1 := v.Args[1]
v_0 := v.Args[0]
b := v.Block
@@ -143,7 +143,7 @@ func rewriteValueAMD64splitload_OpAMD64CMPQconstload_0(v *Value) bool {
return true
}
}
-func rewriteValueAMD64splitload_OpAMD64CMPQload_0(v *Value) bool {
+func rewriteValueAMD64splitload_OpAMD64CMPQload(v *Value) bool {
v_2 := v.Args[2]
v_1 := v.Args[1]
v_0 := v.Args[0]
@@ -168,7 +168,7 @@ func rewriteValueAMD64splitload_OpAMD64CMPQload_0(v *Value) bool {
return true
}
}
-func rewriteValueAMD64splitload_OpAMD64CMPWconstload_0(v *Value) bool {
+func rewriteValueAMD64splitload_OpAMD64CMPWconstload(v *Value) bool {
v_1 := v.Args[1]
v_0 := v.Args[0]
b := v.Block
@@ -191,7 +191,7 @@ func rewriteValueAMD64splitload_OpAMD64CMPWconstload_0(v *Value) bool {
return true
}
}
-func rewriteValueAMD64splitload_OpAMD64CMPWload_0(v *Value) bool {
+func rewriteValueAMD64splitload_OpAMD64CMPWload(v *Value) bool {
v_2 := v.Args[2]
v_1 := v.Args[1]
v_0 := v.Args[0]