一:VirtIO和Passthrough的区别
方法一: passthrough
方法二:virtIO
二:配置逻辑
三:示例Virtio-I2C配置
Virtio-I2C框架
步骤一:QNX IIC资源配置 & 测试
配置
测试
步骤二:BE配置 &测试
配置
测试:
步骤三:Hypervisor配置
配置
测试
步骤四:Android侧配置
配置-config相关
配置-DTS相关
测试
在高通8255平台上,Android是Hypervisor虚拟机上的系统,对于GVM(Guest Virtual Decices虚拟机)使用的通信或者其他资源,有两种方法
在hypervisor上直接将资源配置给GVM使用,即GVM可以访问真实的物理资源
物理资源在QNX侧使用,
由QNX侧提供BE(BackEnd 后端)程序
Android(GVM)侧提供FE(FrontEnd前端)程序
Hypervisor提供Virtio-FIFO管道,管道可以将FE程序的数据和命令传送给BE端
通过上述描述内容,可以确认以下两点
1 配置逻辑为 QNX IIC资源配置,QNX的BE端程序内容,Hypervisor的配置内容,Android的FE端程序内容
2 资源和控制逻辑还掌握在QNX侧,因此测试逻辑是首先保证QNX资源可用,再保证Android侧可以将数据发送到QNX侧
正常配置QNX的一路IIC资源,需要修改如下文件
/SD-QNX4.5.6.0/apps/qnx_ap/boards/core/dalconfig/lemans_rumi/config/i2c_props_lemans.xml
/SD-QNX4.5.6.0/apps/qnx_ap/boards/core/dalconfig/lemans_rumi/config/pin_config.c
使用 QNX i2cdbgr 命令 进行测试
该命令位置参照:/SD-QNX4.5.6.0/apps/qnx_ap/AMSS/platform/services/applications/i2cdbgr/i2cdbgr.c
使用方法参照:/SD-QNX4.5.6.0/apps/qnx_ap/AMSS/platform/services/applications/i2cdbgr/i2cdbgr.use
%C : Application to perform i2c read / write
Usage: i2cdbgr -D [node] -s [slave addr] -r -b [byte size] -o [offset] -i [# bytes to read] -n [speed in KHz (100/400/1000)]
i2cdbgr -D [node] -s [slave addr] -w -b [byte size] -o [offset] -x [value] -n [speed in KHz (100/400/1000)]
where
[node] is of form "/dev/i2cX".
[byte size] is 1, or 2. The value has no effect for read. For write, if the
byte size is 1, then the offset is ignored, and only [value] is written.
If the byte size if 2, then i2cdbgr will write [offset value].
The i2cdbgr uses 8-bit addressing, 8-bit data to read or write from
/dev/i2cX (fd) using i2c_client.h using default frequency.
Examples:
For read:
i2cdbgr -D /dev/i2c1 -s 0x77 -r -b 1 -o 0x4 -i 1 <- read 1 byte from slave addr 0x77
offset 0x4
i2cdbgr -D /dev/i2c1 -s 0x77 -r -b 1 -o 0x4 -i 5 <- read 5 bytes from slave addr
0x77 offset 0x4
For write:
i2cdbgr -D /dev/i2c1 -s 0x77 -w -b 1 -o 0x0 -x 0xa <- write 1 byte to slave addr
0x77 with no offset due to 1 byte size value 0xa
i2cdbgr -D /dev/i2c1 -s 0x77 -w -b 2 -o 0x1 -x 0xb <- write 2 bytes to slave addr
0x77 with offset + value bytes [0x1 0xb]
For Aardvark:
[Setup aardvark in slave mode with address 0x40]
i2cdbgr -D /dev/i2c3 -s 0x40 -r -b 1 -i 1 -n 100 -v //Speed set to 100KHz
i2cdbgr -D /dev/i2c3 -s 0x40 -r -b 1 -i 1 -n 400 -v //Speed set to 400KHz
i2cdbgr -D /dev/i2c3 -s 0x40 -r -b 1 -i 1 -n 1000 -v //Speed set to 1000KHz
测试 示例: i2cdbgr -D /dev/i2c6 -s 0x0c -r -b 1 -o 0x0 -i 0x1 -n 100
测试结果:OK
确认后端程序,这个程序是高通提供的无需修改,有需要时查看即可
/SD-QNX4.5.6.0/apps/qnx_ap/AMSS/platform/vm/vdev/vdev-virtio-i2c-safety/vdev-virtio-i2c.c
Virtio机制是BE以.so形式进行加载运行,所以要求确保上述使用的文件生成so并再车机中运行。
因此在此文件中追加相关内容,将so推送到机器中
SD-QNX4.5.6.0/apps/qnx_ap/target/hypervisor/host/build_files/system.build.tmpl
确认 /mnt/lib64/dll 中存在此
测试结果:OK
/SD-QNX4.5.6.0/apps/qnx_ap/target/filesets/secpol/gvm_la.txt
/SD-QNX4.5.6.0/apps/qnx_ap/target/hypervisor/gvm/ivi/lemans/la/linux-la.config
vdev vdev-virtio-i2c-safety.so loc 0x1cd10000 intr gic:109 verbose 3 controller i2c6 slave 0x0c version 1
测试结果: 无异常log OK
首先保证Android侧 IIC可用,前提是 Android kernel的三个config需要打开,需要配置为 y或者m
CONFIG_I2C_CHARDEV
CONFIG_I2C_MSM_GENI
CONFIG_I2C_VIRTIO
确认config的方法
在build out文件中确认当前config值
build out文件路径:/SD-HQX4.5.6.0/lagvm/LINUX/android/out/target/product/gen4_gvm/obj/DLKM_OBJ/kernel_platform/msm-kernel/.config
组入config的方法
修改/SD-HQX4.5.6.0/lagvm/LINUX/android/kernel_platform/msm-kernel/arch/arm64/configs/vendor/autogvm_GKI.config
在 高通流程中,defconfig位于 /SD-HQX4.5.6.0/lagvm/LINUX/android/kernel_platform/msm-kernel/arch/arm64/configs/gki_defconfig
从Android编译相关log可以看到,高通处理过程中会将上述autogvm_GKI.config merge 到 gki_defconfig中,所以不建议直接更新gki_defconfig。
log如下:
Using msm-kernel/arch/arm64/configs/gki_defconfig as base
Merging msm-kernel/arch/arm64/configs/vendor/autogvm_GKI.config
config最终确认结果
zhd@27:~/27_code/SD-HQX4.5.6.0/lagvm/LINUX/android/out/target/product/gen4_gvm/obj/DLKM_OBJ/kernel_platform/msm-kernel$ grep -inr CONFIG_I2C_CHARDEV .config
2979:CONFIG_I2C_CHARDEV=m
zhd@27:~/27_code/SD-HQX4.5.6.0/lagvm/LINUX/android/out/target/product/gen4_gvm/obj/DLKM_OBJ/kernel_platform/msm-kernel$ grep -inr CONFIG_I2C_MSM_GENI .config
3031:CONFIG_I2C_MSM_GENI=m
zhd@27:~/27_code/SD-HQX4.5.6.0/lagvm/LINUX/android/out/target/product/gen4_gvm/obj/DLKM_OBJ/kernel_platform/msm-kernel$ grep -inr CONFIG_I2C_VIRTIO .config
3051:CONFIG_I2C_VIRTIO=m
上述config 我是以模块形式进行的加载,所以还需要更新文件 /SD-HQX4.5.6.0/lagvm/LINUX/android/kernel_platform/msm-kernel/autogvm.bzl 使得启动时,自动加载相关 .ko文件
这几个.ko文件路径参照相关driver编译路径和makefile即可
例如 /SD-HQX4.5.6.0/lagvm/LINUX/android/kernel_platform/msm-kernel/drivers/i2c/Makefile 中
obj-$(CONFIG_I2C_CHARDEV) += i2c-dev.o
所以路径为 drivers/i2c/i2c-dev.ko
按照正常DTSI配置 IIC节点即可
/SD-HQX4.5.6.0/apps_kernel/kernel_platform/qcom/proprietary/devicetree/qcom/lemans-vm-la.dtsi
aliases {
i2c5= &virtio_i2c_DisplayB; // virtio-iic
};
/home/zhd/27_code/SD-HQX4.5.6.0/apps_kernel/kernel_platform/qcom/proprietary/devicetree/qcom/quin-vm-common.dtsi
virtio_i2c_DisplayB:virtio_i2c_DisplayB@1cd10000{
compatible = "virtio,mmio";
#address-cells = <1>;
#size-cells = <1>;
reg = <0x1cd10000 0x1000>;
interrupts = <GIC_SPI 77 IRQ_TYPE_LEVEL_HIGH>;
status = "okay";
};
这里需要注意两点
这两个数值在这两处一致即可,可任意编写,但不要和其他数值冲突 PS:建议同时比对 la.config (现状不冲突)和 DTS中其他值(防止和未来某项冲突)
2本身希望生成的设备节点和QNX一致为 /dev/i2c-6 ,但由于高通base设计,alises中 如果写 i2c6,生成的节点为 /dev/i2c-7 所以这里写的是 i2c5
PS:QNX设备节点 也不一定非要和Android 完全一致。按照自己设计要求做就行。
同时 也能看到输出波形
测试结果: ok
(●'◡'●)~,此方法简要描述了配置和测试方法, 是不是很简单!。
点到为止,举一反三!
- VirtIO (qnx.com)
- Physical devices (qnx.com)- vdev ioapic (qnx.com)