]> git.baikalelectronics.ru Git - kernel.git/commit
ARM: dts: dra7: Add bus_dma_limit for L3 bus
authorRoger Quadros <rogerq@ti.com>
Fri, 13 Mar 2020 09:47:17 +0000 (11:47 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 1 Apr 2020 09:01:59 +0000 (11:01 +0200)
commit6042d99e4377a3ec555e49e36d48887c333a47a5
treec36aaa90f9ecb3c6cb094b379cf39d09e80340ea
parent6084f832940fb327142c4992d20a08ea52c77dcc
ARM: dts: dra7: Add bus_dma_limit for L3 bus

commit e596c475bbf4042f9d103f1d55fbd5ebf7eb3064 upstream.

The L3 interconnect's memory map is from 0x0 to
0xffffffff. Out of this, System memory (SDRAM) can be
accessed from 0x80000000 to 0xffffffff (2GB)

DRA7 does support 4GB of SDRAM but upper 2GB can only be
accessed by the MPU subsystem.

Add the dma-ranges property to reflect the physical address limit
of the L3 bus.

Issues ere observed only with SATA on DRA7-EVM with 4GB RAM
and CONFIG_ARM_LPAE enabled. This is because the controller
supports 64-bit DMA and its driver sets the dma_mask to 64-bit
thus resulting in DMA accesses beyond L3 limit of 2G.

Setting the correct bus_dma_limit fixes the issue.

Signed-off-by: Roger Quadros <rogerq@ti.com>
Cc: stable@kernel.org
Signed-off-by: Tony Lindgren <tony@atomide.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
arch/arm/boot/dts/dra7.dtsi