Skip to content

CI: Split mingw-w64 tests into per-PR and daily sets#1714

Open
mkannwischer wants to merge 1 commit into
mainfrom
ci-mingw-legacy-versions
Open

CI: Split mingw-w64 tests into per-PR and daily sets#1714
mkannwischer wants to merge 1 commit into
mainfrom
ci-mingw-legacy-versions

Conversation

@mkannwischer
Copy link
Copy Markdown
Contributor

Previously every PR tested a fixed set of mingw-w64 versions.

Mirror the gcc/clang/zig setup: base.yml now tests only the oldest working version (5.4.0) plus the three most recent majors (13.2.0, 14.2.0, 15.2.0) on every PR, while legacy-compilers.yml tests each major version (5.4.0 through 15.2.0) daily.

Previously every PR tested a fixed set of mingw-w64 versions.

Mirror the gcc/clang/zig setup: base.yml now tests only the oldest
working version (5.4.0) plus the three most recent majors (13.2.0,
14.2.0, 15.2.0) on every PR, while legacy-compilers.yml tests each
major version (5.4.0 through 15.2.0) daily.

- Ports pq-code-package/mldsa-native#1138.

Signed-off-by: Matthias J. Kannwischer <matthias@zerorisc.com>
@mkannwischer mkannwischer added the legacy-compiler-tests Triggers legacy compiler tests in CI label Jun 1, 2026
@oqs-bot
Copy link
Copy Markdown
Contributor

oqs-bot commented Jun 1, 2026

CBMC Results (ML-KEM-1024)

Full Results (191 proofs)
Proof Status Current Previous Change
**TOTAL** 1223s 1143s +7.0%
mlk_indcpa_enc 139s 131s +6%
mlk_rej_uniform_c 133s 109s +22%
mlk_indcpa_keypair_derand 123s 118s +4%
mlk_polyvec_basemul_acc_montgomery_cached_c 75s 68s +10%
polyvec_basemul_acc_montgomery_cached_native 36s 31s +16%
mlk_ntt_layer 34s 29s +17%
mlk_poly_rej_uniform 34s 29s +17%
poly_ntt_native 26s 23s +13%
mlk_keccak_squeezeblocks_x4 25s 26s -4%
mlk_poly_reduce_native 21s 20s +5%
mlk_fqmul 17s 18s -6%
keccakf1600x4_permute_native_x4 16s 18s -11%
mlk_poly_decompress_d11_native 15s 12s +25%
mlk_poly_decompress_d5_native 15s 15s +0%
mlk_indcpa_dec 11s 8s +38%
mlk_polyvec_add 11s 9s +22%
mlk_keccak_squeeze_once 9s 7s +29%
mlk_poly_frombytes_native 9s 8s +12%
mlk_poly_frommsg 9s 8s +12%
mlk_poly_ntt 9s 6s +50%
mlk_keccak_squeezeblocks 8s 8s +0%
mlk_keccak_absorb_once_x4 7s 5s +40%
mlk_polymat_permute_bitrev_to_custom 7s 7s +0%
mlk_polyvec_tomont 7s 1s +600%
rej_uniform_native_x86_64 7s 6s +17%
mlk_ct_get_optblocker_i32 6s 5s +20%
mlk_gen_matrix 6s 5s +20%
mlk_ntt_butterfly_block 6s 7s -14%
mlk_poly_rej_uniform_x4 6s 5s +20%
mlk_value_barrier_u32 6s 4s +50%
mlk_gen_matrix_serial 5s 5s +0%
mlk_invntt_layer 5s 4s +25%
poly_decompress_d10_native_x86_64 5s 1s +400%
sys_check_capability 5s 2s +150%
kem_check_pk 4s 4s +0%
kem_enc_derand 4s 3s +33%
kem_keypair 4s 2s +100%
mlk_barrett_reduce 4s 3s +33%
mlk_ct_cmask_nonzero_u8 4s 2s +100%
mlk_ct_cmov_zero 4s 2s +100%
mlk_ct_sel_int16 4s 1s +300%
mlk_keccakf1600_permute_c 4s 7s -43%
mlk_matvec_mul 4s 2s +100%
mlk_poly_compress_d11_c 4s 6s -33%
mlk_poly_compress_d5_native 4s 2s +100%
mlk_poly_mulcache_compute_native 4s 4s +0%
mlk_poly_ntt_c 4s 3s +33%
mlk_polyvec_compress_du 4s 1s +300%
mlk_polyvec_ntt 4s 3s +33%
mlk_scalar_compress_d11 4s 4s +0%
mlk_shake128x4_squeezeblocks 4s 3s +33%
mlk_shake256x4 4s 2s +100%
mlk_value_barrier_u8 4s 2s +100%
poly_decompress_d11_native_x86_64 4s 6s -33%
poly_decompress_d5_native_x86_64 4s 5s -20%
poly_frombytes_native_x86_64 4s 6s -33%
polyvec_basemul_acc_montgomery_cached_k3_native_x86_64 4s 3s +33%
polyvec_basemul_acc_montgomery_cached_k4_native_x86_64 4s 2s +100%
keccak_f1600_x4_native_aarch64_v8a_scalar_hybrid 3s 1s +200%
keccakf1600x4_xor_bytes_native 3s 1s +200%
kem_dec 3s 4s -25%
mlk_ct_memcmp 3s 2s +50%
mlk_enc_getnoise_eta1_eta2 3s 2s +50%
mlk_keccak_absorb_once 3s 5s -40%
mlk_keccakf1600_extract_bytes (big endian) 3s 2s +50%
mlk_keccakf1600x4_extract_bytes 3s 3s +0%
mlk_keccakf1600x4_xor_bytes 3s 1s +200%
mlk_poly_cbd_eta1 3s 3s +0%
mlk_poly_compress_d10 3s 2s +50%
mlk_poly_compress_d11 3s 1s +200%
mlk_poly_compress_d4_native 3s 1s +200%
mlk_poly_compress_d5 3s 3s +0%
mlk_poly_compress_du 3s 4s -25%
mlk_poly_decompress_d10 3s 2s +50%
mlk_poly_decompress_dv 3s 2s +50%
mlk_poly_getnoise_eta1_4x 3s 5s -40%
mlk_poly_invntt_tomont 3s 2s +50%
mlk_poly_mulcache_compute_c 3s 1s +200%
mlk_poly_tobytes 3s 1s +200%
mlk_poly_tobytes_c 3s 2s +50%
mlk_poly_tomont_c 3s 2s +50%
mlk_poly_tomsg 3s 1s +200%
mlk_polyvec_permute_bitrev_to_custom 3s 3s +0%
mlk_polyvec_reduce 3s 3s +0%
mlk_polyvec_tobytes 3s 2s +50%
mlk_scalar_compress_d10 3s 2s +50%
mlk_scalar_decompress_d11 3s 2s +50%
mlk_sha3_256 3s 2s +50%
ntt_native_x86_64 3s 5s -40%
nttunpack_native_x86_64 3s 5s -40%
poly_decompress_d4_native_x86_64 3s 2s +50%
poly_invntt_tomont_native 3s 2s +50%
poly_mulcache_compute_native_aarch64 3s 2s +50%
poly_reduce_native_aarch64 3s 4s -25%
poly_tobytes_native_aarch64 3s 3s +0%
polyvec_basemul_acc_montgomery_cached_k2_native_aarch64 3s 2s +50%
polyvec_basemul_acc_montgomery_cached_k4_native_aarch64 3s 2s +50%
rej_uniform_native 3s 1s +200%
rej_uniform_native_aarch64 3s 3s +0%
intt_native_aarch64 2s 3s -33%
intt_native_x86_64 2s 1s +100%
keccak_f1600_x1_native_aarch64_v84a 2s 1s +100%
keccak_f1600_x4_native_aarch64_v84a 2s 1s +100%
keccak_f1600_x4_native_aarch64_v8a_v84a_scalar_hybrid 2s 1s +100%
keccak_f1600_x4_native_avx2 2s 3s -33%
keccakf1600x4_extract_bytes_native 2s 3s -33%
kem_check_sk 2s 3s -33%
mlk_check_pct 2s 3s -33%
mlk_ct_cmask_nonzero_u16 2s 2s +0%
mlk_ct_get_optblocker_u32 2s 1s +100%
mlk_ct_sel_uint8 2s 3s -33%
mlk_keccakf1600_extract_bytes 2s 2s +0%
mlk_keccakf1600_xor_bytes (big endian) 2s 2s +0%
mlk_keccakf1600x4_extract_bytes_c 2s 3s -33%
mlk_keccakf1600x4_xor_bytes_c 2s 3s -33%
mlk_poly_add 2s 3s -33%
mlk_poly_compress_d11_native 2s 3s -33%
mlk_poly_compress_d4_c 2s 1s +100%
mlk_poly_compress_d5_c 2s 3s -33%
mlk_poly_compress_dv 2s 3s -33%
mlk_poly_decompress_d10_c 2s 3s -33%
mlk_poly_decompress_d10_native 2s 2s +0%
mlk_poly_decompress_d11 2s 2s +0%
mlk_poly_decompress_d11_c 2s 2s +0%
mlk_poly_decompress_d4 2s 2s +0%
mlk_poly_decompress_d4_native 2s 1s +100%
mlk_poly_decompress_d5_c 2s 3s -33%
mlk_poly_frombytes 2s 3s -33%
mlk_poly_getnoise_eta1_4x_native 2s 2s +0%
mlk_poly_invntt_tomont_c 2s 1s +100%
mlk_poly_mulcache_compute 2s 2s +0%
mlk_poly_reduce 2s 1s +100%
mlk_poly_sub 2s 2s +0%
mlk_poly_tobytes_native 2s 2s +0%
mlk_poly_tomont 2s 2s +0%
mlk_poly_tomont_native 2s 3s -33%
mlk_polyvec_basemul_acc_montgomery_cached 2s 3s -33%
mlk_polyvec_frombytes 2s 2s +0%
mlk_polyvec_mulcache_compute 2s 2s +0%
mlk_polyvec_permute_bitrev_to_custom_native 2s 4s -50%
mlk_rej_uniform 2s 3s -33%
mlk_scalar_compress_d4 2s 2s +0%
mlk_scalar_decompress_d10 2s 3s -33%
mlk_scalar_decompress_d4 2s 1s +100%
mlk_scalar_decompress_d5 2s 3s -33%
mlk_scalar_signed_to_unsigned_q 2s 2s +0%
mlk_sha3_512 2s 3s -33%
mlk_shake128_absorb_once 2s 2s +0%
mlk_shake128x4_absorb_once 2s 2s +0%
mlk_value_barrier_i32 2s 3s -33%
ntt_native_aarch64 2s 3s -33%
poly_compress_d10_native_x86_64 2s 1s +100%
poly_compress_d11_native_x86_64 2s 2s +0%
poly_mulcache_compute_native_x86_64 2s 3s -33%
poly_tobytes_native_x86_64 2s 5s -60%
poly_tomont_native_aarch64 2s 1s +100%
poly_tomont_native_x86_64 2s 2s +0%
polyvec_basemul_acc_montgomery_cached_k2_native_x86_64 2s 2s +0%
keccak_f1600_x1_native_aarch64 1s 3s -67%
keccakf1600_permute_native 1s 2s -50%
kem_enc 1s 3s -67%
kem_keypair_derand 1s 1s +0%
mlk_ct_cmask_neg_i16 1s 2s -50%
mlk_ct_get_optblocker_u8 1s 2s -50%
mlk_keccakf1600_permute 1s 3s -67%
mlk_keccakf1600_xor_bytes 1s 1s +0%
mlk_keccakf1600x4_permute 1s 2s -50%
mlk_keypair_getnoise_eta1 1s 3s -67%
mlk_montgomery_reduce 1s 1s +0%
mlk_poly_cbd_eta2 1s 3s -67%
mlk_poly_compress_d10_c 1s 1s +0%
mlk_poly_compress_d10_native 1s 2s -50%
mlk_poly_compress_d4 1s 2s -50%
mlk_poly_decompress_d4_c 1s 3s -67%
mlk_poly_decompress_d5 1s 1s +0%
mlk_poly_decompress_du 1s 2s -50%
mlk_poly_frombytes_c 1s 3s -67%
mlk_poly_getnoise_eta1122_4x 1s 3s -67%
mlk_poly_getnoise_eta2 1s 4s -75%
mlk_poly_reduce_c 1s 2s -50%
mlk_polyvec_decompress_du 1s 1s +0%
mlk_polyvec_invntt_tomont 1s 2s -50%
mlk_scalar_compress_d1 1s 4s -75%
mlk_scalar_compress_d5 1s 2s -50%
mlk_shake128_squeezeblocks 1s 2s -50%
mlk_shake256 1s 2s -50%
poly_compress_d4_native_x86_64 1s 2s -50%
poly_compress_d5_native_x86_64 1s 4s -75%
poly_getnoise_eta1122_4x_native 1s 3s -67%
poly_reduce_native_x86_64 1s 1s +0%
polyvec_basemul_acc_montgomery_cached_k3_native_aarch64 1s 2s -50%

@oqs-bot
Copy link
Copy Markdown
Contributor

oqs-bot commented Jun 1, 2026

CBMC Results (ML-KEM-768)

Full Results (191 proofs)
Proof Status Current Previous Change
**TOTAL** 1226s 1235s -0.7%
mlk_indcpa_keypair_derand 183s 193s -5%
mlk_indcpa_enc 165s 170s -3%
mlk_rej_uniform_c 119s 125s -5%
mlk_polyvec_basemul_acc_montgomery_cached_c 43s 44s -2%
mlk_poly_rej_uniform 30s 33s -9%
mlk_ntt_layer 29s 30s -3%
poly_ntt_native 27s 25s +8%
mlk_keccak_squeezeblocks_x4 25s 24s +4%
mlk_poly_reduce_native 20s 20s +0%
polyvec_basemul_acc_montgomery_cached_native 19s 17s +12%
keccakf1600x4_permute_native_x4 17s 16s +6%
mlk_fqmul 15s 17s -12%
mlk_poly_decompress_d10_native 14s 14s +0%
mlk_poly_decompress_d4_native 14s 12s +17%
mlk_indcpa_dec 12s 13s -8%
mlk_polyvec_add 9s 8s +12%
rej_uniform_native_x86_64 9s 5s +80%
mlk_keccak_squeezeblocks 8s 10s -20%
mlk_poly_compress_d11 8s 2s +300%
mlk_poly_frommsg 8s 7s +14%
mlk_keccak_absorb_once_x4 7s 5s +40%
mlk_ntt_butterfly_block 7s 7s +0%
mlk_poly_frombytes_native 7s 7s +0%
mlk_poly_ntt 7s 8s -12%
mlk_poly_rej_uniform_x4 7s 6s +17%
mlk_keccak_squeeze_once 6s 7s -14%
mlk_keccakf1600_permute_c 6s 3s +100%
kem_dec 5s 3s +67%
mlk_enc_getnoise_eta1_eta2 5s 3s +67%
mlk_gen_matrix_serial 5s 3s +67%
mlk_invntt_layer 5s 4s +25%
mlk_keccakf1600x4_permute 5s 2s +150%
poly_compress_d10_native_x86_64 5s 2s +150%
poly_decompress_d4_native_x86_64 5s 4s +25%
poly_frombytes_native_x86_64 5s 5s +0%
intt_native_aarch64 4s 3s +33%
keccak_f1600_x4_native_avx2 4s 1s +300%
kem_check_pk 4s 5s -20%
mlk_ct_cmov_zero 4s 3s +33%
mlk_ct_get_optblocker_u8 4s 2s +100%
mlk_poly_decompress_d4 4s 2s +100%
mlk_poly_decompress_d4_c 4s 2s +100%
mlk_poly_decompress_d5 4s 2s +100%
mlk_poly_sub 4s 1s +300%
mlk_polymat_permute_bitrev_to_custom 4s 4s +0%
mlk_polyvec_mulcache_compute 4s 1s +300%
mlk_polyvec_ntt 4s 2s +100%
mlk_polyvec_reduce 4s 4s +0%
mlk_scalar_decompress_d10 4s 1s +300%
mlk_scalar_decompress_d11 4s 1s +300%
poly_decompress_d11_native_x86_64 4s 1s +300%
poly_reduce_native_aarch64 4s 2s +100%
keccak_f1600_x1_native_aarch64 3s 1s +200%
keccak_f1600_x1_native_aarch64_v84a 3s 1s +200%
kem_check_sk 3s 2s +50%
mlk_check_pct 3s 4s -25%
mlk_ct_cmask_neg_i16 3s 1s +200%
mlk_ct_cmask_nonzero_u16 3s 3s +0%
mlk_ct_cmask_nonzero_u8 3s 1s +200%
mlk_ct_sel_uint8 3s 2s +50%
mlk_keccak_absorb_once 3s 5s -40%
mlk_keccakf1600_extract_bytes (big endian) 3s 3s +0%
mlk_keccakf1600_permute 3s 3s +0%
mlk_keccakf1600_xor_bytes (big endian) 3s 4s -25%
mlk_poly_cbd_eta2 3s 2s +50%
mlk_poly_compress_d11_c 3s 3s +0%
mlk_poly_compress_d11_native 3s 3s +0%
mlk_poly_compress_d5_native 3s 2s +50%
mlk_poly_compress_dv 3s 3s +0%
mlk_poly_decompress_d10_c 3s 4s -25%
mlk_poly_decompress_d5_c 3s 2s +50%
mlk_poly_decompress_d5_native 3s 3s +0%
mlk_poly_decompress_du 3s 1s +200%
mlk_poly_frombytes_c 3s 2s +50%
mlk_poly_getnoise_eta1122_4x 3s 2s +50%
mlk_poly_getnoise_eta1_4x_native 3s 2s +50%
mlk_poly_invntt_tomont_c 3s 3s +0%
mlk_poly_mulcache_compute 3s 4s -25%
mlk_poly_reduce 3s 2s +50%
mlk_poly_tomont 3s 2s +50%
mlk_polyvec_frombytes 3s 1s +200%
mlk_polyvec_invntt_tomont 3s 3s +0%
mlk_polyvec_permute_bitrev_to_custom 3s 2s +50%
mlk_polyvec_tobytes 3s 4s -25%
mlk_rej_uniform 3s 3s +0%
mlk_scalar_decompress_d5 3s 2s +50%
mlk_shake128x4_absorb_once 3s 1s +200%
mlk_shake128x4_squeezeblocks 3s 3s +0%
mlk_shake256x4 3s 4s -25%
ntt_native_x86_64 3s 4s -25%
nttunpack_native_x86_64 3s 6s -50%
poly_compress_d11_native_x86_64 3s 1s +200%
poly_decompress_d10_native_x86_64 3s 5s -40%
poly_decompress_d5_native_x86_64 3s 5s -40%
poly_getnoise_eta1122_4x_native 3s 2s +50%
poly_tobytes_native_x86_64 3s 3s +0%
poly_tomont_native_aarch64 3s 1s +200%
polyvec_basemul_acc_montgomery_cached_k2_native_aarch64 3s 2s +50%
polyvec_basemul_acc_montgomery_cached_k3_native_x86_64 3s 3s +0%
rej_uniform_native_aarch64 3s 3s +0%
sys_check_capability 3s 3s +0%
keccak_f1600_x4_native_aarch64_v84a 2s 3s -33%
keccak_f1600_x4_native_aarch64_v8a_scalar_hybrid 2s 3s -33%
keccakf1600x4_extract_bytes_native 2s 4s -50%
keccakf1600x4_xor_bytes_native 2s 2s +0%
kem_enc 2s 3s -33%
kem_enc_derand 2s 3s -33%
kem_keypair 2s 2s +0%
kem_keypair_derand 2s 3s -33%
mlk_barrett_reduce 2s 2s +0%
mlk_ct_get_optblocker_i32 2s 2s +0%
mlk_ct_get_optblocker_u32 2s 2s +0%
mlk_ct_sel_int16 2s 3s -33%
mlk_gen_matrix 2s 3s -33%
mlk_keccakf1600x4_extract_bytes_c 2s 2s +0%
mlk_matvec_mul 2s 4s -50%
mlk_poly_cbd_eta1 2s 1s +100%
mlk_poly_compress_d10 2s 2s +0%
mlk_poly_compress_d10_c 2s 3s -33%
mlk_poly_compress_d10_native 2s 3s -33%
mlk_poly_compress_d4 2s 2s +0%
mlk_poly_compress_d4_c 2s 2s +0%
mlk_poly_compress_d4_native 2s 1s +100%
mlk_poly_compress_d5 2s 4s -50%
mlk_poly_compress_d5_c 2s 3s -33%
mlk_poly_compress_du 2s 1s +100%
mlk_poly_decompress_d10 2s 4s -50%
mlk_poly_decompress_d11 2s 2s +0%
mlk_poly_decompress_d11_c 2s 3s -33%
mlk_poly_decompress_dv 2s 2s +0%
mlk_poly_frombytes 2s 2s +0%
mlk_poly_getnoise_eta1_4x 2s 2s +0%
mlk_poly_getnoise_eta2 2s 1s +100%
mlk_poly_invntt_tomont 2s 3s -33%
mlk_poly_mulcache_compute_c 2s 2s +0%
mlk_poly_mulcache_compute_native 2s 3s -33%
mlk_poly_ntt_c 2s 3s -33%
mlk_poly_tobytes_c 2s 3s -33%
mlk_poly_tobytes_native 2s 2s +0%
mlk_polyvec_basemul_acc_montgomery_cached 2s 1s +100%
mlk_scalar_compress_d11 2s 1s +100%
mlk_scalar_compress_d5 2s 2s +0%
mlk_scalar_decompress_d4 2s 2s +0%
mlk_sha3_256 2s 2s +0%
mlk_sha3_512 2s 3s -33%
mlk_shake128_absorb_once 2s 2s +0%
mlk_shake128_squeezeblocks 2s 3s -33%
mlk_shake256 2s 2s +0%
mlk_value_barrier_i32 2s 3s -33%
mlk_value_barrier_u32 2s 3s -33%
mlk_value_barrier_u8 2s 3s -33%
ntt_native_aarch64 2s 1s +100%
poly_compress_d4_native_x86_64 2s 2s +0%
poly_mulcache_compute_native_aarch64 2s 2s +0%
poly_reduce_native_x86_64 2s 2s +0%
poly_tobytes_native_aarch64 2s 2s +0%
poly_tomont_native_x86_64 2s 4s -50%
polyvec_basemul_acc_montgomery_cached_k3_native_aarch64 2s 1s +100%
polyvec_basemul_acc_montgomery_cached_k4_native_aarch64 2s 2s +0%
polyvec_basemul_acc_montgomery_cached_k4_native_x86_64 2s 2s +0%
rej_uniform_native 2s 5s -60%
intt_native_x86_64 1s 3s -67%
keccak_f1600_x4_native_aarch64_v8a_v84a_scalar_hybrid 1s 2s -50%
keccakf1600_permute_native 1s 1s +0%
mlk_ct_memcmp 1s 1s +0%
mlk_keccakf1600_extract_bytes 1s 2s -50%
mlk_keccakf1600_xor_bytes 1s 2s -50%
mlk_keccakf1600x4_extract_bytes 1s 2s -50%
mlk_keccakf1600x4_xor_bytes 1s 2s -50%
mlk_keccakf1600x4_xor_bytes_c 1s 3s -67%
mlk_keypair_getnoise_eta1 1s 4s -75%
mlk_montgomery_reduce 1s 1s +0%
mlk_poly_add 1s 4s -75%
mlk_poly_decompress_d11_native 1s 1s +0%
mlk_poly_reduce_c 1s 1s +0%
mlk_poly_tobytes 1s 2s -50%
mlk_poly_tomont_c 1s 2s -50%
mlk_poly_tomont_native 1s 3s -67%
mlk_poly_tomsg 1s 5s -80%
mlk_polyvec_compress_du 1s 2s -50%
mlk_polyvec_decompress_du 1s 3s -67%
mlk_polyvec_permute_bitrev_to_custom_native 1s 1s +0%
mlk_polyvec_tomont 1s 1s +0%
mlk_scalar_compress_d1 1s 5s -80%
mlk_scalar_compress_d10 1s 1s +0%
mlk_scalar_compress_d4 1s 2s -50%
mlk_scalar_signed_to_unsigned_q 1s 3s -67%
poly_compress_d5_native_x86_64 1s 2s -50%
poly_invntt_tomont_native 1s 3s -67%
poly_mulcache_compute_native_x86_64 1s 2s -50%
polyvec_basemul_acc_montgomery_cached_k2_native_x86_64 1s 2s -50%

@oqs-bot
Copy link
Copy Markdown
Contributor

oqs-bot commented Jun 1, 2026

CBMC Results (ML-KEM-512)

Full Results (191 proofs)
Proof Status Current Previous Change
**TOTAL** 1474s 1261s +16.9%
mlk_indcpa_keypair_derand 276s 229s +21%
mlk_indcpa_enc 189s 163s +16%
mlk_rej_uniform_c 163s 123s +33%
mlk_polyvec_basemul_acc_montgomery_cached_c 60s 51s +18%
mlk_ntt_layer 41s 31s +32%
mlk_poly_rej_uniform 34s 32s +6%
mlk_keccak_squeezeblocks_x4 30s 26s +15%
poly_ntt_native 30s 26s +15%
mlk_poly_reduce_native 22s 21s +5%
keccakf1600x4_permute_native_x4 19s 19s +0%
mlk_poly_decompress_d10_native 19s 15s +27%
mlk_fqmul 17s 16s +6%
mlk_indcpa_dec 17s 14s +21%
mlk_poly_decompress_d4_native 17s 12s +42%
mlk_polyvec_add 12s 12s +0%
mlk_keccak_squeezeblocks 11s 7s +57%
mlk_poly_frombytes_native 9s 8s +12%
mlk_poly_frommsg 9s 9s +0%
mlk_poly_ntt 9s 5s +80%
mlk_keccak_squeeze_once 8s 8s +0%
mlk_poly_cbd_eta2 8s 5s +60%
mlk_poly_rej_uniform_x4 8s 5s +60%
kem_dec 7s 5s +40%
mlk_invntt_layer 7s 4s +75%
mlk_keccak_absorb_once_x4 7s 5s +40%
mlk_ntt_butterfly_block 7s 7s +0%
poly_decompress_d10_native_x86_64 6s 3s +100%
poly_frombytes_native_x86_64 6s 6s +0%
polyvec_basemul_acc_montgomery_cached_native 6s 6s +0%
intt_native_x86_64 5s 1s +400%
mlk_keccakf1600_permute_c 5s 4s +25%
mlk_keypair_getnoise_eta1 5s 1s +400%
mlk_poly_getnoise_eta1_4x_native 5s 2s +150%
mlk_shake256x4 5s 4s +25%
poly_decompress_d4_native_x86_64 5s 4s +25%
poly_tomont_native_aarch64 5s 4s +25%
rej_uniform_native_x86_64 5s 4s +25%
kem_check_pk 4s 1s +300%
mlk_ct_cmov_zero 4s 2s +100%
mlk_keccak_absorb_once 4s 5s -20%
mlk_keccakf1600x4_extract_bytes 4s 3s +33%
mlk_keccakf1600x4_extract_bytes_c 4s 1s +300%
mlk_poly_compress_d5_native 4s 2s +100%
mlk_poly_getnoise_eta1122_4x 4s 2s +100%
mlk_poly_invntt_tomont_c 4s 4s +0%
mlk_poly_ntt_c 4s 3s +33%
mlk_poly_reduce 4s 2s +100%
mlk_poly_sub 4s 3s +33%
mlk_poly_tomsg 4s 3s +33%
mlk_rej_uniform 4s 1s +300%
mlk_scalar_compress_d10 4s 1s +300%
mlk_scalar_decompress_d5 4s 4s +0%
ntt_native_x86_64 4s 3s +33%
poly_compress_d11_native_x86_64 4s 3s +33%
poly_mulcache_compute_native_aarch64 4s 3s +33%
poly_mulcache_compute_native_x86_64 4s 4s +0%
poly_tobytes_native_aarch64 4s 1s +300%
poly_tobytes_native_x86_64 4s 4s +0%
polyvec_basemul_acc_montgomery_cached_k4_native_x86_64 4s 3s +33%
intt_native_aarch64 3s 2s +50%
keccakf1600x4_xor_bytes_native 3s 2s +50%
mlk_ct_cmask_nonzero_u8 3s 2s +50%
mlk_ct_sel_int16 3s 2s +50%
mlk_ct_sel_uint8 3s 3s +0%
mlk_keccakf1600x4_permute 3s 3s +0%
mlk_keccakf1600x4_xor_bytes_c 3s 2s +50%
mlk_poly_compress_d10 3s 2s +50%
mlk_poly_compress_d10_c 3s 2s +50%
mlk_poly_compress_d10_native 3s 1s +200%
mlk_poly_compress_d4 3s 1s +200%
mlk_poly_decompress_d10_c 3s 4s -25%
mlk_poly_decompress_d11 3s 2s +50%
mlk_poly_decompress_d11_c 3s 2s +50%
mlk_poly_decompress_d4 3s 3s +0%
mlk_poly_decompress_d4_c 3s 2s +50%
mlk_poly_decompress_du 3s 2s +50%
mlk_poly_frombytes 3s 2s +50%
mlk_poly_getnoise_eta1_4x 3s 1s +200%
mlk_poly_getnoise_eta2 3s 3s +0%
mlk_poly_mulcache_compute 3s 1s +200%
mlk_poly_mulcache_compute_c 3s 3s +0%
mlk_poly_mulcache_compute_native 3s 2s +50%
mlk_poly_reduce_c 3s 2s +50%
mlk_poly_tobytes 3s 2s +50%
mlk_poly_tobytes_c 3s 1s +200%
mlk_poly_tobytes_native 3s 2s +50%
mlk_poly_tomont 3s 3s +0%
mlk_poly_tomont_c 3s 1s +200%
mlk_polyvec_basemul_acc_montgomery_cached 3s 3s +0%
mlk_polyvec_frombytes 3s 1s +200%
mlk_polyvec_mulcache_compute 3s 6s -50%
mlk_polyvec_permute_bitrev_to_custom_native 3s 4s -25%
mlk_polyvec_reduce 3s 2s +50%
mlk_polyvec_tobytes 3s 2s +50%
mlk_scalar_compress_d1 3s 1s +200%
mlk_scalar_compress_d11 3s 3s +0%
mlk_scalar_compress_d4 3s 2s +50%
mlk_scalar_compress_d5 3s 1s +200%
mlk_scalar_decompress_d10 3s 1s +200%
mlk_sha3_512 3s 2s +50%
mlk_shake128_absorb_once 3s 2s +50%
mlk_value_barrier_u32 3s 1s +200%
mlk_value_barrier_u8 3s 2s +50%
poly_compress_d10_native_x86_64 3s 3s +0%
poly_compress_d4_native_x86_64 3s 1s +200%
poly_decompress_d5_native_x86_64 3s 3s +0%
poly_getnoise_eta1122_4x_native 3s 2s +50%
polyvec_basemul_acc_montgomery_cached_k3_native_x86_64 3s 2s +50%
polyvec_basemul_acc_montgomery_cached_k4_native_aarch64 3s 2s +50%
keccak_f1600_x4_native_aarch64_v84a 2s 2s +0%
keccak_f1600_x4_native_aarch64_v8a_scalar_hybrid 2s 2s +0%
keccak_f1600_x4_native_aarch64_v8a_v84a_scalar_hybrid 2s 1s +100%
keccak_f1600_x4_native_avx2 2s 4s -50%
keccakf1600_permute_native 2s 3s -33%
keccakf1600x4_extract_bytes_native 2s 3s -33%
kem_check_sk 2s 2s +0%
kem_enc 2s 4s -50%
kem_enc_derand 2s 5s -60%
kem_keypair_derand 2s 2s +0%
mlk_barrett_reduce 2s 1s +100%
mlk_ct_cmask_neg_i16 2s 3s -33%
mlk_ct_cmask_nonzero_u16 2s 3s -33%
mlk_ct_get_optblocker_i32 2s 2s +0%
mlk_ct_get_optblocker_u32 2s 3s -33%
mlk_gen_matrix 2s 3s -33%
mlk_keccakf1600_extract_bytes 2s 2s +0%
mlk_keccakf1600_permute 2s 3s -33%
mlk_matvec_mul 2s 2s +0%
mlk_poly_add 2s 3s -33%
mlk_poly_cbd_eta1 2s 2s +0%
mlk_poly_compress_d11 2s 4s -50%
mlk_poly_compress_d11_c 2s 5s -60%
mlk_poly_compress_d4_c 2s 2s +0%
mlk_poly_compress_d4_native 2s 2s +0%
mlk_poly_compress_d5 2s 2s +0%
mlk_poly_compress_d5_c 2s 2s +0%
mlk_poly_compress_du 2s 3s -33%
mlk_poly_decompress_d10 2s 1s +100%
mlk_poly_decompress_d5_c 2s 2s +0%
mlk_poly_decompress_d5_native 2s 2s +0%
mlk_poly_decompress_dv 2s 2s +0%
mlk_poly_frombytes_c 2s 3s -33%
mlk_poly_invntt_tomont 2s 1s +100%
mlk_poly_tomont_native 2s 3s -33%
mlk_polymat_permute_bitrev_to_custom 2s 2s +0%
mlk_polyvec_compress_du 2s 2s +0%
mlk_polyvec_decompress_du 2s 1s +100%
mlk_polyvec_invntt_tomont 2s 2s +0%
mlk_polyvec_ntt 2s 2s +0%
mlk_polyvec_permute_bitrev_to_custom 2s 3s -33%
mlk_polyvec_tomont 2s 5s -60%
mlk_scalar_decompress_d11 2s 3s -33%
mlk_sha3_256 2s 3s -33%
mlk_shake128_squeezeblocks 2s 2s +0%
mlk_shake128x4_absorb_once 2s 4s -50%
mlk_shake128x4_squeezeblocks 2s 1s +100%
mlk_value_barrier_i32 2s 2s +0%
ntt_native_aarch64 2s 3s -33%
nttunpack_native_x86_64 2s 3s -33%
poly_compress_d5_native_x86_64 2s 4s -50%
poly_decompress_d11_native_x86_64 2s 3s -33%
poly_invntt_tomont_native 2s 3s -33%
poly_reduce_native_aarch64 2s 3s -33%
poly_reduce_native_x86_64 2s 1s +100%
polyvec_basemul_acc_montgomery_cached_k2_native_aarch64 2s 2s +0%
polyvec_basemul_acc_montgomery_cached_k2_native_x86_64 2s 2s +0%
polyvec_basemul_acc_montgomery_cached_k3_native_aarch64 2s 3s -33%
rej_uniform_native_aarch64 2s 3s -33%
sys_check_capability 2s 2s +0%
keccak_f1600_x1_native_aarch64 1s 2s -50%
keccak_f1600_x1_native_aarch64_v84a 1s 2s -50%
kem_keypair 1s 2s -50%
mlk_check_pct 1s 2s -50%
mlk_ct_get_optblocker_u8 1s 1s +0%
mlk_ct_memcmp 1s 2s -50%
mlk_enc_getnoise_eta1_eta2 1s 2s -50%
mlk_gen_matrix_serial 1s 3s -67%
mlk_keccakf1600_extract_bytes (big endian) 1s 3s -67%
mlk_keccakf1600_xor_bytes 1s 2s -50%
mlk_keccakf1600_xor_bytes (big endian) 1s 2s -50%
mlk_keccakf1600x4_xor_bytes 1s 3s -67%
mlk_montgomery_reduce 1s 2s -50%
mlk_poly_compress_d11_native 1s 1s +0%
mlk_poly_compress_dv 1s 3s -67%
mlk_poly_decompress_d11_native 1s 2s -50%
mlk_poly_decompress_d5 1s 2s -50%
mlk_scalar_decompress_d4 1s 2s -50%
mlk_scalar_signed_to_unsigned_q 1s 3s -67%
mlk_shake256 1s 2s -50%
poly_tomont_native_x86_64 1s 1s +0%
rej_uniform_native 1s 3s -67%

@mkannwischer mkannwischer marked this pull request as ready for review June 1, 2026 07:32
@mkannwischer mkannwischer requested a review from a team as a code owner June 1, 2026 07:32
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

legacy-compiler-tests Triggers legacy compiler tests in CI

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants