| /* |
| * Copyright (c) 2015 Cisco and/or its affiliates. |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at: |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| /* |
| * client.h: dhcp client |
| */ |
| |
| #ifndef included_dhcp_client_h |
| #define included_dhcp_client_h |
| |
| #include <vnet/ip/ip.h> |
| #include <dhcp/dhcp4_packet.h> |
| |
| #define foreach_dhcp_client_state \ |
| _(DHCP_DISCOVER) \ |
| _(DHCP_REQUEST) \ |
| _(DHCP_BOUND) |
| |
| typedef enum |
| { |
| #define _(a) a, |
| foreach_dhcp_client_state |
| #undef _ |
| } dhcp_client_state_t; |
| |
| struct dhcp_client_t_; |
| |
| /** |
| * Callback function for DHCP complete events |
| */ |
| typedef void (*dhcp_event_cb_t) (u32 client_index, |
| const struct dhcp_client_t_ * client); |
| |
| /** |
| * The set of addresses/mask that contribute forwarding info |
| * and are installed. |
| */ |
| typedef struct dhcp_client_fwd_addresses_t_ |
| { |
| /** the address assigned to this client and it's mask */ |
| ip4_address_t leased_address; |
| u32 subnet_mask_width; |
| |
| /** the address of the DHCP server handing out the address. |
| this is used to send any unicast messages */ |
| ip4_address_t dhcp_server; |
| |
| /** The address of this client's default gateway - may not be present */ |
| ip4_address_t router_address; |
| } dhcp_client_fwd_addresses_t; |
| |
| typedef struct dhcp_client_t_ |
| { |
| dhcp_client_state_t state; |
| |
| /* the interface in question */ |
| u32 sw_if_index; |
| |
| /* State machine retry counter */ |
| u32 retry_count; |
| |
| /* Send next pkt at this time */ |
| f64 next_transmit; |
| f64 lease_expires; |
| |
| /* DHCP transaction ID, a random number */ |
| u32 transaction_id; |
| |
| /** |
| * leased address, other learned info DHCP |
| * the learned set is updated by new messages recieved in the DP |
| * the installed set is what's actually been added |
| */ |
| dhcp_client_fwd_addresses_t learned; |
| dhcp_client_fwd_addresses_t installed; |
| /* have local Addresses and default route been installed */ |
| u8 addresses_installed; |
| |
| ip4_address_t *domain_server_address; /* option 6 */ |
| u32 lease_renewal_interval; /* option 51 */ |
| u32 lease_lifetime; /* option 59 */ |
| |
| /* Requested data (option 55) */ |
| u8 *option_55_data; |
| |
| /* hostname and software client identifiers */ |
| u8 *hostname; |
| u8 *client_identifier; /* software version, e.g. vpe 1.0 */ |
| |
| /* Information used for event callback */ |
| u32 client_index; |
| u32 pid; |
| |
| /* Set the broadcast Flag in the Discover/Request messages */ |
| u8 set_broadcast_flag; |
| /* Interface MAC address, so we can do an rx-packet-for-us check */ |
| u8 client_hardware_address[6]; |
| u8 client_detect_feature_enabled; |
| |
| /* the unicast adjacency for the DHCP server */ |
| adj_index_t ai_ucast; |
| /* the broadcast adjacency on the link */ |
| adj_index_t ai_bcast; |
| /* IP DSCP to set in sent packets */ |
| ip_dscp_t dscp; |
| |
| dhcp_event_cb_t event_callback; |
| } dhcp_client_t; |
| |
| typedef struct |
| { |
| /* DHCP client pool */ |
| dhcp_client_t *clients; |
| uword *client_by_sw_if_index; |
| u32 seed; |
| |
| /* convenience */ |
| vlib_main_t *vlib_main; |
| vnet_main_t *vnet_main; |
| } dhcp_client_main_t; |
| |
| typedef struct |
| { |
| int is_add; |
| u32 sw_if_index; |
| u8 set_broadcast_flag; |
| |
| /* vectors, consumed by dhcp client code */ |
| u8 *hostname; |
| u8 *client_identifier; |
| |
| /* Bytes containing requested option numbers */ |
| u8 *option_55_data; |
| |
| /* Information used for event callback */ |
| u32 client_index; |
| u32 pid; |
| ip_dscp_t dscp; |
| dhcp_event_cb_t event_callback; |
| } dhcp_client_add_del_args_t; |
| |
| extern dhcp_client_main_t dhcp_client_main; |
| |
| #define EVENT_DHCP_CLIENT_WAKEUP 1 |
| |
| int dhcp_client_for_us (u32 bi0, |
| vlib_buffer_t * b0, |
| ip4_header_t * ip0, |
| udp_header_t * u0, dhcp_header_t * dh0); |
| |
| /** |
| * Add/Delete DHCP clients |
| */ |
| extern int dhcp_client_config (u32 is_add, |
| u32 client_index, |
| vlib_main_t * vm, |
| u32 sw_if_index, |
| u8 * hostname, |
| u8 * client_id, |
| dhcp_event_cb_t event_callback, |
| u8 set_broadcast_flag, |
| ip_dscp_t dscp, u32 pid); |
| |
| /** |
| * callback function for clients walking the DHCP client configurations |
| * |
| * @param client The client being visitsed |
| * @param data The data passed during the call to 'walk' |
| * @return !0 to continue walking 0 to stop. |
| */ |
| typedef int (*dhcp_client_walk_cb_t) (const dhcp_client_t * client, |
| void *data); |
| |
| /** |
| * Walk (visit each) DHCP client configuration |
| * |
| * @param cb The callback function invoked as each client is visited |
| * @param ctx Context data passed back to the client in the invocation of |
| * the callback. |
| */ |
| extern void dhcp_client_walk (dhcp_client_walk_cb_t cb, void *ctx); |
| |
| #endif /* included_dhcp_client_h */ |
| |
| /* |
| * fd.io coding-style-patch-verification: ON |
| * |
| * Local Variables: |
| * eval: (c-set-style "gnu") |
| * End: |
| */ |