return (&key->k); \
} \
\
+static int gcszok(size_t nsz, size_t hsz, size_t msz, size_t tsz) \
+ { return (gaead_szokcommon(&pre##_ocb3, nsz, hsz, msz, tsz)); } \
+ \
const gcaead pre##_ocb3 = { \
name "-ocb3", \
pre##_keysz, pre##_ocb3noncesz, pre##_ocb3tagsz, \
PRE##_BLKSZ, PRE##_BLKSZ - 1, 0, AEADF_PCTSZ, \
- gckey \
+ gckey, gcszok \
}; \
\
OCB3_TESTX(PRE, pre, name, fname)
d.len = BLEN(&b); \
\
if (d.len != v[4].len || \
- memcmp(d.buf, v[4].buf, v[4].len) != 0 || \
- memcmp(t.buf, v[5].buf, v[5].len) != 0) { \
+ MEMCMP(d.buf, !=, v[4].buf, v[4].len) || \
+ MEMCMP(t.buf, !=, v[5].buf, v[5].len)) { \
fail_enc: \
printf("\nfail encrypt:\n\tstep = %i", *ip); \
fputs("\n\tkey = ", stdout); type_hex.dump(&v[0], stdout); \
d.len = BLEN(&b); \
\
if (d.len != v[3].len || !win || \
- memcmp(d.buf, v[3].buf, v[3].len) != 0) { \
+ MEMCMP(d.buf, !=, v[3].buf, v[3].len)) { \
fail_dec: \
printf("\nfail decrypt:\n\tstep = %i", *ip); \
fputs("\n\tkey = ", stdout); type_hex.dump(&v[0], stdout); \
if (rc) goto fail; \
\
d.len = tsz; \
- if (memcmp(d.buf, v[1].buf, tsz) != 0) { \
+ if (MEMCMP(d.buf, !=, v[1].buf, tsz)) { \
fail: \
printf("\nfail mct: ksz = %u, tsz = %u", ksz, tsz); \
fputs("\n\texp tag = ", stdout); type_hex.dump(&v[1], stdout); \