当前位置:   article > 正文

Amdgpu device ip early init_amd ipu device

amd ipu device

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的
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47

对ip_blocks的理解,会在另一篇说
接下来很重要的初始化 amdgpu_amdkfd_device_probe , POLARYSI10用的是amdgpu_amdkfd_gfx_8_0_get_functions,hook里面使用函数的都一样,都是amdgpu_amdkfd_gpuvm.c里面的函数

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/IT小白/article/detail/946296
推荐阅读
相关标签
  

闽ICP备14008679号