xref: /openbmc/linux/drivers/net/ethernet/ti/Kconfig (revision 35bbe652c421037822aba29423f5f1f7d0d69f3f)
1ec8f24b7SThomas Gleixner# SPDX-License-Identifier: GPL-2.0-only
2b544dbacSJeff Kirsher#
3b544dbacSJeff Kirsher# TI device configuration
4b544dbacSJeff Kirsher#
5b544dbacSJeff Kirsher
6b544dbacSJeff Kirsherconfig NET_VENDOR_TI
7b544dbacSJeff Kirsher	bool "Texas Instruments (TI) devices"
888f07484SJeff Kirsher	default y
993a76530SGrygorii Strashko	depends on PCI || EISA || AR7 || ARCH_DAVINCI || ARCH_OMAP2PLUS || ARCH_KEYSTONE || ARCH_K3
10a7f7f624SMasahiro Yamada	help
11138b15edSPaul Gortmaker	  If you have a network (Ethernet) card belonging to this class, say Y.
12b544dbacSJeff Kirsher
13b544dbacSJeff Kirsher	  Note that the answer to this question doesn't directly affect the
14b544dbacSJeff Kirsher	  kernel: saying N will just cause the configurator to skip all
15b544dbacSJeff Kirsher	  the questions about TI devices. If you say Y, you will be asked for
16b544dbacSJeff Kirsher	  your specific card in the following questions.
17b544dbacSJeff Kirsher
18b544dbacSJeff Kirsherif NET_VENDOR_TI
19b544dbacSJeff Kirsher
20b544dbacSJeff Kirsherconfig TI_DAVINCI_EMAC
21b544dbacSJeff Kirsher	tristate "TI DaVinci EMAC Support"
222652113fSFlorian Fainelli	depends on ARM && ( ARCH_DAVINCI || ARCH_OMAP3 ) || COMPILE_TEST
23b544dbacSJeff Kirsher	select TI_DAVINCI_MDIO
24b544dbacSJeff Kirsher	select PHYLIB
25b2ef81dcSMao Wenan	select GENERIC_ALLOCATOR
26a7f7f624SMasahiro Yamada	help
27b544dbacSJeff Kirsher	  This driver supports TI's DaVinci Ethernet .
28b544dbacSJeff Kirsher
29b544dbacSJeff Kirsher	  To compile this driver as a module, choose M here: the module
30b544dbacSJeff Kirsher	  will be called davinci_emac_driver.  This is recommended.
31b544dbacSJeff Kirsher
32b544dbacSJeff Kirsherconfig TI_DAVINCI_MDIO
33b544dbacSJeff Kirsher	tristate "TI DaVinci MDIO Support"
3493a76530SGrygorii Strashko	depends on ARCH_DAVINCI || ARCH_OMAP2PLUS || ARCH_KEYSTONE || ARCH_K3 || COMPILE_TEST
35b544dbacSJeff Kirsher	select PHYLIB
36*35bbe652SRandy Dunlap	select MDIO_BITBANG
37a7f7f624SMasahiro Yamada	help
38b544dbacSJeff Kirsher	  This driver supports TI's DaVinci MDIO module.
39b544dbacSJeff Kirsher
40b544dbacSJeff Kirsher	  To compile this driver as a module, choose M here: the module
41b544dbacSJeff Kirsher	  will be called davinci_mdio.  This is recommended.
42b544dbacSJeff Kirsher
435892cd13SMugunthan V Nconfig TI_CPSW_PHY_SEL
44dba235faSGrygorii Strashko	bool "TI CPSW Phy mode Selection (DEPRECATED)"
45dba235faSGrygorii Strashko	default n
46a7f7f624SMasahiro Yamada	help
475892cd13SMugunthan V N	  This driver supports configuring of the phy mode connected to
48dba235faSGrygorii Strashko	  the CPSW. DEPRECATED: use PHY_TI_GMII_SEL.
495892cd13SMugunthan V N
50df828598SMugunthan V Nconfig TI_CPSW
51df828598SMugunthan V N	tristate "TI CPSW Switch Support"
522652113fSFlorian Fainelli	depends on ARCH_DAVINCI || ARCH_OMAP2PLUS || COMPILE_TEST
5392db978fSClay McClure	depends on TI_CPTS || !TI_CPTS
54df828598SMugunthan V N	select TI_DAVINCI_MDIO
550ba517b1SMarkus Pargmann	select MFD_SYSCON
569ed4050cSIvan Khoronzhuk	select PAGE_POOL
570ba517b1SMarkus Pargmann	select REGMAP
58738a2692SGrygorii Strashko	imply PHY_TI_GMII_SEL
59a7f7f624SMasahiro Yamada	help
60df828598SMugunthan V N	  This driver supports TI's CPSW Ethernet Switch.
61df828598SMugunthan V N
62df828598SMugunthan V N	  To compile this driver as a module, choose M here: the module
63df828598SMugunthan V N	  will be called cpsw.
64df828598SMugunthan V N
65ed3525edSIlias Apalodimasconfig TI_CPSW_SWITCHDEV
66ed3525edSIlias Apalodimas	tristate "TI CPSW Switch Support with switchdev"
67ed3525edSIlias Apalodimas	depends on ARCH_DAVINCI || ARCH_OMAP2PLUS || COMPILE_TEST
68aacf6578SGrygorii Strashko	depends on NET_SWITCHDEV
6992db978fSClay McClure	depends on TI_CPTS || !TI_CPTS
7099e9fe22SArnd Bergmann	select PAGE_POOL
71ed3525edSIlias Apalodimas	select TI_DAVINCI_MDIO
72ed3525edSIlias Apalodimas	select MFD_SYSCON
73ed3525edSIlias Apalodimas	select REGMAP
74ed3525edSIlias Apalodimas	select NET_DEVLINK
75ed3525edSIlias Apalodimas	imply PHY_TI_GMII_SEL
76ed3525edSIlias Apalodimas	help
77ed3525edSIlias Apalodimas	  This driver supports TI's CPSW Ethernet Switch.
78ed3525edSIlias Apalodimas
79ed3525edSIlias Apalodimas	  To compile this driver as a module, choose M here: the module
80ed3525edSIlias Apalodimas	  will be called cpsw_new.
81ed3525edSIlias Apalodimas
8287c0e764SRichard Cochranconfig TI_CPTS
8392db978fSClay McClure	tristate "TI Common Platform Time Sync (CPTS) Support"
8492db978fSClay McClure	depends on ARCH_OMAP2PLUS || ARCH_KEYSTONE || COMPILE_TEST
85a41efedfSGrygorii Strashko	depends on COMMON_CLK
8692db978fSClay McClure	depends on PTP_1588_CLOCK
87a7f7f624SMasahiro Yamada	help
8887c0e764SRichard Cochran	  This driver supports the Common Platform Time Sync unit of
896246168bSWingMan Kwok	  the CPSW Ethernet Switch and Keystone 2 1g/10g Switch Subsystem.
906246168bSWingMan Kwok	  The unit can time stamp PTP UDP/IPv4 and Layer 2 packets, and the
916246168bSWingMan Kwok	  driver offers a PTP Hardware Clock.
9287c0e764SRichard Cochran
9393a76530SGrygorii Strashkoconfig TI_K3_AM65_CPSW_NUSS
9493a76530SGrygorii Strashko	tristate "TI K3 AM654x/J721E CPSW Ethernet driver"
9593a76530SGrygorii Strashko	depends on ARCH_K3 && OF && TI_K3_UDMA_GLUE_LAYER
9658356eb3SVignesh Raghavendra	select NET_DEVLINK
9793a76530SGrygorii Strashko	select TI_DAVINCI_MDIO
98bfa323c6SYueHaibing	select PHYLINK
9993a76530SGrygorii Strashko	imply PHY_TI_GMII_SEL
10001241aa0SGrygorii Strashko	depends on TI_K3_AM65_CPTS || !TI_K3_AM65_CPTS
10193a76530SGrygorii Strashko	help
10293a76530SGrygorii Strashko	  This driver supports TI K3 AM654/J721E CPSW2G Ethernet SubSystem.
10393a76530SGrygorii Strashko	  The two-port Gigabit Ethernet MAC (MCU_CPSW0) subsystem provides
10493a76530SGrygorii Strashko	  Ethernet packet communication for the device: One Ethernet port
10593a76530SGrygorii Strashko	  (port 1) with selectable RGMII and RMII interfaces and an internal
10693a76530SGrygorii Strashko	  Communications Port Programming Interface (CPPI) port (port 0).
10793a76530SGrygorii Strashko
10893a76530SGrygorii Strashko	  To compile this driver as a module, choose M here: the module
10993a76530SGrygorii Strashko	  will be called ti-am65-cpsw-nuss.
11093a76530SGrygorii Strashko
11158356eb3SVignesh Raghavendraconfig TI_K3_AM65_CPSW_SWITCHDEV
11258356eb3SVignesh Raghavendra	bool "TI K3 AM654x/J721E CPSW Switch mode support"
11358356eb3SVignesh Raghavendra	depends on TI_K3_AM65_CPSW_NUSS
11458356eb3SVignesh Raghavendra	depends on NET_SWITCHDEV
11558356eb3SVignesh Raghavendra	help
11658356eb3SVignesh Raghavendra	 This enables switchdev support for TI K3 CPSWxG Ethernet
11758356eb3SVignesh Raghavendra	 Switch. Enable this driver to support hardware switch support for AM65
11858356eb3SVignesh Raghavendra	 CPSW NUSS driver.
11958356eb3SVignesh Raghavendra
120f6bd5952SGrygorii Strashkoconfig TI_K3_AM65_CPTS
121f6bd5952SGrygorii Strashko	tristate "TI K3 AM65x CPTS"
12201241aa0SGrygorii Strashko	depends on ARCH_K3 && OF
123f6bd5952SGrygorii Strashko	depends on PTP_1588_CLOCK
124f6bd5952SGrygorii Strashko	help
125f6bd5952SGrygorii Strashko	  Say y here to support the TI K3 AM65x CPTS with 1588 features such as
126f6bd5952SGrygorii Strashko	  PTP hardware clock for each CPTS device and network packets
127f6bd5952SGrygorii Strashko	  timestamping where applicable.
128f6bd5952SGrygorii Strashko	  Depending on integration CPTS blocks enable compliance with
129f6bd5952SGrygorii Strashko	  the IEEE 1588-2008 standard for a precision clock synchronization
130f6bd5952SGrygorii Strashko	  protocol, Ethernet Enhanced Scheduled Traffic Operations (CPTS_ESTFn)
131f6bd5952SGrygorii Strashko	  and PCIe Subsystem Precision Time Measurement (PTM).
132f6bd5952SGrygorii Strashko
1338127224cSIvan Khoronzhukconfig TI_AM65_CPSW_TAS
1348127224cSIvan Khoronzhuk	bool "Enable TAS offload in AM65 CPSW"
1358127224cSIvan Khoronzhuk	depends on TI_K3_AM65_CPSW_NUSS && NET_SCH_TAPRIO && TI_K3_AM65_CPTS
1368127224cSIvan Khoronzhuk	help
1378127224cSIvan Khoronzhuk	  Say y here to support Time Aware Shaper(TAS) offload in AM65 CPSW.
1388127224cSIvan Khoronzhuk	  AM65 CPSW hardware supports Enhanced Scheduled Traffic (EST)
1398127224cSIvan Khoronzhuk	  defined in IEEE 802.1Q 2018. The EST scheduler runs on CPTS and the
1408127224cSIvan Khoronzhuk	  TAS/EST schedule is updated in the Fetch RAM memory of the CPSW.
1418127224cSIvan Khoronzhuk
14284640e27SKaricheri, Muralidharanconfig TI_KEYSTONE_NETCP
14358c11b5fSKaricheri, Muralidharan	tristate "TI Keystone NETCP Core Support"
144f49ae149SKaricheri, Muralidharan	select TI_DAVINCI_MDIO
14584640e27SKaricheri, Muralidharan	depends on OF
14684640e27SKaricheri, Muralidharan	depends on KEYSTONE_NAVIGATOR_DMA && KEYSTONE_NAVIGATOR_QMSS
14792db978fSClay McClure	depends on TI_CPTS || !TI_CPTS
148a7f7f624SMasahiro Yamada	help
14958c11b5fSKaricheri, Muralidharan	  This driver supports TI's Keystone NETCP Core.
15084640e27SKaricheri, Muralidharan
15184640e27SKaricheri, Muralidharan	  To compile this driver as a module, choose M here: the module
15284640e27SKaricheri, Muralidharan	  will be called keystone_netcp.
15384640e27SKaricheri, Muralidharan
15458c11b5fSKaricheri, Muralidharanconfig TI_KEYSTONE_NETCP_ETHSS
15558c11b5fSKaricheri, Muralidharan	depends on TI_KEYSTONE_NETCP
15658c11b5fSKaricheri, Muralidharan	tristate "TI Keystone NETCP Ethernet subsystem Support"
157a7f7f624SMasahiro Yamada	help
15858c11b5fSKaricheri, Muralidharan
15958c11b5fSKaricheri, Muralidharan	  To compile this driver as a module, choose M here: the module
16058c11b5fSKaricheri, Muralidharan	  will be called keystone_netcp_ethss.
16158c11b5fSKaricheri, Muralidharan
162b544dbacSJeff Kirsherconfig TLAN
163b544dbacSJeff Kirsher	tristate "TI ThunderLAN support"
164b544dbacSJeff Kirsher	depends on (PCI || EISA)
165a7f7f624SMasahiro Yamada	help
166b544dbacSJeff Kirsher	  If you have a PCI Ethernet network card based on the ThunderLAN chip
167138b15edSPaul Gortmaker	  which is supported by this driver, say Y here.
168b544dbacSJeff Kirsher
169b544dbacSJeff Kirsher	  Devices currently supported by this driver are Compaq Netelligent,
170b544dbacSJeff Kirsher	  Compaq NetFlex and Olicom cards.  Please read the file
171132db935SJakub Kicinski	  <file:Documentation/networking/device_drivers/ethernet/ti/tlan.rst>
172b255e500SJakub Kicinski	  for more details.
173b544dbacSJeff Kirsher
174b544dbacSJeff Kirsher	  To compile this driver as a module, choose M here. The module
175b544dbacSJeff Kirsher	  will be called tlan.
176b544dbacSJeff Kirsher
177b544dbacSJeff Kirsher	  Please email feedback to <torben.mathiasen@compaq.com>.
178b544dbacSJeff Kirsher
179b544dbacSJeff Kirsherconfig CPMAC
1808ff25eebSKees Cook	tristate "TI AR7 CPMAC Ethernet support"
1818ff25eebSKees Cook	depends on AR7
182b544dbacSJeff Kirsher	select PHYLIB
183a7f7f624SMasahiro Yamada	help
184b544dbacSJeff Kirsher	  TI AR7 CPMAC Ethernet support
185b544dbacSJeff Kirsher
186b544dbacSJeff Kirsherendif # NET_VENDOR_TI
187