Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/external/mpl/dhcp Merge conflicts



details:   https://anonhg.NetBSD.org/src/rev/5ea0e6c6a8da
branches:  trunk
changeset: 1012621:5ea0e6c6a8da
user:      christos <christos%NetBSD.org@localhost>
date:      Mon Aug 03 21:10:56 2020 +0000

description:
Merge conflicts

diffstat:

 external/mpl/dhcp/dhcp2netbsd                          |    5 +-
 external/mpl/dhcp/dist/client/clparse.c                |   32 +-
 external/mpl/dhcp/dist/client/dhc6.c                   |   23 +-
 external/mpl/dhcp/dist/client/dhclient.8               |    5 +-
 external/mpl/dhcp/dist/client/dhclient.c               |  154 ++++++-
 external/mpl/dhcp/dist/common/dhcp-options.5           |   13 +-
 external/mpl/dhcp/dist/common/discover.c               |   15 +-
 external/mpl/dhcp/dist/common/dns.c                    |   38 +-
 external/mpl/dhcp/dist/common/execute.c                |   15 +-
 external/mpl/dhcp/dist/common/ns_name.c                |   39 +-
 external/mpl/dhcp/dist/common/options.c                |  112 ++++-
 external/mpl/dhcp/dist/common/parse.c                  |  108 ++++-
 external/mpl/dhcp/dist/common/socket.c                 |   53 +-
 external/mpl/dhcp/dist/common/tables.c                 |   14 +-
 external/mpl/dhcp/dist/common/tests/domain_name_test.c |    2 +-
 external/mpl/dhcp/dist/includes/dhcpd.h                |   31 +-
 external/mpl/dhcp/dist/includes/ns_name.h              |    5 +-
 external/mpl/dhcp/dist/includes/omapip/isclib.h        |    9 +-
 external/mpl/dhcp/dist/includes/omapip/omapip_p.h      |    7 +-
 external/mpl/dhcp/dist/includes/omapip/result.h        |    2 +-
 external/mpl/dhcp/dist/includes/osdep.h                |   10 +-
 external/mpl/dhcp/dist/keama/conflex.c                 |    4 +-
 external/mpl/dhcp/dist/keama/confparse.c               |    4 +-
 external/mpl/dhcp/dist/keama/data.c                    |    4 +-
 external/mpl/dhcp/dist/keama/data.h                    |    2 +-
 external/mpl/dhcp/dist/keama/dhctoken.h                |    2 +-
 external/mpl/dhcp/dist/keama/eval.c                    |    4 +-
 external/mpl/dhcp/dist/keama/json.c                    |    4 +-
 external/mpl/dhcp/dist/keama/keama.8                   |    2 +-
 external/mpl/dhcp/dist/keama/keama.c                   |    4 +-
 external/mpl/dhcp/dist/keama/keama.h                   |    2 +-
 external/mpl/dhcp/dist/keama/options.c                 |    4 +-
 external/mpl/dhcp/dist/keama/parse.c                   |    4 +-
 external/mpl/dhcp/dist/keama/print.c                   |    4 +-
 external/mpl/dhcp/dist/keama/reduce.c                  |    4 +-
 external/mpl/dhcp/dist/omapip/errwarn.c                |   23 +-
 external/mpl/dhcp/dist/omapip/isclib.c                 |   75 ++-
 external/mpl/dhcp/dist/relay/dhcrelay.c                |   92 ++-
 external/mpl/dhcp/dist/relay/tests/relay_unittests.c   |    4 +-
 external/mpl/dhcp/dist/server/class.c                  |    7 +-
 external/mpl/dhcp/dist/server/confpars.c               |   45 +-
 external/mpl/dhcp/dist/server/ddns.c                   |    9 +-
 external/mpl/dhcp/dist/server/dhcp.c                   |  355 +++++++++++-----
 external/mpl/dhcp/dist/server/dhcpd.c                  |   10 +-
 external/mpl/dhcp/dist/server/dhcpd.conf.5             |   56 ++-
 external/mpl/dhcp/dist/server/dhcpleasequery.c         |   16 +-
 external/mpl/dhcp/dist/server/dhcpv6.c                 |   45 +-
 external/mpl/dhcp/dist/server/failover.c               |   12 +-
 external/mpl/dhcp/dist/server/ldap.c                   |   19 +-
 external/mpl/dhcp/dist/server/mdb.c                    |  120 +++--
 external/mpl/dhcp/dist/server/mdb6.c                   |    6 +-
 external/mpl/dhcp/dist/server/stables.c                |   14 +-
 external/mpl/dhcp/include/config.h                     |   18 +-
 53 files changed, 1157 insertions(+), 509 deletions(-)

diffs (truncated from 4372 to 300 lines):

diff -r 211b4a5e232c -r 5ea0e6c6a8da external/mpl/dhcp/dhcp2netbsd
--- a/external/mpl/dhcp/dhcp2netbsd     Mon Aug 03 21:09:06 2020 +0000
+++ b/external/mpl/dhcp/dhcp2netbsd     Mon Aug 03 21:10:56 2020 +0000
@@ -1,6 +1,6 @@
 #! /bin/sh
 #
-#      $NetBSD: dhcp2netbsd,v 1.2 2018/04/07 22:34:51 christos Exp $
+#      $NetBSD: dhcp2netbsd,v 1.3 2020/08/03 21:10:56 christos Exp $
 #
 # Copyright (c) 2003, 2011 The NetBSD Foundation, Inc.
 # All rights reserved.
@@ -67,8 +67,7 @@
 mv /tmp/dhcp1$$ $c && echo did source mods for $c
 done
 
- for f in dst/dst_api.c dst/dst_support.c dst/hmac_link.c dst/prandom.c \
-     omapip/inet_addr.c omapip/iscprint.c server/dhcpv6.c \
+for f in omapip/inet_addr.c omapip/iscprint.c server/dhcpv6.c \
      server/dhcpleasequery.c server/ldap.c server/mdb6.c; do
        c=$FILE/$f
        sed -E -e \
diff -r 211b4a5e232c -r 5ea0e6c6a8da external/mpl/dhcp/dist/client/clparse.c
--- a/external/mpl/dhcp/dist/client/clparse.c   Mon Aug 03 21:09:06 2020 +0000
+++ b/external/mpl/dhcp/dist/client/clparse.c   Mon Aug 03 21:10:56 2020 +0000
@@ -1,11 +1,11 @@
-/*     $NetBSD: clparse.c,v 1.2 2018/04/07 22:37:29 christos Exp $     */
+/*     $NetBSD: clparse.c,v 1.3 2020/08/03 21:10:56 christos Exp $     */
 
 /* clparse.c
 
    Parser for dhclient config and lease files... */
 
 /*
- * Copyright (c) 2004-2017 by Internet Systems Consortium, Inc. ("ISC")
+ * Copyright (c) 2004-2019 by Internet Systems Consortium, Inc. ("ISC")
  * Copyright (c) 1996-2003 by Internet Software Consortium
  *
  * This Source Code Form is subject to the terms of the Mozilla Public
@@ -29,7 +29,7 @@
  */
 
 #include <sys/cdefs.h>
-__RCSID("$NetBSD: clparse.c,v 1.2 2018/04/07 22:37:29 christos Exp $");
+__RCSID("$NetBSD: clparse.c,v 1.3 2020/08/03 21:10:56 christos Exp $");
 
 #include "dhcpd.h"
 #include <errno.h>
@@ -52,6 +52,9 @@
 
 static void parse_lease_id_format (struct parse *cfile);
 
+extern void discard_duplicate (struct client_lease** lease_list,
+                               struct client_lease* lease);
+
 /* client-conf-file :== client-declarations END_OF_FILE
    client-declarations :== <nil>
                         | client-declaration
@@ -1101,7 +1104,7 @@
        struct parse *cfile;
        int is_static;
 {
-       struct client_lease *lease, *lp, *pl, *next;
+       struct client_lease *lease;
        struct interface_info *ip = (struct interface_info *)0;
        int token;
        const char *val;
@@ -1159,22 +1162,11 @@
        /* The new lease may supersede a lease that's not the
           active lease but is still on the lease list, so scan the
           lease list looking for a lease with the same address, and
-          if we find it, toss it. */
-       pl = (struct client_lease *)0;
-       for (lp = client -> leases; lp; lp = next) {
-               next = lp -> next;
-               if (lp -> address.len == lease -> address.len &&
-                   !memcmp (lp -> address.iabuf, lease -> address.iabuf,
-                            lease -> address.len)) {
-                       if (pl)
-                               pl -> next = next;
-                       else
-                               client -> leases = next;
-                       destroy_client_lease (lp);
-                       break;
-               } else
-                       pl = lp;
-       }
+          if we find it, toss it. We only allow supercession if
+          the leases originated from the same source. In other words,
+          either both are from the config file or both are from the lease
+          file.  This keeps us from discarding fallback leases */
+       discard_duplicate (&client->leases, lease);
 
        /* If this is a preloaded lease, just put it on the list of recorded
           leases - don't make it the active lease. */
diff -r 211b4a5e232c -r 5ea0e6c6a8da external/mpl/dhcp/dist/client/dhc6.c
--- a/external/mpl/dhcp/dist/client/dhc6.c      Mon Aug 03 21:09:06 2020 +0000
+++ b/external/mpl/dhcp/dist/client/dhc6.c      Mon Aug 03 21:10:56 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: dhc6.c,v 1.2 2018/04/07 22:37:29 christos Exp $        */
+/*     $NetBSD: dhc6.c,v 1.3 2020/08/03 21:10:56 christos Exp $        */
 
 /* dhc6.c - DHCPv6 client routines. */
 
@@ -26,7 +26,7 @@
  */
 
 #include <sys/cdefs.h>
-__RCSID("$NetBSD: dhc6.c,v 1.2 2018/04/07 22:37:29 christos Exp $");
+__RCSID("$NetBSD: dhc6.c,v 1.3 2020/08/03 21:10:56 christos Exp $");
 
 #include "dhcpd.h"
 
@@ -821,8 +821,7 @@
                } else {
                        log_error("Invalid IA_NA option cache.");
                        dfree(ia, MDL);
-                       if (ds.len != 0)
-                               data_string_forget(&ds, MDL);
+                       data_string_forget(&ds, MDL);
                        return ISC_R_UNEXPECTED;
                }
        }
@@ -924,8 +923,7 @@
                } else {
                        log_error("Invalid IA_TA option cache.");
                        dfree(ia, MDL);
-                       if (ds.len != 0)
-                               data_string_forget(&ds, MDL);
+                       data_string_forget(&ds, MDL);
                        return ISC_R_UNEXPECTED;
                }
        }
@@ -1047,8 +1045,7 @@
                } else {
                        log_error("Invalid IA_PD option cache.");
                        dfree(ia, MDL);
-                       if (ds.len != 0)
-                               data_string_forget(&ds, MDL);
+                       data_string_forget(&ds, MDL);
                        return ISC_R_UNEXPECTED;
                }
        }
@@ -1163,8 +1160,7 @@
                } else {
                        log_error("Invalid IAADDR option cache.");
                        dfree(addr, MDL);
-                       if (ds.len != 0)
-                               data_string_forget(&ds, MDL);
+                       data_string_forget(&ds, MDL);
                        return ISC_R_UNEXPECTED;
                }
        }
@@ -1288,8 +1284,7 @@
                } else {
                        log_error("Invalid IAPREFIX option cache.");
                        dfree(pfx, MDL);
-                       if (ds.len != 0)
-                               data_string_forget(&ds, MDL);
+                       data_string_forget(&ds, MDL);
                        return ISC_R_UNEXPECTED;
                }
        }
@@ -1311,9 +1306,7 @@
        }
        lease = *src;
 
-       if (lease->server_id.len != 0)
-               data_string_forget(&lease->server_id, file, line);
-
+       data_string_forget(&lease->server_id, file, line);
        for (ia = lease->bindings ; ia != NULL ; ia = nia) {
                nia = ia->next;
 
diff -r 211b4a5e232c -r 5ea0e6c6a8da external/mpl/dhcp/dist/client/dhclient.8
--- a/external/mpl/dhcp/dist/client/dhclient.8  Mon Aug 03 21:09:06 2020 +0000
+++ b/external/mpl/dhcp/dist/client/dhclient.8  Mon Aug 03 21:10:56 2020 +0000
@@ -1,8 +1,8 @@
-.\"    $NetBSD: dhclient.8,v 1.2 2018/04/07 22:37:29 christos Exp $
+.\"    $NetBSD: dhclient.8,v 1.3 2020/08/03 21:10:56 christos Exp $
 .\"
 .\"    Id: dhclient.8,v 1.36 2011/04/15 21:58:12 sar Exp 
 .\"
-.\" Copyright (c) 2004-2018 by Internet Systems Consortium, Inc. ("ISC")
+.\" Copyright (c) 2004-2019 by Internet Systems Consortium, Inc. ("ISC")
 .\" Copyright (c) 1996-2003 by Internet Software Consortium
 .\"
 .\" This Source Code Form is subject to the terms of the Mozilla Public
@@ -57,6 +57,7 @@
 .B -P...
 ]
 ]
+[
 .B -R
 ]
 [
diff -r 211b4a5e232c -r 5ea0e6c6a8da external/mpl/dhcp/dist/client/dhclient.c
--- a/external/mpl/dhcp/dist/client/dhclient.c  Mon Aug 03 21:09:06 2020 +0000
+++ b/external/mpl/dhcp/dist/client/dhclient.c  Mon Aug 03 21:10:56 2020 +0000
@@ -1,11 +1,11 @@
-/*     $NetBSD: dhclient.c,v 1.2 2018/04/07 22:37:29 christos Exp $    */
+/*     $NetBSD: dhclient.c,v 1.3 2020/08/03 21:10:56 christos Exp $    */
 
 /* dhclient.c
 
    DHCP Client. */
 
 /*
- * Copyright (c) 2004-2018 by Internet Systems Consortium, Inc. ("ISC")
+ * Copyright (c) 2004-2020 by Internet Systems Consortium, Inc. ("ISC")
  * Copyright (c) 1995-2003 by Internet Software Consortium
  *
  * This Source Code Form is subject to the terms of the Mozilla Public
@@ -33,7 +33,7 @@
  */
 
 #include <sys/cdefs.h>
-__RCSID("$NetBSD: dhclient.c,v 1.2 2018/04/07 22:37:29 christos Exp $");
+__RCSID("$NetBSD: dhclient.c,v 1.3 2020/08/03 21:10:56 christos Exp $");
 
 #include "dhcpd.h"
 #include <isc/util.h>
@@ -56,6 +56,8 @@
 char *path_dhclient_script = path_dhclient_script_array;
 const char *path_dhclient_duid = NULL;
 
+static void add_to_tail(struct client_lease** lease_list, struct client_lease* lease);
+
 /* False (default) => we write and use a pid file */
 isc_boolean_t no_pid_file = ISC_FALSE;
 isc_boolean_t hw_mismatch_drop = ISC_TRUE;
@@ -82,7 +84,7 @@
 #define ASSERT_STATE(state_is, state_shouldbe) {}
 
 #ifndef UNIT_TEST
-static const char copyright[] = "Copyright 2004-2018 Internet Systems Consortium.";
+static const char copyright[] = "Copyright 2004-2020 Internet Systems Consortium.";
 static const char arr [] = "All rights reserved.";
 static const char message [] = "Internet Systems Consortium DHCP Client";
 static const char url [] = "For info, please visit https://www.isc.org/software/dhcp/";;
@@ -142,8 +144,11 @@
 static int check_option_values(struct universe *universe, unsigned int opt,
                               const char *ptr, size_t len);
 
+#if defined(NSUPDATE)
 static void dhclient_ddns_cb_free(dhcp_ddns_cb_t *ddns_cb,
                                    char* file, int line);
+#endif /* defined NSUPDATE */
+
 static void
 setup(void) {
        isc_result_t status;
@@ -236,7 +241,7 @@
  */
 
 #include <sys/cdefs.h>
-__RCSID("$NetBSD: dhclient.c,v 1.2 2018/04/07 22:37:29 christos Exp $");
+__RCSID("$NetBSD: dhclient.c,v 1.3 2020/08/03 21:10:56 christos Exp $");
 
 #if defined(DHCPv6) && defined(DHCP4o6)
 static void dhcp4o6_poll(void *dummy);
@@ -1225,7 +1230,7 @@
  */
 
 #include <sys/cdefs.h>
-__RCSID("$NetBSD: dhclient.c,v 1.2 2018/04/07 22:37:29 christos Exp $");
+__RCSID("$NetBSD: dhclient.c,v 1.3 2020/08/03 21:10:56 christos Exp $");
 
 void state_reboot (cpp)
        void *cpp;
@@ -1630,8 +1635,16 @@
                write_client_lease(client, client->new, 0, 1);
 
        /* Replace the old active lease with the new one. */
-       if (client->active)
-               destroy_client_lease(client->active);
+       if (client->active) {
+               if (client->active->is_static) {
+                       // We need to preserve the fallback lease in case
+                       // we lose DHCP service again.
+                       add_to_tail(&client->leases, client->active);
+               } else {
+                       destroy_client_lease(client->active);
+               }
+       }
+
        client->active = client->new;
        client->new = NULL;
 
@@ -1650,7 +1663,8 @@
 #if defined (NSUPDATE)
        if (client->config->do_forward_update)
                dhclient_schedule_updates(client, &client->active->address, 1);
-#endif
+#endif /* defined NSUPDATE */
+
 }
 
 /* state_bound is called when we've successfully bound to a particular
@@ -2515,6 +2529,101 @@
        add_timeout(&tv, send_discover, client, 0, 0);



Home | Main Index | Thread Index | Old Index