mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 9e3a25dc99
			
		
	
	
		9e3a25dc99
		
	
	
	
	
		
			
			- move the USB special case that bounced DMA through a device
    bar into the USB code instead of handling it in the common
    DMA code (Laurentiu Tudor and Fredrik Noring)
  - don't dip into the global CMA pool for single page allocations
    (Nicolin Chen)
  - fix a crash when allocating memory for the atomic pool failed
    during boot (Florian Fainelli)
  - move support for MIPS-style uncached segments to the common
    code and use that for MIPS and nios2 (me)
  - make support for DMA_ATTR_NON_CONSISTENT and
    DMA_ATTR_NO_KERNEL_MAPPING generic (me)
  - convert nds32 to the generic remapping allocator (me)
 -----BEGIN PGP SIGNATURE-----
 
 iQI/BAABCgApFiEEgdbnc3r/njty3Iq9D55TZVIEUYMFAl0nPqgLHGhjaEBsc3Qu
 ZGUACgkQD55TZVIEUYNj2hAAxIv2O3wv6V5xhzWwOVo8e/xW1ZLlGAF0/z92u0do
 32Tm8jkdAGjZDnyxam7qisMSIjCNykpauQzVVxyUNBRSsn1V5t7KSaH3/OXCOVcr
 x2VWBirxGO2BbRseaCBjIcA/2qna+VIDGFcNXCtf6rM00YUK6qaJzkMwBKQAeYcM
 uJMJkaf8qaW4hygLJP8axXiGFdIJyFNLAlJ+ok6kYsJHHJNceOp0bo3CDa2mJBK9
 IhraK2zVkyE5EQkQM5cE/Kw1ppPelUKUkHwjgM4wpz2b18WbLu11nKP0hmUcvKRQ
 heY8xWiKxN0QTgS03ou7EVylyrSAE4dIKgzuA4VO32QCGsWypcAg4iU6s5TX6p9g
 tZEW2ckE6wbmRdQPyKoDpZg299/eQjRHc4MAA1yinT8tFMokw2tk8Fq1FWyltwL1
 8EiP5oNs2qUNvNgqUresl6/f6YOacFi1Q6IhgBVj6d6lyhMhlsHfW4w1XA1siv/I
 6l4qJbLohYab6hY7i+mBOd8iG/KrAlr4P6admnv2jDchswbb5t2j+ABE9xv++PFi
 u1HFqMlxqdWQaXGca2UeCUxUjkwO9N+kHpP+VRz+6D2b64dtCWSu8CN23sYXm2tO
 ubWIlrQQZPhhMkoFg7XqKSTacd+ut+SXN9Nxsyv548ETV0l1xbiLRHIbhyoIESD5
 RAI=
 =01Fr
 -----END PGP SIGNATURE-----
Merge tag 'dma-mapping-5.3' of git://git.infradead.org/users/hch/dma-mapping
Pull dma-mapping updates from Christoph Hellwig:
 - move the USB special case that bounced DMA through a device bar into
   the USB code instead of handling it in the common DMA code (Laurentiu
   Tudor and Fredrik Noring)
 - don't dip into the global CMA pool for single page allocations
   (Nicolin Chen)
 - fix a crash when allocating memory for the atomic pool failed during
   boot (Florian Fainelli)
 - move support for MIPS-style uncached segments to the common code and
   use that for MIPS and nios2 (me)
 - make support for DMA_ATTR_NON_CONSISTENT and
   DMA_ATTR_NO_KERNEL_MAPPING generic (me)
 - convert nds32 to the generic remapping allocator (me)
* tag 'dma-mapping-5.3' of git://git.infradead.org/users/hch/dma-mapping: (29 commits)
  dma-mapping: mark dma_alloc_need_uncached as __always_inline
  MIPS: only select ARCH_HAS_UNCACHED_SEGMENT for non-coherent platforms
  usb: host: Fix excessive alignment restriction for local memory allocations
  lib/genalloc.c: Add algorithm, align and zeroed family of DMA allocators
  nios2: use the generic uncached segment support in dma-direct
  nds32: use the generic remapping allocator for coherent DMA allocations
  arc: use the generic remapping allocator for coherent DMA allocations
  dma-direct: handle DMA_ATTR_NO_KERNEL_MAPPING in common code
  dma-direct: handle DMA_ATTR_NON_CONSISTENT in common code
  dma-mapping: add a dma_alloc_need_uncached helper
  openrisc: remove the partial DMA_ATTR_NON_CONSISTENT support
  arc: remove the partial DMA_ATTR_NON_CONSISTENT support
  arm-nommu: remove the partial DMA_ATTR_NON_CONSISTENT support
  ARM: dma-mapping: allow larger DMA mask than supported
  dma-mapping: truncate dma masks to what dma_addr_t can hold
  iommu/dma: Apply dma_{alloc,free}_contiguous functions
  dma-remap: Avoid de-referencing NULL atomic_pool
  MIPS: use the generic uncached segment support in dma-direct
  dma-direct: provide generic support for uncached kernel segments
  au1100fb: fix DMA API abuse
  ...
		
	
			
		
			
				
	
	
		
			211 lines
		
	
	
		
			5.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			211 lines
		
	
	
		
			5.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| # SPDX-License-Identifier: GPL-2.0
 | |
| #
 | |
| # USB device configuration
 | |
| #
 | |
| 
 | |
| config USB_OHCI_BIG_ENDIAN_DESC
 | |
| 	bool
 | |
| 
 | |
| config USB_OHCI_BIG_ENDIAN_MMIO
 | |
| 	bool
 | |
| 
 | |
| config USB_OHCI_LITTLE_ENDIAN
 | |
| 	bool
 | |
| 	default n if STB03xxx || PPC_MPC52xx
 | |
| 	default y
 | |
| 
 | |
| config USB_EHCI_BIG_ENDIAN_MMIO
 | |
| 	bool
 | |
| 
 | |
| config USB_EHCI_BIG_ENDIAN_DESC
 | |
| 	bool
 | |
| 
 | |
| config USB_UHCI_BIG_ENDIAN_MMIO
 | |
| 	bool
 | |
| 
 | |
| config USB_UHCI_BIG_ENDIAN_DESC
 | |
| 	bool
 | |
| 
 | |
| menuconfig USB_SUPPORT
 | |
| 	bool "USB support"
 | |
| 	depends on HAS_IOMEM
 | |
| 	default y
 | |
| 	---help---
 | |
| 	  This option adds core support for Universal Serial Bus (USB).
 | |
| 	  You will also need drivers from the following menu to make use of it.
 | |
| 
 | |
| if USB_SUPPORT
 | |
| 
 | |
| config USB_COMMON
 | |
| 	tristate
 | |
| 
 | |
| config USB_ARCH_HAS_HCD
 | |
| 	def_bool y
 | |
| 
 | |
| config USB
 | |
| 	tristate "Support for Host-side USB"
 | |
| 	depends on USB_ARCH_HAS_HCD
 | |
| 	select GENERIC_ALLOCATOR
 | |
| 	select USB_COMMON
 | |
| 	select NLS  # for UTF-8 strings
 | |
| 	---help---
 | |
| 	  Universal Serial Bus (USB) is a specification for a serial bus
 | |
| 	  subsystem which offers higher speeds and more features than the
 | |
| 	  traditional PC serial port.  The bus supplies power to peripherals
 | |
| 	  and allows for hot swapping.  Up to 127 USB peripherals can be
 | |
| 	  connected to a single USB host in a tree structure.
 | |
| 	  
 | |
| 	  The USB host is the root of the tree, the peripherals are the
 | |
| 	  leaves and the inner nodes are special USB devices called hubs.
 | |
| 	  Most PCs now have USB host ports, used to connect peripherals
 | |
| 	  such as scanners, keyboards, mice, modems, cameras, disks,
 | |
| 	  flash memory, network links, and printers to the PC.
 | |
| 
 | |
| 	  Say Y here if your computer has a host-side USB port and you want
 | |
| 	  to use USB devices.  You then need to say Y to at least one of the
 | |
| 	  Host Controller Driver (HCD) options below.  Choose a USB 1.1
 | |
| 	  controller, such as "UHCI HCD support" or "OHCI HCD support",
 | |
| 	  and "EHCI HCD (USB 2.0) support" except for older systems that
 | |
| 	  do not have USB 2.0 support.  It doesn't normally hurt to select
 | |
| 	  them all if you are not certain.
 | |
| 
 | |
| 	  If your system has a device-side USB port, used in the peripheral
 | |
| 	  side of the USB protocol, see the "USB Gadget" framework instead.
 | |
| 
 | |
| 	  After choosing your HCD, then select drivers for the USB peripherals
 | |
| 	  you'll be using.  You may want to check out the information provided
 | |
| 	  in <file:Documentation/usb/> and especially the links given in
 | |
| 	  <file:Documentation/usb/usb-help.rst>.
 | |
| 
 | |
| 	  To compile this driver as a module, choose M here: the
 | |
| 	  module will be called usbcore.
 | |
| 
 | |
| config USB_PCI
 | |
| 	bool "PCI based USB host interface"
 | |
| 	depends on PCI
 | |
| 	default y
 | |
| 	---help---
 | |
| 	  Many embedded system SOCs (e.g. freescale T2080) have both
 | |
| 	  PCI and USB modules with the USB module directly controlled by
 | |
| 	  registers and having no relationship to the PCI module.
 | |
| 
 | |
| 	  If you have such a device you may say N here and PCI related code
 | |
| 	  will not be built in the USB driver.
 | |
| 
 | |
| if USB
 | |
| 
 | |
| source "drivers/usb/core/Kconfig"
 | |
| 
 | |
| source "drivers/usb/mon/Kconfig"
 | |
| 
 | |
| source "drivers/usb/wusbcore/Kconfig"
 | |
| 
 | |
| source "drivers/usb/host/Kconfig"
 | |
| 
 | |
| source "drivers/usb/renesas_usbhs/Kconfig"
 | |
| 
 | |
| source "drivers/usb/class/Kconfig"
 | |
| 
 | |
| source "drivers/usb/storage/Kconfig"
 | |
| 
 | |
| source "drivers/usb/image/Kconfig"
 | |
| 
 | |
| source "drivers/usb/usbip/Kconfig"
 | |
| 
 | |
| endif
 | |
| 
 | |
| source "drivers/usb/mtu3/Kconfig"
 | |
| 
 | |
| source "drivers/usb/musb/Kconfig"
 | |
| 
 | |
| source "drivers/usb/dwc3/Kconfig"
 | |
| 
 | |
| source "drivers/usb/dwc2/Kconfig"
 | |
| 
 | |
| source "drivers/usb/chipidea/Kconfig"
 | |
| 
 | |
| source "drivers/usb/isp1760/Kconfig"
 | |
| 
 | |
| comment "USB port drivers"
 | |
| 
 | |
| if USB
 | |
| 
 | |
| config USB_USS720
 | |
| 	tristate "USS720 parport driver"
 | |
| 	depends on PARPORT
 | |
| 	select PARPORT_NOT_PC
 | |
| 	---help---
 | |
| 	  This driver is for USB parallel port adapters that use the Lucent
 | |
| 	  Technologies USS-720 chip. These cables are plugged into your USB
 | |
| 	  port and provide USB compatibility to peripherals designed with
 | |
| 	  parallel port interfaces.
 | |
| 
 | |
| 	  The chip has two modes: automatic mode and manual mode. In automatic
 | |
| 	  mode, it looks to the computer like a standard USB printer. Only
 | |
| 	  printers may be connected to the USS-720 in this mode. The generic
 | |
| 	  USB printer driver ("USB Printer support", above) may be used in
 | |
| 	  that mode, and you can say N here if you want to use the chip only
 | |
| 	  in this mode.
 | |
| 
 | |
| 	  Manual mode is not limited to printers, any parallel port
 | |
| 	  device should work. This driver utilizes manual mode.
 | |
| 	  Note however that some operations are three orders of magnitude
 | |
| 	  slower than on a PCI/ISA Parallel Port, so timing critical
 | |
| 	  applications might not work.
 | |
| 
 | |
| 	  Say Y here if you own an USS-720 USB->Parport cable and intend to
 | |
| 	  connect anything other than a printer to it.
 | |
| 
 | |
| 	  To compile this driver as a module, choose M here: the
 | |
| 	  module will be called uss720.
 | |
| 
 | |
| source "drivers/usb/serial/Kconfig"
 | |
| 
 | |
| source "drivers/usb/misc/Kconfig"
 | |
| 
 | |
| source "drivers/usb/atm/Kconfig"
 | |
| 
 | |
| endif # USB
 | |
| 
 | |
| source "drivers/usb/phy/Kconfig"
 | |
| 
 | |
| source "drivers/usb/gadget/Kconfig"
 | |
| 
 | |
| source "drivers/usb/typec/Kconfig"
 | |
| 
 | |
| source "drivers/usb/roles/Kconfig"
 | |
| 
 | |
| config USB_LED_TRIG
 | |
| 	bool "USB LED Triggers"
 | |
| 	depends on LEDS_CLASS && LEDS_TRIGGERS
 | |
| 	select USB_COMMON
 | |
| 	help
 | |
| 	  This option adds LED triggers for USB host and/or gadget activity.
 | |
| 
 | |
| 	  Say Y here if you are working on a system with led-class supported
 | |
| 	  LEDs and you want to use them as activity indicators for USB host or
 | |
| 	  gadget.
 | |
| 
 | |
| config USB_ULPI_BUS
 | |
| 	tristate "USB ULPI PHY interface support"
 | |
| 	select USB_COMMON
 | |
| 	help
 | |
| 	  UTMI+ Low Pin Interface (ULPI) is specification for a commonly used
 | |
| 	  USB 2.0 PHY interface. The ULPI specification defines a standard set
 | |
| 	  of registers that can be used to detect the vendor and product which
 | |
| 	  allows ULPI to be handled as a bus. This module is the driver for that
 | |
| 	  bus.
 | |
| 
 | |
| 	  The ULPI interfaces (the buses) are registered by the drivers for USB
 | |
| 	  controllers which support ULPI register access and have ULPI PHY
 | |
| 	  attached to them. The ULPI PHY drivers themselves are normal PHY
 | |
| 	  drivers.
 | |
| 
 | |
| 	  ULPI PHYs provide often functions such as ADP sensing/probing (OTG
 | |
| 	  protocol) and USB charger detection.
 | |
| 
 | |
| 	  To compile this driver as a module, choose M here: the module will
 | |
| 	  be called ulpi.
 | |
| 
 | |
| endif # USB_SUPPORT
 |