[PATCH v4 18/18] iommu: exynos: add callback for initializing devices from device tree
Javier Martinez Canillas
javier at dowhile0.org
Mon Jan 19 07:27:47 PST 2015
Hello Marek,
I wanted to test your IOMMU series on an Exynos5420 Peach Pit but the
kernel hangs with your series + dependencies on top of 3.19-rc5.
Bisecting I found that $subject is the offending commit. I've pushed
my test branch [0] in case I missed something.
On Fri, Jan 16, 2015 at 10:13 AM, Marek Szyprowski
<m.szyprowski at samsung.com> wrote:
> This patch adds implementation of of_xlate callback, which prepares
> masters device for attaching to IOMMU. This callback is called during
> creating devices from device tree.
>
> Signed-off-by: Marek Szyprowski <m.szyprowski at samsung.com>
> ---
> drivers/iommu/exynos-iommu.c | 28 ++++++++++++++++++++++++++++
> 1 file changed, 28 insertions(+)
>
> diff --git a/drivers/iommu/exynos-iommu.c b/drivers/iommu/exynos-iommu.c
> index ea2659159e63..5432b443abfc 100644
> --- a/drivers/iommu/exynos-iommu.c
> +++ b/drivers/iommu/exynos-iommu.c
> @@ -1077,6 +1077,33 @@ static phys_addr_t exynos_iommu_iova_to_phys(struct iommu_domain *iommu_domain,
> return phys;
> }
>
> +static int exynos_iommu_of_xlate(struct device *dev,
> + struct of_phandle_args *spec)
> +{
> + struct exynos_iommu_owner *owner = dev->archdata.iommu;
> + struct platform_device *sysmmu = of_find_device_by_node(spec->np);
> + struct sysmmu_drvdata *data;
> +
> + if (!sysmmu)
> + return -ENODEV;
> +
> + data = platform_get_drvdata(sysmmu);
> + if (!data)
> + return -ENODEV;
> +
> + if (!owner) {
> + owner = kzalloc(sizeof(*owner), GFP_KERNEL);
> + if (!owner)
> + return -ENOMEM;
> +
> + INIT_LIST_HEAD(&owner->clients);
> + dev->archdata.iommu = owner;
> + }
> +
> + list_add_tail(&data->owner_node, &owner->clients);
This is the line that causes the kernel to hang, if I comment the
list_add_tail() call then the kernel boots.
I checked that neither data nor owner are NULL and that the
owner->clients list_head is initialized. Do you have any ideas what
could be happening?
Thanks a lot and best regards,
Javier
[0]: git://git.collabora.co.uk/git/user/javier/linux.git exynos-sysmmu-3.19-rc5
More information about the linux-arm-kernel
mailing list