Amdgpu device ip early init

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里面的函数

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值