X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Flibsystemd-network%2Fdhcp-server-internal.h;h=58750c441813807a0f44cc42baeed9e6aaf7999c;hb=5569b33a8ce1968200db801ef28585347103239c;hp=ce2e260945f9250bfbdb8cc5f3bcf6eb21771a1b;hpb=c7d9ffe6d629cb5b34dd749e4a88b190b11a0f48;p=elogind.git diff --git a/src/libsystemd-network/dhcp-server-internal.h b/src/libsystemd-network/dhcp-server-internal.h index ce2e26094..58750c441 100644 --- a/src/libsystemd-network/dhcp-server-internal.h +++ b/src/libsystemd-network/dhcp-server-internal.h @@ -20,15 +20,32 @@ along with systemd; If not, see . ***/ +#pragma once + #include "sd-event.h" #include "sd-dhcp-server.h" +#include "hashmap.h" #include "refcnt.h" #include "util.h" #include "log.h" #include "dhcp-internal.h" +typedef struct DHCPClientId { + size_t length; + uint8_t *data; +} DHCPClientId; + +typedef struct DHCPLease { + DHCPClientId client_id; + + be32_t address; + be32_t gateway; + uint8_t chaddr[16]; + usec_t expiration; +} DHCPLease; + struct sd_dhcp_server { RefCount n_ref; @@ -40,14 +57,14 @@ struct sd_dhcp_server { int index; be32_t address; + be32_t netmask; be32_t pool_start; size_t pool_size; -}; + size_t next_offer; -typedef struct DHCPClientId { - size_t length; - uint8_t *data; -} DHCPClientId; + Hashmap *leases_by_client_id; + DHCPLease **bound_leases; +}; typedef struct DHCPRequest { /* received message */ @@ -64,10 +81,13 @@ typedef struct DHCPRequest { DEFINE_TRIVIAL_CLEANUP_FUNC(sd_dhcp_server*, sd_dhcp_server_unref); #define _cleanup_dhcp_server_unref_ _cleanup_(sd_dhcp_server_unrefp) -#define log_dhcp_server(client, fmt, ...) log_meta(LOG_DEBUG, __FILE__, __LINE__, __func__, "DHCP SERVER: " fmt, ##__VA_ARGS__) +#define log_dhcp_server(client, fmt, ...) log_internal(LOG_DEBUG, 0, __FILE__, __LINE__, __func__, "DHCP SERVER: " fmt, ##__VA_ARGS__) int dhcp_server_handle_message(sd_dhcp_server *server, DHCPMessage *message, size_t length); int dhcp_server_send_packet(sd_dhcp_server *server, DHCPRequest *req, DHCPPacket *packet, int type, size_t optoffset); + +unsigned long client_id_hash_func(const void *p, const uint8_t hash_key[HASH_KEY_SIZE]); +int client_id_compare_func(const void *_a, const void *_b);