Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/oasisprotocol/deoxysii
Go Deoxys-II-256-128
https://github.com/oasisprotocol/deoxysii
aead cryptography go golang mrae
Last synced: 2 months ago
JSON representation
Go Deoxys-II-256-128
- Host: GitHub
- URL: https://github.com/oasisprotocol/deoxysii
- Owner: oasisprotocol
- License: mit
- Created: 2019-03-19T13:31:26.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2024-04-17T15:09:25.000Z (9 months ago)
- Last Synced: 2024-06-21T18:12:24.783Z (7 months ago)
- Topics: aead, cryptography, go, golang, mrae
- Language: Go
- Size: 246 KB
- Stars: 24
- Watchers: 29
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
### deoxysii - Deoxys-II-256-128 for Go
[![Build status][github-ci-tests-badge]][github-ci-tests-link]
[![GoDoc][godoc-badge]][godoc-link][github-ci-tests-badge]: https://github.com/oasisprotocol/deoxysii/workflows/ci-tests/badge.svg
[github-ci-tests-link]: https://github.com/oasisprotocol/deoxysii/actions?query=workflow:ci-tests
[godoc-badge]: https://godoc.org/github.com/oasisprotocol/deoxysii?status.svg
[godoc-link]: https://godoc.org/github.com/oasisprotocol/deoxysiiThis package provides a "from-the-paper" implementation of the
[Deoxys-II-256-128 v1.43][1] algorithm from the [final CAESAR portfolio][2].#### Implementations
* (`ct32`) Portable 32 bit constant time implementation (Extremely slow).
* (`ct64`) Portable 64 bit constant time implementation (Extremely slow).
* (`aesni`) SSSE3 + AESNI implementation for `amd64`
* (`vartime`) Portable and variable time (insecure) implementation,
for illustrative purposes (tested/benchmarked but never reachable
or usable by external consumers).#### Notes
Performance for the AES-NI implementation still has room for improvement,
however given that the Deoxys-BC-384 tweakable block cipher has 3 more
rounds than AES-256, and Deoxys-II will do two passes over the data
payload, it is likely reasonably close to what can be expected.The pure software constant time implementation would benefit considerably
from vector optimizations as the amount of internal paralleism is quite
high, making it well suited to be implemented with [bitslicing][3].
Additionally a rather ludicrous amount of time is spent implementing the
`h` permutation in software, that can be replaced with a single `PSHUFB`
instruction.[1]: https://drive.google.com/file/d/1IUELtBUdp6vrY8uhxHhycsGuSH_XlpMJ/view?usp=drive_web
[2]: https://competitions.cr.yp.to/caesar-submissions.html
[3]: https://eprint.iacr.org/2009/129.pdf