Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/external/mpl/dhcp Gut omapip support since the socket stuff ...
details: https://anonhg.NetBSD.org/src/rev/39d2b9079f45
branches: trunk
changeset: 838313:39d2b9079f45
user: christos <christos%NetBSD.org@localhost>
date: Thu Jan 10 17:41:47 2019 +0000
description:
Gut omapip support since the socket stuff to support it is gone, and
adjust to the new isc library reality.
diffstat:
external/mpl/dhcp/Makefile.inc | 4 +-
external/mpl/dhcp/dist/common/dns.c | 84 ++++++++++++++++++++++++-----
external/mpl/dhcp/dist/omapip/buffer.c | 6 +-
external/mpl/dhcp/dist/omapip/connection.c | 7 +-
external/mpl/dhcp/dist/omapip/dispatch.c | 14 ++++-
external/mpl/dhcp/dist/omapip/isclib.c | 10 ++-
external/mpl/dhcp/dist/server/dhcpv6.c | 12 ++--
external/mpl/dhcp/dist/server/mdb6.c | 34 +++--------
external/mpl/dhcp/include/config.h | 13 ++++
9 files changed, 127 insertions(+), 57 deletions(-)
diffs (truncated from 539 to 300 lines):
diff -r d78bd11819d9 -r 39d2b9079f45 external/mpl/dhcp/Makefile.inc
--- a/external/mpl/dhcp/Makefile.inc Thu Jan 10 17:05:56 2019 +0000
+++ b/external/mpl/dhcp/Makefile.inc Thu Jan 10 17:41:47 2019 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: Makefile.inc,v 1.4 2018/08/12 15:39:22 christos Exp $
+# $NetBSD: Makefile.inc,v 1.5 2019/01/10 17:41:47 christos Exp $
WARNS?= 1 # XXX -Wshadow -Wcast-qual -Wsign-compare
@@ -10,7 +10,7 @@
-Wno-format-security -Wno-error=unused-const-variable
DIST:= ${.PARSEDIR}/dist
-BIND:= ${.PARSEDIR}/../../bsd/bind/dist
+BIND:= ${.PARSEDIR}/../../mpl/bind/dist
.PATH: ${DIST}/${DHCPSRCDIR}
COBJDIR!=cd ${.PARSEDIR}/lib/common && ${PRINTOBJDIR}
diff -r d78bd11819d9 -r 39d2b9079f45 external/mpl/dhcp/dist/common/dns.c
--- a/external/mpl/dhcp/dist/common/dns.c Thu Jan 10 17:05:56 2019 +0000
+++ b/external/mpl/dhcp/dist/common/dns.c Thu Jan 10 17:41:47 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: dns.c,v 1.2 2018/04/07 22:37:29 christos Exp $ */
+/* $NetBSD: dns.c,v 1.3 2019/01/10 17:41:47 christos Exp $ */
/* dns.c
@@ -29,14 +29,13 @@
*/
#include <sys/cdefs.h>
-__RCSID("$NetBSD: dns.c,v 1.2 2018/04/07 22:37:29 christos Exp $");
+__RCSID("$NetBSD: dns.c,v 1.3 2019/01/10 17:41:47 christos Exp $");
/*! \file common/dns.c
*/
#include "dhcpd.h"
#include "arpa/nameser.h"
-#include <isc/md5.h>
-#include <isc/sha2.h>
+#include <isc/md.h>
#include <dns/result.h>
/*
@@ -1482,8 +1481,9 @@
unsigned id_len)
{
struct data_string *id = &ddns_cb->dhcid;
- isc_sha256_t sha256;
- unsigned char buf[ISC_SHA256_DIGESTLENGTH];
+ isc_md_t *md;
+ isc_result_t result;
+ unsigned char buf[256]; // XXX: big enough > 32
unsigned char fwd_buf[256];
unsigned fwd_buflen = 0;
@@ -1491,6 +1491,11 @@
if (type < 0 || type > 65535)
return (0);
+ md = isc_md_new();
+ if (md == NULL) {
+ return (0);
+ }
+
/* We need to convert the fwd name to wire representation */
if (MRns_name_pton((char *)ddns_cb->fwd_name.data, fwd_buf, 256) == -1)
return (0);
@@ -1511,17 +1516,41 @@
/* The next is the digest type, SHA-256 is 1 */
putUChar(id->buffer->data + 2, 1u);
+
/* Computing the digest */
- isc_sha256_init(&sha256);
- isc_sha256_update(&sha256, identifier, id_len);
- isc_sha256_update(&sha256, fwd_buf, fwd_buflen);
- isc_sha256_final(buf, &sha256);
+ result = isc_md_init(md, ISC_MD_SHA256);
+ if (result != ISC_R_SUCCESS) {
+ goto end;
+ }
+
+ result = isc_md_update(md, identifier, id_len);
+ if (result != ISC_R_SUCCESS) {
+ goto end;
+ }
+
+ result = isc_md_update(md, fwd_buf, fwd_buflen);
+ if (result != ISC_R_SUCCESS) {
+ goto end;
+ }
+
+ result = isc_md_final(md, buf, &id_len);
+ if (result != ISC_R_SUCCESS) {
+ goto end;
+ }
+
+ isc_md_free(md);
+ md = NULL;
memcpy(id->buffer->data + 3, &buf, ISC_SHA256_DIGESTLENGTH);
id->len = ISC_SHA256_DIGESTLENGTH + 2 + 1;
return (1);
+end:
+ if (md != NULL) {
+ isc_md_free(md);
+ }
+ return (0);
}
/*!
@@ -1551,8 +1580,9 @@
unsigned len)
{
struct data_string *id = &ddns_cb->dhcid;
- unsigned char buf[ISC_MD5_DIGESTLENGTH];
- isc_md5_t md5;
+ unsigned char buf[256]; // XXX: big enough (> 16)
+ isc_md_t *md;
+ isc_result_t result;
int i;
/* Types can only be 0..(2^16)-1. */
@@ -1584,9 +1614,28 @@
id->buffer->data[2] = "0123456789abcdef"[type % 15];
/* Mash together an MD5 hash of the identifier. */
- isc_md5_init(&md5);
- isc_md5_update(&md5, data, len);
- isc_md5_final(&md5, buf);
+ md = isc_md_new();
+ if (md == NULL) {
+ return (0);
+ }
+
+ result = isc_md_init(md, ISC_MD_MD5);
+ if (result != ISC_R_SUCCESS) {
+ goto end;
+ }
+
+ result = isc_md_update(md, data, len);
+ if (result != ISC_R_SUCCESS) {
+ goto end;
+ }
+
+ result = isc_md_final(md, buf, &len);
+ if (result != ISC_R_SUCCESS) {
+ goto end;
+ }
+
+ isc_md_free(md);
+ md = NULL;
/* Convert into ASCII. */
for (i = 0; i < ISC_MD5_DIGESTLENGTH; i++) {
@@ -1601,6 +1650,11 @@
id->terminated = 1;
return (1);
+end:
+ if (md != NULL) {
+ isc_md_free(md);
+ }
+ return (0);
}
int get_dhcid(dhcp_ddns_cb_t *ddns_cb,
diff -r d78bd11819d9 -r 39d2b9079f45 external/mpl/dhcp/dist/omapip/buffer.c
--- a/external/mpl/dhcp/dist/omapip/buffer.c Thu Jan 10 17:05:56 2019 +0000
+++ b/external/mpl/dhcp/dist/omapip/buffer.c Thu Jan 10 17:41:47 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: buffer.c,v 1.2 2018/04/07 22:37:30 christos Exp $ */
+/* $NetBSD: buffer.c,v 1.3 2019/01/10 17:41:47 christos Exp $ */
/* buffer.c
@@ -29,7 +29,7 @@
*/
#include <sys/cdefs.h>
-__RCSID("$NetBSD: buffer.c,v 1.2 2018/04/07 22:37:30 christos Exp $");
+__RCSID("$NetBSD: buffer.c,v 1.3 2019/01/10 17:41:47 christos Exp $");
#include "dhcpd.h"
@@ -341,6 +341,7 @@
status = ISC_R_SUCCESS;
leave:
+#if 0
/*
* If we have any bytes to send and we have a proper io object
* inform the socket code that we would like to know when we
@@ -354,6 +355,7 @@
ISC_SOCKFDWATCH_WRITE);
}
}
+#endif
return (status);
}
diff -r d78bd11819d9 -r 39d2b9079f45 external/mpl/dhcp/dist/omapip/connection.c
--- a/external/mpl/dhcp/dist/omapip/connection.c Thu Jan 10 17:05:56 2019 +0000
+++ b/external/mpl/dhcp/dist/omapip/connection.c Thu Jan 10 17:41:47 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: connection.c,v 1.2 2018/04/07 22:37:30 christos Exp $ */
+/* $NetBSD: connection.c,v 1.3 2019/01/10 17:41:47 christos Exp $ */
/* connection.c
@@ -29,7 +29,7 @@
*/
#include <sys/cdefs.h>
-__RCSID("$NetBSD: connection.c,v 1.2 2018/04/07 22:37:30 christos Exp $");
+__RCSID("$NetBSD: connection.c,v 1.3 2019/01/10 17:41:47 christos Exp $");
#include "dhcpd.h"
#include <isc/util.h>
@@ -843,7 +843,8 @@
/* Create the context for the dst module */
if (mode & SIG_MODE_INIT) {
- status = dst_context_create(key, dhcp_gbl_ctx.mctx, dctx);
+ status = dst_context_create(key, dhcp_gbl_ctx.mctx,
+ ISC_LOGCATEGORY_GENERAL, false, 0, dctx);
if (status != ISC_R_SUCCESS) {
return status;
}
diff -r d78bd11819d9 -r 39d2b9079f45 external/mpl/dhcp/dist/omapip/dispatch.c
--- a/external/mpl/dhcp/dist/omapip/dispatch.c Thu Jan 10 17:05:56 2019 +0000
+++ b/external/mpl/dhcp/dist/omapip/dispatch.c Thu Jan 10 17:41:47 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: dispatch.c,v 1.2 2018/04/07 22:37:30 christos Exp $ */
+/* $NetBSD: dispatch.c,v 1.3 2019/01/10 17:41:47 christos Exp $ */
/* dispatch.c
@@ -29,7 +29,7 @@
*/
#include <sys/cdefs.h>
-__RCSID("$NetBSD: dispatch.c,v 1.2 2018/04/07 22:37:30 christos Exp $");
+__RCSID("$NetBSD: dispatch.c,v 1.3 2019/01/10 17:41:47 christos Exp $");
#include "dhcpd.h"
@@ -121,6 +121,7 @@
* 1 is delete, 0 is leave in place
*/
#define SOCKDELETE 1
+#ifdef ISC_SOCKFDWATCH_READ
static int
omapi_iscsock_cb(isc_task_t *task,
isc_socket_t *socket,
@@ -197,6 +198,7 @@
*/
return (0);
}
+#endif
/* Register an I/O handle so that we can do asynchronous I/O on it. */
@@ -212,7 +214,9 @@
{
isc_result_t status;
omapi_io_object_t *obj, *p;
+#ifdef ISC_SOCKFDWATCH_READ
int fd_flags = 0, fd = 0;
+#endif
/* omapi_io_states is a static object. If its reference count
is zero, this is the first I/O handle to be registered, so
@@ -250,6 +254,7 @@
* a write socket we asssume they are the same socket.
*/
+#ifdef ISC_SOCKFDWATCH_READ
if (readfd) {
fd_flags |= ISC_SOCKFDWATCH_READ;
fd = readfd(h);
@@ -278,6 +283,7 @@
return (status);
}
}
+#endif
/* Find the last I/O state, if there are any. */
@@ -318,7 +324,9 @@
(omapi_object_t *))
{
omapi_io_object_t *obj;
+#ifdef ISC_SOCKFDWATCH_READ
int fd_flags = 0;
+#endif
Home |
Main Index |
Thread Index |
Old Index