db449ef
--- dhcp-3.0.5/client/dhclient.c.decline	2007-03-30 15:29:58.000000000 -0400
db449ef
+++ dhcp-3.0.5/client/dhclient.c	2007-03-30 15:50:25.000000000 -0400
db449ef
@@ -934,6 +934,7 @@
db449ef
 	void *cpp;
db449ef
 {
db449ef
 	struct client_state *client = cpp;
db449ef
+	enum dhcp_state init_state = client->state;
db449ef
 
db449ef
 	ASSERT_STATE(state, S_INIT);
db449ef
 
db449ef
@@ -946,9 +947,16 @@
db449ef
 	client -> first_sending = cur_time;
db449ef
 	client -> interval = client -> config -> initial_interval;
db449ef
 
db449ef
-	/* Add an immediate timeout to cause the first DHCPDISCOVER packet
db449ef
-	   to go out. */
db449ef
-	send_discover (client);
db449ef
+	if (init_state != S_DECLINED) {
db449ef
+		/* Add an immediate timeout to cause the first DHCPDISCOVER packet
db449ef
+		   to go out. */
db449ef
+		send_discover(client);
db449ef
+	} else {
db449ef
+		/* We've received an OFFER and it has been DECLINEd by dhclient-script.
db449ef
+		 * wait for a random time between 1 and backoff_cutoff seconds before
db449ef
+		 * trying again. */
db449ef
+		add_timeout(cur_time + ((1 + (random() >> 2)) %  client->config->backoff_cutoff), send_discover, client, 0, 0);
db449ef
+	}
db449ef
 }
db449ef
 
db449ef
 /* state_selecting is called when one or more DHCPOFFER packets have been
db449ef
@@ -1215,6 +1223,7 @@
db449ef
 		send_decline (client);
db449ef
 		destroy_client_lease (client -> new);
db449ef
 		client -> new = (struct client_lease *)0;
db449ef
+		client -> state = S_DECLINED;
db449ef
 		state_init (client);
db449ef
 		return;
db449ef
 	}
db449ef
@@ -3183,6 +3192,7 @@
db449ef
 			      case S_INIT:
db449ef
 			      case S_REBINDING:
db449ef
 			      case S_STOPPED:
db449ef
+			      case S_DECLINED:
db449ef
 				break;
db449ef
 			}
db449ef
 			client -> state = S_INIT;
db449ef
--- dhcp-3.0.5/includes/dhcpd.h.decline	2007-03-30 15:30:14.000000000 -0400
db449ef
+++ dhcp-3.0.5/includes/dhcpd.h	2007-03-30 15:50:53.000000000 -0400
db449ef
@@ -704,7 +704,8 @@
db449ef
 	S_BOUND = 5,
db449ef
 	S_RENEWING = 6,
db449ef
 	S_REBINDING = 7,
db449ef
-	S_STOPPED = 8
db449ef
+	S_STOPPED = 8,
db449ef
+	S_DECLINED = 9
db449ef
 };
db449ef
 
db449ef
 /* Authentication and BOOTP policy possibilities (not all values work