2022-03-10 17:06:31 +00:00
|
|
|
From 908ea5f3a45a050a878de16d5acde6eda1b77d9f Mon Sep 17 00:00:00 2001
|
2019-03-01 11:50:13 +00:00
|
|
|
From: Pavel Zhukov <pzhukov@redhat.com>
|
|
|
|
Date: Thu, 21 Feb 2019 10:42:50 +0100
|
2022-03-10 17:06:31 +00:00
|
|
|
Subject: [PATCH 20/28] Discover all hwaddress for xid uniqueness
|
2019-03-01 11:50:13 +00:00
|
|
|
|
|
|
|
---
|
|
|
|
common/discover.c | 2 ++
|
|
|
|
common/lpf.c | 27 ++++++++++++++++++++++-----
|
|
|
|
includes/dhcpd.h | 3 +++
|
|
|
|
3 files changed, 27 insertions(+), 5 deletions(-)
|
|
|
|
|
2018-04-06 11:00:29 +00:00
|
|
|
diff --git a/common/discover.c b/common/discover.c
|
2022-03-10 17:06:31 +00:00
|
|
|
index b4b1959..96dcdcf 100644
|
2018-04-06 11:00:29 +00:00
|
|
|
--- a/common/discover.c
|
|
|
|
+++ b/common/discover.c
|
2022-03-10 17:06:31 +00:00
|
|
|
@@ -653,6 +653,8 @@ discover_interfaces(int state) {
|
2018-04-06 11:00:29 +00:00
|
|
|
interface_dereference(&tmp, MDL);
|
|
|
|
tmp = interfaces; /* XXX */
|
|
|
|
}
|
|
|
|
+ if (tmp != NULL)
|
2018-09-24 12:52:31 +00:00
|
|
|
+ try_hw_addr(tmp);
|
2018-04-06 11:00:29 +00:00
|
|
|
|
|
|
|
if (dhcp_interface_discovery_hook) {
|
|
|
|
(*dhcp_interface_discovery_hook)(tmp);
|
2018-09-24 12:52:31 +00:00
|
|
|
diff --git a/common/lpf.c b/common/lpf.c
|
2022-03-10 17:06:31 +00:00
|
|
|
index fcaa13d..77a5668 100644
|
2018-09-24 12:52:31 +00:00
|
|
|
--- a/common/lpf.c
|
|
|
|
+++ b/common/lpf.c
|
2022-03-10 17:06:31 +00:00
|
|
|
@@ -713,8 +713,22 @@ ioctl_get_ll(char *name)
|
2018-09-24 12:52:31 +00:00
|
|
|
return sll;
|
|
|
|
}
|
|
|
|
|
|
|
|
+// define ?
|
|
|
|
+void try_hw_addr(struct interface_info *info){
|
|
|
|
+ get_hw_addr2(info);
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
void
|
|
|
|
get_hw_addr(struct interface_info *info)
|
|
|
|
+{
|
|
|
|
+ if (get_hw_addr2(info) == ISC_R_NOTFOUND){
|
|
|
|
+ log_fatal("Unsupported device type for \"%s\"",
|
|
|
|
+ info->name);
|
|
|
|
+ }
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+isc_result_t
|
|
|
|
+get_hw_addr2(struct interface_info *info)
|
|
|
|
{
|
|
|
|
struct hardware *hw = &info->hw_address;
|
|
|
|
char *name = info->name;
|
2022-03-10 17:06:31 +00:00
|
|
|
@@ -724,7 +738,8 @@ get_hw_addr(struct interface_info *info)
|
2018-09-24 12:52:31 +00:00
|
|
|
int sll_allocated = 0;
|
|
|
|
char *dup = NULL;
|
|
|
|
char *colon = NULL;
|
|
|
|
-
|
|
|
|
+ isc_result_t result = ISC_R_SUCCESS;
|
|
|
|
+
|
|
|
|
if (getifaddrs(&ifaddrs) == -1)
|
|
|
|
log_fatal("Failed to get interfaces");
|
|
|
|
|
2022-03-10 17:06:31 +00:00
|
|
|
@@ -808,14 +823,16 @@ get_hw_addr(struct interface_info *info)
|
2018-09-24 12:52:31 +00:00
|
|
|
hw->hbuf[4] = 0xef;
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
- default:
|
|
|
|
- freeifaddrs(ifaddrs);
|
|
|
|
- log_fatal("Unsupported device type %hu for \"%s\"",
|
|
|
|
- sll->sll_hatype, name);
|
|
|
|
+ default:
|
|
|
|
+ log_error("Unsupported device type %hu for \"%s\"",
|
|
|
|
+ sll->sll_hatype, name);
|
|
|
|
+ result = ISC_R_NOTFOUND;
|
|
|
|
+
|
|
|
|
}
|
|
|
|
|
|
|
|
if (sll_allocated)
|
|
|
|
dfree(sll, MDL);
|
|
|
|
freeifaddrs(ifaddrs);
|
|
|
|
+ return result;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
diff --git a/includes/dhcpd.h b/includes/dhcpd.h
|
2022-03-10 17:06:31 +00:00
|
|
|
index e9e52e7..fabad01 100644
|
2018-09-24 12:52:31 +00:00
|
|
|
--- a/includes/dhcpd.h
|
|
|
|
+++ b/includes/dhcpd.h
|
2022-03-10 17:06:31 +00:00
|
|
|
@@ -2653,7 +2653,10 @@ void print_dns_status (int, struct dhcp_ddns_cb *, isc_result_t);
|
2018-09-24 12:52:31 +00:00
|
|
|
#endif
|
|
|
|
const char *print_time(TIME);
|
|
|
|
|
|
|
|
+
|
|
|
|
void get_hw_addr(struct interface_info *info);
|
|
|
|
+void try_hw_addr(struct interface_info *info);
|
|
|
|
+isc_result_t get_hw_addr2(struct interface_info *info);
|
|
|
|
char *buf_to_hex (const unsigned char *s, unsigned len,
|
|
|
|
const char *file, int line);
|
|
|
|
char *format_lease_id(const unsigned char *s, unsigned len, int format,
|
2019-03-01 11:50:13 +00:00
|
|
|
--
|
2022-03-10 17:06:31 +00:00
|
|
|
2.35.1
|
2019-03-01 11:50:13 +00:00
|
|
|
|