158 lines
3.9 KiB
Plaintext
158 lines
3.9 KiB
Plaintext
# STM32 HAL Ethernet driver configuration options
|
|
|
|
# Copyright (c) 2017 Erwin Rol <erwin@erwinrol.com>
|
|
# Copyright (c) 2020 Alexander Kozhinov <AlexanderKozhinov@yandex.com>
|
|
# SPDX-License-Identifier: Apache-2.0
|
|
|
|
DT_COMPAT_ST_STM32_ETHERNET := st,stm32-ethernet
|
|
|
|
menuconfig ETH_STM32_HAL
|
|
bool "STM32 HAL Ethernet driver"
|
|
default y if $(dt_compat_enabled,$(DT_COMPAT_ST_STM32_ETHERNET))
|
|
select USE_STM32_HAL_ETH
|
|
select NOCACHE_MEMORY if SOC_SERIES_STM32H7X && CPU_CORTEX_M7
|
|
help
|
|
Enable STM32 HAL based Ethernet driver. It is available for
|
|
all Ethernet enabled variants of the F2, F4, F7 and H7 series.
|
|
|
|
if ETH_STM32_HAL
|
|
|
|
config ETH_STM32_HAL_RX_THREAD_STACK_SIZE
|
|
int "RX thread stack size"
|
|
default 1500
|
|
help
|
|
RX thread stack size
|
|
|
|
config ETH_STM32_HAL_RX_THREAD_PRIO
|
|
int "RX thread priority"
|
|
default 2
|
|
help
|
|
RX thread priority
|
|
|
|
config ETH_STM32_HAL_USE_DTCM_FOR_DMA_BUFFER
|
|
bool "Use DTCM for DMA buffers"
|
|
default y
|
|
depends on SOC_SERIES_STM32F7X
|
|
help
|
|
When this option is activated, the buffers for DMA transfer are
|
|
moved from SRAM to the DTCM (Data Tightly Coupled Memory).
|
|
|
|
config ETH_STM32_HAL_PHY_ADDRESS
|
|
int "Phy address"
|
|
default 0
|
|
help
|
|
The phy address to use.
|
|
|
|
config ETH_STM32_HAL_RANDOM_MAC
|
|
bool "Random MAC address"
|
|
depends on ENTROPY_GENERATOR
|
|
default y
|
|
help
|
|
Generate a random MAC address dynamically.
|
|
|
|
if !ETH_STM32_HAL_RANDOM_MAC
|
|
|
|
config ETH_STM32_HAL_MAC3
|
|
hex "MAC Address Byte 3"
|
|
default 0
|
|
range 0 0xff
|
|
help
|
|
This is the byte 3 of the MAC address.
|
|
|
|
config ETH_STM32_HAL_MAC4
|
|
hex "MAC Address Byte 4"
|
|
default 0
|
|
range 0 0xff
|
|
help
|
|
This is the byte 4 of the MAC address.
|
|
|
|
config ETH_STM32_HAL_MAC5
|
|
hex "MAC Address Byte 5"
|
|
default 0
|
|
range 0 0xff
|
|
help
|
|
This is the byte 5 of the MAC address.
|
|
|
|
endif # !ETH_STM32_HAL_RANDOM_MAC
|
|
|
|
config ETH_STM32_HAL_MII
|
|
bool "Use MII interface"
|
|
help
|
|
Use the MII physical interface instead of RMII.
|
|
|
|
config ETH_STM32_CARRIER_CHECK_RX_IDLE_TIMEOUT_MS
|
|
int "Carrier check timeout period (ms)"
|
|
default 500
|
|
range 100 30000
|
|
help
|
|
Set the RX idle timeout period in milliseconds after which the
|
|
PHY's carrier status is re-evaluated.
|
|
|
|
config ETH_STM32_AUTO_NEGOTIATION_ENABLE
|
|
bool "Enable autonegotiation mode"
|
|
default y
|
|
help
|
|
Enable this if using autonegotiation
|
|
|
|
if !ETH_STM32_AUTO_NEGOTIATION_ENABLE
|
|
|
|
config ETH_STM32_SPEED_10M
|
|
bool "Enable this if using 10 Mbps for speed when autonegotiation is diabled"
|
|
default n
|
|
help
|
|
Set this if using 10 Mbps and when autonegotiation is disabled, otherwise speed
|
|
is 100 Mbps
|
|
|
|
config ETH_STM32_MODE_HALFDUPLEX
|
|
bool "Enable this if using half duplex"
|
|
default n
|
|
help
|
|
Set this if using half duplex when autonegotiation is disabled otherwise
|
|
duplex mode is full duplex
|
|
|
|
endif # !ETH_STM32_AUTO_NEGOTIATION_ENABLE
|
|
|
|
if SOC_SERIES_STM32F7X || SOC_SERIES_STM32H7X
|
|
|
|
config PTP_CLOCK_STM32_HAL
|
|
bool "STM32 HAL PTP clock driver support"
|
|
default y
|
|
depends on PTP_CLOCK || NET_L2_PTP
|
|
help
|
|
Enable STM32 PTP clock support.
|
|
|
|
config ETH_STM32_HAL_PTP_CLOCK_SRC_HZ
|
|
int "Frequency of the clock source for the PTP timer"
|
|
default 50000000
|
|
depends on PTP_CLOCK_STM32_HAL
|
|
help
|
|
Set the frequency in Hz sourced to the PTP timer.
|
|
If the value is set properly, the timer will be accurate.
|
|
|
|
config ETH_STM32_HAL_PTP_CLOCK_ADJ_MIN_PCT
|
|
int "Lower bound of clock frequency adjustment (in percent)"
|
|
default 90
|
|
depends on PTP_CLOCK_STM32_HAL
|
|
help
|
|
Specifies lower bound of PTP clock rate adjustment.
|
|
|
|
config ETH_STM32_HAL_PTP_CLOCK_ADJ_MAX_PCT
|
|
int "Upper bound of clock frequency adjustment (in percent)"
|
|
default 110
|
|
depends on PTP_CLOCK_STM32_HAL
|
|
help
|
|
Specifies upper bound of PTP clock rate adjustment.
|
|
|
|
config ETH_STM32_HAL_PTP_CLOCK_INIT_PRIO
|
|
int
|
|
default 85
|
|
depends on PTP_CLOCK_STM32_HAL
|
|
help
|
|
STM32 PTP Clock initialization priority level. There is
|
|
a dependency from the network stack that this device
|
|
initializes before network stack (NET_INIT_PRIO).
|
|
|
|
endif # SOC_SERIES_STM32F7X || SOC_SERIES_STM32H7X
|
|
|
|
endif # ETH_STM32_HAL
|