On Wed, Jan 25, 2017 at 10:46:53AM +0100, Peter Zijlstra wrote: > Which is absolutely insane.
Right, IMO, the simplest thing to do for your purposes is to embed a struct amd_iommu pointer into struct perf_amd_iommu at init time so that you don't have to do all that crazy dance in the PMU functions and iterate over the iommus in get_amd_iommu() each time. Which would then simplify all your other functions. For example: int amd_iommu_pc_get_reg(unsigned int idx, u8 bank, u8 cntr, u8 fxn, u64 *value) should be int amd_iommu_pc_get_reg(struct amd_iommu *iommu, u8 bank, u8 cntr, u8 fxn, u64 *value) and you can save yourself a lot of glue code and get rid of that get_amd_iommu() thing. -- Regards/Gruss, Boris. Good mailing practices for 400: avoid top-posting and trim the reply.