]> Cypherpunks repositories - gostls13.git/commit
crypto/sha1: Avo port of sha1block_amd64.s
authorGarrett Bodley <garrett.bodley@gmail.com>
Wed, 17 Jul 2024 02:44:17 +0000 (22:44 -0400)
committerRoland Shoemaker <roland@golang.org>
Wed, 4 Sep 2024 20:35:55 +0000 (20:35 +0000)
commitf9eb06c3022b20ae0b7944717d58d582eb5677ea
treee93610177c179996bcc831a748361fd4e139460e
parentdbd50a16dc79d0876f9c523af2aaeb9e1b7b7839
crypto/sha1: Avo port of sha1block_amd64.s

This implementation utilizes the same registers found in the reference
implementation, aiming to produce a minimal semantic diff between the
Avo-generated output and the original hand-written assembly.

To verify the Avo implementation, the reference and Avo-generated
assembly files are fed to `go tool asm`, capturing the debug output into
corresponding temp files. The debug output contains supplementary
metadata (line numbers, instruction offsets, and source file references)
that must be removed in order to obtain a semantic diff of the two
files. This is accomplished via a small utility script written in awk.

Commands used to verify Avo output:

GOROOT=$(go env GOROOT)
ASM_PATH="src/crypto/sha1/sha1block_amd64.s"
REFERENCE="54fe0fd43fcf8609666c16ae6d15ed92873b1564"

go tool asm -o /dev/null -I "$GOROOT"/src/runtime -debug \
  <(git cat-file -p "$REFERENCE:$ASM_PATH") \
  > /tmp/reference.s

go tool asm -o /dev/null -I "$GOROOT"/src/runtime -debug \
  "$ASM_PATH" \
  > /tmp/avo.s

normalize(){
  awk '{
    $1=$2=$3="";
    print substr($0,4)
  }'
}

diff <(normalize < /tmp/reference.s) <(normalize < /tmp/avo.s)

1273c1273
< MOVQ $K_XMM_AR<>(SB), R8
---
> LEAQ K_XMM_AR<>(SB), R8

Change-Id: I39168fadb01baa9a96bc2b432fc94b492d036ce4
Reviewed-on: https://go-review.googlesource.com/c/go/+/598795
Reviewed-by: Dmitri Shuralyov <dmitshur@google.com>
LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
Reviewed-by: Filippo Valsorda <filippo@golang.org>
Reviewed-by: Roland Shoemaker <roland@golang.org>
src/cmd/compile/internal/types2/stdlib_test.go
src/crypto/sha1/_asm/go.mod [new file with mode: 0644]
src/crypto/sha1/_asm/go.sum [new file with mode: 0644]
src/crypto/sha1/_asm/sha1block_amd64_asm.go [new file with mode: 0644]
src/crypto/sha1/sha1block_amd64.s
src/go/types/stdlib_test.go