设备树节点为vision_apps_core_heaps_lo: vision-apps-core-heap-memory-lo@94000000 { compatible = "shared-dma-pool"; reg = <0x00 0x94000000 0x00 0x0a800000>; no-map; };,我该如何在驱动中获得vision_apps_core_heaps_lo这个参数
时间: 2023-11-22 14:57:00 浏览: 145
在驱动中获取设备树节点的参数需要使用`of_get_property()`函数。具体步骤如下:
1. 获取设备节点
```
struct device_node *np = of_find_node_by_name(NULL, "vision_apps_core_heaps_lo");
if (!np) {
pr_err("Failed to find device node\n");
return -ENODEV;
}
```
2. 获取`compatible`属性值
```
const char *compatible;
if (of_property_read_string(np, "compatible", &compatible)) {
pr_err("No compatible string in device node\n");
return -EINVAL;
}
```
3. 获取`reg`属性值
```
u32 reg[3];
if (of_property_read_u32_array(np, "reg", reg, 3)) {
pr_err("No reg property in device node\n");
return -EINVAL;
}
```
这样就可以获取到`compatible`和`reg`属性值了,可以根据需要进行后续的处理。
相关问题
stack_depot_disable=on kasan.stacktrace=off kvm-arm.mode=protected cgroup_disable=pressure qcom_dma_heaps.enable_bitstream_contig_heap=y kpti=0 ssbd=force-off lpm_levels.sleep_disabled=1 video=vfb:640x400,bpp=32,memsize=3072000 msm_rtb.filter=0x237 service_locator.enable=1 swiotlb=4096 firmware_class.path=/vendor/firmware_mnt/image loop.max_part=7 kvm-arm.mode=nvhe hibernate=nocompress noswap_randomize pcie_ports=compat console=ttyMSM0,115200n8 earlycon=qcom_geni,0xa90000 qcom_geni_serial.con_enabled=1 slub_debug=FZPU bootconfig buildvariant=userdebug rootwait ro init=/init resume=/dev/sda13
这是一个启动参数列表,用于指定 Linux 操作系统的启动选项。其中包含了一些针对特定硬件或软件的优化设置,例如:
- stack_depot_disable=on:禁用堆栈存储器。
- kasan.stacktrace=off:禁用 KASan 堆栈跟踪。
- kvm-arm.mode=protected/nvhe:设置 KVM ARM 的虚拟化模式。
- cgroup_disable=pressure:禁用 cgroup 内存压力控制。
- kpti=0:禁用内核页表隔离(KPTI)。
- ssbd=force-off:禁用 Spectre 漏洞的防护措施。
- lpm_levels.sleep_disabled=1:禁用低功耗模式。
- video=vfb:640x400,bpp=32,memsize=3072000:设置虚拟帧缓冲器的分辨率、颜色深度和内存大小。
- msm_rtb.filter=0x237:设置 MSM RTB 过滤器。
- service_locator.enable=1:启用服务定位器。
- swiotlb=4096:设置 I/O 内存管理器的缓冲区大小。
- firmware_class.path=/vendor/firmware_mnt/image:设置固件文件路径。
- loop.max_part=7:设置循环设备的最大分区数。
- hibernate=nocompress:设置休眠时不压缩内存数据。
- noswap_randomize:禁用交换空间的随机化地址。
- pcie_ports=compat:设置 PCIe 接口的兼容性模式。
- console=ttyMSM0,115200n8 earlycon=qcom_geni,0xa90000 qcom_geni_serial.con_enabled=1:设置控制台终端和串口的参数。
- slub_debug=FZPU:启用 SLUB 分配器的调试模式。
- bootconfig:指定使用 Bootconfig 工具进行启动配置。
- buildvariant=userdebug:设置构建变体为用户调试版。
- rootwait ro:等待根文件系统挂载完成,以只读模式启动。
- init=/init:指定 init 进程的路径。
- resume=/dev/sda13:设置恢复分区的设备路径。
bootargs = "qcom_dma_heaps.enable_bitstream_contig_heap=y kpti=0 ssbd=force-off lpm_levels.sleep_disabled=1 video=vfb:640x400,bpp=32,memsize=3072000 msm_rtb.filter=0x237
`bootargs` 是 Linux 内核启动时传递给内核的参数,它们很大程度上影响了系统的启动和运行方式。这里是您提供的 `bootargs` 参数:
1. `qcom_dma_heaps.enable_bitstream_contig_heap=y`:启用 bitstream 连续堆,即将 bitstream 分配到物理连续的内存区域,以提高 DMA 性能。
2. `kpti=0`:禁用内核页表隔离(KPTI),这是一种针对 Meltdown 和 Spectre 安全漏洞的内核保护机制。
3. `ssbd=force-off`:关闭 Speculative Store Bypass Disable(SSBD)保护机制。
4. `lpm_levels.sleep_disabled=1`:禁用低功耗模式,即防止系统进入睡眠状态。
5. `video=vfb:640x400,bpp=32,memsize=3072000`:配置虚拟帧缓冲(Virtual Frame Buffer),分辨率为 640x400,像素深度为 32 位,内存大小为 3072000 字节。
6. `msm_rtb.filter=0x237`:配置 MSM Ready To Boot(RTB)过滤器,0x237 是一个十六进制值,表示仅允许特定类型的 RTB 消息通过。
阅读全文