bufinfo是我们调试dmabuf使用的一个非常有效的debug 信息。因此我们需要了解下它的由来以及记录的关键信息。并且根据场景需要来对跟踪的信息进行调整和完善,以满足我们的调试需要。
一,bufinfo的生成
首先在内核初始化子系统时会调用dma子系统的初始化函数,如下:
linux_5.18_stable/drivers/dma-buf/dma-buf.c
subsys_initcall(dma_buf_init);
随后在dma_buf_init的初始函数中调用dma_buf_init_debugfs()函数以在debugfs文件系统中创建debug文件bufinfo。
static int __init dma_buf_init(void) { int ret; ret = dma_buf_init_sysfs_statistics(); if (ret) return ret; dma_buf_mnt = kern_mount(&dma_buf_fs_type); if (IS_ERR(dma_buf_mnt)) return PTR_ERR(dma_buf_mnt); mutex_init(&db_list.lock); INIT_LIST_HEAD(&db_list.head); dma_buf_init_debugfs(); return 0; }
随后在dma_buf_init_debugfs()函数中创建dma_buf目录。通常在/sys/kernel/debug/dma_buf。因为我们通常会把debugfs子系统挂载/sys/kernel/debug路径下。最后再创建调试日志文件bufinfo。
static int dma_buf_init_deb