summaryrefslogtreecommitdiff
path: root/drivers/cdx/controller/mcdi_functions.c
diff options
context:
space:
mode:
authorJosua Mayer <josua@solid-run.com>2025-01-01 15:13:33 +0300
committerDamien Le Moal <dlemoal@kernel.org>2025-01-06 07:49:37 +0300
commit8c87215dd3a2c814dcffc0bafe8c80c8f98f2574 (patch)
treead32bfbfdba35b9772776c5514e9bdf92e033468 /drivers/cdx/controller/mcdi_functions.c
parent7b64859fde26ea4bb662db7401c8ebec5ac7f8b5 (diff)
downloadlinux-8c87215dd3a2c814dcffc0bafe8c80c8f98f2574.tar.xz
ata: libahci_platform: support non-consecutive port numbers
So far ahci_platform relied on number of child nodes in firmware to allocate arrays and expected port numbers to start from 0 without holes. This number of ports is then set in private structure for use when configuring phys and regulators. Some platforms may not use every port of an ahci controller. E.g. SolidRUN CN9130 Clearfog uses only port 1 but not port 0, leading to the following errors during boot: [ 1.719476] ahci f2540000.sata: invalid port number 1 [ 1.724562] ahci f2540000.sata: No port enabled Update all accessesors of ahci_host_priv phys and target_pwrs arrays to support holes. Access is gated by hpriv->mask_port_map which has a bit set for each enabled port. Update ahci_platform_get_resources to ignore holes in the port numbers and enable ports defined in firmware by their reg property only. When firmware does not define children it is assumed that there is exactly one port, using index 0. Signed-off-by: Josua Mayer <josua@solid-run.com> Reviewed-by: Hans de Goede <hdegoede@redhat.com> Signed-off-by: Damien Le Moal <dlemoal@kernel.org>
Diffstat (limited to 'drivers/cdx/controller/mcdi_functions.c')
0 files changed, 0 insertions, 0 deletions