RE: [PATCH rc v3] iommufd: Fix struct iommu_hwpt_pgfault init and padding
From: Tian, Kevin
Date: Mon Jan 20 2025 - 20:22:02 EST
> From: Nicolin Chen <nicolinc@xxxxxxxxxx>
> Sent: Tuesday, January 21, 2025 3:51 AM
>
> The iommu_hwpt_pgfault is used to report IO page fault data to userspace,
> but iommufd_fault_fops_read was never zeroing its padding. This leaks the
> content of the kernel stack memory to userspace.
>
> Meanwhile, although the padding could be done by the compiler, explicitly
> add a 32-bit padding. Also, change the __u64 addr to __aligned_u64.
>
> pahole result, before:
> struct iommu_hwpt_pgfault {
> __u32 flags; /* 0 4 */
> __u32 dev_id; /* 4 4 */
> __u32 pasid; /* 8 4 */
> __u32 grpid; /* 12 4 */
> __u32 perm; /* 16 4 */
>
> /* XXX 4 bytes hole, try to pack */
>
> __u64 addr; /* 24 8 */
> __u32 length; /* 32 4 */
> __u32 cookie; /* 36 4 */
>
> /* size: 40, cachelines: 1, members: 8 */
> /* sum members: 36, holes: 1, sum holes: 4 */
> /* last cacheline: 40 bytes */
> };
>
> pahole result, after:
> struct iommu_hwpt_pgfault {
> __u32 flags; /* 0 4 */
> __u32 dev_id; /* 4 4 */
> __u32 pasid; /* 8 4 */
> __u32 grpid; /* 12 4 */
> __u32 perm; /* 16 4 */
> __u32 __reserved; /* 20 4 */
> __u64 addr __attribute__((__aligned__(8))); /* 24 8 */
> __u32 length; /* 32 4 */
> __u32 cookie; /* 36 4 */
>
> /* size: 40, cachelines: 1, members: 9 */
> /* forced alignments: 1 */
> /* last cacheline: 40 bytes */
> } __attribute__((__aligned__(8)));
>
> Fixes: c714f15860fc ("iommufd: Add fault and response message definitions")
> Cc: stable@xxxxxxxxxxxxxxx
> Reviewed-by: Jason Gunthorpe <jgg@xxxxxxxxxx>
> Signed-off-by: Nicolin Chen <nicolinc@xxxxxxxxxx>
Reviewed-by: Kevin Tian <kevin.tian@xxxxxxxxx>