Jason,

On 10/8/2025 6:38 PM, Jason Gunthorpe wrote:
> On Wed, Oct 08, 2025 at 03:13:32PM +0530, Vasant Hegde wrote:
>> Jason,
>>
>> On 9/3/2025 11:16 PM, Jason Gunthorpe wrote:
>>> AMD IOMMU v1 is unique in supporting contiguous pages with a variable size
>>> and it can decode the full 64 bit VA space. Unlike other x86 page tables
>>> this explicitly does not do sign extension as part of allowing the entire
>>> 64 bit VA space to be supported.
>>
>> I am still catching up w/ entire series.. But here is few fixes needed to 
>> boot
>> this series w/ SME.
> 
> I got them all, like this - thanks a lot!

Looks good. Thanks!

-Vasant


> 
> diff --git a/drivers/iommu/amd/iommu.c b/drivers/iommu/amd/iommu.c
> index 92095fd17b3899..0b97db94c8c4e0 100644
> --- a/drivers/iommu/amd/iommu.c
> +++ b/drivers/iommu/amd/iommu.c
> @@ -2054,7 +2054,7 @@ static void set_dte_entry(struct amd_iommu *iommu,
>                                                      &pt_info);
>                       }
>  
> -                     new.data[0] |= pt_info.host_pt_root |
> +                     new.data[0] |= __sme_set(pt_info.host_pt_root) |
>                                      (pt_info.mode & DEV_ENTRY_MODE_MASK)
>                                              << DEV_ENTRY_MODE_SHIFT;
>               }
> @@ -2166,7 +2166,7 @@ static int init_gcr3_table(struct iommu_dev_data 
> *dev_data,
>               return ret;
>  
>       pt_iommu_x86_64_hw_info(&pdom->amdv2, &pt_info);
> -     ret = update_gcr3(dev_data, 0, pt_info.gcr3_pt, true);
> +     ret = update_gcr3(dev_data, 0, __sme_set(pt_info.gcr3_pt), true);
>       if (ret)
>               free_gcr3_table(&dev_data->gcr3_info);
>  
> diff --git a/drivers/iommu/generic_pt/fmt/amdv1.h 
> b/drivers/iommu/generic_pt/fmt/amdv1.h
> index d7660d4170ef78..26e29b08a9b4ae 100644
> --- a/drivers/iommu/generic_pt/fmt/amdv1.h
> +++ b/drivers/iommu/generic_pt/fmt/amdv1.h
> @@ -73,22 +73,29 @@ enum {
>  
>  static inline pt_oaddr_t amdv1pt_table_pa(const struct pt_state *pts)
>  {
> -     return oalog2_mul(FIELD_GET(AMDV1PT_FMT_OA, pts->entry),
> -                       PT_GRANULE_LG2SZ);
> +     u64 entry = pts->entry;
> +
> +     if (pts_feature(pts, PT_FEAT_AMDV1_ENCRYPT_TABLES))
> +             entry = __sme_clr(entry);
> +     return oalog2_mul(FIELD_GET(AMDV1PT_FMT_OA, entry), PT_GRANULE_LG2SZ);
>  }
>  #define pt_table_pa amdv1pt_table_pa
>  
>  /* Returns the oa for the start of the contiguous entry */
>  static inline pt_oaddr_t amdv1pt_entry_oa(const struct pt_state *pts)
>  {
> -     pt_oaddr_t oa = FIELD_GET(AMDV1PT_FMT_OA, pts->entry);
> +     u64 entry = pts->entry;
> +     pt_oaddr_t oa;
>  
> -     if (FIELD_GET(AMDV1PT_FMT_NEXT_LEVEL, pts->entry) ==
> -         AMDV1PT_FMT_NL_SIZE) {
> +     if (pts_feature(pts, PT_FEAT_AMDV1_ENCRYPT_TABLES))
> +             entry = __sme_clr(entry);
> +     oa = FIELD_GET(AMDV1PT_FMT_OA, entry);
> +
> +     if (FIELD_GET(AMDV1PT_FMT_NEXT_LEVEL, entry) == AMDV1PT_FMT_NL_SIZE) {
>               unsigned int sz_bits = oaffz(oa);
>  
>               oa = oalog2_set_mod(oa, 0, sz_bits);
> -     } else if (PT_WARN_ON(FIELD_GET(AMDV1PT_FMT_NEXT_LEVEL, pts->entry) !=
> +     } else if (PT_WARN_ON(FIELD_GET(AMDV1PT_FMT_NEXT_LEVEL, entry) !=
>                             AMDV1PT_FMT_NL_DEFAULT))
>               return 0;
>       return oalog2_mul(oa, PT_GRANULE_LG2SZ);
> diff --git a/drivers/iommu/generic_pt/fmt/x86_64.h 
> b/drivers/iommu/generic_pt/fmt/x86_64.h
> index be2a0a770f903f..d33b2fcd865b84 100644
> --- a/drivers/iommu/generic_pt/fmt/x86_64.h
> +++ b/drivers/iommu/generic_pt/fmt/x86_64.h
> @@ -79,14 +79,22 @@ enum {
>  
>  static inline pt_oaddr_t x86_64_pt_table_pa(const struct pt_state *pts)
>  {
> -     return oalog2_mul(FIELD_GET(X86_64_FMT_OA, pts->entry),
> +     u64 entry = pts->entry;
> +
> +     if (pts_feature(pts, PT_FEAT_X86_64_AMD_ENCRYPT_TABLES))
> +             entry = __sme_clr(entry);
> +     return oalog2_mul(FIELD_GET(X86_64_FMT_OA, entry),
>                         PT_TABLEMEM_LG2SZ);
>  }
>  #define pt_table_pa x86_64_pt_table_pa
>  
>  static inline pt_oaddr_t x86_64_pt_entry_oa(const struct pt_state *pts)
>  {
> -     return oalog2_mul(FIELD_GET(X86_64_FMT_OA, pts->entry),
> +     u64 entry = pts->entry;
> +
> +     if (pts_feature(pts, PT_FEAT_X86_64_AMD_ENCRYPT_TABLES))
> +             entry = __sme_clr(entry);
> +     return oalog2_mul(FIELD_GET(X86_64_FMT_OA, entry),
>                         PT_GRANULE_LG2SZ);
>  }
>  #define pt_entry_oa x86_64_pt_entry_oa


Reply via email to