/* SID/SSID sizes */
        smmu->ssid_bits = FIELD_GET(IDR1_SSIDSIZE, reg);
        smmu->sid_bits = FIELD_GET(IDR1_SIDSIZE, reg);
+       smmu->iommu.max_pasids = 1UL << smmu->ssid_bits;
 
        /*
         * If the SMMU supports fewer bits than would fill a single L2 stream
 
 
        raw_spin_lock_init(&iommu->register_lock);
 
+       /*
+        * A value of N in PSS field of eCap register indicates hardware
+        * supports PASID field of N+1 bits.
+        */
+       if (pasid_supported(iommu))
+               iommu->iommu.max_pasids = 2UL << ecap_pss(iommu->ecap);
+
        /*
         * This is only for hotplug; at boot time intel_iommu_enabled won't
         * be set yet. When intel_iommu_init() runs, it registers the units
 
 #define VTD_FLAG_IRQ_REMAP_PRE_ENABLED (1 << 1)
 #define VTD_FLAG_SVM_CAPABLE           (1 << 2)
 
-extern int intel_iommu_sm;
-
 #define sm_supported(iommu)    (intel_iommu_sm && ecap_smts((iommu)->ecap))
 #define pasid_supported(iommu) (sm_supported(iommu) &&                 \
                                 ecap_pasid((iommu)->ecap))
 extern const struct iommu_ops intel_iommu_ops;
 
 #ifdef CONFIG_INTEL_IOMMU
+extern int intel_iommu_sm;
 extern int iommu_calculate_agaw(struct intel_iommu *iommu);
 extern int iommu_calculate_max_sagaw(struct intel_iommu *iommu);
 extern int dmar_disabled;
 }
 #define dmar_disabled  (1)
 #define intel_iommu_enabled (0)
+#define intel_iommu_sm (0)
 #endif
 
 static inline const char *decode_prq_descriptor(char *str, size_t size,
 
  * @list: Used by the iommu-core to keep a list of registered iommus
  * @ops: iommu-ops for talking to this iommu
  * @dev: struct device for sysfs handling
+ * @max_pasids: number of supported PASIDs
  */
 struct iommu_device {
        struct list_head list;
        const struct iommu_ops *ops;
        struct fwnode_handle *fwnode;
        struct device *dev;
+       u32 max_pasids;
 };
 
 /**