[SLOF] [PATCH 6/7] net-snk: Use transaction IDs in DHCPv4, too

Stefan Berger stefanb at linux.vnet.ibm.com
Tue Dec 22 02:59:31 AEDT 2015


On 12/17/2015 03:18 PM, Thomas Huth wrote:
> Generate a proper transaction ID before sending DHCPv4 packets
> and check whether the DHCPv4 replies contain that correct XID, too.
>
> Signed-off-by: Thomas Huth <thuth at redhat.com>
> ---
>   clients/net-snk/app/netapps/netboot.c |  2 ++
>   clients/net-snk/app/netlib/dhcp.c     | 17 +++++++++++++++--
>   clients/net-snk/app/netlib/dhcp.h     |  1 +
>   3 files changed, 18 insertions(+), 2 deletions(-)
>
> diff --git a/clients/net-snk/app/netapps/netboot.c b/clients/net-snk/app/netapps/netboot.c
> index d51d5a8..9f5ff8d 100644
> --- a/clients/net-snk/app/netapps/netboot.c
> +++ b/clients/net-snk/app/netapps/netboot.c
> @@ -332,6 +332,8 @@ int dhcp(char *ret_buffer, filename_ip_t * fn_ip, unsigned int retries, int flag
>   	int i = (int) retries+1;
>   	int rc = -1;
>   
> +	if (flags != F_IPV6)
> +		dhcpv4_generate_transaction_id();

Same comment as before. flags == F_IPV4?

>   	if (flags != F_IPV4)
>   		dhcpv6_generate_transaction_id();
>   
> diff --git a/clients/net-snk/app/netlib/dhcp.c b/clients/net-snk/app/netlib/dhcp.c
> index 5f26f3a..bd9c104 100644
> --- a/clients/net-snk/app/netlib/dhcp.c
> +++ b/clients/net-snk/app/netlib/dhcp.c
> @@ -178,11 +178,18 @@ static uint32_t dhcp_server_ip     = 0;
>   static uint32_t dhcp_siaddr_ip     = 0;
>   static int8_t   dhcp_filename[256];
>   static int8_t   dhcp_tftp_name[256];
> +static uint32_t dhcp_xid;
>   
>   static char   * response_buffer;
>   
>   /*>>>>>>>>>>>>>>>>>>>>>>>>>>>> IMPLEMENTATION <<<<<<<<<<<<<<<<<<<<<<<<<<<*/
>   
> +void
> +dhcpv4_generate_transaction_id(void)
> +{
> +	dhcp_xid = (rand() << 16) ^ rand();
> +}
> +
>   int32_t
>   dhcpv4(char *ret_buffer, filename_ip_t * fn_ip) {
>   
> @@ -627,6 +634,7 @@ dhcp_send_discover(int fd) {
>   	btph -> op = 1;
>   	btph -> htype = 1;
>   	btph -> hlen = 6;
> +	btph -> xid = dhcp_xid;
>   	memcpy(btph -> chaddr, get_mac_address(), 6);
>   
>   	memset(&opt, 0, sizeof(dhcp_options_t));
> @@ -670,6 +678,7 @@ dhcp_send_request(int fd) {
>   	btph -> op = 1;
>   	btph -> htype = 1;
>   	btph -> hlen = 6;
> +	btph -> xid = dhcp_xid;
>   	memcpy(btph -> chaddr, get_mac_address(), 6);
>   
>   	memset(&opt, 0, sizeof(dhcp_options_t));
> @@ -718,6 +727,7 @@ void dhcp_send_release(int fd) {
>   	btph -> op = 1;
>   	btph -> htype = 1;
>   	btph -> hlen = 6;
> +	btph -> xid = dhcp_xid;
>   	strcpy((char *) btph -> file, "");
>   	memcpy(btph -> chaddr, get_mac_address(), 6);
>   	btph -> ciaddr = htonl(dhcp_own_ip);
> @@ -763,8 +773,11 @@ handle_dhcp(int fd, uint8_t * packet, int32_t packetsize) {
>   	btph = (struct btphdr *) packet;
>   	iph = (struct iphdr *) packet - sizeof(struct udphdr) -
>   	      sizeof(struct iphdr);
> -	if (btph -> op != 2)
> -		return -1; // it is not Boot Reply
> +
> +	if (btph->op != 2)
> +		return -1;		/* It is not a Bootp/DHCP reply */
> +	if (btph->xid != dhcp_xid)
> +		return -1;		/* The transaction ID does not match */
>   
>   	if (memcmp(btph -> vend, dhcp_magic, 4)) {
>   		// It is BootP - RFC 951
> diff --git a/clients/net-snk/app/netlib/dhcp.h b/clients/net-snk/app/netlib/dhcp.h
> index 69dd49d..54fb1ee 100644
> --- a/clients/net-snk/app/netlib/dhcp.h
> +++ b/clients/net-snk/app/netlib/dhcp.h
> @@ -43,6 +43,7 @@ struct btphdr {
>   	uint8_t vend[64];    /**< Optional parameters field (DHCP-options)     */
>   };
>   
> +void dhcpv4_generate_transaction_id(void);
>   int bootp(char *ret_buffer, filename_ip_t *, unsigned int);
>   int dhcpv4(char *ret_buffer, filename_ip_t *);
>   void dhcp_send_release(int fd);
Rest looks good.

    Stefan



More information about the SLOF mailing list