赞
踩
ip的意思是 Intellectual Property , 是知识产权,可以理解成不同的架构有不同的设计方式.所以抽象出来,通过宏去访问.在初始化时,按照asic的形式注册(在radeon的代码中是用的asic. 猜测全称是application specific integrated circuit, 目的是给不同框架使用对应api.)
我们以CHIP_POLARIS10进行分析, POLARISI10还属于VEGA之前的架构,分析起来没那么累
在函数入口,POLARISI10的family设置成AMDGPU_FAMILY_VI 也就是Iceland, Tonga (130)
设置ip block, vi_set_ip_blocks() 这里设置很多ip操作的函数
在使用时,通过amdgpu_device_ip_get_ip_block传入对应的type.匹配数组中的ip_block.
举栗子:
//第一步,设置一堆ip
vi_set_ip_blocks(){
//adev->asic_type== CHIP_POLARIS10
amdgpu_device_ip_block_add(adev, &vi_common_ip_block);
amdgpu_device_ip_block_add(adev, &gmc_v8_1_ip_block);
amdgpu_device_ip_block_add(adev, &tonga_ih_ip_block);
amdgpu_device_ip_block_add(adev, &pp_smu_ip_block);
if (adev->enable_virtual_display)//0
amdgpu_device_ip_block_add(adev, &dce_virtual_ip_block);
amdgpu_device_ip_block_add(adev, &gfx_v8_0_ip_block);
amdgpu_device_ip_block_add(adev, &sdma_v3_1_ip_block);
amdgpu_device_ip_block_add(adev, &uvd_v6_3_ip_block);
amdgpu_device_ip_block_add(adev, &vce_v3_4_ip_block);
}
//在amdgpu_device_ip_block_add的方式是
int amdgpu_device_ip_block_add(struct amdgpu_device *adev,
const struct amdgpu_ip_block_version *ip_block_version)
{
if (!ip_block_version)
return -EINVAL;
DRM_INFO("add ip block number %d <%s>\n", adev->num_ip_blocks,
ip_block_version->funcs->name);
adev->ip_blocks[adev->num_ip_blocks++].version = ip_block_version;
return 0;
}
//就是将这些ip放到数组,并且num_ip_blocks++ ,全放完成, 进行批量early_init.标记ip_block里面的status.valid=true
//最简单的查找是acp里面amdgpu_device_ip_get_ip_block
struct amdgpu_ip_block *
amdgpu_device_ip_get_ip_block(struct amdgpu_device *adev,
enum amd_ip_block_type type)
{
int i;
for (i = 0; i < adev->num_ip_blocks; i++)
if (adev->ip_blocks[i].version->type == type)
return &adev->ip_blocks[i];
return NULL;
}
//通过amd_ip_block_type在version里面遍历.
//其他也是如此.因为这个block的func里面都是
//初始化,复位, 状态获取这一类的东西. 他们的hook里面肯定还是用了WREG32的
对ip_blocks的理解,会在另一篇说
接下来很重要的初始化 amdgpu_amdkfd_device_probe , POLARYSI10用的是amdgpu_amdkfd_gfx_8_0_get_functions,hook里面使用函数的都一样,都是amdgpu_amdkfd_gpuvm.c里面的函数
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。