1ec8f24b7SThomas Gleixner# SPDX-License-Identifier: GPL-2.0-only 26a528644SVincent Mailhol 36a528644SVincent Mailholmenuconfig CAN_DEV 46a528644SVincent Mailhol tristate "CAN Device Drivers" 56a528644SVincent Mailhol default y 6d7786af5SVincent Mailhol depends on CAN 76a528644SVincent Mailhol help 86a528644SVincent Mailhol Controller Area Network (CAN) is serial communications protocol up to 96a528644SVincent Mailhol 1Mbit/s for its original release (now known as Classical CAN) and up 106a528644SVincent Mailhol to 8Mbit/s for the more recent CAN with Flexible Data-Rate 116a528644SVincent Mailhol (CAN-FD). The CAN bus was originally mainly for automotive, but is now 126a528644SVincent Mailhol widely used in marine (NMEA2000), industrial, and medical 136a528644SVincent Mailhol applications. More information on the CAN network protocol family 146a528644SVincent Mailhol PF_CAN is contained in <Documentation/networking/can.rst>. 156a528644SVincent Mailhol 166a528644SVincent Mailhol This section contains all the CAN(-FD) device drivers including the 176a528644SVincent Mailhol virtual ones. If you own such devices or plan to use the virtual CAN 186a528644SVincent Mailhol interfaces to develop applications, say Y here. 196a528644SVincent Mailhol 206a528644SVincent Mailhol To compile as a module, choose M here: the module will be called 216a528644SVincent Mailhol can-dev. 226a528644SVincent Mailhol 236a528644SVincent Mailholif CAN_DEV 24ccb29637SOliver Hartkopp 25ccb29637SOliver Hartkoppconfig CAN_VCAN 26ccb29637SOliver Hartkopp tristate "Virtual Local CAN Interface (vcan)" 27a7f7f624SMasahiro Yamada help 28ccb29637SOliver Hartkopp Similar to the network loopback devices, vcan offers a 29ccb29637SOliver Hartkopp virtual local CAN interface. 30ccb29637SOliver Hartkopp 31ccb29637SOliver Hartkopp This driver can also be built as a module. If so, the module 32ccb29637SOliver Hartkopp will be called vcan. 33ccb29637SOliver Hartkopp 34a8f820a3SOliver Hartkoppconfig CAN_VXCAN 35a8f820a3SOliver Hartkopp tristate "Virtual CAN Tunnel (vxcan)" 36a7f7f624SMasahiro Yamada help 37a8f820a3SOliver Hartkopp Similar to the virtual ethernet driver veth, vxcan implements a 38a8f820a3SOliver Hartkopp local CAN traffic tunnel between two virtual CAN network devices. 39a8f820a3SOliver Hartkopp When creating a vxcan, two vxcan devices are created as pair. 40a8f820a3SOliver Hartkopp When one end receives the packet it appears on its pair and vice 41a8f820a3SOliver Hartkopp versa. The vxcan can be used for cross namespace communication. 42a8f820a3SOliver Hartkopp 43a8f820a3SOliver Hartkopp In opposite to vcan loopback devices the vxcan only forwards CAN 44a8f820a3SOliver Hartkopp frames to its pair and does *not* provide a local echo of sent 45a8f820a3SOliver Hartkopp CAN frames. To disable a potential echo in af_can.c the vxcan driver 46a8f820a3SOliver Hartkopp announces IFF_ECHO in the interface flags. To have a clean start 47a8f820a3SOliver Hartkopp in each namespace the CAN GW hop counter is set to zero. 48a8f820a3SOliver Hartkopp 49a8f820a3SOliver Hartkopp This driver can also be built as a module. If so, the module 50a8f820a3SOliver Hartkopp will be called vxcan. 51a8f820a3SOliver Hartkopp 52a1044e36SOliver Hartkoppconfig CAN_SLCAN 53a1044e36SOliver Hartkopp tristate "Serial / USB serial CAN Adaptors (slcan)" 5421eaab6dSLinus Torvalds depends on TTY 55a7f7f624SMasahiro Yamada help 56a1044e36SOliver Hartkopp CAN driver for several 'low cost' CAN interfaces that are attached 57a1044e36SOliver Hartkopp via serial lines or via USB-to-serial adapters using the LAWICEL 58a1044e36SOliver Hartkopp ASCII protocol. The driver implements the tty linediscipline N_SLCAN. 59a1044e36SOliver Hartkopp 60a1044e36SOliver Hartkopp As only the sending and receiving of CAN frames is implemented, this 61a1044e36SOliver Hartkopp driver should work with the (serial/USB) CAN hardware from: 62c128df73SOliver Hartkopp www.canusb.com / www.can232.com / www.mictronics.de / www.canhack.de 63a1044e36SOliver Hartkopp 64a1044e36SOliver Hartkopp Userspace tools to attach the SLCAN line discipline (slcan_attach, 651eb11012SDiego Elio Pettenò slcand) can be found in the can-utils at the linux-can project, see 661eb11012SDiego Elio Pettenò https://github.com/linux-can/can-utils for details. 67a1044e36SOliver Hartkopp 68a1044e36SOliver Hartkopp The slcan driver supports up to 10 CAN netdevices by default which 69a1044e36SOliver Hartkopp can be changed by the 'maxdev=xx' module option. This driver can 70a1044e36SOliver Hartkopp also be built as a module. If so, the module will be called slcan. 71a1044e36SOliver Hartkopp 72df6ad5ddSVincent Mailholconfig CAN_NETLINK 736a528644SVincent Mailhol bool "CAN device drivers with Netlink support" 74a30d5155SMarc Kleine-Budde default y 75a7f7f624SMasahiro Yamada help 76df6ad5ddSVincent Mailhol Enables the common framework for CAN device drivers. This is the 77df6ad5ddSVincent Mailhol standard library and provides features for the Netlink interface such 78df6ad5ddSVincent Mailhol as bittiming validation, support of CAN error states, device restart 79df6ad5ddSVincent Mailhol and others. 8039549eefSWolfgang Grandegger 816a528644SVincent Mailhol The additional features selected by this option will be added to the 826a528644SVincent Mailhol can-dev module. 836a528644SVincent Mailhol 84df6ad5ddSVincent Mailhol This is required by all platform and hardware CAN drivers. If you 85df6ad5ddSVincent Mailhol plan to use such devices or if unsure, say Y. 86df6ad5ddSVincent Mailhol 87df6ad5ddSVincent Mailholif CAN_NETLINK 886586c5d7SMarc Kleine-Budde 8939549eefSWolfgang Grandeggerconfig CAN_CALC_BITTIMING 9039549eefSWolfgang Grandegger bool "CAN bit-timing calculation" 91a30d5155SMarc Kleine-Budde default y 92a7f7f624SMasahiro Yamada help 9339549eefSWolfgang Grandegger If enabled, CAN bit-timing parameters will be calculated for the 9439549eefSWolfgang Grandegger bit-rate specified via Netlink argument "bitrate" when the device 9539549eefSWolfgang Grandegger get started. This works fine for the most common CAN controllers 9639549eefSWolfgang Grandegger with standard bit-rates but may fail for exotic bit-rates or CAN 9739549eefSWolfgang Grandegger source clock frequencies. Disabling saves some space, but then the 9839549eefSWolfgang Grandegger bit-timing parameters must be specified directly using the Netlink 9939549eefSWolfgang Grandegger arguments "tq", "prop_seg", "phase_seg1", "phase_seg2" and "sjw". 1000c7e1151SVincent Mailhol 1010c7e1151SVincent Mailhol The additional features selected by this option will be added to the 1020c7e1151SVincent Mailhol can-dev module. 1030c7e1151SVincent Mailhol 10439549eefSWolfgang Grandegger If unsure, say Y. 10539549eefSWolfgang Grandegger 106bfe0092dSVincent Mailholconfig CAN_RX_OFFLOAD 107bfe0092dSVincent Mailhol bool 108bfe0092dSVincent Mailhol 10968f40152SMarc Kleine-Buddeconfig CAN_AT91 11068f40152SMarc Kleine-Budde tristate "Atmel AT91 onchip CAN controller" 1119dc8be28SChen Gang depends on (ARCH_AT91 || COMPILE_TEST) && HAS_IOMEM 112a7f7f624SMasahiro Yamada help 113b9e379bcSUwe Kleine-König This is a driver for the SoC CAN controller in Atmel's AT91SAM9263 114b9e379bcSUwe Kleine-König and AT91SAM9X5 processors. 11568f40152SMarc Kleine-Budde 116*43da2f07SMax Staudtconfig CAN_CAN327 117*43da2f07SMax Staudt tristate "Serial / USB serial ELM327 based OBD-II Interfaces (can327)" 118*43da2f07SMax Staudt depends on TTY 119*43da2f07SMax Staudt select CAN_RX_OFFLOAD 120*43da2f07SMax Staudt help 121*43da2f07SMax Staudt CAN driver for several 'low cost' OBD-II interfaces based on the 122*43da2f07SMax Staudt ELM327 OBD-II interpreter chip. 123*43da2f07SMax Staudt 124*43da2f07SMax Staudt This is a best effort driver - the ELM327 interface was never 125*43da2f07SMax Staudt designed to be used as a standalone CAN interface. However, it can 126*43da2f07SMax Staudt still be used for simple request-response protocols (such as OBD II), 127*43da2f07SMax Staudt and to monitor broadcast messages on a bus (such as in a vehicle). 128*43da2f07SMax Staudt 129*43da2f07SMax Staudt Please refer to the documentation for information on how to use it: 130*43da2f07SMax Staudt Documentation/networking/device_drivers/can/can327.rst 131*43da2f07SMax Staudt 132*43da2f07SMax Staudt If this driver is built as a module, it will be called can327. 133*43da2f07SMax Staudt 13426821162SMarc Kleine-Buddeconfig CAN_FLEXCAN 13526821162SMarc Kleine-Budde tristate "Support for Freescale FLEXCAN based chips" 1368dad5561SAngelo Dureghello depends on OF || COLDFIRE || COMPILE_TEST 1378dad5561SAngelo Dureghello depends on HAS_IOMEM 138bfe0092dSVincent Mailhol select CAN_RX_OFFLOAD 139a7f7f624SMasahiro Yamada help 14026821162SMarc Kleine-Budde Say Y here if you want to support for Freescale FlexCAN. 14126821162SMarc Kleine-Budde 14226821162SMarc Kleine-Buddeconfig CAN_GRCAN 14326821162SMarc Kleine-Budde tristate "Aeroflex Gaisler GRCAN and GRHCAN CAN devices" 14451894cbaSMarc Kleine-Budde depends on OF && HAS_DMA && HAS_IOMEM 145a7f7f624SMasahiro Yamada help 14626821162SMarc Kleine-Budde Say Y here if you want to use Aeroflex Gaisler GRCAN or GRHCAN. 14726821162SMarc Kleine-Budde Note that the driver supports little endian, even though little 14826821162SMarc Kleine-Budde endian syntheses of the cores would need some modifications on 14926821162SMarc Kleine-Budde the hardware level to work. 15026821162SMarc Kleine-Budde 151631eb227SIra W. Snyderconfig CAN_JANZ_ICAN3 152631eb227SIra W. Snyder tristate "Janz VMOD-ICAN3 Intelligent CAN controller" 1536586c5d7SMarc Kleine-Budde depends on MFD_JANZ_CMODIO 154a7f7f624SMasahiro Yamada help 155631eb227SIra W. Snyder Driver for Janz VMOD-ICAN3 Intelligent CAN controller module, which 156631eb227SIra W. Snyder connects to a MODULbus carrier board. 157631eb227SIra W. Snyder 158631eb227SIra W. Snyder This driver can also be built as a module. If so, the module will be 159631eb227SIra W. Snyder called janz-ican3.ko. 160631eb227SIra W. Snyder 16126ad340eSHenning Collianderconfig CAN_KVASER_PCIEFD 16226ad340eSHenning Colliander depends on PCI 16326ad340eSHenning Colliander tristate "Kvaser PCIe FD cards" 1641d48595cSArnd Bergmann select CRC32 16526ad340eSHenning Colliander help 16626ad340eSHenning Colliander This is a driver for the Kvaser PCI Express CAN FD family. 16726ad340eSHenning Colliander 16826ad340eSHenning Colliander Supported devices: 16926ad340eSHenning Colliander Kvaser PCIEcan 4xHS 17026ad340eSHenning Colliander Kvaser PCIEcan 2xHS v2 17126ad340eSHenning Colliander Kvaser PCIEcan HS v2 17226ad340eSHenning Colliander Kvaser Mini PCI Express HS v2 17326ad340eSHenning Colliander Kvaser Mini PCI Express 2xHS v2 17426ad340eSHenning Colliander 1750738eff1SGerhard Bertelsmannconfig CAN_SUN4I 1760738eff1SGerhard Bertelsmann tristate "Allwinner A10 CAN controller" 1770738eff1SGerhard Bertelsmann depends on MACH_SUN4I || MACH_SUN7I || COMPILE_TEST 178a7f7f624SMasahiro Yamada help 1790738eff1SGerhard Bertelsmann Say Y here if you want to use CAN controller found on Allwinner 1800738eff1SGerhard Bertelsmann A10/A20 SoCs. 1810738eff1SGerhard Bertelsmann 1820738eff1SGerhard Bertelsmann To compile this driver as a module, choose M here: the module will 1830738eff1SGerhard Bertelsmann be called sun4i_can. 1840738eff1SGerhard Bertelsmann 18526821162SMarc Kleine-Buddeconfig CAN_TI_HECC 18626821162SMarc Kleine-Budde depends on ARM 18726821162SMarc Kleine-Budde tristate "TI High End CAN Controller" 188bfe0092dSVincent Mailhol select CAN_RX_OFFLOAD 189a7f7f624SMasahiro Yamada help 19026821162SMarc Kleine-Budde Driver for TI HECC (High End CAN Controller) module found on many 19126821162SMarc Kleine-Budde TI devices. The device specifications are available from www.ti.com 19226821162SMarc Kleine-Budde 193b1201e44SKedareswara rao Appanaconfig CAN_XILINXCAN 194b1201e44SKedareswara rao Appana tristate "Xilinx CAN" 195963a822bSMichal Simek depends on ARCH_ZYNQ || ARM64 || MICROBLAZE || COMPILE_TEST 196b1201e44SKedareswara rao Appana depends on COMMON_CLK && HAS_IOMEM 197a7f7f624SMasahiro Yamada help 198b1201e44SKedareswara rao Appana Xilinx CAN driver. This driver supports both soft AXI CAN IP and 199b1201e44SKedareswara rao Appana Zynq CANPS IP. 200b1201e44SKedareswara rao Appana 20126821162SMarc Kleine-Buddeconfig PCH_CAN 20226821162SMarc Kleine-Budde tristate "Intel EG20T PCH CAN controller" 20326821162SMarc Kleine-Budde depends on PCI && (X86_32 || COMPILE_TEST) 204a7f7f624SMasahiro Yamada help 20526821162SMarc Kleine-Budde This driver is for PCH CAN of Topcliff (Intel EG20T PCH) which 20626821162SMarc Kleine-Budde is an IOH for x86 embedded processor (Intel Atom E6xx series). 20726821162SMarc Kleine-Budde This driver can access CAN bus. 208b93cf3f0SOliver Hartkopp 209881ff67aSBhupesh Sharmasource "drivers/net/can/c_can/Kconfig" 2102a367c3aSWolfgang Grandeggersource "drivers/net/can/cc770/Kconfig" 2112dcb8e87SMartin Jerabeksource "drivers/net/can/ctucanfd/Kconfig" 2120c4d9c94SMarek Vasutsource "drivers/net/can/ifi_canfd/Kconfig" 21383407c7fSMarek Vasutsource "drivers/net/can/m_can/Kconfig" 21483407c7fSMarek Vasutsource "drivers/net/can/mscan/Kconfig" 2158ac8321eSStephane Grosjeansource "drivers/net/can/peak_canfd/Kconfig" 216dd3bd23eSRamesh Shanmugasundaramsource "drivers/net/can/rcar/Kconfig" 21783407c7fSMarek Vasutsource "drivers/net/can/sja1000/Kconfig" 21803fd3cf5SKurt Van Dijcksource "drivers/net/can/softing/Kconfig" 21983407c7fSMarek Vasutsource "drivers/net/can/spi/Kconfig" 22083407c7fSMarek Vasutsource "drivers/net/can/usb/Kconfig" 22103fd3cf5SKurt Van Dijck 222df6ad5ddSVincent Mailholendif #CAN_NETLINK 2236586c5d7SMarc Kleine-Budde 224ccb29637SOliver Hartkoppconfig CAN_DEBUG_DEVICES 225ccb29637SOliver Hartkopp bool "CAN devices debugging messages" 226a7f7f624SMasahiro Yamada help 227ccb29637SOliver Hartkopp Say Y here if you want the CAN device drivers to produce a bunch of 228ccb29637SOliver Hartkopp debug messages to the system log. Select this if you are having 229ccb29637SOliver Hartkopp a problem with CAN support and want to see more of what is going 230ccb29637SOliver Hartkopp on. 231ccb29637SOliver Hartkopp 2326a528644SVincent Mailholendif #CAN_DEV 233