[PATCH v4 20/23] iommu/tegra241-cmdqv: Simplify deinit flow in tegra241_cmdqv_remove_vintf()
Jason Gunthorpe
jgg at nvidia.com
Thu May 15 10:27:08 PDT 2025
On Thu, May 08, 2025 at 08:02:41PM -0700, Nicolin Chen wrote:
> The current flow of tegra241_cmdqv_remove_vintf() is:
> 1. For each LVCMDQ, tegra241_vintf_remove_lvcmdq():
> a. Disable the LVCMDQ HW
> b. Release the LVCMDQ SW resource
> 2. For current VINTF, tegra241_vintf_hw_deinit():
> c. Disable all LVCMDQ HWs
> d. Disable VINTF HW
>
> Obviously, the step 1.a and the step 2.c are redundant.
>
> Since tegra241_vintf_hw_deinit() disables all of its LVCMDQ HWs, it could
> simplify the flow in tegra241_cmdqv_remove_vintf() by calling that first:
> 1. For current VINTF, tegra241_vintf_hw_deinit():
> a. Disable all LVCMDQ HWs
> b. Disable VINTF HW
> 2. Release all LVCMDQ SW resources
>
> Drop tegra241_vintf_remove_lvcmdq(), and move tegra241_vintf_free_lvcmdq()
> as the new step 2.
>
> Acked-by: Pranjal Shrivastava <praan at google.com>
> Signed-off-by: Nicolin Chen <nicolinc at nvidia.com>
> ---
> drivers/iommu/arm/arm-smmu-v3/tegra241-cmdqv.c | 13 +++----------
> 1 file changed, 3 insertions(+), 10 deletions(-)
Reviewed-by: Jason Gunthorpe <jgg at nvidia.com>
Jason
More information about the linux-arm-kernel
mailing list