iPXE
Functions
fakedhcp.c File Reference

Fake DHCP packets. More...

#include <stdint.h>
#include <stdlib.h>
#include <stdio.h>
#include <errno.h>
#include <string.h>
#include <ipxe/settings.h>
#include <ipxe/netdevice.h>
#include <ipxe/dhcppkt.h>
#include <ipxe/fakedhcp.h>

Go to the source code of this file.

Functions

 FILE_LICENCE (GPL2_OR_LATER_OR_UBDL)
 
static int copy_encap_settings (struct dhcp_packet *dest, struct settings *source, unsigned int encapsulator)
 Copy settings to DHCP packet. More...
 
static int copy_settings (struct dhcp_packet *dest, struct settings *source)
 Copy settings to DHCP packet. More...
 
int create_fakedhcpdiscover (struct net_device *netdev, void *data, size_t max_len)
 Create fake DHCPDISCOVER packet. More...
 
int create_fakedhcpack (struct net_device *netdev, void *data, size_t max_len)
 Create fake DHCPACK packet. More...
 
int create_fakepxebsack (struct net_device *netdev, void *data, size_t max_len)
 Create fake PXE Boot Server ACK packet. More...
 

Detailed Description

Fake DHCP packets.

Definition in file fakedhcp.c.

Function Documentation

◆ FILE_LICENCE()

FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL  )

◆ copy_encap_settings()

static int copy_encap_settings ( struct dhcp_packet dest,
struct settings source,
unsigned int  encapsulator 
)
static

Copy settings to DHCP packet.

Parameters
destDestination DHCP packet
sourceSource settings block
encapsulatorEncapsulating setting tag number, or zero
Return values
rcReturn status code

Definition at line 50 of file fakedhcp.c.

52  {
53  struct setting setting = { .name = "" };
54  unsigned int subtag;
55  unsigned int tag;
56  void *data;
57  int len;
58  int rc;
59 
60  for ( subtag = DHCP_MIN_OPTION; subtag <= DHCP_MAX_OPTION; subtag++ ) {
61  tag = DHCP_ENCAP_OPT ( encapsulator, subtag );
62  switch ( tag ) {
63  case DHCP_EB_ENCAP:
64  case DHCP_VENDOR_ENCAP:
65  /* Process encapsulated settings */
66  if ( ( rc = copy_encap_settings ( dest, source,
67  tag ) ) != 0 )
68  return rc;
69  break;
70  default:
71  /* Copy setting, if present */
72  setting.tag = tag;
73  len = fetch_raw_setting_copy ( source, &setting, &data);
74  if ( len >= 0 ) {
75  rc = dhcppkt_store ( dest, tag, data, len );
76  free ( data );
77  if ( rc != 0 )
78  return rc;
79  }
80  break;
81  }
82  }
83 
84  return 0;
85 }
struct arbelprm_rc_send_wqe rc
Definition: arbel.h:14
#define DHCP_EB_ENCAP
Etherboot-specific encapsulated options.
Definition: dhcp.h:354
int fetch_raw_setting_copy(struct settings *settings, const struct setting *setting, void **data)
Fetch value of setting.
Definition: settings.c:821
#define DHCP_MAX_OPTION
Maximum normal DHCP option.
Definition: dhcp.h:539
#define DHCP_MIN_OPTION
Minimum normal DHCP option.
Definition: dhcp.h:63
const char * name
Name.
Definition: settings.h:28
static int copy_encap_settings(struct dhcp_packet *dest, struct settings *source, unsigned int encapsulator)
Copy settings to DHCP packet.
Definition: fakedhcp.c:50
uint64_t tag
Setting tag, if applicable.
Definition: settings.h:43
static void(* free)(struct refcnt *refcnt))
Definition: refcnt.h:54
int dhcppkt_store(struct dhcp_packet *dhcppkt, unsigned int tag, const void *data, size_t len)
Store value of DHCP packet setting.
Definition: dhcppkt.c:164
A setting.
Definition: settings.h:23
if(len >=6 *4) __asm__ __volatile__("movsl" if(len >=5 *4) __asm__ __volatile__("movsl" if(len >=4 *4) __asm__ __volatile__("movsl" if(len >=3 *4) __asm__ __volatile__("movsl" if(len >=2 *4) __asm__ __volatile__("movsl" if(len >=1 *4) __asm__ __volatile__("movsl" if((len % 4) >=2) __asm__ __volatile__("movsw" if((len % 2) >=1) __asm__ __volatile__("movsb" return dest
Definition: string.h:150
uint8_t data[48]
Additional event data.
Definition: ena.h:22
#define DHCP_VENDOR_ENCAP
Vendor encapsulated options.
Definition: dhcp.h:93
#define DHCP_ENCAP_OPT(encapsulator, encapsulated)
Construct a tag value for an encapsulated option.
Definition: dhcp.h:41
uint64_t tag
Identity tag.
Definition: edd.h:30
uint32_t len
Length.
Definition: ena.h:14

References data, dest, DHCP_EB_ENCAP, DHCP_ENCAP_OPT, DHCP_MAX_OPTION, DHCP_MIN_OPTION, DHCP_VENDOR_ENCAP, dhcppkt_store(), fetch_raw_setting_copy(), free, len, setting::name, rc, tag, and setting::tag.

Referenced by copy_settings().

◆ copy_settings()

static int copy_settings ( struct dhcp_packet dest,
struct settings source 
)
static

Copy settings to DHCP packet.

Parameters
destDestination DHCP packet
sourceSource settings block
Return values
rcReturn status code

Definition at line 94 of file fakedhcp.c.

95  {
96  return copy_encap_settings ( dest, source, 0 );
97 }
static int copy_encap_settings(struct dhcp_packet *dest, struct settings *source, unsigned int encapsulator)
Copy settings to DHCP packet.
Definition: fakedhcp.c:50
if(len >=6 *4) __asm__ __volatile__("movsl" if(len >=5 *4) __asm__ __volatile__("movsl" if(len >=4 *4) __asm__ __volatile__("movsl" if(len >=3 *4) __asm__ __volatile__("movsl" if(len >=2 *4) __asm__ __volatile__("movsl" if(len >=1 *4) __asm__ __volatile__("movsl" if((len % 4) >=2) __asm__ __volatile__("movsw" if((len % 2) >=1) __asm__ __volatile__("movsb" return dest
Definition: string.h:150

References copy_encap_settings(), and dest.

Referenced by create_fakedhcpack(), and create_fakepxebsack().

◆ create_fakedhcpdiscover()

int create_fakedhcpdiscover ( struct net_device netdev,
void *  data,
size_t  max_len 
)

Create fake DHCPDISCOVER packet.

Parameters
netdevNetwork device
dataBuffer for DHCP packet
max_lenSize of DHCP packet buffer
Return values
rcReturn status code

Used by external code.

Definition at line 109 of file fakedhcp.c.

110  {
111  struct dhcp_packet dhcppkt;
112  struct in_addr ciaddr = { 0 };
113  int rc;
114 
115  if ( ( rc = dhcp_create_request ( &dhcppkt, netdev, DHCPDISCOVER,
116  dhcp_last_xid, ciaddr, data,
117  max_len ) ) != 0 ) {
118  DBG ( "Could not create DHCPDISCOVER: %s\n",
119  strerror ( rc ) );
120  return rc;
121  }
122 
123  return 0;
124 }
struct arbelprm_rc_send_wqe rc
Definition: arbel.h:14
A DHCP packet.
Definition: dhcppkt.h:20
int dhcp_create_request(struct dhcp_packet *dhcppkt, struct net_device *netdev, unsigned int msgtype, uint32_t xid, struct in_addr ciaddr, void *data, size_t max_len)
Create DHCP request packet.
Definition: dhcp.c:1007
static struct net_device * netdev
Definition: gdbudp.c:52
char * strerror(int errno)
Retrieve string representation of error number.
Definition: strerror.c:78
#define DHCPDISCOVER
Definition: dhcp.h:198
IP address structure.
Definition: in.h:41
uint32_t dhcp_last_xid
Most recent DHCP transaction ID.
Definition: dhcp.c:124
uint8_t data[48]
Additional event data.
Definition: ena.h:22
#define DBG(...)
Print a debugging message.
Definition: compiler.h:498

References data, DBG, dhcp_create_request(), dhcp_last_xid, DHCPDISCOVER, netdev, rc, and strerror().

Referenced by efi_pxe_fake_all().

◆ create_fakedhcpack()

int create_fakedhcpack ( struct net_device netdev,
void *  data,
size_t  max_len 
)

Create fake DHCPACK packet.

Parameters
netdevNetwork device
dataBuffer for DHCP packet
max_lenSize of DHCP packet buffer
Return values
rcReturn status code

Used by external code.

Definition at line 136 of file fakedhcp.c.

137  {
138  struct dhcp_packet dhcppkt;
139  int rc;
140 
141  /* Create base DHCPACK packet */
142  if ( ( rc = dhcp_create_packet ( &dhcppkt, netdev, DHCPACK,
143  dhcp_last_xid, NULL, 0,
144  data, max_len ) ) != 0 ) {
145  DBG ( "Could not create DHCPACK: %s\n", strerror ( rc ) );
146  return rc;
147  }
148 
149  /* Merge in globally-scoped settings, then netdev-specific
150  * settings. Do it in this order so that netdev-specific
151  * settings take precedence regardless of stated priorities.
152  */
153  if ( ( rc = copy_settings ( &dhcppkt, NULL ) ) != 0 ) {
154  DBG ( "Could not set DHCPACK global settings: %s\n",
155  strerror ( rc ) );
156  return rc;
157  }
158  if ( ( rc = copy_settings ( &dhcppkt,
159  netdev_settings ( netdev ) ) ) != 0 ) {
160  DBG ( "Could not set DHCPACK netdev settings: %s\n",
161  strerror ( rc ) );
162  return rc;
163  }
164 
165  return 0;
166 }
struct arbelprm_rc_send_wqe rc
Definition: arbel.h:14
A DHCP packet.
Definition: dhcppkt.h:20
static int copy_settings(struct dhcp_packet *dest, struct settings *source)
Copy settings to DHCP packet.
Definition: fakedhcp.c:94
static struct settings * netdev_settings(struct net_device *netdev)
Get per-netdevice configuration settings block.
Definition: netdevice.h:583
int dhcp_create_packet(struct dhcp_packet *dhcppkt, struct net_device *netdev, uint8_t msgtype, uint32_t xid, const void *options, size_t options_len, void *data, size_t max_len)
Create a DHCP packet.
Definition: dhcp.c:944
static struct net_device * netdev
Definition: gdbudp.c:52
char * strerror(int errno)
Retrieve string representation of error number.
Definition: strerror.c:78
#define DHCPACK
Definition: dhcp.h:202
uint32_t dhcp_last_xid
Most recent DHCP transaction ID.
Definition: dhcp.c:124
uint8_t data[48]
Additional event data.
Definition: ena.h:22
#define DBG(...)
Print a debugging message.
Definition: compiler.h:498
#define NULL
NULL pointer (VOID *)
Definition: Base.h:321

References copy_settings(), data, DBG, dhcp_create_packet(), dhcp_last_xid, DHCPACK, netdev, netdev_settings(), NULL, rc, and strerror().

Referenced by create_fakepxebsack(), efi_pxe_fake_all(), and nbi_prepare_dhcp().

◆ create_fakepxebsack()

int create_fakepxebsack ( struct net_device netdev,
void *  data,
size_t  max_len 
)

Create fake PXE Boot Server ACK packet.

Parameters
netdevNetwork device
dataBuffer for DHCP packet
max_lenSize of DHCP packet buffer
Return values
rcReturn status code

Used by external code.

Definition at line 178 of file fakedhcp.c.

179  {
180  struct dhcp_packet dhcppkt;
181  struct settings *proxy_settings;
182  struct settings *pxebs_settings;
183  int rc;
184 
185  /* Identify available settings */
186  proxy_settings = find_settings ( PROXYDHCP_SETTINGS_NAME );
187  pxebs_settings = find_settings ( PXEBS_SETTINGS_NAME );
188  if ( ( ! proxy_settings ) && ( ! pxebs_settings ) ) {
189  /* No PXE boot server; return the regular DHCPACK */
190  return create_fakedhcpack ( netdev, data, max_len );
191  }
192 
193  /* Create base DHCPACK packet */
194  if ( ( rc = dhcp_create_packet ( &dhcppkt, netdev, DHCPACK,
195  dhcp_last_xid, NULL, 0,
196  data, max_len ) ) != 0 ) {
197  DBG ( "Could not create PXE BS ACK: %s\n",
198  strerror ( rc ) );
199  return rc;
200  }
201 
202  /* Populate ciaddr */
203  fetch_ipv4_setting ( netdev_settings ( netdev ), &ip_setting,
204  &dhcppkt.dhcphdr->ciaddr );
205 
206  /* Merge in ProxyDHCP options */
207  if ( proxy_settings &&
208  ( ( rc = copy_settings ( &dhcppkt, proxy_settings ) ) != 0 ) ) {
209  DBG ( "Could not copy ProxyDHCP settings: %s\n",
210  strerror ( rc ) );
211  return rc;
212  }
213 
214  /* Merge in BootServerDHCP options, if present */
215  if ( pxebs_settings &&
216  ( ( rc = copy_settings ( &dhcppkt, pxebs_settings ) ) != 0 ) ) {
217  DBG ( "Could not copy PXE BS settings: %s\n",
218  strerror ( rc ) );
219  return rc;
220  }
221 
222  return 0;
223 }
struct arbelprm_rc_send_wqe rc
Definition: arbel.h:14
A DHCP packet.
Definition: dhcppkt.h:20
int fetch_ipv4_setting(struct settings *settings, const struct setting *setting, struct in_addr *inp)
Fetch value of IPv4 address setting.
Definition: settings.c:912
int create_fakedhcpack(struct net_device *netdev, void *data, size_t max_len)
Create fake DHCPACK packet.
Definition: fakedhcp.c:136
static int copy_settings(struct dhcp_packet *dest, struct settings *source)
Copy settings to DHCP packet.
Definition: fakedhcp.c:94
static struct settings * netdev_settings(struct net_device *netdev)
Get per-netdevice configuration settings block.
Definition: netdevice.h:583
int dhcp_create_packet(struct dhcp_packet *dhcppkt, struct net_device *netdev, uint8_t msgtype, uint32_t xid, const void *options, size_t options_len, void *data, size_t max_len)
Create a DHCP packet.
Definition: dhcp.c:944
#define PROXYDHCP_SETTINGS_NAME
Settings block name used for ProxyDHCP responses.
Definition: dhcp.h:711
static struct net_device * netdev
Definition: gdbudp.c:52
#define PXEBS_SETTINGS_NAME
Setting block name used for BootServerDHCP responses.
Definition: dhcp.h:714
char * strerror(int errno)
Retrieve string representation of error number.
Definition: strerror.c:78
A settings block.
Definition: settings.h:132
#define DHCPACK
Definition: dhcp.h:202
uint32_t dhcp_last_xid
Most recent DHCP transaction ID.
Definition: dhcp.c:124
struct settings * find_settings(const char *name)
Find settings block.
Definition: settings.c:406
uint8_t data[48]
Additional event data.
Definition: ena.h:22
#define DBG(...)
Print a debugging message.
Definition: compiler.h:498
#define NULL
NULL pointer (VOID *)
Definition: Base.h:321

References dhcphdr::ciaddr, copy_settings(), create_fakedhcpack(), data, DBG, dhcp_create_packet(), dhcp_last_xid, DHCPACK, dhcp_packet::dhcphdr, fetch_ipv4_setting(), find_settings(), netdev, netdev_settings(), NULL, PROXYDHCP_SETTINGS_NAME, PXEBS_SETTINGS_NAME, rc, and strerror().

Referenced by efi_pxe_fake_all().