Checkboxes
This commit is contained in:
parent
ab412bda38
commit
06dcca459e
48
README.md
48
README.md
@ -22,29 +22,31 @@ listed below.
|
||||
|
||||
## Requirements on C implementations that are automatically checked
|
||||
|
||||
* Code is valid C99
|
||||
* Passes functional tests
|
||||
* API functions do not write outside provided buffers
|
||||
* Compiles with `-Wall -Wextra -Wpedantic -Werror` with `gcc` and `clang`
|
||||
* Consistent test vectors across runs
|
||||
* Consistent test vectors on big-endian and little-endian machines
|
||||
* Consistent test vectors on 32-bit and 64-bit machines
|
||||
* No errors/warnings reported by valgrind
|
||||
* No errors/warnings reported by address sanitizer
|
||||
* Only dependencies:
|
||||
* `common_crypto.c` (Keccak, AES, SHA-2)
|
||||
* `randombytes.c`
|
||||
* API functions return `0` on success, negative on failure
|
||||
* No dynamic memory allocations
|
||||
* No branching on secret data (dynamically checked using valgrind)
|
||||
* No access to secret memory locations (dynamically checked using valgrind)
|
||||
* Separate subdirectories (without symlinks) for each parameter set of each scheme
|
||||
* Builds under Linux, MacOS, and Windows
|
||||
* Makefile-based build for each separate scheme
|
||||
* Makefile-based build for Windows (`nmake`)
|
||||
* All exported symbols are namespaced with `PQCLEAN_SCHEMENAME_`
|
||||
* Each implementation comes with a `LICENSE` file (see below)
|
||||
* Each implementation comes with a `META` file giving details about version of the algorithm, designers, etc.
|
||||
_The checking of items on this list is still being developed. Checked items should be working._
|
||||
|
||||
* [ ] Code is valid C99
|
||||
* [ ] Passes functional tests
|
||||
* [ ] API functions do not write outside provided buffers
|
||||
* [ ] Compiles with `-Wall -Wextra -Wpedantic -Werror` with `gcc` and `clang`
|
||||
* [ ] Consistent test vectors across runs
|
||||
* [ ] Consistent test vectors on big-endian and little-endian machines
|
||||
* [ ] Consistent test vectors on 32-bit and 64-bit machines
|
||||
* [ ] No errors/warnings reported by valgrind
|
||||
* [ ] No errors/warnings reported by address sanitizer
|
||||
* [ ] Only dependencies:
|
||||
* [ ] `common_crypto.c` (Keccak, AES, SHA-2)
|
||||
* [ ] `randombytes.c`
|
||||
* [ ] API functions return `0` on success, negative on failure
|
||||
* [ ] No dynamic memory allocations
|
||||
* [ ] No branching on secret data (dynamically checked using valgrind)
|
||||
* [ ] No access to secret memory locations (dynamically checked using valgrind)
|
||||
* [ ] Separate subdirectories (without symlinks) for each parameter set of each scheme
|
||||
* [ ] Builds under Linux, MacOS, and Windows
|
||||
* [ ] Makefile-based build for each separate scheme
|
||||
* [ ] Makefile-based build for Windows (`nmake`)
|
||||
* [ ] All exported symbols are namespaced with `PQCLEAN_SCHEMENAME_`
|
||||
* [ ] Each implementation comes with a `LICENSE` file (see below)
|
||||
* [ ] Each implementation comes with a `META` file giving details about version of the algorithm, designers, etc.
|
||||
|
||||
|
||||
## Requirements on C implementations that are manually checked
|
||||
|
Loading…
Reference in New Issue
Block a user