EDA365电子论坛网

标题: 3568开发板实时内核的效果测试 [打印本页]

作者: 罗罗诺亚    时间: 2022-10-9 10:48
标题: 3568开发板实时内核的效果测试
本帖最后由 Heaven_1 于 2022-10-9 16:14 编辑 + n3 p3 E# ~; N- p
3 o$ _9 Z, l+ b! y! u& b+ k
在工业4.0时代,人工智能和工业物联网的发展走上了快车道,越来越多的行业对实时操作系统有了更加迫切的需求。基于此,飞凌嵌入式推出了在OK3568-C开发板  飞凌嵌入式官网-ARM嵌入式核心板、开发板、工控机、单片机解决方案-专注智能设备核心平台研发与制造 - 保定飞凌嵌入式技术有限公司    上运行的实时操作系统,本文中小编将为大家介绍飞凌嵌入式在OK3568-C开发板上实现实时性的方式,以及实时内核的效果测试。7 U0 }' z8 y% a5 J& X

9 l$ [9 c0 S& R2 M9 @& L; p" c4 |+ H6 j$ x1 D# r& O$ z

+ |/ F8 h$ e. c, l8 c, m$ c8 U4 P( H6 a# K! R
) I( c8 p" J$ M; b- J( W

* J  c0 v, w: f7 I; |
# G4 q0 B/ c* d, }/ v
[backcolor=rgba(18, 18, 18, 0.5)]​
+ Z  u. Y" d' n0 f1 ?. ^* ?1 q4 y( k8 K6 A! T2 l

9 z' A8 |' p1 D7 u: d+ b3 y* w3 l. H; g$ D& ^+ y' V' f$ j

$ C; E7 Q' C( ^' z7 H编辑切换为居中
- A' \3 h2 m8 C/ d% ?/ S0 `2 e: A9 J" N3 s  e

& p  V/ k0 d9 o& i& H, q3 X& {+ i# ]7 J$ C. n& I, w& L0 l2 C( t/ E

/ x# o7 f2 m; n3 m  F" e; q) r) o+ I; V; \$ U/ P! O

. F7 V* I: |9 V& W" D/ ~4 C: c( a: n+ e# j' L
3 O( u, [: q5 x. E8 m# V

* t( e4 V2 i# y; y* v9 J
8 l4 H9 x+ t% F' Q8 k; _8 r7 X6 N7 H2 A) G, |& d
0 \+ z% @. j9 u8 ^  P3 e
1$ Z/ `3 F1 |8 ^' x+ g5 {

9 y6 M5 b( r" {& H% N0 ^" g为什么选择实时操作系统 ?
. U" O' g( P5 T% F5 B/ U" [: G. {8 z7 O6 M$ w; W$ F

& l/ H/ ^( j1 z+ j  @2 y8 L
8 o- v* j, J9 [# h! o) S; i" T% z! n! y8 J$ ?
0 `- o& E) c4 {) Q

$ y: v2 ?0 q9 A$ \
0 V; ^3 \* R: m我们都知道,操作系统可以分为实时操作系统和分时操作系统。分时操作系统其实就是将系统处理机时间与内存空间按一定的时间间隔轮流地切换给各终端用户的程序使用。目前市面上绝大多数板卡上运行的Linux系统都是分时操作系统。# M5 F# t$ ^! E" z2 d  Y0 d( p

' Q, J' V3 g. W5 V  i  M
& U' ~% y. a' G2 Y) h. z7 [$ |4 ~4 A  @$ g" \9 J( E; q5 H7 `

$ m* _4 o! D; ^5 w% f7 P( u但是随着自动驾驶、智能机器人等行业的兴起,对板载操作系统的实时性也提出了更高的要求。这时候,分时系统就无法满足某些对实时性要求较高的行业的需求了,必须对Linux系统进行改进,使其具有更好的实时性,以顺应行业的发展。
# O$ |" N: N7 w: F0 @" {
  h" }! o$ k1 p, v) }- [1 C3 |& P# }2 Y9 t1 E3 g

8 I3 [' A+ G1 X- m8 \
2 c6 Q5 m+ D. v2 C% [5 J
% o' V& V! z5 j' Q; z9 o
2 ~* D$ ^" w4 }5 c5 r  n% I! ]1 h& p: k1 ]' E7 P/ s
[backcolor=rgba(18, 18, 18, 0.5)]​
3 ^4 R$ s* b' z0 Z: U2 D( @! c+ R/ K' F* @- r

4 q9 t! H( l5 ~3 c; M  x) N. `* ^9 ~* M

3 d- Z* ]3 X  g( y编辑切换为居中
3 @. i" a3 b6 z. }
# t0 d7 V% K+ `8 y, y  Q2 u- R7 U  c9 z$ `6 x" u( ]
4 i) P9 x7 ?* R' o" V
2 @2 X* z7 c/ c7 E/ n' s" d

7 M) t- @0 \' Q* k) F0 z
6 V+ [0 M1 B7 \. D5 L
9 w6 q: x& [/ \0 k: c
: j, T6 V. J3 E8 n! Q/ I" H2 I( ?2 }1 M& k) [

. U+ R+ _0 q$ W2 ^1 X" ~# @- H3 |  t' t3 M: g3 Z/ {

) l5 R* W; K) H2 A6 d% V8 P- W例如无人驾驶技术,系统需要根据复杂的路况情况及时做出分析判断,做出反应,执行刹车或变道操作;又比如车载安全气囊,在遇到突发事故时,系统必须第一时间做出反应弹出安全气囊,保护车内乘客人身安全。这些实际应用场景都离不开实时操作系统。
2 G; \1 o5 k. `# F$ T! ^; `8 H8 W- H6 B5 ?" [; e

7 @5 b; F" T: J# `/ ^* V/ ?- q6 d! v4 r$ _* l5 N7 ~: A2 |

7 Z6 n: q% \4 r, A% M3 `2
+ J7 _$ j% H. ]
* L$ V8 q) f7 D. x如何实现“实时性” ?
/ Q/ [  `) e- d% L9 x& V
+ D* U9 L9 T! k) d; H# t5 D3 f  Y
$ R: r/ I+ [# {9 a' h
0 q$ h+ P' g3 b  y: A- s! n- }. j: A! H( R

7 j2 f0 Y/ h. b( T1 D, o: z3 t! P  u& N/ O2 a

6 e2 c) @: ^5 a' GLinux系统可以采用打补丁的方式来实现“实时性”。RT-Linux就是在Linux的基础上加入了一个实时补丁,从而将Linux改进成实时操作系统。简单地说,“实时补丁”的主要工作就是针对Linux系统的优先级倒置、自旋锁等问题进行改进,以达到实时操作系统的要求。
  l( T* l+ R) n( U% v% b
8 e' Y, Y8 H) d2 e3 {0 E% k3 |* n

4 s/ Y6 k' v' W* s+ o7 w7 @
* h  |. z# Y7 @. g" z) f" z5 B基于这个思路,我们就可以通过对内核打实时补丁的方法让OK3568-C开发板上的Linux系统满足实时性的需求。/ B( v3 s% k, q5 A% `: h4 {8 K( c
& z  V2 ?. [2 f& E: H: c& P
: b& m5 ~  G* g, `6 O+ s

& O: O7 J+ v* r" b/ G5 O  j  S: `- S8 _
飞凌提供了两个补丁文件:; [9 q# Z2 B3 f+ G/ P
( j/ V8 v0 j( n, U* j3 U
0001-patch-patch-4.19.206-rt87.patch-fix-kernel-sched-cor.patch0002-fix-kernel-sched-core.c.patch
6 s: n0 x7 M% O) H% V
* d% q- _$ M2 Z7 t3 S6 p
! T9 j) {  P8 l; X% f
) w4 g& G! r/ V- C0 }
将两个补丁文件拷贝到源码/OK3568-linux-source/kernel路径下,执行以下命令:. ~. \: i' c  L  X' U
9 _  W+ r, @' t; }. ~
patch-p1 <0001-patch-patch-4.19.206-rt87.patch-fix-kernel-sched-cor.patchpatch-p1 < 0002-fix-kernel-sched-core.c.patch
* d: q" x# P) X6 c+ |; F

1 a" H' [' ^' t9 {& g8 w* W7 |: l5 F8 }- ?% N  O

6 o2 }- I4 i: \3 @然后,在源码执行./build.sh kernel命令,即可在/OK3568-linux-source/kernel目录下生成boot.img镜像文件。
* @/ Y8 i6 Y7 N- d6 G& l
  f1 v8 Q; Z" w0 m! l7 q5 ^7 u9 ?8 ]% `. x: q6 b
$ U7 t; {+ s7 w+ e; s# {
$ {( p7 [$ T# Y
客户也可以直接单步烧写飞凌制作完成的boot.img镜像文件。
7 o9 E6 J" q/ ~8 ]2 I
2 u& [# w/ n1 A2 ^3 c& F  t8 u
0 U) t& q) r. H
/ J, ~$ T5 d7 r3 q/ b' f& n7 c$ I5 t% N
使用Type-C线连接开发板和主机,按住recover键不松开,然后再按reset键系统复位,大约两秒后松开recover键。系统将提示发现一个loader设备。/ |( E' y8 J. ?5 ?
# \8 t3 `! J9 w3 L3 K

* |) @6 C% f3 y; |+ z4 D
3 v, {$ Q6 ?; j6 K: i
! Z- a: i8 c/ R; a/ ?4 F' j  h. u* Z
[backcolor=rgba(18, 18, 18, 0.5)]​
7 h0 m6 L; _% G" ~! M0 n% J
9 G# o% G9 i: e# J$ c; H
8 K; Q9 ^( b8 D

6 M" g$ g9 k9 `) v" X
9 d& u" h5 d, K编辑切换为居中6 x0 J1 S/ u. \

) d8 w& D* R+ T8 y
9 I4 }9 R% i; Q9 X1 ^- g8 X: K2 S1 z2 `: k0 l/ k5 D7 e

; w+ q6 P4 i% P添加图片注释,不超过 140 字(可选)
$ `5 l! d( v; H' M) T8 L
7 d* s5 g2 d4 C- s( K, z( Z
# O# R5 ]; F2 p# c9 x9 ?5 g% h6 R6 r1 u' G7 Z& z% \

) L* J/ X) ^9 C' ]6 P1 c1 I* w' A
3 l6 V8 H( r0 S4 @" H; P9 z. a1 W( J
2 z- k) q) W$ \0 M( s% V8 x5 p' ?. ^& U- _
点击“设备分区表”按钮,将自动读取分区地址。
  v7 f. R( X: [/ g( ?# s/ X
% J* u# P6 m* s
5 k0 U4 J  G3 O4 `# u1 T% U5 m! I
4 }# L: V; {% `
% y3 S1 L6 q3 t$ V% ~# P  q
[backcolor=rgba(18, 18, 18, 0.5)]​, ^+ [7 v2 o) f' u& @( J! Y

9 j( B+ g, G1 c

1 I3 v0 V. F6 u" |$ z
4 e% C! c# Y7 _# ?
$ j! M% @1 R' R7 ~9 A4 h编辑切换为居中
& `' k6 C4 A/ e8 `8 f: A0 r
) j% v: X3 P6 n: T, z# {& L2 z6 C( _; Q1 p) C

; c- K8 t4 V( q: @& l; v+ a: J9 h6 b
添加图片注释,不超过 140 字(可选)+ u  m0 G9 Y8 C* c; R3 D& p- [) s

! x( ~$ F3 G" C, G$ H
6 R* N9 j" k% Q: A6 d! S  b7 w2 P* I! V2 b  r( ^7 I7 ~

  h- k  A5 k9 n+ Y7 Q1 V2 g4 x) t3 Y/ [* P! M0 l

6 T* d+ @/ s  q# P" F6 o! A. e
% E6 `) @% q* f, L& D) [: I- x+ j点击左侧勾选boot分区。
. T& a; x6 ?' W/ ~4 Z1 {" _
' B/ {" y0 D% D% L
0 j; t* f* ?  P) n% Q0 g1 |
- l8 x- {) m! [: B2 v4 P2 Q$ s8 v" u
[backcolor=rgba(18, 18, 18, 0.5)]​
6 g! {4 D7 O: O2 x7 u: N4 h0 X$ w5 |5 X: \
1 e: }2 X; M2 Q; ?

0 W$ s* E) t3 G# W6 k# z
1 N6 h2 T0 v- g# S& q7 b编辑切换为居中
2 E& u! c( |" T, P; V
  N1 R( o+ w  K/ [0 c6 K# S
8 I5 Z2 w! x- Z% a5 i- S
: y5 \9 K' g6 j; \$ D5 K4 R, \
5 X6 |+ Z8 C1 V+ P! D添加图片注释,不超过 140 字(可选)
* p! o: Y8 S9 d7 p9 g
4 \- e8 \; K  U+ f1 Q7 o! ]6 w% j( l8 \
# M& ~0 ^; v: O( |: m
, F2 i9 l! s4 e9 z1 Y; A

" G8 n* S# d+ g; M. U
2 @. g; O) |6 `& }) ^* _, W5 ^1 Y3 g. W/ A+ o
最后,点击右侧选择您编译生成的boot镜像文件路径,点击“执行”按钮将自动烧写并重新启动。
4 U2 G# c: z, b! ?: [# ~- c- T% Y  i7 t2 H( F: S
8 U4 q* ]- R- h$ C. @
$ S0 z# }1 U& T. @3 w6 D
+ K. t+ f4 e- o5 h5 ?5 c4 Z& l
想要了解有关实时补丁的详细资料,您可以在公众号留言联系飞凌嵌入式销售工程师。) z# `/ p! Y& x- h, h1 f( [

) o6 J" v8 J6 ]  y8 s8 S( F$ S8 k- k  z2 p! j  K

0 `# g" b' o4 Q- O
" h( ~$ c% _% L( p6 b2 ^. i3
# u) w/ x  C$ J+ u- p2 X
/ e2 N& V1 }$ Y' K# @& q- B/ P实时内核效果测试
9 c5 o# n9 [$ T6 j$ W$ \6 ?1 d, r! x) A0 [& m2 u6 u& G

$ E" o: g1 D& H
1 L8 I5 A- p4 ~4 @: e" r/ e( Z; d# l+ o: d' y6 C
8 H& Z/ U7 r1 V* @* _

& z0 E: }- F+ N% H
: m+ V. a, C" M6 J4 L. C. y测试实时性的关键指标便是“延时”,延时指的是不论系统运行在代码的什么位置,当事件发生时,系统响应该事件的时间。" {* v$ b. f- I7 C5 n

4 l# t$ b0 J& D- X( ^% w/ G5 ]( S- x. t0 s) n/ [3 J( h
; V, j# c0 V) n! U% X. x

2 ~9 n5 |$ [# D. a其中中断延时指的是中断触发到中断服务函数执行完毕的时间;调度延时指的是进程在队列中等待直到获取CPU控制权被执行的时间。
$ m9 J, c4 h% P! R/ e7 t
4 ]8 j# ]6 O4 D/ L- c' g0 e; u. [5 i0 E8 l& h3 P* j( j7 ^  e
$ }& p) G5 j# }$ t3 w

: i% ~" w) R4 {+ g. P" C! [实时性,也可以表现为对这两段延时最大的容忍程度。这里通过cyclictest软件测量中断延时和调度延时时间。
" v& l4 o! J4 I/ w% R5 }$ t1 H2 \! E

% K* ]+ V& x9 c9 p2 L2 H5 O/ f+ D6 z7 E

. u! H" o1 e/ d: H9 w0 n) _由于在真实的使用环境下并不能触发最大的延时时间,因此在没有合适负载的情况下运行cyclictest所测得的延时统计数据是没有意义的。这里我们采用官方提供的hackbench工具来模拟部分类型的负载,然后在此基础上运行cyclictest软件来测试事件发生时,系统响应该事件的时间。
9 J& S- ~3 A9 R$ y9 k5 m, k; m% |, p- E' J

* d0 Y/ X! n+ t+ F' q; g* u# u4 R; n) b: r1 U, h$ ^4 f

, G; j1 \9 u3 ^6 s8 o5 K& w2 D先来看一下未打实时补丁的测试结果:
7 |( S& e; j/ h; l  m# a" b6 j' W9 P3 n  D8 |: y$ R

6 X6 @" M! i9 E; J5 r0 o! Q6 |* H" t4 B
6 }: m2 G5 o$ M- Y+ _
[backcolor=rgba(18, 18, 18, 0.5)]​
$ v" X/ g5 A7 Q! q, I0 J
" X+ k" _" K  Y" g1 N- w- w3 I

, L+ `# ~4 S6 J6 G$ H! Y( ^& M' |  _7 c7 Y. l* z3 W: B
% N3 P) v/ X# I5 \
编辑切换为居中0 m6 q3 a. G% ^+ f

2 a* a, L2 i9 e! S+ D- g% I3 a, h! j8 @" I( _# g  I
' o9 o0 n( _$ s

* d/ e1 ?4 `: o& N添加图片注释,不超过 140 字(可选)/ l! F6 Z* c8 J. [& r' s" a

. }  K- y% T+ L& p
1 K3 ?9 g  Z; L: ~* K* W8 {
% }' |3 X' E' S
6 m+ t6 {) u" `' O0 ?) P' n3 S7 I% ~0 a5 O: C% y7 }2 V
* P, P, {" M  J/ N. ]6 v3 F
7 V7 Z" {! q9 Q5 M* k
再来看一下打实时补丁后的测试结果:
3 ]2 E; e9 x: \; q1 [/ F( K( a3 ]
! y  x, t# D( A- D, A, t+ s+ ]! K" p+ M$ j
; E# q) R  q, F

3 u. X, \) ^2 D0 G" k7 _  M
[backcolor=rgba(18, 18, 18, 0.5)]​
" m& g$ H7 [0 Q# \% {/ i4 P
/ d6 v, S6 R; X/ B* g# U
% B; e' Y! _2 i  k9 q/ ?

8 ~& \2 N/ \4 G  Y9 m* o+ t2 K+ `9 o6 T3 ?6 [0 o) T9 S; B. V2 c
编辑切换为居中- \# P/ Y$ h* K! g

0 h  _6 o; x0 _+ b5 q
) t; t$ @. ?4 Z9 S& j. V: W
+ u! [4 z# |1 I
& q1 ?- b- O5 R) w% p" m, t0 e0 _  d8 ^& G1 b
$ v2 m7 i2 i. i1 A9 c2 c

1 N! A5 B0 m3 m' i
  t9 _1 z" r3 {, Z
1 d+ Y; H- d: J5 K# _
- H  m& c. L7 A7 s7 S# Q" H% c  |/ P. T5 w4 n2 g; @$ T7 ]

# V  J% |, A9 w0 A这里我们着重比较两者Max得出的参数,因为系统的实时性能是由最大延时时间决定的。通过对打实时补丁前后测试结果进行对比,打实时补丁以后,可以明显看出延时从213μs降低到80μs以内,实时效果还是十分明显的。(不同测试条件下的延时不同,这里的测试结果仅供大家参考); o( b/ u1 ?* {3 N
( m0 N1 q; C3 s5 D' P

9 P+ E2 V* ?; ~$ S* W2 _* X# X+ V
作者: somethingabc    时间: 2022-10-9 16:13
测试环境不一样




欢迎光临 EDA365电子论坛网 (https://bbs.eda365.com/) Powered by Discuz! X3.2