2024年11月06日 第27讲 ISP设备绑定到SMMU 极客笔记
本讲是Camera KMD ISP子系统专题的第27讲,我们讲解Camera KMD ISP子系统之Camera ISP设备绑定到SMMU。
更多资源:
资源 | 描述 |
---|---|
在线课程 | 极客笔记在线课程 |
知识星球 | 星球名称:深入浅出Android Camera 星球ID: 17296815 |
极客笔记圈 |
iommus = <&apps_smmu 0x800>
0x800: streamId
arm_smmu_device_probe()
arm_smmu_init_structures(smmu);
arm_smmu_init_strtab(smmu);
arm_smmu_init_strtab_2lvl(smmu);
//分配num_l1_ents多个stream table entry内容
strtab = dmam_alloc_coherent(smmu->dev, l1size, &cfg->strtab_dma, GFP_KERNEL | __GFP_ZERO);
cfg->strtab = strtab;
arm_smmu_init_l1_strtab(smmu);
//分配num_l1_ents多个l1 desc,l1 desc为中间变量存储L2 ste 地址,最终l1 desc的内容会保存到cfg->strtab_dma[sid>>STRTAB_SPLIT]
cfg->l1_desc = devm_kzalloc(smmu->dev, size, GFP_KERNEL);
/* Set the strtab base address */
reg = smmu->strtab_cfg.strtab_dma & STRTAB_BASE_ADDR_MASK;
reg |= STRTAB_BASE_RA;
smmu->strtab_cfg.strtab_base = reg;//把strtab_dma地址存到strtab_base里面
arm_smmu_device_reset(smmu, bypass);//重启smmu设备
//配置STE BASE地址到SMMU硬件寄存器,这样SMMU就可以通过这个基地址找到后面STE,CD,Page table了
writeq_relaxed(smmu->strtab_cfg.strtab_base, smmu->base + ARM_SMMU_STRTAB_BASE);
本文链接:http://so.lmcjl.com/news/17177/