实时linux部署测试

By Toradex 胡珊逢

1). 简介

对于实时、决策或者低延时应用,Linux能够提供多种方案。第一种方法是和 Linux 内核一起运行一个hypervisor或者co-kernel。这种方案中hypervisor或者co-kernel的优先级高于 Linux,实时任务则运行于其中。另外一种方式是使用非对称异构多核系统,Linux和另外一个实时内核分别运行在不同处理器内核上。最后,还可使 Linux 更具抢占性从而提高其实时性能。这通常可以通过 PREEMPT_RT 补丁实现。本文就基于Toradex Colilbri iMX6 ARM计算机模块系统着重介绍如何部署病测试PREEMPT_RT 补丁。

 

2). 部署

a). 下载 Linux 内核源码

---------------------

Toradex-ubuntu$ git clone -b toradex_4.1-2.0.x-imx git://git.toradex.com/linux-toradex.git

---------------------

或者从 FTP 下载

ftp://ftp.toradex.cn

Linux/I.MX6/SourceCode/v2.7/linux-toradex.tar.gz

 

b). 下载rt补丁

ftp://ftp.toradex.cn

Linux/I.MX6/RT-Linux/Linux4.1.35/patch.tar.gz

 

c). 安装补丁

---------------------

Toradex-ubuntu $cdlinux-toradex

Toradex-ubuntu $ patch -p1 < ../patch/patch-4.1.35-rt41.patch

Toradex-ubuntu $ patch -p1 < ../patch/0001-fix-build.patch

Toradex-ubuntu $ patch -p1 < ../patch/0002-fix-build.patch

Toradex-ubuntu $ patch -p1 < ../patch/0003-Work-around-CPU-stalls-in-the-imx-sdma-driver.patch

Toradex-ubuntu $ patch -p1 < ../patch/0004-export-swait-locked-functions.patch

---------------------

注意,根据所在的目录,需要调整 patch 命令–p 的参数。

 

d). 配置内核

---------------------

Toradex-ubuntu $ make colibri_imx6_defconfig

Toradex-ubuntu $ make menuconfig

---------------------

勾选下面选项

---------------------

./ Kernel Features  --->Preemption Model (Fully Preemptible Kernel (RT))  --->(X) Fully Preemptible Kernel (RT)

./ Timer frequency (100 Hz)  --->(X) 1000 Hz

---------------------

虽然在 Linux 使用了rt补丁,但是Linux 的大部分驱动却并不是使用PREEMPT_RT API,这些驱动的存在会影响实时性能,特别是显示驱动。因此,如果你的应用中不需要显示功能,那么可以在 Linux 内核配置中禁用它,以及其他你所不需要的功能。设备驱动位于下面位置:

---------------------

Device Drivers  --→

---------------------

 

e). 编译内核

---------------------

Toradex-ubuntu $ make -j4 uImage LOADADDR=10008000

---------------------

 

3). 测试

a). 这里我们也将使用 console image(无图形界面)的镜像作为测试。

ftp://ftp.toradex.cn/

Linux/I.MX6/RT-Linux/Linux4.1.35/Colibri_iMX6_LinuxConsoleImageV2.7_20170308.tar.bz2

 

b). 根据这里说明将上面console image更新到Colibri iMX6模块上面, 然后用上一章节编译出的uImage 替换Colibri iMX6 上的内核,并重新启动。

 

c). 在没有使用 PREEMPT_RT 补丁的 Linux 中,cyclictest测试如下,测试过程中使用 stress 增加 CPU负荷

---------------------

root@colibri-imx6:~# uname -a

Linux colibri-imx6 4.1.35-v2.7b1+gc117783 #1 SMP Thu Jan 19 09:06:57 CST 2017 armv7l GNU/Linux

 

root@colibri-imx6:~# stress -c 2 &

[1] 535

root@colibri-imx6:~# stress: info: [535] dispatching hogs: 2 cpu, 0 io, 0 vm, 0 hdd

 

root@colibri-imx6:~# cyclictest -n -p 80 -t -D10m

# /dev/cpu_dma_latency set to 0us

policy: fifo: loadavg: 2.00 1.79 1.04 3/74 541         

 

T: 0 (  539) P:80 I:1000 C: 599994 Min:     10 Act:   13 Avg:   13 Max:     826

T: 1 (  540) P:80 I:1500 C: 399996 Min:     10 Act:   13 Avg:   13 Max:      42

---------------------

 

d). 使用 PREEMPT_RT 补丁后,做同样的测试

---------------------

root@colibri-imx6:~# uname -a

Linux colibri-imx6 4.1.35-rt41 #1 SMP PREEMPT RT Wed Mar 8 11:41:31 CST 2017 armv7l GNU/Linux

 

root@colibri-imx6:~# stress -c 2 &

[1] 526

root@colibri-imx6:~# stress: info: [526] dispatching hogs: 2 cpu, 0 io, 0 vm, 0 hdd

 

root@colibri-imx6:~# cyclictest -n -p 80 -t -D10m

# /dev/cpu_dma_latency set to 0us

policy: fifo: loadavg: 2.00 1.78 1.01 3/114 535         

 

T: 0 (  530) P:80 I:1000 C: 599994 Min:     14 Act:   20 Avg:   18 Max:      71

T: 1 (  531) P:80 I:1500 C: 399996 Min:     14 Act:   16 Avg:   17 Max:      50

---------------------

 

通过对比测试发现,使用 PREEMPT_RT 补丁后,最大延时由 826us 降到 71us。

 

4). 总结

PREEMPT_RT通过软件的方法提高普通 Linux 的实时能力,但这仍然不是真正意义上的实时,正如上面的测试,还是会出现数十微秒的延时,当系统的负荷增加时,可能出现更长的延时情况。Colibri iMX7 上的 M4 内核可以运行FreeRTOS,从而提供真正的实时操作系统。详细的情况,请参考Toradex举办的网络研讨会《使用嵌入式 Linux 进行实时系统开发》

你可能感兴趣的:(实时linux部署测试)