udhcpd: reduce stack usage by ~700 bytes. +28 bytes code size

Signed-off-by: Denys Vlasenko <dvlasenk@redhat.com>
This commit is contained in:
Denys Vlasenko 2010-10-21 12:33:10 +02:00
parent 08187356d7
commit 0bb35e19a7
2 changed files with 14 additions and 5 deletions

View File

@ -432,6 +432,7 @@ static int raw_bcast_from_client_config_ifindex(struct dhcp_packet *packet)
} }
/* Broadcast a DHCP discover packet to the network, with an optionally requested IP */ /* Broadcast a DHCP discover packet to the network, with an optionally requested IP */
/* NOINLINE: limit stack usage in caller */
static NOINLINE int send_discover(uint32_t xid, uint32_t requested) static NOINLINE int send_discover(uint32_t xid, uint32_t requested)
{ {
struct dhcp_packet packet; struct dhcp_packet packet;
@ -460,6 +461,7 @@ static NOINLINE int send_discover(uint32_t xid, uint32_t requested)
/* RFC 2131 3.1 paragraph 3: /* RFC 2131 3.1 paragraph 3:
* "The client _broadcasts_ a DHCPREQUEST message..." * "The client _broadcasts_ a DHCPREQUEST message..."
*/ */
/* NOINLINE: limit stack usage in caller */
static NOINLINE int send_select(uint32_t xid, uint32_t server, uint32_t requested) static NOINLINE int send_select(uint32_t xid, uint32_t server, uint32_t requested)
{ {
struct dhcp_packet packet; struct dhcp_packet packet;
@ -500,7 +502,8 @@ static NOINLINE int send_select(uint32_t xid, uint32_t server, uint32_t requeste
} }
/* Unicast or broadcast a DHCP renew message */ /* Unicast or broadcast a DHCP renew message */
static int send_renew(uint32_t xid, uint32_t server, uint32_t ciaddr) /* NOINLINE: limit stack usage in caller */
static NOINLINE int send_renew(uint32_t xid, uint32_t server, uint32_t ciaddr)
{ {
struct dhcp_packet packet; struct dhcp_packet packet;
@ -543,6 +546,7 @@ static int send_renew(uint32_t xid, uint32_t server, uint32_t ciaddr)
#if ENABLE_FEATURE_UDHCPC_ARPING #if ENABLE_FEATURE_UDHCPC_ARPING
/* Broadcast a DHCP decline message */ /* Broadcast a DHCP decline message */
/* NOINLINE: limit stack usage in caller */
static NOINLINE int send_decline(uint32_t xid, uint32_t server, uint32_t requested) static NOINLINE int send_decline(uint32_t xid, uint32_t server, uint32_t requested)
{ {
struct dhcp_packet packet; struct dhcp_packet packet;
@ -588,6 +592,7 @@ static int send_release(uint32_t server, uint32_t ciaddr)
} }
/* Returns -1 on errors that are fatal for the socket, -2 for those that aren't */ /* Returns -1 on errors that are fatal for the socket, -2 for those that aren't */
/* NOINLINE: limit stack usage in caller */
static NOINLINE int udhcp_recv_raw_packet(struct dhcp_packet *dhcp_pkt, int fd) static NOINLINE int udhcp_recv_raw_packet(struct dhcp_packet *dhcp_pkt, int fd)
{ {
int bytes; int bytes;

View File

@ -132,7 +132,8 @@ static uint32_t select_lease_time(struct dhcp_packet *packet)
} }
/* We got a DHCP DISCOVER. Send an OFFER. */ /* We got a DHCP DISCOVER. Send an OFFER. */
static void send_offer(struct dhcp_packet *oldpacket, uint32_t static_lease_nip, struct dyn_lease *lease) /* NOINLINE: limit stack usage in caller */
static NOINLINE void send_offer(struct dhcp_packet *oldpacket, uint32_t static_lease_nip, struct dyn_lease *lease)
{ {
struct dhcp_packet packet; struct dhcp_packet packet;
uint32_t lease_time_sec; uint32_t lease_time_sec;
@ -202,7 +203,8 @@ static void send_offer(struct dhcp_packet *oldpacket, uint32_t static_lease_nip,
send_packet(&packet, /*force_bcast:*/ 0); send_packet(&packet, /*force_bcast:*/ 0);
} }
static void send_NAK(struct dhcp_packet *oldpacket) /* NOINLINE: limit stack usage in caller */
static NOINLINE void send_NAK(struct dhcp_packet *oldpacket)
{ {
struct dhcp_packet packet; struct dhcp_packet packet;
@ -212,7 +214,8 @@ static void send_NAK(struct dhcp_packet *oldpacket)
send_packet(&packet, /*force_bcast:*/ 1); send_packet(&packet, /*force_bcast:*/ 1);
} }
static void send_ACK(struct dhcp_packet *oldpacket, uint32_t yiaddr) /* NOINLINE: limit stack usage in caller */
static NOINLINE void send_ACK(struct dhcp_packet *oldpacket, uint32_t yiaddr)
{ {
struct dhcp_packet packet; struct dhcp_packet packet;
uint32_t lease_time_sec; uint32_t lease_time_sec;
@ -243,7 +246,8 @@ static void send_ACK(struct dhcp_packet *oldpacket, uint32_t yiaddr)
} }
} }
static void send_inform(struct dhcp_packet *oldpacket) /* NOINLINE: limit stack usage in caller */
static NOINLINE void send_inform(struct dhcp_packet *oldpacket)
{ {
struct dhcp_packet packet; struct dhcp_packet packet;