forgejo/modules/auth/password/hash
Gusted 4f64ee294e
[v1.22] [GITEA] Drop sha256-simd in favor of stdlib
- In Go 1.21 the crypto/sha256 [got a massive
improvement](https://go.dev/doc/go1.21#crypto/sha256) by utilizing the
SHA instructions for AMD64 CPUs, which sha256-simd already was doing.
The performance is now on par and I think it's preferable to use the
standard library rather than a package when possible.

```
cpu: AMD Ryzen 5 3600X 6-Core Processor
                │  simd.txt   │               go.txt                │
                │   sec/op    │    sec/op     vs base               │
Hash/8Bytes-12    63.25n ± 1%    73.38n ± 1%  +16.02% (p=0.002 n=6)
Hash/64Bytes-12   98.73n ± 1%   105.30n ± 1%   +6.65% (p=0.002 n=6)
Hash/1K-12        567.2n ± 1%    572.8n ± 1%   +0.99% (p=0.002 n=6)
Hash/8K-12        4.062µ ± 1%    4.062µ ± 1%        ~ (p=0.396 n=6)
Hash/1M-12        512.1µ ± 0%    510.6µ ± 1%        ~ (p=0.485 n=6)
Hash/5M-12        2.556m ± 1%    2.564m ± 0%        ~ (p=0.093 n=6)
Hash/10M-12       5.112m ± 0%    5.127m ± 0%        ~ (p=0.093 n=6)
geomean           13.82µ         14.27µ        +3.28%

                │   simd.txt   │               go.txt                │
                │     B/s      │     B/s       vs base               │
Hash/8Bytes-12    120.6Mi ± 1%   104.0Mi ± 1%  -13.81% (p=0.002 n=6)
Hash/64Bytes-12   618.2Mi ± 1%   579.8Mi ± 1%   -6.22% (p=0.002 n=6)
Hash/1K-12        1.682Gi ± 1%   1.665Gi ± 1%   -0.98% (p=0.002 n=6)
Hash/8K-12        1.878Gi ± 1%   1.878Gi ± 1%        ~ (p=0.310 n=6)
Hash/1M-12        1.907Gi ± 0%   1.913Gi ± 1%        ~ (p=0.485 n=6)
Hash/5M-12        1.911Gi ± 1%   1.904Gi ± 0%        ~ (p=0.093 n=6)
Hash/10M-12       1.910Gi ± 0%   1.905Gi ± 0%        ~ (p=0.093 n=6)
geomean           1.066Gi        1.032Gi        -3.18%
```

(cherry picked from commit abd94ff5b5)
(cherry picked from commit 15e81637ab)

Conflicts:
	go.mod
	https://codeberg.org/forgejo/forgejo/pulls/1581
(cherry picked from commit 325d92917f)

Conflicts:
	modules/context/context_cookie.go
	https://codeberg.org/forgejo/forgejo/pulls/1617
(cherry picked from commit 358819e895)
(cherry picked from commit 362fd7aae1)
2023-10-30 14:37:04 +01:00
..
argon2.go Make CI use a dummy password hasher for all tests (#22983) 2023-02-20 13:20:30 +08:00
bcrypt.go Make CI use a dummy password hasher for all tests (#22983) 2023-02-20 13:20:30 +08:00
common.go Provide the ability to set password hash algorithm parameters (#22942) 2023-02-19 15:35:20 +08:00
dummy.go Make CI use a dummy password hasher for all tests (#22983) 2023-02-20 13:20:30 +08:00
dummy_test.go Make CI use a dummy password hasher for all tests (#22983) 2023-02-20 13:20:30 +08:00
hash.go Make CI use a dummy password hasher for all tests (#22983) 2023-02-20 13:20:30 +08:00
hash_test.go Make CI use a dummy password hasher for all tests (#22983) 2023-02-20 13:20:30 +08:00
pbkdf2.go [v1.22] [GITEA] Drop sha256-simd in favor of stdlib 2023-10-30 14:37:04 +01:00
scrypt.go Make CI use a dummy password hasher for all tests (#22983) 2023-02-20 13:20:30 +08:00
setting.go [SECURITY] default to pbkdf2 with 320,000 iterations 2023-10-30 13:53:54 +01:00
setting_test.go [SECURITY] default to pbkdf2 with 320,000 iterations 2023-10-30 13:53:54 +01:00