uint64_t timeout; /* Timeout for current state */
uint8_t *dhsecret;
uint8_t *sharedsecret;
- uint32_t sharedsecretlen, sharedsecretallocd;
struct transform_inst_if *new_transform; /* For key setup/verify */
};
{
_Bool ok;
- /* Make room for the shared key */
- st->sharedsecretlen=st->chosen_transform->keylen?:st->dh->shared_len;
- assert(st->sharedsecretlen);
- if (st->sharedsecretlen > st->sharedsecretallocd) {
- st->sharedsecretallocd=st->sharedsecretlen;
- st->sharedsecret=safe_realloc_ary(st->sharedsecret,1,
- st->sharedsecretallocd,
- "site:sharedsecret");
- }
-
/* Generate the shared key */
if (!st->dh->makeshared(st->dh->st,st->dhsecret,st->dh->secret_len,
- pk, st->sharedsecret,st->sharedsecretlen))
+ pk, st->sharedsecret,st->dh->shared_len))
return False;
/* Set up the transform */
struct transform_if *generator=st->chosen_transform;
struct transform_inst_if *generated=generator->create(generator->st);
ok = generated->setkey(generated->st,st->sharedsecret,
- st->sharedsecretlen,st->our_name_later);
+ st->dh->shared_len,st->our_name_later);
dispose_transform(&st->new_transform);
if (!ok) return False;
FILLZERO(st->remoteN);
dispose_transform(&st->new_transform);
memset(st->dhsecret,0,st->dh->secret_len);
- if (st->sharedsecret) memset(st->sharedsecret,0,st->sharedsecretlen);
+ memset(st->sharedsecret,0,st->dh->shared_len);
set_link_quality(st);
if (st->keepalive && !current_valid(st))
transport_peers_clear(st,&st->setup_peers);
/* XXX mlock these */
st->dhsecret=safe_malloc(st->dh->secret_len,"site:dhsecret");
- st->sharedsecretlen=st->sharedsecretallocd=0;
- st->sharedsecret=0;
+ st->sharedsecret=safe_malloc(st->dh->shared_len, "site:sharedsecret");
#define SET_CAPBIT(bit) do { \
uint32_t capflag = 1UL << (bit); \
update_max_start_pad(&transform_max_start_pad, 28);
/* 4byte seqnum, 16byte pad, 4byte MACIV, 4byte IV */
- /* We need 256*2 bits for serpent keys, 32 bits for CBC-IV and 32 bits
- for CBCMAC-IV, and 32 bits for init sequence number */
- st->ops.keylen=REQUIRED_KEYLEN;
st->ops.create=transform_create;
/* First parameter must be a dict */