nuttx-apps/netutils/netlib/netlib_obtainipv4addr.c
zhangshuai39 6d52a0fbc1 netutils/netlib: Encapsulate the dhcp configuration network code and modify at all calling locations
The DHCP configuration network code is called multiple times, so it is encapsulated

Signed-off-by: zhangshuai39 <zhangshuai39@xiaomi.com>
2024-08-23 22:10:04 +08:00

182 lines
4.9 KiB
C

/****************************************************************************
* apps/netutils/netlib/netlib_obtainipv4addr.c
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership. The
* ASF licenses this file to you 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.
*
****************************************************************************/
/****************************************************************************
* Included Files
****************************************************************************/
#include <debug.h>
#include <sys/types.h>
#include "netutils/dhcpc.h"
#include "netutils/netlib.h"
/****************************************************************************
* Private Functions
****************************************************************************/
/****************************************************************************
* Name: dhcp_setup_result
*
* Description:
* Set network connection parameters
*
* Parameters:
* ifname The name of the interface to use
* ds The configure network parameter values
*
* Return:
* 0 on success
* Negative integer on failure
*
****************************************************************************/
static int dhcp_setup_result(FAR const char *ifname,
FAR struct dhcpc_state *ds)
{
int ret = netlib_set_ipv4addr(ifname, &ds->ipaddr);
if (ret < 0)
{
nerr("ERROR: set IPv4 address failed: %d\n", ret);
return ret;
}
if (ds->netmask.s_addr != 0)
{
ret = netlib_set_ipv4netmask(ifname, &ds->netmask);
if (ret < 0)
{
nerr("ERROR: set IPv4 netmask failed: %d\n", ret);
return ret;
}
}
if (ds->default_router.s_addr != 0)
{
ret = netlib_set_dripv4addr(ifname, &ds->default_router);
if (ret < 0)
{
nerr("ERROR: set default router address failed: %d\n", ret);
return ret;
}
}
#ifdef CONFIG_NETDB_DNSCLIENT
if (ds->dnsaddr.s_addr != 0)
{
ret = netlib_set_ipv4dnsaddr(&ds->dnsaddr);
if (ret < 0)
{
nerr("ERROR: set the DNS server address failed: %d\n", ret);
return ret;
}
}
#endif
return OK;
}
/****************************************************************************
* Name: dhcp_obtain_statefuladdr
*
* Description:
* Configure network by dhcp
*
* Parameters:
* ifname The name of the interface to use
*
* Return:
* 0 on success
* Negative integer on failure
*
****************************************************************************/
static int dhcp_obtain_statefuladdr(FAR const char *ifname)
{
struct dhcpc_state ds;
FAR void *handle;
uint8_t mac[IFHWADDRLEN];
int ret = netlib_getmacaddr(ifname, mac);
if (ret < 0)
{
nerr("ERROR: get MAC address failed for '%s' : %d\n", ifname, ret);
return ret;
}
/* Set up the DHCPC modules */
handle = dhcpc_open(ifname, &mac, IFHWADDRLEN);
if (handle == NULL)
{
nerr("ERROR: dhcpc open failed for '%s'\n", ifname);
return -EINVAL;
}
/* Get an IP address. Note that there is no logic for renewing the
* IP address in this example. The address should be renewed in
* (ds.lease_time / 2) seconds.
*/
ret = dhcpc_request(handle, &ds);
if (ret == OK)
{
ret = dhcp_setup_result(ifname, &ds);
}
else
{
nerr("ERROR: dhcpc request failed: %d\n", ret);
}
dhcpc_close(handle);
return ret;
}
/****************************************************************************
* Public Functions
****************************************************************************/
/****************************************************************************
* Name: netlib_obtain_ipv4addr
*
* Description:
* Perform DHCP in an attempt to get the IP
* address of the specified network device.
*
* Parameters:
* ifname The name of the interface to use
*
* Return:
* 0 on success
* Negative integer on failure
*
****************************************************************************/
int netlib_obtain_ipv4addr(FAR const char *ifname)
{
if (ifname == NULL)
{
nerr("ERROR: Invalid network card name\n");
return -EINVAL;
}
return dhcp_obtain_statefuladdr(ifname);
}