mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-01-11 17:10:13 +00:00
iommupt: Make pt_feature() always_inline
gcc 8.5 on powerpc does not automatically inline these functions even
though they evaluate to constants in key cases. Since the constant
propagation is essential for some code elimination and built-time checks
this causes a build failure:
ERROR: modpost: "__pt_no_sw_bit" [drivers/iommu/generic_pt/fmt/iommu_amdv1.ko] undefined!
Caused by this:
if (pts_feature(&pts, PT_FEAT_DMA_INCOHERENT) &&
!pt_test_sw_bit_acquire(&pts,
SW_BIT_CACHE_FLUSH_DONE))
flush_writes_item(&pts);
Where pts_feature() evaluates to a constant false. Mark them as
__always_inline to force it to evaluate to a constant and trigger the code
elimination.
Fixes: 7c5b184db714 ("genpt: Generic Page Table base API")
Reported-by: kernel test robot <lkp@intel.com>
Closes: https://lore.kernel.org/oe-kbuild-all/202512230720.9y9DtWIo-lkp@intel.com/
Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
This commit is contained in:
parent
7adfd68274
commit
6a3d5fda2c
@ -202,7 +202,7 @@ static inline bool pt_table_install32(struct pt_state *pts, u32 table_entry)
|
||||
|
||||
#define PT_SUPPORTED_FEATURE(feature_nr) (PT_SUPPORTED_FEATURES & BIT(feature_nr))
|
||||
|
||||
static inline bool pt_feature(const struct pt_common *common,
|
||||
static __always_inline bool pt_feature(const struct pt_common *common,
|
||||
unsigned int feature_nr)
|
||||
{
|
||||
if (PT_FORCE_ENABLED_FEATURES & BIT(feature_nr))
|
||||
@ -212,7 +212,7 @@ static inline bool pt_feature(const struct pt_common *common,
|
||||
return common->features & BIT(feature_nr);
|
||||
}
|
||||
|
||||
static inline bool pts_feature(const struct pt_state *pts,
|
||||
static __always_inline bool pts_feature(const struct pt_state *pts,
|
||||
unsigned int feature_nr)
|
||||
{
|
||||
return pt_feature(pts->range->common, feature_nr);
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user