RZ/A Flexible Software Package Documentation  Release v3.3.0

 
Ethernet (r_gether)

Functions

fsp_err_t R_GETHER_Open (ether_ctrl_t *const p_ctrl, ether_cfg_t const *const p_cfg)
 After ETHERC, EDMAC and PHY-LSI are reset in software, an auto negotiation of PHY-LSI is begun. Afterwards, the link signal change interrupt is permitted. Implements ether_api_t::open. More...
 
fsp_err_t R_GETHER_Close (ether_ctrl_t *const p_ctrl)
 Disables interrupts. Removes power and releases hardware lock. Implements ether_api_t::close. More...
 
fsp_err_t R_GETHER_Read (ether_ctrl_t *const p_ctrl, void *const p_buffer, uint32_t *const length_bytes)
 Receive Ethernet frame. Receives data to the location specified by the pointer to the receive buffer. In zero copy mode, the address of the receive buffer is returned. In non zero copy mode, the received data in the internal buffer is copied to the pointer passed by the argument. Implements ether_api_t::read. More...
 
fsp_err_t R_GETHER_BufferRelease (ether_ctrl_t *const p_ctrl)
 Move to the next buffer in the circular receive buffer list. Implements ether_api_t::bufferRelease. More...
 
fsp_err_t R_GETHER_Write (ether_ctrl_t *const p_ctrl, void *const p_buffer, uint32_t const frame_length)
 Transmit Ethernet frame. Transmits data from the location specified by the pointer to the transmit buffer, with the data size equal to the specified frame length. In the non zero copy mode, transmits data after being copied to the internal buffer. Implements ether_api_t::write. More...
 
fsp_err_t R_GETHER_LinkProcess (ether_ctrl_t *const p_ctrl)
 The Link up processing, the Link down processing, and the magic packet detection processing are executed. Implements ether_api_t::linkProcess. More...
 
fsp_err_t R_GETHER_WakeOnLANEnable (ether_ctrl_t *const p_ctrl)
 The setting of ETHERC is changed from normal sending and receiving mode to magic packet detection mode. Implements ether_api_t::wakeOnLANEnable. More...
 
fsp_err_t R_GETHER_CallbackSet (ether_ctrl_t *const p_api_ctrl, void(*p_callback)(ether_callback_args_t *), void const *const p_context, ether_callback_args_t *const p_callback_memory)
 
fsp_err_t R_GETHER_RxBufferUpdate (ether_ctrl_t *const p_ctrl, __attribute__((unused)) void *const p_buffer)
 Change the buffer pointer of the current rx buffer descriptor. Implements ether_api_t::rxBufferUpdate. More...
 
fsp_err_t R_GETHER_TxStatusGet (__attribute__((unused)) ether_ctrl_t *const p_ctrl, __attribute__((unused)) void *const p_buffer_address)
 

Detailed Description

Driver for the Ethernet peripheral on RZ MPUs. This module implements the Ethernet Interface.

Overview

This module performs Ethernet frame transmission and reception using an Ethernet controller and an Ethernet DMA controller.

Features

The Ethernet module supports the following features:

Configuration

Build Time Configurations for r_gether

The following build time configurations are defined in fsp_cfg/r_gether_cfg.h:

ConfigurationOptionsDefaultDescription
Parameter Checking
  • Default (BSP)
  • Enabled
  • Disabled
Default (BSP) If selected code for parameter checking is included in the build.
ET0_LINKSTA Pin Status Flag
  • Fall -> Rise
  • Rise -> Fall
Fall -> Rise Specify the polarity of the link signal output by the PHY-LSI. When 0 is specified, link-up and link-down correspond respectively to the fall and rise of the LINKSTA signal. When 1 is specified, link-up and link-down correspond respectively to the rise and fall of the LINKSTA signal.
Link Signal Change Flag
  • Unused
  • Used
Unused Use LINKSTA signal for detect link status changes 0 = unused (use PHY-LSI status register) 1 = use (use LINKSTA signal)

Configurations for Networking > Gigabit Ethernet (r_gether)

This module can be added to the Stacks tab via New Stack > Networking > Gigabit Ethernet (r_gether).

ConfigurationOptionsDefaultDescription
General > NameName must be a valid C symbolg_gether0 Module name.
General > Channel
  • 0
  • 1
1 Select the ether channel number.
General > MAC addressMust be a valid MAC address00:11:22:33:44:55 MAC address of this channel.
General > Zero-copy Mode
  • Disable
  • Enable
Disable Enable or disable zero-copy mode.
General > Flow control functionality
  • Disable
  • Enable
Disable Enable or disable flow control.
Filters > Multicast Mode
  • Disable
  • Enable
Enable Enable or disable multicast frame reception.
Filters > Promiscuous Mode
  • Disable
  • Enable
Disable Enable this option to receive packets addressed to other NICs.
Filters > Broadcast filterMust be a valid non-negative integer with maximum configurable value of 65535. 0 Limit of the number of broadcast frames received continuously
Buffers > Number of TX bufferMust be an integer from 1 to 87 Number of transmit buffers
Buffers > Number of RX bufferMust be an integer from 1 to 88 Number of receive buffers
Buffers > Allocate RX buffer
  • Disable
  • Enable
Enable Allocates the RX buffer when generating the configuration structure
Buffers > Buffer sizeMust be at least 1514 which is the maximum Ethernet frame size.1514 Size of Ethernet buffer
Buffers > Padding
  • Disable
  • Enable
Disable The padding size that is automatically inserted into the received packets
Interrupts > Interrupt priorityValue must be an integer between 0 and 3124 Select the EDMAC interrupt priority.
Interrupts > CallbackName must be a valid C symbolNULL Callback provided when an ISR occurs

Interrupt Configuration

The first R_GETHER_Open function call sets EINT interrupts. The user could provide callback function which would be invoked when EINT interrupt handler has been completed. The callback arguments will contain information about a channel number, the ETHERC and EDMAC status, the event code, and a pointer to the user defined context.

Callback Configuration

When the callback function is called, a variable in which the channel number for which the detection occurred and a constant shown in Table 2.4 are stored is passed as an argument. If the value of this argument is to be used outside the callback function, its value should be copied into, for example, a global variable.

Pin Configuration

To use the Ethernet module, input/output signals of the peripheral function have to be allocated to pins with the multi-function pin controller (MPC). Please perform the pin setting before calling the R_GETHER_Open function.

Usage Notes

Ethernet Frame Format

The Ethernet module supports the Ethernet II/IEEE 802.3 frame format.

Frame Format for Data Transmission and Reception

frame_format_image.svg
Frame Format Image

The preamble and SFD signal the start of an Ethernet frame. The FCS contains the CRC of the Ethernet frame and is calculated on the transmitting side. When data is received the CRC value of the frame is calculated in hardware, and the Ethernet frame is discarded if the values do not match. When the hardware determines that the data is normal, the valid range of receive data is: (transmission destination address) + (transmission source address) + (length/type) + (data).

PAUSE Frame Format

pause_frame_format_image.svg
Pause Frame Format Image

The transmission destination address is specified as 01:80:C2:00:00:01 (a multicast address reserved for PAUSE frames). At the start of the payload the length/type is specified as 0x8808 and the operation code as 0x0001. The pause duration in the payload is specified by the value of the automatic PAUSE (AP) bits in the automatic PAUSE frame setting register (APR), or the manual PAUSE time setting (MP) bits in the manual PAUSE frame setting register (MPR).

Limitations

Memory alignment limitation for Ethernet buffer

The Ethernet Driver has several alignment constraints:

Examples

ETHER Basic Example

This is a basic example of minimal use of the ETHER in an application.

Note
In this example zero-copy mode is disabled and there are no restrictions on buffer alignment.
#define ETHER_EXAMPLE_MAXIMUM_ETHERNET_FRAME_SIZE (1514)
#define ETHER_EXAMPLE_TRANSMIT_ETHERNET_FRAME_SIZE (60)
#define ETHER_EXAMPLE_SOURCE_MAC_ADDRESS 0x74, 0x90, 0x50, 0x00, 0x79, 0x01
#define ETHER_EXAMPLE_DESTINATION_MAC_ADDRESS 0x74, 0x90, 0x50, 0x00, 0x79, 0x02
#define ETHER_EXAMPLE_FRAME_TYPE 0x00, 0x2E
#define ETHER_EXAMPLE_PAYLOAD 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, \
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, \
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, \
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, \
/* Receive data buffer */
static uint8_t gp_read_buffer[ETHER_EXAMPLE_MAXIMUM_ETHERNET_FRAME_SIZE] = {0};
/* Transmit data buffer */
static uint8_t gp_send_data[ETHER_EXAMPLE_TRANSMIT_ETHERNET_FRAME_SIZE] =
{
ETHER_EXAMPLE_DESTINATION_MAC_ADDRESS, /* Destination MAC address */
ETHER_EXAMPLE_SOURCE_MAC_ADDRESS, /* Source MAC address */
ETHER_EXAMPLE_FRAME_TYPE, /* Type field */
ETHER_EXAMPLE_PAYLOAD /* Payload value (46byte) */
};
void ether_basic_example (void)
{
fsp_err_t err = FSP_SUCCESS;
/* Source MAC Address */
static uint8_t mac_address_source[6] = {ETHER_EXAMPLE_SOURCE_MAC_ADDRESS};
uint32_t read_data_size = 0;
g_ether0_cfg.p_mac_address = mac_address_source;
/* Open the ether instance with initial configuration. */
err = R_GETHER_Open(&g_ether0_ctrl, &g_ether0_cfg);
/* Handle any errors. This function should be defined by the user. */
assert(FSP_SUCCESS == err);
do
{
/* When the Ethernet link status read from the PHY-LSI Basic Status register is link-up,
* Initializes the module and make auto negotiation. */
err = R_GETHER_LinkProcess(&g_ether0_ctrl);
} while (FSP_SUCCESS != err);
/* Transmission is non-blocking. */
/* User data copy to internal buffer and is transferred by DMA in the background. */
err = R_GETHER_Write(&g_ether0_ctrl, (void *) gp_send_data, sizeof(gp_send_data));
assert(FSP_SUCCESS == err);
/* received data copy to user buffer from internal buffer. */
do
{
err = R_GETHER_Read(&g_ether0_ctrl, (void *) gp_read_buffer, &read_data_size);
} while (FSP_ERR_ETHER_ERROR_NO_DATA == err);
assert(FSP_SUCCESS == err);
/* Disable transmission and receive function and close the ether instance. */
R_GETHER_Close(&g_ether0_ctrl);
}

ETHER Advanced Example

The example demonstrates using send and receive function in zero copy mode. Transmit buffers must be 32-byte aligned and the receive buffer must be released once its contents have been used.

#define ETHER_EXAMPLE_FLAG_ON (1U)
#define ETHER_EXAMPLE_FLAG_OFF (0U)
#define ETHER_EXAMPLE_ETHER_ISR_EE_FR_MASK (1UL << 18)
#define ETHER_EXAMPLE_ETHER_ISR_EE_TC_MASK (1UL << 21)
#define ETHER_EXAMPLE_ETHER_ISR_EC_MPD_MASK (1UL << 1)
#define ETHER_EXAMPLE_ALIGNMENT_32_BYTE (32)
static volatile uint32_t g_example_receive_complete = 0;
static volatile uint32_t g_example_transfer_complete = 0;
static volatile uint32_t g_example_magic_packet_done = 0;
static uint8_t gp_send_data_internal[ETHER_EXAMPLE_TRANSMIT_ETHERNET_FRAME_SIZE] =
{
ETHER_EXAMPLE_DESTINATION_MAC_ADDRESS, /* Destination MAC address */
ETHER_EXAMPLE_SOURCE_MAC_ADDRESS, /* Source MAC address */
ETHER_EXAMPLE_FRAME_TYPE, /* Type field */
ETHER_EXAMPLE_PAYLOAD /* Payload value (46byte) */
};
void ether_example_callback (ether_callback_args_t * p_args) {
switch (p_args->event)
{
{
if (ETHER_EXAMPLE_ETHER_ISR_EC_MPD_MASK == (p_args->status_ecsr & ETHER_EXAMPLE_ETHER_ISR_EC_MPD_MASK))
{
g_example_magic_packet_done = ETHER_EXAMPLE_FLAG_ON;
}
if (ETHER_EXAMPLE_ETHER_ISR_EE_TC_MASK == (p_args->status_eesr & ETHER_EXAMPLE_ETHER_ISR_EE_TC_MASK))
{
g_example_transfer_complete = ETHER_EXAMPLE_FLAG_ON;
}
if (ETHER_EXAMPLE_ETHER_ISR_EE_FR_MASK == (p_args->status_eesr & ETHER_EXAMPLE_ETHER_ISR_EE_FR_MASK))
{
g_example_receive_complete = ETHER_EXAMPLE_FLAG_ON;
}
break;
}
default:
{
}
}
}
void ether_advanced_use_internal_buffer_example (void) {
fsp_err_t err = FSP_SUCCESS;
/* Source MAC Address */
static uint8_t mac_address_source[6] = {ETHER_EXAMPLE_SOURCE_MAC_ADDRESS};
static uint8_t read_buffer[ETHER_EXAMPLE_BUFFER_SIZE];
uint32_t read_data_size = 0;
g_ether0_cfg.p_mac_address = mac_address_source;
g_ether0_cfg.p_callback = (void (*)(ether_callback_args_t *))ether_example_callback;
/* Open the ether instance with initial configuration. */
err = R_GETHER_Open(&g_ether0_ctrl, &g_ether0_cfg);
/* Handle any errors. This function should be defined by the user. */
assert(FSP_SUCCESS == err);
do
{
/* When the Ethernet link status read from the PHY-LSI Basic Status register is link-up,
* Initializes the module and make auto negotiation. */
err = R_GETHER_LinkProcess(&g_ether0_ctrl);
} while (FSP_SUCCESS != err);
/* Set user buffer to TX descriptor and enable transmission. */
err = R_GETHER_Write(&g_ether0_ctrl, (void *) gp_send_data_internal, sizeof(gp_send_data_internal));
if (FSP_SUCCESS == err)
{
/* Wait for the transmission to complete. */
/* Data array should not change in zero copy mode until transfer complete. */
while (ETHER_EXAMPLE_FLAG_ON != g_example_transfer_complete)
{
;
}
}
/* Get receive buffer from RX descriptor. */
do
{
err = R_GETHER_Read(&g_ether0_ctrl, (void *) read_buffer, &read_data_size);
} while (FSP_ERR_ETHER_ERROR_NO_DATA == err);
assert(FSP_SUCCESS == err);
/* Process received data here */
/* Release receive buffer to RX descriptor. */
err = R_GETHER_BufferRelease(&g_ether0_ctrl);
assert(FSP_SUCCESS == err);
/* Disable transmission and receive function and close the ether instance. */
R_GETHER_Close(&g_ether0_ctrl);
}
#define ETHER_EXAMPLE_ALIGNMENT_32_BYTE (32)
#define ETHER_EXAMPLE_ETHERNET_FRAME_PAYLOAD_OFFSET (14)
/* The data buffer must be 32-byte aligned when using zero copy mode. */
static uint8_t gp_send_data_external[ETHER_EXAMPLE_TRANSMIT_ETHERNET_FRAME_SIZE] =
{
ETHER_EXAMPLE_DESTINATION_MAC_ADDRESS, /* Destination MAC address */
ETHER_EXAMPLE_SOURCE_MAC_ADDRESS, /* Source MAC address */
ETHER_EXAMPLE_FRAME_TYPE, /* Type field */
ETHER_EXAMPLE_PAYLOAD /* Payload value (46byte) */
};
typedef struct st_buffer_node
{
uint8_t * p_buffer;
struct st_buffer_node * p_next;
} buffer_node_t;
void ether_advanced_use_external_buffer_example (void) {
fsp_err_t err = FSP_SUCCESS;
/* Source MAC Address */
uint8_t mac_address_source[6] = {ETHER_EXAMPLE_SOURCE_MAC_ADDRESS};
uint8_t * p_tx_buffer = NULL;
uint8_t * p_rx_allocate_buffer = NULL;
buffer_node_t * p_tx_buffer_head;
buffer_node_t * p_tx_buffer_tail;
uint32_t read_data_size = 0;
uint8_t i;
g_ether0_cfg.p_mac_address = mac_address_source;
/* Create ring buffer structure to manage transmit buffer.*/
p_tx_buffer_head = (buffer_node_t *) malloc(sizeof(buffer_node_t));
p_tx_buffer_tail = p_tx_buffer_head;
for (i = 0; i < g_ether0_cfg.num_tx_descriptors - 1; i++)
{
p_tx_buffer_tail->p_buffer = NULL;
p_tx_buffer_tail->p_next = (buffer_node_t *) malloc(sizeof(buffer_node_t));
p_tx_buffer_tail = p_tx_buffer_tail->p_next;
}
p_tx_buffer_tail->p_buffer = NULL;
p_tx_buffer_tail->p_next = p_tx_buffer_head;
/* Open the ether instance with initial configuration. */
err = R_GETHER_Open(&g_ether0_ctrl, &g_ether0_cfg);
/* Handle any errors. This function should be defined by the user. */
assert(FSP_SUCCESS == err);
i = 0;
/* Initialize receive buffer in Ethernet driver. */
while (i < g_ether0_cfg.num_rx_descriptors)
{
p_rx_allocate_buffer = malloc(g_ether0_cfg.ether_buffer_size * sizeof(char));
if (NULL != p_rx_allocate_buffer)
{
/* Set receive buffer to Ethernet driver. */
err = R_GETHER_RxBufferUpdate(&g_ether0_ctrl, (void *) p_rx_allocate_buffer);
if (FSP_SUCCESS == err)
{
i++;
}
}
else
{
assert(0);
}
}
do
{
/* When the Ethernet link status read from the PHY-LSI Basic Status register is link-up,
* Initializes the module and make auto negotiation. */
err = R_GETHER_LinkProcess(&g_ether0_ctrl);
} while (FSP_SUCCESS != err);
for (i = 0; i < g_ether0_cfg.num_rx_descriptors; i++)
{
if (NULL == p_tx_buffer_tail->p_buffer)
{
/* Allocate memory to transmit buffer */
p_tx_buffer = (uint8_t *) malloc(sizeof(gp_send_data_external));
/* Process transmit data here. */
memcpy(p_tx_buffer, gp_send_data_external, sizeof(gp_send_data_external));
gp_send_data_external[ETHER_EXAMPLE_ETHERNET_FRAME_PAYLOAD_OFFSET]++;
/* Set user buffer to TX descriptor and enable transmission. */
err = R_GETHER_Write(&g_ether0_ctrl, (void *) gp_send_data_external, sizeof(gp_send_data_external));
/* Register transmit buffer to ring buffer. */
if (FSP_SUCCESS == err)
{
p_tx_buffer_tail->p_buffer = p_tx_buffer;
p_tx_buffer_tail = p_tx_buffer_tail->p_next;
}
else
{
/* Release transmit buffer. */
free(p_tx_buffer);
}
}
/* Get receive buffer from RX descriptor. */
do
{
err = R_GETHER_Read(&g_ether0_ctrl, (void *) p_rx_allocate_buffer, &read_data_size);
} while (FSP_ERR_ETHER_ERROR_NO_DATA == err);
free(p_rx_allocate_buffer);
if (FSP_SUCCESS == err)
{
/* Allocate new receive buffer and update receive buffer to RX descriptor. */
p_rx_allocate_buffer = malloc(g_ether0_cfg.ether_buffer_size * sizeof(char));
if (NULL != p_rx_allocate_buffer)
{
R_GETHER_RxBufferUpdate(&g_ether0_ctrl, p_rx_allocate_buffer);
}
else
{
assert(0);
}
/* Process received data here. */
}
}
}

Data Structures

struct  gether_instance_rx_descriptor_t
 
struct  ether_instance_descriptor_t
 
struct  ether_instance_ctrl_t
 

Enumerations

enum  gether_previous_link_status_t
 
enum  gether_link_change_t
 
enum  gether_link_establish_status_t
 

Data Structure Documentation

◆ gether_instance_rx_descriptor_t

struct gether_instance_rx_descriptor_t

DMAC descriptor as defined in the hardware manual. Structure must be packed at 1 byte.

◆ ether_instance_descriptor_t

struct ether_instance_descriptor_t

EDMAC descriptor as defined in the hardware manual. Structure must be packed at 1 byte.

◆ ether_instance_ctrl_t

struct ether_instance_ctrl_t

GETHER control block. DO NOT INITIALIZE. Initialization occurs when ether_api_t::open is called.

Data Fields

uint32_t open
 Used to determine if the channel is configured.
 
ether_cfg_t const * p_gether_cfg
 Pointer to initial configurations.
 
gether_instance_tx_descriptor_t * p_tx_descriptor
 Pointer to the currently referenced transmit descriptor.
 
gether_instance_rx_descriptor_tp_rx_descriptor
 Pointer to the currently referenced receive descriptor.
 
void * p_reg_emac
 Base register of gethernet controller for this channel.
 
void * p_reg_ether
 Base register of DMA controller for this channel.
 
void * p_reg_toe
 Base register of TOE controller for this channel.
 
gether_previous_link_status_t previous_link_status
 Previous link status.
 
gether_link_change_t link_change
 status of link change
 
gether_link_establish_status_t link_establish_status
 Current Link status.
 

Enumeration Type Documentation

◆ gether_previous_link_status_t

Enumerator
GETHER_PREVIOUS_LINK_STATUS_DOWN 

Previous link status is down.

GETHER_PREVIOUS_LINK_STATUS_UP 

Previous link status is up.

◆ gether_link_change_t

Enumerator
GETHER_LINK_CHANGE_NO_CHANGE 

Link status is no change.

GETHER_LINK_CHANGE_LINK_DOWN 

Link status changes to down.

GETHER_LINK_CHANGE_LINK_UP 

Link status changes to up.

◆ gether_link_establish_status_t

Enumerator
GETHER_LINK_ESTABLISH_STATUS_DOWN 

Link establish status is down.

GETHER_LINK_ESTABLISH_STATUS_UP 

Link establish status is up.

Function Documentation

◆ R_GETHER_Open()

fsp_err_t R_GETHER_Open ( ether_ctrl_t *const  p_ctrl,
ether_cfg_t const *const  p_cfg 
)

After ETHERC, EDMAC and PHY-LSI are reset in software, an auto negotiation of PHY-LSI is begun. Afterwards, the link signal change interrupt is permitted. Implements ether_api_t::open.

Return values
FSP_SUCCESSChannel opened successfully.
FSP_ERR_ASSERTIONPointer to ETHER control block or configuration structure is NULL.
FSP_ERR_ALREADY_OPENControl block has already been opened or channel is being used by another instance. Call close() then open() to reconfigure.
FSP_ERR_ETHER_ERROR_PHY_COMMUNICATIONInitialization of PHY-LSI failed.
FSP_ERR_INVALID_CHANNELInvalid channel number is given.
FSP_ERR_INVALID_POINTERPointer to MAC address is NULL.
FSP_ERR_INVALID_ARGUMENTInterrupt is not enabled.
FSP_ERR_ETHER_PHY_ERROR_LINKInitialization of PHY-LSI failed.

◆ R_GETHER_Close()

fsp_err_t R_GETHER_Close ( ether_ctrl_t *const  p_ctrl)

Disables interrupts. Removes power and releases hardware lock. Implements ether_api_t::close.

Return values
FSP_SUCCESSChannel successfully closed.
FSP_ERR_ASSERTIONPointer to ETHER control block is NULL.
FSP_ERR_NOT_OPENThe control block has not been opened

◆ R_GETHER_Read()

fsp_err_t R_GETHER_Read ( ether_ctrl_t *const  p_ctrl,
void *const  p_buffer,
uint32_t *const  length_bytes 
)

Receive Ethernet frame. Receives data to the location specified by the pointer to the receive buffer. In zero copy mode, the address of the receive buffer is returned. In non zero copy mode, the received data in the internal buffer is copied to the pointer passed by the argument. Implements ether_api_t::read.

Return values
FSP_SUCCESSProcessing completed successfully.
FSP_ERR_ASSERTIONPointer to ETHER control block is NULL.
FSP_ERR_NOT_OPENThe control block has not been opened.
FSP_ERR_ETHER_ERROR_NO_DATAThere is no data in receive buffer.
FSP_ERR_ETHER_ERROR_LINKAuto-negotiation is not completed, and reception is not enabled.
FSP_ERR_ETHER_ERROR_MAGIC_PACKET_MODEAs a Magic Packet is being detected, transmission and reception is not enabled.
FSP_ERR_INVALID_POINTERValue of the pointer is NULL.

◆ R_GETHER_BufferRelease()

fsp_err_t R_GETHER_BufferRelease ( ether_ctrl_t *const  p_ctrl)

Move to the next buffer in the circular receive buffer list. Implements ether_api_t::bufferRelease.

Return values
FSP_SUCCESSProcessing completed successfully.
FSP_ERR_ASSERTIONPointer to ETHER control block is NULL.
FSP_ERR_NOT_OPENThe control block has not been opened
FSP_ERR_ETHER_ERROR_LINKAuto-negotiation is not completed, and reception is not enabled.
FSP_ERR_ETHER_ERROR_MAGIC_PACKET_MODEAs a Magic Packet is being detected, transmission and reception is not enabled.

◆ R_GETHER_Write()

fsp_err_t R_GETHER_Write ( ether_ctrl_t *const  p_ctrl,
void *const  p_buffer,
uint32_t const  frame_length 
)

Transmit Ethernet frame. Transmits data from the location specified by the pointer to the transmit buffer, with the data size equal to the specified frame length. In the non zero copy mode, transmits data after being copied to the internal buffer. Implements ether_api_t::write.

Return values
FSP_SUCCESSProcessing completed successfully.
FSP_ERR_ASSERTIONPointer to ETHER control block is NULL.
FSP_ERR_NOT_OPENThe control block has not been opened.
FSP_ERR_ETHER_ERROR_LINKAuto-negotiation is not completed, and reception is not enabled.
FSP_ERR_ETHER_ERROR_MAGIC_PACKET_MODEAs a Magic Packet is being detected, transmission and reception is not enabled.
FSP_ERR_ETHER_ERROR_TRANSMIT_BUFFER_FULLTransmit buffer is not empty.
FSP_ERR_INVALID_POINTERValue of the pointer is NULL.
FSP_ERR_INVALID_ARGUMENTValue of the send frame size is out of range.

◆ R_GETHER_LinkProcess()

fsp_err_t R_GETHER_LinkProcess ( ether_ctrl_t *const  p_ctrl)

The Link up processing, the Link down processing, and the magic packet detection processing are executed. Implements ether_api_t::linkProcess.

Return values
FSP_SUCCESSLink is up.
FSP_ERR_ASSERTIONPointer to ETHER control block is NULL.
FSP_ERR_NOT_OPENThe control block has not been opened.
FSP_ERR_ETHER_ERROR_LINKLink is down.
FSP_ERR_ETHER_PHY_ERROR_LINKInitialization of the PHY-LSI failed.

◆ R_GETHER_WakeOnLANEnable()

fsp_err_t R_GETHER_WakeOnLANEnable ( ether_ctrl_t *const  p_ctrl)

The setting of ETHERC is changed from normal sending and receiving mode to magic packet detection mode. Implements ether_api_t::wakeOnLANEnable.

Return values
FSP_SUCCESSProcessing completed successfully.
FSP_ERR_ASSERTIONPointer to ETHER control block is NULL.
FSP_ERR_NOT_OPENThe control block has not been opened.
FSP_ERR_ETHER_ERROR_LINKAuto-negotiation is not completed, and reception is not enabled.
FSP_ERR_ETHER_PHY_ERROR_LINKInitialization of PHY-LSI failed.

◆ R_GETHER_CallbackSet()

fsp_err_t R_GETHER_CallbackSet ( ether_ctrl_t *const  p_api_ctrl,
void(*)(ether_callback_args_t *)  p_callback,
void const *const  p_context,
ether_callback_args_t *const  p_callback_memory 
)

(end addtogroup GETHER) Updates the user callback with the option to provide memory for the callback argument structure. Implements ether_api_t::callbackSet.

Return values
FSP_SUCCESSCallback updated successfully.
FSP_ERR_ASSERTIONA required pointer is NULL.
FSP_ERR_NOT_OPENThe control block has not been opened.
FSP_ERR_NO_CALLBACK_MEMORYp_callback is non-secure and p_callback_memory is either secure or NULL.

◆ R_GETHER_RxBufferUpdate()

fsp_err_t R_GETHER_RxBufferUpdate ( ether_ctrl_t *const  p_ctrl,
__attribute__((unused)) void *const  p_buffer 
)

Change the buffer pointer of the current rx buffer descriptor. Implements ether_api_t::rxBufferUpdate.

Return values
FSP_SUCCESSProcessing completed successfully.
FSP_ERR_ASSERTIONA pointer argument is NULL.
FSP_ERR_NOT_OPENThe control block has not been opened.
FSP_ERR_INVALID_POINTERThe pointer of buffer is NULL or not aligned on a 32-bit boundary.
FSP_ERR_INVALID_MODEDriver is configured to non zero copy mode.

◆ R_GETHER_TxStatusGet()

fsp_err_t R_GETHER_TxStatusGet ( __attribute__((unused)) ether_ctrl_t *const  p_ctrl,
__attribute__((unused)) void *const  p_buffer_address 
)

Provides status of Ethernet driver in the user provided pointer. Implements ether_api_t::txStatusGet.

Return values
FSP_SUCCESSTransmit buffer address is stored in provided p_buffer_address.
FSP_ERR_ASSERTIONPointer to ETHER control block is NULL.
FSP_ERR_NOT_OPENThe control block has not been opened.
FSP_ERR_INVALID_POINTERp_status is NULL.
FSP_ERR_NOT_FOUNDTransmit buffer address has been overwritten in transmit descriptor.