2019-11-01 13:45:29 +01:00
|
|
|
# ETH_MCUX Ethernet driver configuration options
|
2016-06-16 18:33:47 +02:00
|
|
|
|
2016-12-20 18:23:48 +01:00
|
|
|
# Copyright (c) 2016-2017 ARM Ltd
|
2017-01-19 02:01:01 +01:00
|
|
|
# SPDX-License-Identifier: Apache-2.0
|
2016-06-16 18:33:47 +02:00
|
|
|
|
2017-01-02 21:03:19 +01:00
|
|
|
menuconfig ETH_MCUX
|
2018-08-14 16:19:20 +02:00
|
|
|
bool "MCUX Ethernet driver"
|
2019-01-28 21:12:20 +01:00
|
|
|
depends on HAS_MCUX_ENET
|
2019-01-31 11:34:26 +01:00
|
|
|
select NOCACHE_MEMORY if HAS_MCUX_CACHE
|
|
|
|
select ARM_MPU if CPU_CORTEX_M7
|
2020-09-02 00:31:40 +02:00
|
|
|
select NET_POWER_MANAGEMENT if PM_DEVICE
|
2016-06-16 18:33:47 +02:00
|
|
|
help
|
2016-12-20 18:23:48 +01:00
|
|
|
Enable MCUX Ethernet driver. Note, this driver performs one shot PHY
|
|
|
|
setup. There is no support for PHY disconnect, reconnect or
|
|
|
|
configuration change.
|
2016-06-16 18:33:47 +02:00
|
|
|
|
2017-01-02 21:03:19 +01:00
|
|
|
if ETH_MCUX
|
2019-03-07 05:01:43 +01:00
|
|
|
|
2017-02-21 17:25:23 +01:00
|
|
|
config ETH_MCUX_PROMISCUOUS_MODE
|
2022-03-09 12:05:12 +01:00
|
|
|
bool "Promiscuous mode"
|
2017-02-21 17:25:23 +01:00
|
|
|
help
|
2017-12-05 16:34:28 +01:00
|
|
|
Place the Ethernet receiver in promiscuous mode. This may be useful
|
|
|
|
for debugging and not needed for normal work.
|
2017-02-21 17:25:23 +01:00
|
|
|
|
2020-04-10 08:31:01 +02:00
|
|
|
config ETH_MCUX_RMII_EXT_CLK
|
2022-03-09 12:05:12 +01:00
|
|
|
bool "RMII clock from external sources"
|
2020-04-10 08:31:01 +02:00
|
|
|
help
|
|
|
|
Setting this option will configure MCUX clock block to feed RMII
|
|
|
|
reference clock from external source (ENET_1588_CLKIN)
|
|
|
|
|
2020-04-11 11:06:36 +02:00
|
|
|
config ETH_MCUX_NO_PHY_SMI
|
|
|
|
bool "Do not use SMI for PHY communication"
|
|
|
|
help
|
|
|
|
Some PHY devices, with DSA capabilities do not use SMI for
|
|
|
|
communication with MAC ENET controller. Other busses - like SPI
|
|
|
|
or I2C are used instead.
|
|
|
|
|
2017-01-06 23:20:47 +01:00
|
|
|
config ETH_MCUX_PHY_TICK_MS
|
|
|
|
int "PHY poll period (ms)"
|
|
|
|
default 1000
|
|
|
|
range 100 30000
|
|
|
|
help
|
|
|
|
Set the PHY status polling period.
|
|
|
|
|
2017-02-08 17:39:24 +01:00
|
|
|
config ETH_MCUX_PHY_EXTRA_DEBUG
|
2022-03-09 12:05:12 +01:00
|
|
|
bool "Additional detailed PHY debug"
|
2017-02-08 17:39:24 +01:00
|
|
|
help
|
|
|
|
Enable additional PHY related debug information related to
|
|
|
|
PHY status polling.
|
|
|
|
|
2017-01-02 21:03:19 +01:00
|
|
|
config ETH_MCUX_RX_BUFFERS
|
|
|
|
int "Number of MCUX RX buffers"
|
2019-01-18 17:40:10 +01:00
|
|
|
default 1
|
2016-06-16 18:33:47 +02:00
|
|
|
range 1 16
|
|
|
|
help
|
2016-12-20 18:23:48 +01:00
|
|
|
Set the number of RX buffers provided to the MCUX driver.
|
2016-06-16 18:33:47 +02:00
|
|
|
|
2017-01-02 21:03:19 +01:00
|
|
|
config ETH_MCUX_TX_BUFFERS
|
|
|
|
int "Number of MCUX TX buffers"
|
2019-01-18 17:40:10 +01:00
|
|
|
default 1
|
2022-01-29 15:35:20 +01:00
|
|
|
range 1 16
|
2016-06-16 18:33:47 +02:00
|
|
|
help
|
2016-12-20 18:23:48 +01:00
|
|
|
Set the number of TX buffers provided to the MCUX driver.
|
2016-06-16 18:33:47 +02:00
|
|
|
|
2019-12-10 15:17:04 +01:00
|
|
|
config ETH_MCUX_HW_ACCELERATION
|
2022-03-09 12:05:12 +01:00
|
|
|
bool "Hardware acceleration"
|
2019-12-10 15:17:04 +01:00
|
|
|
help
|
|
|
|
Enable hardware acceleration for the following:
|
|
|
|
- IPv4, UDP and TCP checksum (both Rx and Tx)
|
|
|
|
|
2018-01-25 07:55:18 +01:00
|
|
|
config PTP_CLOCK_MCUX
|
|
|
|
bool "MCUX PTP clock driver support"
|
Kconfig: Use the first default with a satisfied condition
Up until now, Zephyr has patched Kconfig to use the last 'default' with
a satisfied condition, instead of the first one. I'm not sure why the
patch was added (it predates Kconfiglib), but I suspect it's related to
Kconfig.defconfig files.
There are at least three problems with the patch:
1. It's inconsistent with how Kconfig works in other projects, which
might confuse newcomers.
2. Due to oversights, earlier 'range' properties are still preferred,
as well as earlier 'default' properties on choices.
In addition to being inconsistent, this makes it impossible to
override 'range' properties and choice 'default' properties if the
base definition of the symbol/choice already has 'range'/'default'
properties.
I've seen errors caused by the inconsistency, and I suspect there
are more.
3. A fork of Kconfiglib that adds the patch needs to be maintained.
Get rid of the patch and go back to standard Kconfig behavior, as
follows:
1. Include the Kconfig.defconfig files first instead of last in
Kconfig.zephyr.
2. Include boards/Kconfig and arch/<arch>/Kconfig first instead of
last in arch/Kconfig.
3. Include arch/<arch>/soc/*/Kconfig first instead of last in
arch/<arch>/Kconfig.
4. Swap a few other 'source's to preserve behavior for some scattered
symbols with multiple definitions.
Swap 'source's in some no-op cases too, where it might match the
intent.
5. Reverse the defaults on symbol definitions that have more than one
default.
Skip defaults that are mutually exclusive, e.g. where each default
has an 'if <some board>' condition. They are already safe.
6. Remove the prefer-later-defaults patch from Kconfiglib.
Testing was done with a Python script that lists all Kconfig
symbols/choices with multiple defaults, along with a whitelist of fixed
symbols. The script also verifies that there are no "unreachable"
defaults hidden by defaults without conditions
As an additional test, zephyr/.config was generated before and after the
change for several samples and checked to be identical (after sorting).
This commit includes some default-related cleanups as well:
- Simplify some symbol definitions, e.g. where a default has 'if FOO'
when the symbol already has 'depends on FOO'.
- Remove some redundant 'default ""' for string symbols. This is the
implicit default.
Piggyback fixes for swapped ranges on BT_L2CAP_RX_MTU and
BT_L2CAP_TX_MTU (caused by confusing inconsistency).
Piggyback some fixes for style nits too, e.g. unindented help texts.
Signed-off-by: Ulf Magnusson <Ulf.Magnusson@nordicsemi.no>
2018-07-30 10:57:47 +02:00
|
|
|
default y
|
2021-09-09 05:37:39 +02:00
|
|
|
depends on PTP_CLOCK || NET_L2_PTP
|
2018-01-25 07:55:18 +01:00
|
|
|
help
|
|
|
|
Enable MCUX PTP clock support.
|
|
|
|
|
|
|
|
if PTP_CLOCK_MCUX
|
|
|
|
|
|
|
|
config ETH_MCUX_PTP_CLOCK_SRC_HZ
|
|
|
|
int "Frequency of the clock source for the PTP timer"
|
2022-01-11 00:54:18 +01:00
|
|
|
default 50000000 if SOC_SERIES_KINETIS_K6X
|
|
|
|
default 50000000 if SOC_SERIES_IMX_RT10XX
|
|
|
|
default 24000000 if SOC_SERIES_IMX_RT11XX
|
2018-01-25 07:55:18 +01:00
|
|
|
help
|
|
|
|
Set the frequency in Hz sourced to the PTP timer.
|
|
|
|
If the value is set properly, the timer will be accurate.
|
|
|
|
|
2021-09-16 20:58:57 +02:00
|
|
|
config ETH_MCUX_PTP_CLOCK_INIT_PRIO
|
|
|
|
int
|
|
|
|
default 85
|
|
|
|
help
|
|
|
|
MCUX PTP Clock initialization priority level. There is
|
|
|
|
a dependency from the network stack that this device
|
|
|
|
initializes before network stack (NET_INIT_PRIO).
|
|
|
|
|
2018-01-25 07:55:18 +01:00
|
|
|
endif # PTP_CLOCK_MCUX
|
|
|
|
|
2018-09-27 14:23:06 +02:00
|
|
|
endif # ETH_MCUX
|