mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-05-06 01:59:54 -04:00
mlxsw: pci: Query resources before and after issuing 'CONFIG_PROFILE' command
Currently, as part of mlxsw_pci_init(), resources are queried from firmware before issuing the 'CONFIG_PROFILE' command. There are resources whose size depend on the enablement of the unified bridge model that is performed via 'CONFIG_PROFILE' command. As a preparation for unified bridge model, add an additional query after issuing this command. Both queries are required as KVD sizes are read from firmware and then are configured as part of 'CONFIG_PROFILE' command. Signed-off-by: Amit Cohen <amcohen@nvidia.com> Signed-off-by: Ido Schimmel <idosch@nvidia.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
committed by
David S. Miller
parent
89df3c6261
commit
6131d9630d
@@ -1551,6 +1551,14 @@ static int mlxsw_pci_init(void *bus_priv, struct mlxsw_core *mlxsw_core,
|
||||
if (err)
|
||||
goto err_config_profile;
|
||||
|
||||
/* Some resources depend on unified bridge model, which is configured
|
||||
* as part of config_profile. Query the resources again to get correct
|
||||
* values.
|
||||
*/
|
||||
err = mlxsw_core_resources_query(mlxsw_core, mbox, res);
|
||||
if (err)
|
||||
goto err_requery_resources;
|
||||
|
||||
err = mlxsw_pci_aqs_init(mlxsw_pci, mbox);
|
||||
if (err)
|
||||
goto err_aqs_init;
|
||||
@@ -1568,6 +1576,7 @@ static int mlxsw_pci_init(void *bus_priv, struct mlxsw_core *mlxsw_core,
|
||||
err_request_eq_irq:
|
||||
mlxsw_pci_aqs_fini(mlxsw_pci);
|
||||
err_aqs_init:
|
||||
err_requery_resources:
|
||||
err_config_profile:
|
||||
err_cqe_v_check:
|
||||
err_query_resources:
|
||||
|
||||
Reference in New Issue
Block a user