freebsd-dev/crypto/openssh/bufec.c

75 lines
1.9 KiB
C
Raw Normal View History

2015-01-05 16:09:55 +00:00
/* $OpenBSD: bufec.c,v 1.4 2014/04/30 05:29:56 djm Exp $ */
2011-02-17 11:47:40 +00:00
/*
2015-01-05 16:09:55 +00:00
* Copyright (c) 2012 Damien Miller <djm@mindrot.org>
2011-02-17 11:47:40 +00:00
*
* Permission to use, copy, modify, and distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
2015-01-05 16:09:55 +00:00
/* Emulation wrappers for legacy OpenSSH buffer API atop sshbuf */
2011-02-17 11:47:40 +00:00
2015-01-05 16:09:55 +00:00
#include "includes.h"
2011-02-17 11:47:40 +00:00
#include <sys/types.h>
#include "buffer.h"
#include "log.h"
2015-01-05 16:09:55 +00:00
#include "ssherr.h"
2011-02-17 11:47:40 +00:00
2015-01-05 16:09:55 +00:00
#ifdef OPENSSL_HAS_ECC
2011-02-17 11:47:40 +00:00
int
buffer_put_ecpoint_ret(Buffer *buffer, const EC_GROUP *curve,
const EC_POINT *point)
{
2015-01-05 16:09:55 +00:00
int ret;
2011-02-17 11:47:40 +00:00
2015-01-05 16:09:55 +00:00
if ((ret = sshbuf_put_ec(buffer, point, curve)) != 0) {
error("%s: %s", __func__, ssh_err(ret));
return -1;
2011-02-17 11:47:40 +00:00
}
2015-01-05 16:09:55 +00:00
return 0;
2011-02-17 11:47:40 +00:00
}
void
buffer_put_ecpoint(Buffer *buffer, const EC_GROUP *curve,
const EC_POINT *point)
{
if (buffer_put_ecpoint_ret(buffer, curve, point) == -1)
fatal("%s: buffer error", __func__);
}
int
buffer_get_ecpoint_ret(Buffer *buffer, const EC_GROUP *curve,
EC_POINT *point)
{
2015-01-05 16:09:55 +00:00
int ret;
2011-02-17 11:47:40 +00:00
2015-01-05 16:09:55 +00:00
if ((ret = sshbuf_get_ec(buffer, point, curve)) != 0) {
error("%s: %s", __func__, ssh_err(ret));
2011-02-17 11:47:40 +00:00
return -1;
}
2015-01-05 16:09:55 +00:00
return 0;
2011-02-17 11:47:40 +00:00
}
void
buffer_get_ecpoint(Buffer *buffer, const EC_GROUP *curve,
EC_POINT *point)
{
if (buffer_get_ecpoint_ret(buffer, curve, point) == -1)
fatal("%s: buffer error", __func__);
}
#endif /* OPENSSL_HAS_ECC */
2015-01-05 16:09:55 +00:00