mirror of
https://github.com/cesanta/mongoose.git
synced 2024-12-21 13:42:15 +08:00
199 lines
5.3 KiB
C
199 lines
5.3 KiB
C
/* USER CODE BEGIN Header */
|
|
/**
|
|
******************************************************************************
|
|
* File Name : LWIP.c
|
|
* Description : This file provides initialization code for LWIP
|
|
* middleWare.
|
|
******************************************************************************
|
|
* @attention
|
|
*
|
|
* Copyright (c) 2023 STMicroelectronics.
|
|
* All rights reserved.
|
|
*
|
|
* This software is licensed under terms that can be found in the LICENSE file
|
|
* in the root directory of this software component.
|
|
* If no LICENSE file comes with this software, it is provided AS-IS.
|
|
*
|
|
******************************************************************************
|
|
*/
|
|
/* USER CODE END Header */
|
|
|
|
/* Includes ------------------------------------------------------------------*/
|
|
#include "lwip.h"
|
|
#include "lwip/init.h"
|
|
#include "lwip/netif.h"
|
|
#if defined ( __CC_ARM ) /* MDK ARM Compiler */
|
|
#include "lwip/sio.h"
|
|
#endif /* MDK ARM Compiler */
|
|
#include "ethernetif.h"
|
|
|
|
/* USER CODE BEGIN 0 */
|
|
|
|
/* USER CODE END 0 */
|
|
/* Private function prototypes -----------------------------------------------*/
|
|
static void ethernet_link_status_updated(struct netif *netif);
|
|
/* ETH Variables initialization ----------------------------------------------*/
|
|
void Error_Handler(void);
|
|
|
|
/* USER CODE BEGIN 1 */
|
|
|
|
/* USER CODE END 1 */
|
|
|
|
/* Variables Initialization */
|
|
struct netif gnetif;
|
|
ip4_addr_t ipaddr;
|
|
ip4_addr_t netmask;
|
|
ip4_addr_t gw;
|
|
|
|
/* USER CODE BEGIN 2 */
|
|
|
|
/* USER CODE END 2 */
|
|
|
|
/**
|
|
* LwIP initialization function
|
|
*/
|
|
void MX_LWIP_Init(void)
|
|
{
|
|
/* Initilialize the LwIP stack with RTOS */
|
|
tcpip_init( NULL, NULL );
|
|
|
|
/* IP addresses initialization with DHCP (IPv4) */
|
|
ipaddr.addr = 0;
|
|
netmask.addr = 0;
|
|
gw.addr = 0;
|
|
|
|
/* add the network interface (IPv4/IPv6) with RTOS */
|
|
netif_add(&gnetif, &ipaddr, &netmask, &gw, NULL, ðernetif_init, &tcpip_input);
|
|
|
|
/* Registers the default network interface */
|
|
netif_set_default(&gnetif);
|
|
|
|
if (netif_is_link_up(&gnetif))
|
|
{
|
|
/* When the netif is fully configured this function must be called */
|
|
netif_set_up(&gnetif);
|
|
}
|
|
else
|
|
{
|
|
/* When the netif link is down this function must be called */
|
|
netif_set_down(&gnetif);
|
|
}
|
|
|
|
/* Set the link callback function, this function is called on change of link status*/
|
|
netif_set_link_callback(&gnetif, ethernet_link_status_updated);
|
|
|
|
/* Create the Ethernet link handler thread */
|
|
/* USER CODE BEGIN H7_OS_THREAD_DEF_CREATE_CMSIS_RTOS_V1 */
|
|
osThreadDef(EthLink, ethernet_link_thread, osPriorityBelowNormal, 0, configMINIMAL_STACK_SIZE *2);
|
|
osThreadCreate (osThread(EthLink), &gnetif);
|
|
netif_set_up(&gnetif);
|
|
/* USER CODE END H7_OS_THREAD_DEF_CREATE_CMSIS_RTOS_V1 */
|
|
|
|
/* Start DHCP negotiation for a network interface (IPv4) */
|
|
dhcp_start(&gnetif);
|
|
|
|
/* USER CODE BEGIN 3 */
|
|
|
|
/* USER CODE END 3 */
|
|
}
|
|
|
|
#ifdef USE_OBSOLETE_USER_CODE_SECTION_4
|
|
/* Kept to help code migration. (See new 4_1, 4_2... sections) */
|
|
/* Avoid to use this user section which will become obsolete. */
|
|
/* USER CODE BEGIN 4 */
|
|
/* USER CODE END 4 */
|
|
#endif
|
|
|
|
/**
|
|
* @brief Notify the User about the network interface config status
|
|
* @param netif: the network interface
|
|
* @retval None
|
|
*/
|
|
static void ethernet_link_status_updated(struct netif *netif)
|
|
{
|
|
if (netif_is_up(netif))
|
|
{
|
|
/* USER CODE BEGIN 5 */
|
|
/* USER CODE END 5 */
|
|
}
|
|
else /* netif is down */
|
|
{
|
|
/* USER CODE BEGIN 6 */
|
|
/* USER CODE END 6 */
|
|
}
|
|
}
|
|
|
|
#if defined ( __CC_ARM ) /* MDK ARM Compiler */
|
|
/**
|
|
* Opens a serial device for communication.
|
|
*
|
|
* @param devnum device number
|
|
* @return handle to serial device if successful, NULL otherwise
|
|
*/
|
|
sio_fd_t sio_open(u8_t devnum)
|
|
{
|
|
sio_fd_t sd;
|
|
|
|
/* USER CODE BEGIN 7 */
|
|
sd = 0; // dummy code
|
|
/* USER CODE END 7 */
|
|
|
|
return sd;
|
|
}
|
|
|
|
/**
|
|
* Sends a single character to the serial device.
|
|
*
|
|
* @param c character to send
|
|
* @param fd serial device handle
|
|
*
|
|
* @note This function will block until the character can be sent.
|
|
*/
|
|
void sio_send(u8_t c, sio_fd_t fd)
|
|
{
|
|
/* USER CODE BEGIN 8 */
|
|
/* USER CODE END 8 */
|
|
}
|
|
|
|
/**
|
|
* Reads from the serial device.
|
|
*
|
|
* @param fd serial device handle
|
|
* @param data pointer to data buffer for receiving
|
|
* @param len maximum length (in bytes) of data to receive
|
|
* @return number of bytes actually received - may be 0 if aborted by sio_read_abort
|
|
*
|
|
* @note This function will block until data can be received. The blocking
|
|
* can be cancelled by calling sio_read_abort().
|
|
*/
|
|
u32_t sio_read(sio_fd_t fd, u8_t *data, u32_t len)
|
|
{
|
|
u32_t recved_bytes;
|
|
|
|
/* USER CODE BEGIN 9 */
|
|
recved_bytes = 0; // dummy code
|
|
/* USER CODE END 9 */
|
|
return recved_bytes;
|
|
}
|
|
|
|
/**
|
|
* Tries to read from the serial device. Same as sio_read but returns
|
|
* immediately if no data is available and never blocks.
|
|
*
|
|
* @param fd serial device handle
|
|
* @param data pointer to data buffer for receiving
|
|
* @param len maximum length (in bytes) of data to receive
|
|
* @return number of bytes actually received
|
|
*/
|
|
u32_t sio_tryread(sio_fd_t fd, u8_t *data, u32_t len)
|
|
{
|
|
u32_t recved_bytes;
|
|
|
|
/* USER CODE BEGIN 10 */
|
|
recved_bytes = 0; // dummy code
|
|
/* USER CODE END 10 */
|
|
return recved_bytes;
|
|
}
|
|
#endif /* MDK ARM Compiler */
|
|
|