Message ID | 20210201121416.1488439-3-Bilal.Wasim@imgtec.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Series | Misc bug fixes in mtk power domain driver | expand |
Hi Bilal, Thank you for the patch! Yet something to improve: [auto build test ERROR on robh/for-next] [also build test ERROR on keystone/next soc/for-next rockchip/for-next arm64/for-next/core shawnguo/for-next clk/clk-next kvmarm/next next-20210125] [cannot apply to xlnx/master arm/for-next] [If your patch is applied to the wrong git tree, kindly drop us a note. And when submitting patch, we suggest to use '--base' as documented in https://git-scm.com/docs/git-format-patch] url: https://github.com/0day-ci/linux/commits/Bilal-Wasim/Misc-bug-fixes-in-mtk-power-domain-driver/20210201-201713 base: https://git.kernel.org/pub/scm/linux/kernel/git/robh/linux.git for-next config: powerpc64-randconfig-r023-20210201 (attached as .config) compiler: clang version 13.0.0 (https://github.com/llvm/llvm-project 275c6af7d7f1ed63a03d05b4484413e447133269) reproduce (this is a W=1 build): wget https://raw.githubusercontent.com/intel/lkp-tests/master/sbin/make.cross -O ~/bin/make.cross chmod +x ~/bin/make.cross # install powerpc64 cross compiling tool for clang build # apt-get install binutils-powerpc64-linux-gnu # https://github.com/0day-ci/linux/commit/6ec2b10aece5d26e1ad75ef4b9bbe1260f6c68de git remote add linux-review https://github.com/0day-ci/linux git fetch --no-tags linux-review Bilal-Wasim/Misc-bug-fixes-in-mtk-power-domain-driver/20210201-201713 git checkout 6ec2b10aece5d26e1ad75ef4b9bbe1260f6c68de # save the attached .config to linux build tree COMPILER_INSTALL_PATH=$HOME/0day COMPILER=clang make.cross ARCH=powerpc64 If you fix the issue, kindly add following tag as appropriate Reported-by: kernel test robot <lkp@intel.com> All errors (new ones prefixed by >>): In file included from drivers/soc/mediatek/mtk-pm-domains.c:18: >> drivers/soc/mediatek/mt8173-pm-domains.h:66:11: error: use of undeclared identifier 'MTK_SCPD_DOMAIN_SUPPLY' .caps = MTK_SCPD_DOMAIN_SUPPLY, ^ >> drivers/soc/mediatek/mt8173-pm-domains.h:90:17: error: invalid application of 'sizeof' to an incomplete type 'const struct scpsys_domain_data []' .num_domains = ARRAY_SIZE(scpsys_domain_data_mt8173), ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ include/linux/kernel.h:49:32: note: expanded from macro 'ARRAY_SIZE' #define ARRAY_SIZE(arr) (sizeof(arr) / sizeof((arr)[0]) + __must_be_array(arr)) ^~~~~ 2 errors generated. vim +/MTK_SCPD_DOMAIN_SUPPLY +66 drivers/soc/mediatek/mt8173-pm-domains.h 8 9 /* 10 * MT8173 power domain support 11 */ 12 13 static const struct scpsys_domain_data scpsys_domain_data_mt8173[] = { 14 [MT8173_POWER_DOMAIN_VDEC] = { 15 .sta_mask = PWR_STATUS_VDEC, 16 .ctl_offs = SPM_VDE_PWR_CON, 17 .sram_pdn_bits = GENMASK(11, 8), 18 .sram_pdn_ack_bits = GENMASK(12, 12), 19 }, 20 [MT8173_POWER_DOMAIN_VENC] = { 21 .sta_mask = PWR_STATUS_VENC, 22 .ctl_offs = SPM_VEN_PWR_CON, 23 .sram_pdn_bits = GENMASK(11, 8), 24 .sram_pdn_ack_bits = GENMASK(15, 12), 25 }, 26 [MT8173_POWER_DOMAIN_ISP] = { 27 .sta_mask = PWR_STATUS_ISP, 28 .ctl_offs = SPM_ISP_PWR_CON, 29 .sram_pdn_bits = GENMASK(11, 8), 30 .sram_pdn_ack_bits = GENMASK(13, 12), 31 }, 32 [MT8173_POWER_DOMAIN_MM] = { 33 .sta_mask = PWR_STATUS_DISP, 34 .ctl_offs = SPM_DIS_PWR_CON, 35 .sram_pdn_bits = GENMASK(11, 8), 36 .sram_pdn_ack_bits = GENMASK(12, 12), 37 .bp_infracfg = { 38 BUS_PROT_UPDATE_TOPAXI(MT8173_TOP_AXI_PROT_EN_MM_M0 | 39 MT8173_TOP_AXI_PROT_EN_MM_M1), 40 }, 41 }, 42 [MT8173_POWER_DOMAIN_VENC_LT] = { 43 .sta_mask = PWR_STATUS_VENC_LT, 44 .ctl_offs = SPM_VEN2_PWR_CON, 45 .sram_pdn_bits = GENMASK(11, 8), 46 .sram_pdn_ack_bits = GENMASK(15, 12), 47 }, 48 [MT8173_POWER_DOMAIN_AUDIO] = { 49 .sta_mask = PWR_STATUS_AUDIO, 50 .ctl_offs = SPM_AUDIO_PWR_CON, 51 .sram_pdn_bits = GENMASK(11, 8), 52 .sram_pdn_ack_bits = GENMASK(15, 12), 53 }, 54 [MT8173_POWER_DOMAIN_USB] = { 55 .sta_mask = PWR_STATUS_USB, 56 .ctl_offs = SPM_USB_PWR_CON, 57 .sram_pdn_bits = GENMASK(11, 8), 58 .sram_pdn_ack_bits = GENMASK(15, 12), 59 .caps = MTK_SCPD_ACTIVE_WAKEUP, 60 }, 61 [MT8173_POWER_DOMAIN_MFG_ASYNC] = { 62 .sta_mask = PWR_STATUS_MFG_ASYNC, 63 .ctl_offs = SPM_MFG_ASYNC_PWR_CON, 64 .sram_pdn_bits = GENMASK(11, 8), 65 .sram_pdn_ack_bits = 0, > 66 .caps = MTK_SCPD_DOMAIN_SUPPLY, 67 }, 68 [MT8173_POWER_DOMAIN_MFG_2D] = { 69 .sta_mask = PWR_STATUS_MFG_2D, 70 .ctl_offs = SPM_MFG_2D_PWR_CON, 71 .sram_pdn_bits = GENMASK(11, 8), 72 .sram_pdn_ack_bits = GENMASK(13, 12), 73 }, 74 [MT8173_POWER_DOMAIN_MFG] = { 75 .sta_mask = PWR_STATUS_MFG, 76 .ctl_offs = SPM_MFG_PWR_CON, 77 .sram_pdn_bits = GENMASK(13, 8), 78 .sram_pdn_ack_bits = GENMASK(21, 16), 79 .bp_infracfg = { 80 BUS_PROT_UPDATE_TOPAXI(MT8173_TOP_AXI_PROT_EN_MFG_S | 81 MT8173_TOP_AXI_PROT_EN_MFG_M0 | 82 MT8173_TOP_AXI_PROT_EN_MFG_M1 | 83 MT8173_TOP_AXI_PROT_EN_MFG_SNOOP_OUT), 84 }, 85 }, 86 }; 87 88 static const struct scpsys_soc_data mt8173_scpsys_data = { 89 .domains_data = scpsys_domain_data_mt8173, > 90 .num_domains = ARRAY_SIZE(scpsys_domain_data_mt8173), 91 .pwr_sta_offs = SPM_PWR_STATUS, 92 .pwr_sta2nd_offs = SPM_PWR_STATUS_2ND, 93 }; 94 --- 0-DAY CI Kernel Test Service, Intel Corporation https://lists.01.org/hyperkitty/list/kbuild-all@lists.01.org
On 01/02/2021 13:14, Bilal Wasim wrote: > The mfg_async power domain in mt8173 is used to power up imgtec > gpu. This domain requires the da9211 regulator to be enabled before > the power domain can be enabled successfully. > > Signed-off-by: Bilal Wasim <Bilal.Wasim@imgtec.com> > Reviewed-by: Hsin-Yi Wang <hsinyi@chromium.org> > --- > drivers/soc/mediatek/mt8173-pm-domains.h | 1 + > 1 file changed, 1 insertion(+) > > diff --git a/drivers/soc/mediatek/mt8173-pm-domains.h b/drivers/soc/mediatek/mt8173-pm-domains.h > index 3e8ee5dabb43..065b8195e7d6 100644 > --- a/drivers/soc/mediatek/mt8173-pm-domains.h > +++ b/drivers/soc/mediatek/mt8173-pm-domains.h > @@ -63,6 +63,7 @@ static const struct scpsys_domain_data scpsys_domain_data_mt8173[] = { > .ctl_offs = SPM_MFG_ASYNC_PWR_CON, > .sram_pdn_bits = GENMASK(11, 8), > .sram_pdn_ack_bits = 0, > + .caps = MTK_SCPD_DOMAIN_SUPPLY, Hm, I think the problem here is, that we don't find the regulator "domain-supply" in the DTS. And that provokes that we error out on all power domains. Not sure if we should fix that somehow, so that a missing regulator will only affect one power domain (and it's childs). Regards, Matthias > }, > [MT8173_POWER_DOMAIN_MFG_2D] = { > .sta_mask = PWR_STATUS_MFG_2D, >
diff --git a/drivers/soc/mediatek/mt8173-pm-domains.h b/drivers/soc/mediatek/mt8173-pm-domains.h index 3e8ee5dabb43..065b8195e7d6 100644 --- a/drivers/soc/mediatek/mt8173-pm-domains.h +++ b/drivers/soc/mediatek/mt8173-pm-domains.h @@ -63,6 +63,7 @@ static const struct scpsys_domain_data scpsys_domain_data_mt8173[] = { .ctl_offs = SPM_MFG_ASYNC_PWR_CON, .sram_pdn_bits = GENMASK(11, 8), .sram_pdn_ack_bits = 0, + .caps = MTK_SCPD_DOMAIN_SUPPLY, }, [MT8173_POWER_DOMAIN_MFG_2D] = { .sta_mask = PWR_STATUS_MFG_2D,