[RFC PATCH 0/3] ahci: add ports-implemented dt bindings.

From: Srinivas Kandagatla
Date: Tue Mar 29 2016 - 09:11:41 EST


Hi Tejun,

On some SOCs PORTS_IMPL register value is never programmed by the BIOS
and left at zero value. Which means that no sata ports are available for
software. AHCI driver used to cope up with this by fabricating the
port_map if the PORTS_IMPL register is read zero, but recent patch [1]
broke this workaround as zero value was valid for nvme disks.

This patch adds ports-implemented dt bindings as workaround for this issue
in a way that DT can dictate the port_map incase where the SOCs does not
program it already.

Am sure that there are more than one SOC that hits this issue.

Without this patchset, ACHI on APQ8064 Qualcomm platform is broken in mainline.
With the below patchset am able to get back the functionality.

Thanks,
srini
[1] 566d18 "libata: disable forced PORTS_IMPL for >= AHCI 1.3"

Srinivas Kandagatla (3):
libahci: save port map for forced port map
ata: ahci-platform: Add ports-implemented dt bindings.
ARM: dts: apq8064: add ahci ports-implemented mask

Documentation/devicetree/bindings/ata/ahci-platform.txt | 11 +++++++++++
arch/arm/boot/dts/qcom-apq8064.dtsi | 1 +
drivers/ata/ahci_platform.c | 4 ++++
drivers/ata/libahci.c | 1 +
4 files changed, 17 insertions(+)

--
2.5.0