udhcp: add a few TODOs
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
parent
26918dd28e
commit
ed8982bfc0
@ -74,6 +74,9 @@ config FEATURE_UDHCP_PORT
|
|||||||
At the cost of ~300 bytes, enables -P port option.
|
At the cost of ~300 bytes, enables -P port option.
|
||||||
This feature is typically not needed.
|
This feature is typically not needed.
|
||||||
|
|
||||||
|
# TODO: UDHCP_DEBUG is inconvenient to use.
|
||||||
|
# Make it controllable at runtime (say, via -v, -vv, -vvv)
|
||||||
|
|
||||||
config UDHCP_DEBUG
|
config UDHCP_DEBUG
|
||||||
bool "Compile udhcp with noisy debugging messages"
|
bool "Compile udhcp with noisy debugging messages"
|
||||||
default n
|
default n
|
||||||
|
@ -23,6 +23,7 @@ extern const uint8_t MAC_BCAST_ADDR[6]; /* six all-ones */
|
|||||||
|
|
||||||
#define DHCP_OPTIONS_BUFSIZE 308
|
#define DHCP_OPTIONS_BUFSIZE 308
|
||||||
|
|
||||||
|
//TODO: rename to dhcp_packet; rename ciaddr/yiaddr/chaddr
|
||||||
struct dhcpMessage {
|
struct dhcpMessage {
|
||||||
uint8_t op; /* 1 = BOOTREQUEST, 2 = BOOTREPLY */
|
uint8_t op; /* 1 = BOOTREQUEST, 2 = BOOTREPLY */
|
||||||
uint8_t htype; /* hardware address type. 1 = 10mb ethernet */
|
uint8_t htype; /* hardware address type. 1 = 10mb ethernet */
|
||||||
@ -44,6 +45,7 @@ struct dhcpMessage {
|
|||||||
uint8_t options[DHCP_OPTIONS_BUFSIZE + CONFIG_UDHCPC_SLACK_FOR_BUGGY_SERVERS];
|
uint8_t options[DHCP_OPTIONS_BUFSIZE + CONFIG_UDHCPC_SLACK_FOR_BUGGY_SERVERS];
|
||||||
} PACKED;
|
} PACKED;
|
||||||
|
|
||||||
|
//TODO: rename to ip_udp_dhcp_packet?
|
||||||
struct udp_dhcp_packet {
|
struct udp_dhcp_packet {
|
||||||
struct iphdr ip;
|
struct iphdr ip;
|
||||||
struct udphdr udp;
|
struct udphdr udp;
|
||||||
|
@ -78,6 +78,10 @@ struct server_config_t {
|
|||||||
typedef uint32_t leasetime_t;
|
typedef uint32_t leasetime_t;
|
||||||
typedef int32_t signed_leasetime_t;
|
typedef int32_t signed_leasetime_t;
|
||||||
|
|
||||||
|
//TODO: (1) rename to dyn_lease (that's what it is. we also have static_lease).
|
||||||
|
//(2) lease_mac16 may be shortened to lease_mac[6], since e.g. ARP probing uses
|
||||||
|
//only 6 first bytes anyway. We can check received dhcp packets
|
||||||
|
//that their "chaddr"s have only 6 first bytes != 0, and complain otherwise.
|
||||||
struct dhcpOfferedAddr {
|
struct dhcpOfferedAddr {
|
||||||
uint8_t lease_mac16[16];
|
uint8_t lease_mac16[16];
|
||||||
/* "nip": IP in network order */
|
/* "nip": IP in network order */
|
||||||
|
@ -22,7 +22,7 @@ static struct dhcpOfferedAddr *oldest_expired_lease(void)
|
|||||||
for (i = 0; i < server_config.max_leases; i++) {
|
for (i = 0; i < server_config.max_leases; i++) {
|
||||||
if (leases[i].expires < oldest_time) {
|
if (leases[i].expires < oldest_time) {
|
||||||
oldest_time = leases[i].expires;
|
oldest_time = leases[i].expires;
|
||||||
oldest_lease = &(leases[i]);
|
oldest_lease = &leases[i];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return oldest_lease;
|
return oldest_lease;
|
||||||
@ -142,7 +142,7 @@ static int nobody_responds_to_arp(uint32_t addr, const uint8_t *safe_mac)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* Find a new usable (we think) address. */
|
/* Find a new usable (we think) address */
|
||||||
uint32_t FAST_FUNC find_free_or_expired_address(const uint8_t *chaddr)
|
uint32_t FAST_FUNC find_free_or_expired_address(const uint8_t *chaddr)
|
||||||
{
|
{
|
||||||
uint32_t addr;
|
uint32_t addr;
|
||||||
|
Loading…
Reference in New Issue
Block a user