ubpf_vm.rs 58 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356
  1. // SPDX-License-Identifier: (Apache-2.0 OR MIT)
  2. // Converted from the tests for uBPF <https://github.com/iovisor/ubpf>
  3. // Copyright 2015 Big Switch Networks, Inc
  4. // Copyright 2016 6WIND S.A. <quentin.monnet@6wind.com>
  5. // The tests contained in this file are extracted from the unit tests of uBPF software. Each test
  6. // in this file has a name in the form `test_vm_<name>`, and corresponds to the (human-readable)
  7. // code in `ubpf/tree/master/tests/<name>`, available at
  8. // <https://github.com/iovisor/ubpf/tree/master/tests> (hyphen had to be replaced with underscores
  9. // as Rust will not accept them in function names). It is strongly advised to refer to the uBPF
  10. // version to understand what these program do.
  11. //
  12. // Each program was assembled from the uBPF version with the assembler provided by uBPF itself, and
  13. // available at <https://github.com/iovisor/ubpf/tree/master/ubpf>.
  14. // The very few modifications that have been realized should be indicated.
  15. // These are unit tests for the eBPF interpreter.
  16. extern crate rbpf;
  17. mod common;
  18. use rbpf::helpers;
  19. use rbpf::assembler::assemble;
  20. use common::{TCP_SACK_ASM, TCP_SACK_MATCH, TCP_SACK_NOMATCH};
  21. #[test]
  22. fn test_vm_add() {
  23. let prog = assemble("
  24. mov32 r0, 0
  25. mov32 r1, 2
  26. add32 r0, 1
  27. add32 r0, r1
  28. exit").unwrap();
  29. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  30. assert_eq!(vm.execute_program().unwrap(), 0x3);
  31. }
  32. #[test]
  33. fn test_vm_alu64_arith() {
  34. let prog = assemble("
  35. mov r0, 0
  36. mov r1, 1
  37. mov r2, 2
  38. mov r3, 3
  39. mov r4, 4
  40. mov r5, 5
  41. mov r6, 6
  42. mov r7, 7
  43. mov r8, 8
  44. mov r9, 9
  45. add r0, 23
  46. add r0, r7
  47. sub r0, 13
  48. sub r0, r1
  49. mul r0, 7
  50. mul r0, r3
  51. div r0, 2
  52. div r0, r4
  53. exit").unwrap();
  54. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  55. assert_eq!(vm.execute_program().unwrap(), 0x2a);
  56. }
  57. #[test]
  58. fn test_vm_alu64_bit() {
  59. let prog = assemble("
  60. mov r0, 0
  61. mov r1, 1
  62. mov r2, 2
  63. mov r3, 3
  64. mov r4, 4
  65. mov r5, 5
  66. mov r6, 6
  67. mov r7, 7
  68. mov r8, 8
  69. or r0, r5
  70. or r0, 0xa0
  71. and r0, 0xa3
  72. mov r9, 0x91
  73. and r0, r9
  74. lsh r0, 32
  75. lsh r0, 22
  76. lsh r0, r8
  77. rsh r0, 32
  78. rsh r0, 19
  79. rsh r0, r7
  80. xor r0, 0x03
  81. xor r0, r2
  82. exit").unwrap();
  83. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  84. assert_eq!(vm.execute_program().unwrap(), 0x11);
  85. }
  86. #[test]
  87. fn test_vm_alu_arith() {
  88. let prog = assemble("
  89. mov32 r0, 0
  90. mov32 r1, 1
  91. mov32 r2, 2
  92. mov32 r3, 3
  93. mov32 r4, 4
  94. mov32 r5, 5
  95. mov32 r6, 6
  96. mov32 r7, 7
  97. mov32 r8, 8
  98. mov32 r9, 9
  99. add32 r0, 23
  100. add32 r0, r7
  101. sub32 r0, 13
  102. sub32 r0, r1
  103. mul32 r0, 7
  104. mul32 r0, r3
  105. div32 r0, 2
  106. div32 r0, r4
  107. exit").unwrap();
  108. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  109. assert_eq!(vm.execute_program().unwrap(), 0x2a);
  110. }
  111. #[test]
  112. fn test_vm_alu_bit() {
  113. let prog = assemble("
  114. mov32 r0, 0
  115. mov32 r1, 1
  116. mov32 r2, 2
  117. mov32 r3, 3
  118. mov32 r4, 4
  119. mov32 r5, 5
  120. mov32 r6, 6
  121. mov32 r7, 7
  122. mov32 r8, 8
  123. or32 r0, r5
  124. or32 r0, 0xa0
  125. and32 r0, 0xa3
  126. mov32 r9, 0x91
  127. and32 r0, r9
  128. lsh32 r0, 22
  129. lsh32 r0, r8
  130. rsh32 r0, 19
  131. rsh32 r0, r7
  132. xor32 r0, 0x03
  133. xor32 r0, r2
  134. exit").unwrap();
  135. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  136. assert_eq!(vm.execute_program().unwrap(), 0x11);
  137. }
  138. #[test]
  139. fn test_vm_arsh32_high_shift() {
  140. let prog = assemble("
  141. mov r0, 8
  142. lddw r1, 0x100000001
  143. arsh32 r0, r1
  144. exit").unwrap();
  145. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  146. assert_eq!(vm.execute_program().unwrap(), 0x4);
  147. }
  148. #[test]
  149. fn test_vm_arsh() {
  150. let prog = assemble("
  151. mov32 r0, 0xf8
  152. lsh32 r0, 28
  153. arsh32 r0, 16
  154. exit").unwrap();
  155. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  156. assert_eq!(vm.execute_program().unwrap(), 0xffff8000);
  157. }
  158. #[test]
  159. fn test_vm_arsh64() {
  160. let prog = assemble("
  161. mov32 r0, 1
  162. lsh r0, 63
  163. arsh r0, 55
  164. mov32 r1, 5
  165. arsh r0, r1
  166. exit").unwrap();
  167. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  168. assert_eq!(vm.execute_program().unwrap(), 0xfffffffffffffff8);
  169. }
  170. #[test]
  171. fn test_vm_arsh_reg() {
  172. let prog = assemble("
  173. mov32 r0, 0xf8
  174. mov32 r1, 16
  175. lsh32 r0, 28
  176. arsh32 r0, r1
  177. exit").unwrap();
  178. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  179. assert_eq!(vm.execute_program().unwrap(), 0xffff8000);
  180. }
  181. #[test]
  182. fn test_vm_arsh_imm_overflow() {
  183. let prog = assemble("
  184. mov r0, 1
  185. lsh r0, 63
  186. arsh r0, 0xff20
  187. exit").unwrap();
  188. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  189. assert_eq!(vm.execute_program().unwrap(), 0xffffffff80000000);
  190. }
  191. #[test]
  192. fn test_vm_arsh_reg_overflow() {
  193. let prog = assemble("
  194. mov r0, 1
  195. lsh r0, 63
  196. mov r1, 0xff04
  197. arsh r0, r1
  198. exit").unwrap();
  199. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  200. assert_eq!(vm.execute_program().unwrap(), 0xf800000000000000);
  201. }
  202. #[test]
  203. fn test_vm_arsh32_imm_overflow() {
  204. let prog = assemble("
  205. mov32 r0, 1
  206. lsh32 r0, 31
  207. arsh32 r0, 0xff10
  208. exit").unwrap();
  209. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  210. assert_eq!(vm.execute_program().unwrap(), 0xffff8000);
  211. }
  212. #[test]
  213. fn test_vm_arsh32_reg_overflow() {
  214. let prog = assemble("
  215. mov32 r0, 1
  216. lsh32 r0, 31
  217. mov32 r1, 32
  218. arsh32 r0, r1
  219. exit").unwrap();
  220. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  221. assert_eq!(vm.execute_program().unwrap(), 0x80000000);
  222. }
  223. #[test]
  224. fn test_vm_be16() {
  225. let prog = assemble("
  226. ldxh r0, [r1]
  227. be16 r0
  228. exit").unwrap();
  229. let mem = &mut [
  230. 0x11, 0x22
  231. ];
  232. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  233. assert_eq!(vm.execute_program(mem).unwrap(), 0x1122);
  234. }
  235. #[test]
  236. fn test_vm_be16_high() {
  237. let prog = assemble("
  238. ldxdw r0, [r1]
  239. be16 r0
  240. exit").unwrap();
  241. let mem = &mut [
  242. 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77, 0x88
  243. ];
  244. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  245. assert_eq!(vm.execute_program(mem).unwrap(), 0x1122);
  246. }
  247. #[test]
  248. fn test_vm_be32() {
  249. let prog = assemble("
  250. ldxw r0, [r1]
  251. be32 r0
  252. exit").unwrap();
  253. let mem = &mut [
  254. 0x11, 0x22, 0x33, 0x44
  255. ];
  256. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  257. assert_eq!(vm.execute_program(mem).unwrap(), 0x11223344);
  258. }
  259. #[test]
  260. fn test_vm_be32_high() {
  261. let prog = assemble("
  262. ldxdw r0, [r1]
  263. be32 r0
  264. exit").unwrap();
  265. let mem = &mut [
  266. 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77, 0x88
  267. ];
  268. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  269. assert_eq!(vm.execute_program(mem).unwrap(), 0x11223344);
  270. }
  271. #[test]
  272. fn test_vm_be64() {
  273. let prog = assemble("
  274. ldxdw r0, [r1]
  275. be64 r0
  276. exit").unwrap();
  277. let mem = &mut [
  278. 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77, 0x88
  279. ];
  280. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  281. assert_eq!(vm.execute_program(mem).unwrap(), 0x1122334455667788);
  282. }
  283. #[test]
  284. fn test_vm_call() {
  285. let prog = assemble("
  286. mov r1, 1
  287. mov r2, 2
  288. mov r3, 3
  289. mov r4, 4
  290. mov r5, 5
  291. call 0
  292. exit").unwrap();
  293. let mut vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  294. vm.register_helper(0, helpers::gather_bytes).unwrap();
  295. assert_eq!(vm.execute_program().unwrap(), 0x0102030405);
  296. }
  297. #[test]
  298. fn test_vm_call_memfrob() {
  299. let prog = assemble("
  300. mov r6, r1
  301. add r1, 2
  302. mov r2, 4
  303. call 1
  304. ldxdw r0, [r6]
  305. be64 r0
  306. exit").unwrap();
  307. let mem = &mut [
  308. 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08
  309. ];
  310. let mut vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  311. vm.register_helper(1, helpers::memfrob).unwrap();
  312. assert_eq!(vm.execute_program(mem).unwrap(), 0x102292e2f2c0708);
  313. }
  314. // TODO: helpers::trash_registers needs asm!().
  315. // Try this again once asm!() is available in stable.
  316. //#[test]
  317. //fn test_vm_call_save() {
  318. //let prog = &[
  319. //0xb7, 0x06, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00,
  320. //0xb7, 0x07, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00,
  321. //0xb7, 0x08, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00,
  322. //0xb7, 0x09, 0x00, 0x00, 0x00, 0x40, 0x00, 0x00,
  323. //0x85, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00,
  324. //0xb7, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  325. //0x4f, 0x60, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  326. //0x4f, 0x70, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  327. //0x4f, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  328. //0x4f, 0x90, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  329. //0x95, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
  330. //];
  331. //let mut vm = rbpf::EbpfVmNoData::new(Some(prog)).unwrap();
  332. //vm.register_helper(2, helpers::trash_registers);
  333. //assert_eq!(vm.execute_program().unwrap(), 0x4321);
  334. //}
  335. #[test]
  336. fn test_vm_div32_high_divisor() {
  337. let prog = assemble("
  338. mov r0, 12
  339. lddw r1, 0x100000004
  340. div32 r0, r1
  341. exit").unwrap();
  342. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  343. assert_eq!(vm.execute_program().unwrap(), 0x3);
  344. }
  345. #[test]
  346. fn test_vm_div32_imm() {
  347. let prog = assemble("
  348. lddw r0, 0x10000000c
  349. div32 r0, 4
  350. exit").unwrap();
  351. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  352. assert_eq!(vm.execute_program().unwrap(), 0x3);
  353. }
  354. #[test]
  355. fn test_vm_div32_reg() {
  356. let prog = assemble("
  357. lddw r0, 0x10000000c
  358. mov r1, 4
  359. div32 r0, r1
  360. exit").unwrap();
  361. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  362. assert_eq!(vm.execute_program().unwrap(), 0x3);
  363. }
  364. #[test]
  365. fn test_vm_div64_imm() {
  366. let prog = assemble("
  367. mov r0, 0xc
  368. lsh r0, 32
  369. div r0, 4
  370. exit").unwrap();
  371. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  372. assert_eq!(vm.execute_program().unwrap(), 0x300000000);
  373. }
  374. #[test]
  375. fn test_vm_div64_reg() {
  376. let prog = assemble("
  377. mov r0, 0xc
  378. lsh r0, 32
  379. mov r1, 4
  380. div r0, r1
  381. exit").unwrap();
  382. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  383. assert_eq!(vm.execute_program().unwrap(), 0x300000000);
  384. }
  385. #[test]
  386. fn test_vm_early_exit() {
  387. let prog = assemble("
  388. mov r0, 3
  389. exit
  390. mov r0, 4
  391. exit").unwrap();
  392. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  393. assert_eq!(vm.execute_program().unwrap(), 0x3);
  394. }
  395. // uBPF limits the number of user functions at 64. We don't.
  396. //#[test]
  397. //fn test_vm_err_call_bad_imm() {
  398. //}
  399. #[test]
  400. #[should_panic(expected = "Error: unknown helper function (id: 0x3f)")]
  401. fn test_vm_err_call_unreg() {
  402. let prog = assemble("
  403. mov r1, 1
  404. mov r2, 2
  405. mov r3, 3
  406. mov r4, 4
  407. mov r5, 5
  408. call 63
  409. exit").unwrap();
  410. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  411. vm.execute_program().unwrap();
  412. }
  413. #[test]
  414. fn test_vm_div64_by_zero_imm() {
  415. let prog = assemble("
  416. mov32 r0, 1
  417. div r0, 0
  418. exit").unwrap();
  419. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  420. assert_eq!(vm.execute_program().unwrap(), 0x0);
  421. }
  422. #[test]
  423. fn test_vm_div_by_zero_imm() {
  424. let prog = assemble("
  425. mov32 r0, 1
  426. div32 r0, 0
  427. exit").unwrap();
  428. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  429. assert_eq!(vm.execute_program().unwrap(), 0x0);
  430. }
  431. #[test]
  432. fn test_vm_mod64_by_zero_imm() {
  433. let prog = assemble("
  434. mov32 r0, 1
  435. mod r0, 0
  436. exit").unwrap();
  437. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  438. assert_eq!(vm.execute_program().unwrap(), 0x1);
  439. }
  440. #[test]
  441. fn test_vm_mod_by_zero_imm() {
  442. let prog = assemble("
  443. mov32 r0, 1
  444. mod32 r0, 0
  445. exit").unwrap();
  446. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  447. assert_eq!(vm.execute_program().unwrap(), 0x1);
  448. }
  449. // Make sure we only consider the last 32 bits of the divisor.
  450. #[test]
  451. fn test_vm_mod_by_zero_reg_long() {
  452. let prog = assemble("
  453. lddw r1, 0x100000000
  454. mod32 r0, r1
  455. exit").unwrap();
  456. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  457. assert_eq!(vm.execute_program().unwrap(), 0x0);
  458. }
  459. #[test]
  460. fn test_vm_div64_by_zero_reg() {
  461. let prog = assemble("
  462. mov32 r0, 1
  463. mov32 r1, 0
  464. div r0, r1
  465. exit").unwrap();
  466. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  467. assert_eq!(vm.execute_program().unwrap(), 0x0);
  468. }
  469. #[test]
  470. fn test_vm_div_by_zero_reg() {
  471. let prog = assemble("
  472. mov32 r0, 1
  473. mov32 r1, 0
  474. div32 r0, r1
  475. exit").unwrap();
  476. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  477. assert_eq!(vm.execute_program().unwrap(), 0x0);
  478. }
  479. // Make sure we only consider the last 32 bits of the divisor.
  480. #[test]
  481. fn test_vm_div_by_zero_reg_long() {
  482. let prog = assemble("
  483. lddw r1, 0x100000000
  484. div32 r0, r1
  485. exit").unwrap();
  486. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  487. assert_eq!(vm.execute_program().unwrap(), 0x0);
  488. }
  489. #[test]
  490. fn test_vm_mod64_by_zero_reg() {
  491. let prog = assemble("
  492. mov32 r0, 1
  493. mov32 r1, 0
  494. mod r0, r1
  495. exit").unwrap();
  496. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  497. assert_eq!(vm.execute_program().unwrap(), 0x1);
  498. }
  499. #[test]
  500. fn test_vm_mod_by_zero_reg() {
  501. let prog = assemble("
  502. mov32 r0, 1
  503. mov32 r1, 0
  504. mod32 r0, r1
  505. exit").unwrap();
  506. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  507. assert_eq!(vm.execute_program().unwrap(), 0x1);
  508. }
  509. #[test]
  510. #[should_panic(expected = "Error: out of bounds memory store (insn #1)")]
  511. fn test_vm_err_stack_out_of_bound() {
  512. let prog = assemble("
  513. stb [r10], 0
  514. exit").unwrap();
  515. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  516. vm.execute_program().unwrap();
  517. }
  518. #[test]
  519. fn test_vm_exit() {
  520. let prog = assemble("
  521. mov r0, 0
  522. exit").unwrap();
  523. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  524. assert_eq!(vm.execute_program().unwrap(), 0x0);
  525. }
  526. #[test]
  527. fn test_vm_ja() {
  528. let prog = assemble("
  529. mov r0, 1
  530. ja +1
  531. mov r0, 2
  532. exit").unwrap();
  533. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  534. assert_eq!(vm.execute_program().unwrap(), 0x1);
  535. }
  536. #[test]
  537. fn test_vm_jeq_imm() {
  538. let prog = assemble("
  539. mov32 r0, 0
  540. mov32 r1, 0xa
  541. jeq r1, 0xb, +4
  542. mov32 r0, 1
  543. mov32 r1, 0xb
  544. jeq r1, 0xb, +1
  545. mov32 r0, 2
  546. exit").unwrap();
  547. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  548. assert_eq!(vm.execute_program().unwrap(), 0x1);
  549. }
  550. #[test]
  551. fn test_vm_jeq_reg() {
  552. let prog = assemble("
  553. mov32 r0, 0
  554. mov32 r1, 0xa
  555. mov32 r2, 0xb
  556. jeq r1, r2, +4
  557. mov32 r0, 1
  558. mov32 r1, 0xb
  559. jeq r1, r2, +1
  560. mov32 r0, 2
  561. exit").unwrap();
  562. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  563. assert_eq!(vm.execute_program().unwrap(), 0x1);
  564. }
  565. #[test]
  566. fn test_vm_jge_imm() {
  567. let prog = assemble("
  568. mov32 r0, 0
  569. mov32 r1, 0xa
  570. jge r1, 0xb, +4
  571. mov32 r0, 1
  572. mov32 r1, 0xc
  573. jge r1, 0xb, +1
  574. mov32 r0, 2
  575. exit").unwrap();
  576. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  577. assert_eq!(vm.execute_program().unwrap(), 0x1);
  578. }
  579. #[test]
  580. fn test_vm_jle_imm() {
  581. let prog = assemble("
  582. mov32 r0, 0
  583. mov32 r1, 5
  584. jle r1, 4, +1
  585. jle r1, 6, +1
  586. exit
  587. jle r1, 5, +1
  588. exit
  589. mov32 r0, 1
  590. exit").unwrap();
  591. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  592. assert_eq!(vm.execute_program().unwrap(), 0x1);
  593. }
  594. #[test]
  595. fn test_vm_jle_reg() {
  596. let prog = assemble("
  597. mov r0, 0
  598. mov r1, 5
  599. mov r2, 4
  600. mov r3, 6
  601. jle r1, r2, +2
  602. jle r1, r1, +1
  603. exit
  604. jle r1, r3, +1
  605. exit
  606. mov r0, 1
  607. exit").unwrap();
  608. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  609. assert_eq!(vm.execute_program().unwrap(), 0x1);
  610. }
  611. #[test]
  612. fn test_vm_jgt_imm() {
  613. let prog = assemble("
  614. mov32 r0, 0
  615. mov32 r1, 5
  616. jgt r1, 6, +2
  617. jgt r1, 5, +1
  618. jgt r1, 4, +1
  619. exit
  620. mov32 r0, 1
  621. exit").unwrap();
  622. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  623. assert_eq!(vm.execute_program().unwrap(), 0x1);
  624. }
  625. #[test]
  626. fn test_vm_jgt_reg() {
  627. let prog = assemble("
  628. mov r0, 0
  629. mov r1, 5
  630. mov r2, 6
  631. mov r3, 4
  632. jgt r1, r2, +2
  633. jgt r1, r1, +1
  634. jgt r1, r3, +1
  635. exit
  636. mov r0, 1
  637. exit").unwrap();
  638. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  639. assert_eq!(vm.execute_program().unwrap(), 0x1);
  640. }
  641. #[test]
  642. fn test_vm_jlt_imm() {
  643. let prog = assemble("
  644. mov32 r0, 0
  645. mov32 r1, 5
  646. jlt r1, 4, +2
  647. jlt r1, 5, +1
  648. jlt r1, 6, +1
  649. exit
  650. mov32 r0, 1
  651. exit").unwrap();
  652. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  653. assert_eq!(vm.execute_program().unwrap(), 0x1);
  654. }
  655. #[test]
  656. fn test_vm_jlt_reg() {
  657. let prog = assemble("
  658. mov r0, 0
  659. mov r1, 5
  660. mov r2, 4
  661. mov r3, 6
  662. jlt r1, r2, +2
  663. jlt r1, r1, +1
  664. jlt r1, r3, +1
  665. exit
  666. mov r0, 1
  667. exit").unwrap();
  668. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  669. assert_eq!(vm.execute_program().unwrap(), 0x1);
  670. }
  671. #[test]
  672. fn test_vm_jit_bounce() {
  673. let prog = assemble("
  674. mov r0, 1
  675. mov r6, r0
  676. mov r7, r6
  677. mov r8, r7
  678. mov r9, r8
  679. mov r0, r9
  680. exit").unwrap();
  681. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  682. assert_eq!(vm.execute_program().unwrap(), 0x1);
  683. }
  684. #[test]
  685. fn test_vm_jne_reg() {
  686. let prog = assemble("
  687. mov32 r0, 0
  688. mov32 r1, 0xb
  689. mov32 r2, 0xb
  690. jne r1, r2, +4
  691. mov32 r0, 1
  692. mov32 r1, 0xa
  693. jne r1, r2, +1
  694. mov32 r0, 2
  695. exit").unwrap();
  696. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  697. assert_eq!(vm.execute_program().unwrap(), 0x1);
  698. }
  699. #[test]
  700. fn test_vm_jset_imm() {
  701. let prog = assemble("
  702. mov32 r0, 0
  703. mov32 r1, 0x7
  704. jset r1, 0x8, +4
  705. mov32 r0, 1
  706. mov32 r1, 0x9
  707. jset r1, 0x8, +1
  708. mov32 r0, 2
  709. exit").unwrap();
  710. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  711. assert_eq!(vm.execute_program().unwrap(), 0x1);
  712. }
  713. #[test]
  714. fn test_vm_jset_reg() {
  715. let prog = assemble("
  716. mov32 r0, 0
  717. mov32 r1, 0x7
  718. mov32 r2, 0x8
  719. jset r1, r2, +4
  720. mov32 r0, 1
  721. mov32 r1, 0x9
  722. jset r1, r2, +1
  723. mov32 r0, 2
  724. exit").unwrap();
  725. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  726. assert_eq!(vm.execute_program().unwrap(), 0x1);
  727. }
  728. #[test]
  729. fn test_vm_jsge_imm() {
  730. let prog = assemble("
  731. mov32 r0, 0
  732. mov r1, -2
  733. jsge r1, -1, +5
  734. jsge r1, 0, +4
  735. mov32 r0, 1
  736. mov r1, -1
  737. jsge r1, -1, +1
  738. mov32 r0, 2
  739. exit").unwrap();
  740. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  741. assert_eq!(vm.execute_program().unwrap(), 0x1);
  742. }
  743. #[test]
  744. fn test_vm_jsge_reg() {
  745. let prog = assemble("
  746. mov32 r0, 0
  747. mov r1, -2
  748. mov r2, -1
  749. mov32 r3, 0
  750. jsge r1, r2, +5
  751. jsge r1, r3, +4
  752. mov32 r0, 1
  753. mov r1, r2
  754. jsge r1, r2, +1
  755. mov32 r0, 2
  756. exit").unwrap();
  757. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  758. assert_eq!(vm.execute_program().unwrap(), 0x1);
  759. }
  760. #[test]
  761. fn test_vm_jsle_imm() {
  762. let prog = assemble("
  763. mov32 r0, 0
  764. mov r1, -2
  765. jsle r1, -3, +1
  766. jsle r1, -1, +1
  767. exit
  768. mov32 r0, 1
  769. jsle r1, -2, +1
  770. mov32 r0, 2
  771. exit").unwrap();
  772. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  773. assert_eq!(vm.execute_program().unwrap(), 0x1);
  774. }
  775. #[test]
  776. fn test_vm_jsle_reg() {
  777. let prog = assemble("
  778. mov32 r0, 0
  779. mov r1, -1
  780. mov r2, -2
  781. mov32 r3, 0
  782. jsle r1, r2, +1
  783. jsle r1, r3, +1
  784. exit
  785. mov32 r0, 1
  786. mov r1, r2
  787. jsle r1, r2, +1
  788. mov32 r0, 2
  789. exit").unwrap();
  790. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  791. assert_eq!(vm.execute_program().unwrap(), 0x1);
  792. }
  793. #[test]
  794. fn test_vm_jsgt_imm() {
  795. let prog = assemble("
  796. mov32 r0, 0
  797. mov r1, -2
  798. jsgt r1, -1, +4
  799. mov32 r0, 1
  800. mov32 r1, 0
  801. jsgt r1, -1, +1
  802. mov32 r0, 2
  803. exit").unwrap();
  804. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  805. assert_eq!(vm.execute_program().unwrap(), 0x1);
  806. }
  807. #[test]
  808. fn test_vm_jsgt_reg() {
  809. let prog = assemble("
  810. mov32 r0, 0
  811. mov r1, -2
  812. mov r2, -1
  813. jsgt r1, r2, +4
  814. mov32 r0, 1
  815. mov32 r1, 0
  816. jsgt r1, r2, +1
  817. mov32 r0, 2
  818. exit").unwrap();
  819. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  820. assert_eq!(vm.execute_program().unwrap(), 0x1);
  821. }
  822. #[test]
  823. fn test_vm_jslt_imm() {
  824. let prog = assemble("
  825. mov32 r0, 0
  826. mov r1, -2
  827. jslt r1, -3, +2
  828. jslt r1, -2, +1
  829. jslt r1, -1, +1
  830. exit
  831. mov32 r0, 1
  832. exit").unwrap();
  833. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  834. assert_eq!(vm.execute_program().unwrap(), 0x1);
  835. }
  836. #[test]
  837. fn test_vm_jslt_reg() {
  838. let prog = assemble("
  839. mov32 r0, 0
  840. mov r1, -2
  841. mov r2, -3
  842. mov r3, -1
  843. jslt r1, r1, +2
  844. jslt r1, r2, +1
  845. jslt r1, r3, +1
  846. exit
  847. mov32 r0, 1
  848. exit").unwrap();
  849. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  850. assert_eq!(vm.execute_program().unwrap(), 0x1);
  851. }
  852. #[test]
  853. fn test_vm_jeq32_imm() {
  854. let prog = assemble("
  855. mov r9, 1
  856. lsh r9, 32
  857. mov32 r0, 0x0
  858. mov32 r1, 0xa
  859. jeq32 r1, 0xb, +5
  860. mov32 r0, 1
  861. mov r1, 0xb
  862. or r1, r9
  863. jeq32 r1, 0xb, +1
  864. mov32 r0, 2
  865. exit").unwrap();
  866. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  867. assert_eq!(vm.execute_program().unwrap(), 0x1);
  868. }
  869. #[test]
  870. fn test_vm_jeq32_reg() {
  871. let prog = assemble("
  872. mov r9, 1
  873. lsh r9, 32
  874. mov32 r0, 0
  875. mov32 r1, 0xa
  876. mov32 r2, 0xb
  877. jeq32 r1, r2, +5
  878. mov32 r0, 1
  879. mov32 r1, 0xb
  880. or r1, r9
  881. jeq32 r1, r2, +1
  882. mov32 r0, 2
  883. exit").unwrap();
  884. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  885. assert_eq!(vm.execute_program().unwrap(), 0x1);
  886. }
  887. #[test]
  888. fn test_vm_jge32_imm() {
  889. let prog = assemble("
  890. mov r9, 1
  891. lsh r9, 32
  892. mov32 r0, 0
  893. mov32 r1, 0xa
  894. jge32 r1, 0xb, +5
  895. mov32 r0, 1
  896. or r1, r9
  897. mov32 r1, 0xc
  898. jge32 r1, 0xb, +1
  899. mov32 r0, 2
  900. exit").unwrap();
  901. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  902. assert_eq!(vm.execute_program().unwrap(), 0x1);
  903. }
  904. #[test]
  905. fn test_vm_jge32_reg() {
  906. let prog = assemble("
  907. mov r9, 1
  908. lsh r9, 32
  909. mov32 r0, 0
  910. mov32 r1, 0xa
  911. mov32 r2, 0xb
  912. jge32 r1, r2, +5
  913. mov32 r0, 1
  914. or r1, r9
  915. mov32 r1, 0xc
  916. jge32 r1, r2, +1
  917. mov32 r0, 2
  918. exit").unwrap();
  919. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  920. assert_eq!(vm.execute_program().unwrap(), 0x1);
  921. }
  922. #[test]
  923. fn test_vm_jgt32_imm() {
  924. let prog = assemble("
  925. mov r9, 1
  926. lsh r9, 32
  927. mov32 r0, 0
  928. mov32 r1, 5
  929. or r1, r9
  930. jgt32 r1, 6, +4
  931. jgt32 r1, 5, +3
  932. jgt32 r1, 4, +1
  933. exit
  934. mov32 r0, 1
  935. exit").unwrap();
  936. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  937. assert_eq!(vm.execute_program().unwrap(), 0x1);
  938. }
  939. #[test]
  940. fn test_vm_jgt32_reg() {
  941. let prog = assemble("
  942. mov r9, 1
  943. lsh r9, 32
  944. mov r0, 0
  945. mov r1, 5
  946. mov32 r1, 5
  947. or r1, r9
  948. mov r2, 6
  949. mov r3, 4
  950. jgt32 r1, r2, +4
  951. jgt32 r1, r1, +3
  952. jgt32 r1, r3, +1
  953. exit
  954. mov r0, 1
  955. exit").unwrap();
  956. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  957. assert_eq!(vm.execute_program().unwrap(), 0x1);
  958. }
  959. #[test]
  960. fn test_vm_jle32_imm() {
  961. let prog = assemble("
  962. mov r9, 1
  963. lsh r9, 32
  964. mov32 r0, 0
  965. mov32 r1, 5
  966. or r1, r9
  967. jle32 r1, 4, +5
  968. jle32 r1, 6, +1
  969. exit
  970. jle32 r1, 5, +1
  971. exit
  972. mov32 r0, 1
  973. exit").unwrap();
  974. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  975. assert_eq!(vm.execute_program().unwrap(), 0x1);
  976. }
  977. #[test]
  978. fn test_vm_jle32_reg() {
  979. let prog = assemble("
  980. mov r9, 1
  981. lsh r9, 32
  982. mov r0, 0
  983. mov r1, 5
  984. mov r2, 4
  985. mov r3, 6
  986. or r1, r9
  987. jle32 r1, r2, +5
  988. jle32 r1, r1, +1
  989. exit
  990. jle32 r1, r3, +1
  991. exit
  992. mov r0, 1
  993. exit").unwrap();
  994. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  995. assert_eq!(vm.execute_program().unwrap(), 0x1);
  996. }
  997. #[test]
  998. fn test_vm_jlt32_imm() {
  999. let prog = assemble("
  1000. mov r9, 1
  1001. lsh r9, 32
  1002. mov32 r0, 0
  1003. mov32 r1, 5
  1004. or r1, r9
  1005. jlt32 r1, 4, +4
  1006. jlt32 r1, 5, +3
  1007. jlt32 r1, 6, +1
  1008. exit
  1009. mov32 r0, 1
  1010. exit").unwrap();
  1011. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1012. assert_eq!(vm.execute_program().unwrap(), 0x1);
  1013. }
  1014. #[test]
  1015. fn test_vm_jlt32_reg() {
  1016. let prog = assemble("
  1017. mov r9, 1
  1018. lsh r9, 32
  1019. mov r0, 0
  1020. mov r1, 5
  1021. mov r2, 4
  1022. mov r3, 6
  1023. or r1, r9
  1024. jlt32 r1, r2, +4
  1025. jlt32 r1, r1, +3
  1026. jlt32 r1, r3, +1
  1027. exit
  1028. mov r0, 1
  1029. exit").unwrap();
  1030. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1031. assert_eq!(vm.execute_program().unwrap(), 0x1);
  1032. }
  1033. #[test]
  1034. fn test_vm_jne32_imm() {
  1035. let prog = assemble("
  1036. mov r9, 1
  1037. lsh r9, 32
  1038. mov32 r0, 0
  1039. mov32 r1, 0xb
  1040. or r1, r9
  1041. jne32 r1, 0xb, +4
  1042. mov32 r0, 1
  1043. mov32 r1, 0xa
  1044. or r1, r9
  1045. jne32 r1, 0xb, +1
  1046. mov32 r0, 2
  1047. exit").unwrap();
  1048. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1049. assert_eq!(vm.execute_program().unwrap(), 0x1);
  1050. }
  1051. #[test]
  1052. fn test_vm_jne32_reg() {
  1053. let prog = assemble("
  1054. mov r9, 1
  1055. lsh r9, 32
  1056. mov32 r0, 0
  1057. mov32 r1, 0xb
  1058. or r1, r9
  1059. mov32 r2, 0xb
  1060. jne32 r1, r2, +4
  1061. mov32 r0, 1
  1062. mov32 r1, 0xa
  1063. or r1, r9
  1064. jne32 r1, r2, +1
  1065. mov32 r0, 2
  1066. exit").unwrap();
  1067. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1068. assert_eq!(vm.execute_program().unwrap(), 0x1);
  1069. }
  1070. #[test]
  1071. fn test_vm_jset32_imm() {
  1072. let prog = assemble("
  1073. mov r9, 1
  1074. lsh r9, 32
  1075. mov32 r0, 0
  1076. mov32 r1, 0x7
  1077. or r1, r9
  1078. jset32 r1, 0x8, +4
  1079. mov32 r0, 1
  1080. mov32 r1, 0x9
  1081. jset32 r1, 0x8, +1
  1082. mov32 r0, 2
  1083. exit").unwrap();
  1084. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1085. assert_eq!(vm.execute_program().unwrap(), 0x1);
  1086. }
  1087. #[test]
  1088. fn test_vm_jset32_reg() {
  1089. let prog = assemble("
  1090. mov r9, 1
  1091. lsh r9, 32
  1092. mov32 r0, 0
  1093. mov32 r1, 0x7
  1094. or r1, r9
  1095. mov32 r2, 0x8
  1096. jset32 r1, r2, +4
  1097. mov32 r0, 1
  1098. mov32 r1, 0x9
  1099. jset32 r1, r2, +1
  1100. mov32 r0, 2
  1101. exit").unwrap();
  1102. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1103. assert_eq!(vm.execute_program().unwrap(), 0x1);
  1104. }
  1105. #[test]
  1106. fn test_vm_jsge32_imm() {
  1107. let prog = assemble("
  1108. mov r9, 1
  1109. lsh r9, 32
  1110. mov32 r0, 0
  1111. mov32 r1, -2
  1112. or r1, r9
  1113. jsge32 r1, -1, +5
  1114. jsge32 r1, 0, +4
  1115. mov32 r0, 1
  1116. mov r1, -1
  1117. jsge32 r1, -1, +1
  1118. mov32 r0, 2
  1119. exit").unwrap();
  1120. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1121. assert_eq!(vm.execute_program().unwrap(), 0x1);
  1122. }
  1123. #[test]
  1124. fn test_vm_jsge32_reg() {
  1125. let prog = assemble("
  1126. mov r9, 1
  1127. lsh r9, 32
  1128. mov32 r0, 0
  1129. mov32 r1, -2
  1130. or r1, r9
  1131. mov r2, -1
  1132. mov32 r3, 0
  1133. jsge32 r1, r2, +5
  1134. jsge32 r1, r3, +4
  1135. mov32 r0, 1
  1136. mov r1, r2
  1137. jsge32 r1, r2, +1
  1138. mov32 r0, 2
  1139. exit").unwrap();
  1140. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1141. assert_eq!(vm.execute_program().unwrap(), 0x1);
  1142. }
  1143. #[test]
  1144. fn test_vm_jsgt32_imm() {
  1145. let prog = assemble("
  1146. mov r9, 1
  1147. lsh r9, 32
  1148. mov32 r0, 0
  1149. mov32 r1, -2
  1150. or r1, r9
  1151. jsgt32 r1, -1, +4
  1152. mov32 r0, 1
  1153. mov32 r1, 0
  1154. jsgt32 r1, -1, +1
  1155. mov32 r0, 2
  1156. exit").unwrap();
  1157. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1158. assert_eq!(vm.execute_program().unwrap(), 0x1);
  1159. }
  1160. #[test]
  1161. fn test_vm_jsgt32_reg() {
  1162. let prog = assemble("
  1163. mov r9, 1
  1164. lsh r9, 32
  1165. mov32 r0, 0
  1166. mov32 r1, -2
  1167. or r1, r9
  1168. mov r2, -1
  1169. jsgt32 r1, r2, +4
  1170. mov32 r0, 1
  1171. mov32 r1, 0
  1172. jsgt32 r1, r2, +1
  1173. mov32 r0, 2
  1174. exit").unwrap();
  1175. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1176. assert_eq!(vm.execute_program().unwrap(), 0x1);
  1177. }
  1178. #[test]
  1179. fn test_vm_jsle32_imm() {
  1180. let prog = assemble("
  1181. mov r9, 1
  1182. lsh r9, 32
  1183. mov32 r0, 0
  1184. mov32 r1, -2
  1185. or r1, r9
  1186. jsle32 r1, -3, +5
  1187. jsle32 r1, -1, +1
  1188. exit
  1189. mov32 r0, 1
  1190. jsle32 r1, -2, +1
  1191. mov32 r0, 2
  1192. exit").unwrap();
  1193. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1194. assert_eq!(vm.execute_program().unwrap(), 0x1);
  1195. }
  1196. #[test]
  1197. fn test_vm_jsle32_reg() {
  1198. let prog = assemble("
  1199. mov r9, 1
  1200. lsh r9, 32
  1201. mov32 r0, 0
  1202. mov32 r1, -2
  1203. or r1, r9
  1204. mov r2, -3
  1205. mov32 r3, 0
  1206. jsle32 r1, r2, +6
  1207. jsle32 r1, r3, +1
  1208. exit
  1209. mov32 r0, 1
  1210. mov r1, r2
  1211. jsle32 r1, r2, +1
  1212. mov32 r0, 2
  1213. exit").unwrap();
  1214. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1215. assert_eq!(vm.execute_program().unwrap(), 0x1);
  1216. }
  1217. #[test]
  1218. fn test_vm_jslt32_imm() {
  1219. let prog = assemble("
  1220. mov r9, 1
  1221. lsh r9, 32
  1222. mov32 r0, 0
  1223. mov32 r1, -2
  1224. or r1, r9
  1225. jslt32 r1, -3, +4
  1226. jslt32 r1, -2, +3
  1227. jslt32 r1, -1, +1
  1228. exit
  1229. mov32 r0, 1
  1230. exit").unwrap();
  1231. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1232. assert_eq!(vm.execute_program().unwrap(), 0x1);
  1233. }
  1234. #[test]
  1235. fn test_vm_jslt32_reg() {
  1236. let prog = assemble("
  1237. mov r9, 1
  1238. lsh r9, 32
  1239. mov32 r0, 0
  1240. mov32 r1, -2
  1241. or r1, r9
  1242. mov r2, -3
  1243. mov r3, -1
  1244. jslt32 r1, r1, +4
  1245. jslt32 r1, r2, +3
  1246. jslt32 r1, r3, +1
  1247. exit
  1248. mov32 r0, 1
  1249. exit").unwrap();
  1250. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1251. assert_eq!(vm.execute_program().unwrap(), 0x1);
  1252. }
  1253. #[test]
  1254. fn test_vm_lddw() {
  1255. let prog = assemble("lddw r0, 0x1122334455667788
  1256. exit").unwrap();
  1257. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1258. assert_eq!(vm.execute_program().unwrap(), 0x1122334455667788);
  1259. }
  1260. #[test]
  1261. fn test_vm_lddw2() {
  1262. let prog = assemble("
  1263. lddw r0, 0x0000000080000000
  1264. exit").unwrap();
  1265. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1266. assert_eq!(vm.execute_program().unwrap(), 0x80000000);
  1267. }
  1268. #[test]
  1269. fn test_vm_ldxb_all() {
  1270. let prog = assemble("
  1271. mov r0, r1
  1272. ldxb r9, [r0+0]
  1273. lsh r9, 0
  1274. ldxb r8, [r0+1]
  1275. lsh r8, 4
  1276. ldxb r7, [r0+2]
  1277. lsh r7, 8
  1278. ldxb r6, [r0+3]
  1279. lsh r6, 12
  1280. ldxb r5, [r0+4]
  1281. lsh r5, 16
  1282. ldxb r4, [r0+5]
  1283. lsh r4, 20
  1284. ldxb r3, [r0+6]
  1285. lsh r3, 24
  1286. ldxb r2, [r0+7]
  1287. lsh r2, 28
  1288. ldxb r1, [r0+8]
  1289. lsh r1, 32
  1290. ldxb r0, [r0+9]
  1291. lsh r0, 36
  1292. or r0, r1
  1293. or r0, r2
  1294. or r0, r3
  1295. or r0, r4
  1296. or r0, r5
  1297. or r0, r6
  1298. or r0, r7
  1299. or r0, r8
  1300. or r0, r9
  1301. exit").unwrap();
  1302. let mem = &mut [
  1303. 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
  1304. 0x08, 0x09
  1305. ];
  1306. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  1307. assert_eq!(vm.execute_program(mem).unwrap(), 0x9876543210);
  1308. }
  1309. #[test]
  1310. fn test_vm_ldxb() {
  1311. let prog = assemble("
  1312. ldxb r0, [r1+2]
  1313. exit").unwrap();
  1314. let mem = &mut [
  1315. 0xaa, 0xbb, 0x11, 0xcc, 0xdd
  1316. ];
  1317. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  1318. assert_eq!(vm.execute_program(mem).unwrap(), 0x11);
  1319. }
  1320. #[test]
  1321. fn test_vm_ldxdw() {
  1322. let prog = assemble("
  1323. ldxdw r0, [r1+2]
  1324. exit").unwrap();
  1325. let mem = &mut [
  1326. 0xaa, 0xbb, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66,
  1327. 0x77, 0x88, 0xcc, 0xdd
  1328. ];
  1329. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  1330. assert_eq!(vm.execute_program(mem).unwrap(), 0x8877665544332211);
  1331. }
  1332. #[test]
  1333. fn test_vm_ldxh_all() {
  1334. let prog = assemble("
  1335. mov r0, r1
  1336. ldxh r9, [r0+0]
  1337. be16 r9
  1338. lsh r9, 0
  1339. ldxh r8, [r0+2]
  1340. be16 r8
  1341. lsh r8, 4
  1342. ldxh r7, [r0+4]
  1343. be16 r7
  1344. lsh r7, 8
  1345. ldxh r6, [r0+6]
  1346. be16 r6
  1347. lsh r6, 12
  1348. ldxh r5, [r0+8]
  1349. be16 r5
  1350. lsh r5, 16
  1351. ldxh r4, [r0+10]
  1352. be16 r4
  1353. lsh r4, 20
  1354. ldxh r3, [r0+12]
  1355. be16 r3
  1356. lsh r3, 24
  1357. ldxh r2, [r0+14]
  1358. be16 r2
  1359. lsh r2, 28
  1360. ldxh r1, [r0+16]
  1361. be16 r1
  1362. lsh r1, 32
  1363. ldxh r0, [r0+18]
  1364. be16 r0
  1365. lsh r0, 36
  1366. or r0, r1
  1367. or r0, r2
  1368. or r0, r3
  1369. or r0, r4
  1370. or r0, r5
  1371. or r0, r6
  1372. or r0, r7
  1373. or r0, r8
  1374. or r0, r9
  1375. exit").unwrap();
  1376. let mem = &mut [
  1377. 0x00, 0x00, 0x00, 0x01, 0x00, 0x02, 0x00, 0x03,
  1378. 0x00, 0x04, 0x00, 0x05, 0x00, 0x06, 0x00, 0x07,
  1379. 0x00, 0x08, 0x00, 0x09
  1380. ];
  1381. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  1382. assert_eq!(vm.execute_program(mem).unwrap(), 0x9876543210);
  1383. }
  1384. #[test]
  1385. fn test_vm_ldxh_all2() {
  1386. let prog = assemble("
  1387. mov r0, r1
  1388. ldxh r9, [r0+0]
  1389. be16 r9
  1390. ldxh r8, [r0+2]
  1391. be16 r8
  1392. ldxh r7, [r0+4]
  1393. be16 r7
  1394. ldxh r6, [r0+6]
  1395. be16 r6
  1396. ldxh r5, [r0+8]
  1397. be16 r5
  1398. ldxh r4, [r0+10]
  1399. be16 r4
  1400. ldxh r3, [r0+12]
  1401. be16 r3
  1402. ldxh r2, [r0+14]
  1403. be16 r2
  1404. ldxh r1, [r0+16]
  1405. be16 r1
  1406. ldxh r0, [r0+18]
  1407. be16 r0
  1408. or r0, r1
  1409. or r0, r2
  1410. or r0, r3
  1411. or r0, r4
  1412. or r0, r5
  1413. or r0, r6
  1414. or r0, r7
  1415. or r0, r8
  1416. or r0, r9
  1417. exit").unwrap();
  1418. let mem = &mut [
  1419. 0x00, 0x01, 0x00, 0x02, 0x00, 0x04, 0x00, 0x08,
  1420. 0x00, 0x10, 0x00, 0x20, 0x00, 0x40, 0x00, 0x80,
  1421. 0x01, 0x00, 0x02, 0x00
  1422. ];
  1423. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  1424. assert_eq!(vm.execute_program(mem).unwrap(), 0x3ff);
  1425. }
  1426. #[test]
  1427. fn test_vm_ldxh() {
  1428. let prog = assemble("
  1429. ldxh r0, [r1+2]
  1430. exit").unwrap();
  1431. let mem = &mut [
  1432. 0xaa, 0xbb, 0x11, 0x22, 0xcc, 0xdd
  1433. ];
  1434. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  1435. assert_eq!(vm.execute_program(mem).unwrap(), 0x2211);
  1436. }
  1437. #[test]
  1438. fn test_vm_ldxh_same_reg() {
  1439. let prog = assemble("
  1440. mov r0, r1
  1441. sth [r0], 0x1234
  1442. ldxh r0, [r0]
  1443. exit").unwrap();
  1444. let mem = &mut [
  1445. 0xff, 0xff
  1446. ];
  1447. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  1448. assert_eq!(vm.execute_program(mem).unwrap(), 0x1234);
  1449. }
  1450. #[test]
  1451. fn test_vm_ldxw_all() {
  1452. let prog = assemble("
  1453. mov r0, r1
  1454. ldxw r9, [r0+0]
  1455. be32 r9
  1456. ldxw r8, [r0+4]
  1457. be32 r8
  1458. ldxw r7, [r0+8]
  1459. be32 r7
  1460. ldxw r6, [r0+12]
  1461. be32 r6
  1462. ldxw r5, [r0+16]
  1463. be32 r5
  1464. ldxw r4, [r0+20]
  1465. be32 r4
  1466. ldxw r3, [r0+24]
  1467. be32 r3
  1468. ldxw r2, [r0+28]
  1469. be32 r2
  1470. ldxw r1, [r0+32]
  1471. be32 r1
  1472. ldxw r0, [r0+36]
  1473. be32 r0
  1474. or r0, r1
  1475. or r0, r2
  1476. or r0, r3
  1477. or r0, r4
  1478. or r0, r5
  1479. or r0, r6
  1480. or r0, r7
  1481. or r0, r8
  1482. or r0, r9
  1483. exit").unwrap();
  1484. let mem = &mut [
  1485. 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x02,
  1486. 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x08,
  1487. 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x02, 0x00,
  1488. 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x08, 0x00,
  1489. 0x00, 0x01, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00
  1490. ];
  1491. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  1492. assert_eq!(vm.execute_program(mem).unwrap(), 0x030f0f);
  1493. }
  1494. #[test]
  1495. fn test_vm_ldxw() {
  1496. let prog = assemble("
  1497. ldxw r0, [r1+2]
  1498. exit").unwrap();
  1499. let mem = &mut [
  1500. 0xaa, 0xbb, 0x11, 0x22, 0x33, 0x44, 0xcc, 0xdd
  1501. ];
  1502. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  1503. assert_eq!(vm.execute_program(mem).unwrap(), 0x44332211);
  1504. }
  1505. #[test]
  1506. fn test_vm_le16() {
  1507. let prog = assemble("
  1508. ldxh r0, [r1]
  1509. le16 r0
  1510. exit").unwrap();
  1511. let mem = &mut [
  1512. 0x22, 0x11
  1513. ];
  1514. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  1515. assert_eq!(vm.execute_program(mem).unwrap(), 0x1122);
  1516. }
  1517. #[test]
  1518. fn test_vm_le32() {
  1519. let prog = assemble("
  1520. ldxw r0, [r1]
  1521. le32 r0
  1522. exit").unwrap();
  1523. let mem = &mut [
  1524. 0x44, 0x33, 0x22, 0x11
  1525. ];
  1526. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  1527. assert_eq!(vm.execute_program(mem).unwrap(), 0x11223344);
  1528. }
  1529. #[test]
  1530. fn test_vm_le64() {
  1531. let prog = assemble("
  1532. ldxdw r0, [r1]
  1533. le64 r0
  1534. exit").unwrap();
  1535. let mem = &mut [
  1536. 0x88, 0x77, 0x66, 0x55, 0x44, 0x33, 0x22, 0x11
  1537. ];
  1538. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  1539. assert_eq!(vm.execute_program(mem).unwrap(), 0x1122334455667788);
  1540. }
  1541. #[test]
  1542. fn test_vm_lsh_imm() {
  1543. let prog = assemble("
  1544. mov r0, 1
  1545. lsh r0, 4
  1546. exit").unwrap();
  1547. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1548. assert_eq!(vm.execute_program().unwrap(), 0x10);
  1549. }
  1550. #[test]
  1551. fn test_vm_lsh_reg() {
  1552. let prog = assemble("
  1553. mov r0, 1
  1554. mov r7, 4
  1555. lsh r0, r7
  1556. exit").unwrap();
  1557. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1558. assert_eq!(vm.execute_program().unwrap(), 0x10);
  1559. }
  1560. #[test]
  1561. fn test_vm_lsh32_imm() {
  1562. let prog = assemble("
  1563. mov32 r0, 1
  1564. lsh32 r0, 4
  1565. exit").unwrap();
  1566. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1567. assert_eq!(vm.execute_program().unwrap(), 0x10);
  1568. }
  1569. #[test]
  1570. fn test_vm_lsh32_reg() {
  1571. let prog = assemble("
  1572. mov32 r0, 1
  1573. mov32 r7, 4
  1574. lsh32 r0, r7
  1575. exit").unwrap();
  1576. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1577. assert_eq!(vm.execute_program().unwrap(), 0x10);
  1578. }
  1579. #[test]
  1580. fn test_vm_lsh_imm_overflow() {
  1581. let prog = assemble("
  1582. mov r0, 1
  1583. lsh r0, 64
  1584. exit").unwrap();
  1585. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1586. assert_eq!(vm.execute_program().unwrap(), 0x1);
  1587. }
  1588. #[test]
  1589. fn test_vm_lsh_reg_overflow() {
  1590. let prog = assemble("
  1591. mov r0, 1
  1592. mov r7, 64
  1593. lsh r0, r7
  1594. exit").unwrap();
  1595. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1596. assert_eq!(vm.execute_program().unwrap(), 0x1);
  1597. }
  1598. #[test]
  1599. fn test_vm_lsh32_imm_overflow() {
  1600. let prog = assemble("
  1601. mov32 r0, 1
  1602. lsh32 r0, 32
  1603. exit").unwrap();
  1604. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1605. assert_eq!(vm.execute_program().unwrap(), 0x1);
  1606. }
  1607. #[test]
  1608. fn test_vm_lsh32_reg_overflow() {
  1609. let prog = assemble("
  1610. mov32 r0, 1
  1611. mov32 r7, 32
  1612. lsh32 r0, r7
  1613. exit").unwrap();
  1614. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1615. assert_eq!(vm.execute_program().unwrap(), 0x1);
  1616. }
  1617. #[test]
  1618. fn test_vm_mod() {
  1619. let prog = assemble("
  1620. mov32 r0, 5748
  1621. mod32 r0, 92
  1622. mov32 r1, 13
  1623. mod32 r0, r1
  1624. exit").unwrap();
  1625. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1626. assert_eq!(vm.execute_program().unwrap(), 0x5);
  1627. }
  1628. #[test]
  1629. fn test_vm_mod32() {
  1630. let prog = assemble("
  1631. lddw r0, 0x100000003
  1632. mod32 r0, 3
  1633. exit").unwrap();
  1634. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1635. assert_eq!(vm.execute_program().unwrap(), 0x0);
  1636. }
  1637. #[test]
  1638. fn test_vm_mod64() {
  1639. let prog = assemble("
  1640. mov32 r0, -1316649930
  1641. lsh r0, 32
  1642. or r0, 0x100dc5c8
  1643. mov32 r1, 0xdde263e
  1644. lsh r1, 32
  1645. or r1, 0x3cbef7f3
  1646. mod r0, r1
  1647. mod r0, 0x658f1778
  1648. exit").unwrap();
  1649. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1650. assert_eq!(vm.execute_program().unwrap(), 0x30ba5a04);
  1651. }
  1652. #[test]
  1653. fn test_vm_mov() {
  1654. let prog = assemble("
  1655. mov32 r1, 1
  1656. mov32 r0, r1
  1657. exit").unwrap();
  1658. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1659. assert_eq!(vm.execute_program().unwrap(), 0x1);
  1660. }
  1661. #[test]
  1662. fn test_vm_mul32_imm() {
  1663. let prog = assemble("
  1664. mov r0, 3
  1665. mul32 r0, 4
  1666. exit").unwrap();
  1667. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1668. assert_eq!(vm.execute_program().unwrap(), 0xc);
  1669. }
  1670. #[test]
  1671. fn test_vm_mul32_reg() {
  1672. let prog = assemble("
  1673. mov r0, 3
  1674. mov r1, 4
  1675. mul32 r0, r1
  1676. exit").unwrap();
  1677. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1678. assert_eq!(vm.execute_program().unwrap(), 0xc);
  1679. }
  1680. #[test]
  1681. fn test_vm_mul32_reg_overflow() {
  1682. let prog = assemble("
  1683. mov r0, 0x40000001
  1684. mov r1, 4
  1685. mul32 r0, r1
  1686. exit").unwrap();
  1687. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1688. assert_eq!(vm.execute_program().unwrap(), 0x4);
  1689. }
  1690. #[test]
  1691. fn test_vm_mul64_imm() {
  1692. let prog = assemble("
  1693. mov r0, 0x40000001
  1694. mul r0, 4
  1695. exit").unwrap();
  1696. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1697. assert_eq!(vm.execute_program().unwrap(), 0x100000004);
  1698. }
  1699. #[test]
  1700. fn test_vm_mul64_reg() {
  1701. let prog = assemble("
  1702. mov r0, 0x40000001
  1703. mov r1, 4
  1704. mul r0, r1
  1705. exit").unwrap();
  1706. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1707. assert_eq!(vm.execute_program().unwrap(), 0x100000004);
  1708. }
  1709. #[test]
  1710. fn test_vm_mul_loop() {
  1711. let prog = assemble("
  1712. mov r0, 0x7
  1713. add r1, 0xa
  1714. lsh r1, 0x20
  1715. rsh r1, 0x20
  1716. jeq r1, 0x0, +4
  1717. mov r0, 0x7
  1718. mul r0, 0x7
  1719. add r1, -1
  1720. jne r1, 0x0, -3
  1721. exit").unwrap();
  1722. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1723. assert_eq!(vm.execute_program().unwrap(), 0x75db9c97);
  1724. }
  1725. #[test]
  1726. fn test_vm_neg64() {
  1727. let prog = assemble("
  1728. mov32 r0, 2
  1729. neg r0
  1730. exit").unwrap();
  1731. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1732. assert_eq!(vm.execute_program().unwrap(), 0xfffffffffffffffe);
  1733. }
  1734. #[test]
  1735. fn test_vm_neg() {
  1736. let prog = assemble("
  1737. mov32 r0, 2
  1738. neg32 r0
  1739. exit").unwrap();
  1740. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1741. assert_eq!(vm.execute_program().unwrap(), 0xfffffffe);
  1742. }
  1743. #[test]
  1744. fn test_vm_prime() {
  1745. let prog = assemble("
  1746. mov r1, 67
  1747. mov r0, 0x1
  1748. mov r2, 0x2
  1749. jgt r1, 0x2, +4
  1750. ja +10
  1751. add r2, 0x1
  1752. mov r0, 0x1
  1753. jge r2, r1, +7
  1754. mov r3, r1
  1755. div r3, r2
  1756. mul r3, r2
  1757. mov r4, r1
  1758. sub r4, r3
  1759. mov r0, 0x0
  1760. jne r4, 0x0, -10
  1761. exit").unwrap();
  1762. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1763. assert_eq!(vm.execute_program().unwrap(), 0x1);
  1764. }
  1765. #[test]
  1766. fn test_vm_rhs32() {
  1767. let prog = assemble("
  1768. xor r0, r0
  1769. sub r0, 1
  1770. rsh32 r0, 8
  1771. exit").unwrap();
  1772. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1773. assert_eq!(vm.execute_program().unwrap(), 0x00ffffff);
  1774. }
  1775. #[test]
  1776. fn test_vm_rsh_reg() {
  1777. let prog = assemble("
  1778. mov r0, 0x10
  1779. mov r7, 4
  1780. rsh r0, r7
  1781. exit").unwrap();
  1782. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1783. assert_eq!(vm.execute_program().unwrap(), 0x1);
  1784. }
  1785. #[test]
  1786. fn test_vm_stack() {
  1787. let prog = assemble("
  1788. mov r1, 51
  1789. stdw [r10-16], 0xab
  1790. stdw [r10-8], 0xcd
  1791. and r1, 1
  1792. lsh r1, 3
  1793. mov r2, r10
  1794. add r2, r1
  1795. ldxdw r0, [r2-16]
  1796. exit").unwrap();
  1797. let vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1798. assert_eq!(vm.execute_program().unwrap(), 0xcd);
  1799. }
  1800. #[test]
  1801. fn test_vm_stack2() {
  1802. let prog = assemble("
  1803. stb [r10-4], 0x01
  1804. stb [r10-3], 0x02
  1805. stb [r10-2], 0x03
  1806. stb [r10-1], 0x04
  1807. mov r1, r10
  1808. mov r2, 0x4
  1809. sub r1, r2
  1810. call 1
  1811. mov r1, 0
  1812. ldxb r2, [r10-4]
  1813. ldxb r3, [r10-3]
  1814. ldxb r4, [r10-2]
  1815. ldxb r5, [r10-1]
  1816. call 0
  1817. xor r0, 0x2a2a2a2a
  1818. exit").unwrap();
  1819. let mut vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1820. vm.register_helper(0, helpers::gather_bytes).unwrap();
  1821. vm.register_helper(1, helpers::memfrob).unwrap();
  1822. assert_eq!(vm.execute_program().unwrap(), 0x01020304);
  1823. }
  1824. #[test]
  1825. fn test_vm_stb() {
  1826. let prog = assemble("
  1827. stb [r1+2], 0x11
  1828. ldxb r0, [r1+2]
  1829. exit").unwrap();
  1830. let mem = &mut [
  1831. 0xaa, 0xbb, 0xff, 0xcc, 0xdd
  1832. ];
  1833. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  1834. assert_eq!(vm.execute_program(mem).unwrap(), 0x11);
  1835. }
  1836. #[test]
  1837. fn test_vm_stdw() {
  1838. let prog = assemble("
  1839. stdw [r1+2], 0x44332211
  1840. ldxdw r0, [r1+2]
  1841. exit").unwrap();
  1842. let mem = &mut [
  1843. 0xaa, 0xbb, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
  1844. 0xff, 0xff, 0xcc, 0xdd
  1845. ];
  1846. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  1847. assert_eq!(vm.execute_program(mem).unwrap(), 0x44332211);
  1848. }
  1849. // If this case is not handled properly in check_mem(), then we may overflow when adding the
  1850. // context address and the offset, and make the thread panic with "attempt to add with overflow".
  1851. // Check that we panic with the expected out-of-bounds error.
  1852. #[test]
  1853. #[should_panic(expected = "Error: out of bounds memory store (insn #1)")]
  1854. fn test_vm_stdw_add_overflow() {
  1855. let prog = assemble("
  1856. stdw [r2-0x1], 0x44332211
  1857. ldxw r0, [r1+2]
  1858. exit").unwrap();
  1859. let mem = &mut [
  1860. 0xaa, 0xbb, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
  1861. 0xff, 0xff, 0xcc, 0xdd
  1862. ];
  1863. let mut vm = rbpf::EbpfVmFixedMbuff::new(Some(&prog), 0x00, 0x10).unwrap();
  1864. _ = vm.execute_program(mem).unwrap();
  1865. }
  1866. #[test]
  1867. fn test_vm_sth() {
  1868. let prog = assemble("
  1869. sth [r1+2], 0x2211
  1870. ldxh r0, [r1+2]
  1871. exit").unwrap();
  1872. let mem = &mut [
  1873. 0xaa, 0xbb, 0xff, 0xff, 0xcc, 0xdd
  1874. ];
  1875. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  1876. assert_eq!(vm.execute_program(mem).unwrap(), 0x2211);
  1877. }
  1878. #[test]
  1879. fn test_vm_string_stack() {
  1880. let prog = assemble("
  1881. mov r1, 0x78636261
  1882. stxw [r10-8], r1
  1883. mov r6, 0x0
  1884. stxb [r10-4], r6
  1885. stxb [r10-12], r6
  1886. mov r1, 0x79636261
  1887. stxw [r10-16], r1
  1888. mov r1, r10
  1889. add r1, -8
  1890. mov r2, r1
  1891. call 0x4
  1892. mov r1, r0
  1893. mov r0, 0x1
  1894. lsh r1, 0x20
  1895. rsh r1, 0x20
  1896. jne r1, 0x0, +11
  1897. mov r1, r10
  1898. add r1, -8
  1899. mov r2, r10
  1900. add r2, -16
  1901. call 0x4
  1902. mov r1, r0
  1903. lsh r1, 0x20
  1904. rsh r1, 0x20
  1905. mov r0, 0x1
  1906. jeq r1, r6, +1
  1907. mov r0, 0x0
  1908. exit").unwrap();
  1909. let mut vm = rbpf::EbpfVmNoData::new(Some(&prog)).unwrap();
  1910. vm.register_helper(4, helpers::strcmp).unwrap();
  1911. assert_eq!(vm.execute_program().unwrap(), 0x0);
  1912. }
  1913. #[test]
  1914. fn test_vm_stw() {
  1915. let prog = assemble("
  1916. stw [r1+2], 0x44332211
  1917. ldxw r0, [r1+2]
  1918. exit").unwrap();
  1919. let mem = &mut [
  1920. 0xaa, 0xbb, 0xff, 0xff, 0xff, 0xff, 0xcc, 0xdd
  1921. ];
  1922. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  1923. assert_eq!(vm.execute_program(mem).unwrap(), 0x44332211);
  1924. }
  1925. #[test]
  1926. fn test_vm_stxb() {
  1927. let prog = assemble("
  1928. mov32 r2, 0x11
  1929. stxb [r1+2], r2
  1930. ldxb r0, [r1+2]
  1931. exit").unwrap();
  1932. let mem = &mut [
  1933. 0xaa, 0xbb, 0xff, 0xcc, 0xdd
  1934. ];
  1935. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  1936. assert_eq!(vm.execute_program(mem).unwrap(), 0x11);
  1937. }
  1938. #[test]
  1939. fn test_vm_stxb_all() {
  1940. let prog = assemble("
  1941. mov r0, 0xf0
  1942. mov r2, 0xf2
  1943. mov r3, 0xf3
  1944. mov r4, 0xf4
  1945. mov r5, 0xf5
  1946. mov r6, 0xf6
  1947. mov r7, 0xf7
  1948. mov r8, 0xf8
  1949. stxb [r1], r0
  1950. stxb [r1+1], r2
  1951. stxb [r1+2], r3
  1952. stxb [r1+3], r4
  1953. stxb [r1+4], r5
  1954. stxb [r1+5], r6
  1955. stxb [r1+6], r7
  1956. stxb [r1+7], r8
  1957. ldxdw r0, [r1]
  1958. be64 r0
  1959. exit").unwrap();
  1960. let mem = &mut [
  1961. 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff
  1962. ];
  1963. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  1964. assert_eq!(vm.execute_program(mem).unwrap(), 0xf0f2f3f4f5f6f7f8);
  1965. }
  1966. #[test]
  1967. fn test_vm_stxb_all2() {
  1968. let prog = assemble("
  1969. mov r0, r1
  1970. mov r1, 0xf1
  1971. mov r9, 0xf9
  1972. stxb [r0], r1
  1973. stxb [r0+1], r9
  1974. ldxh r0, [r0]
  1975. be16 r0
  1976. exit").unwrap();
  1977. let mem = &mut [
  1978. 0xff, 0xff
  1979. ];
  1980. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  1981. assert_eq!(vm.execute_program(mem).unwrap(), 0xf1f9);
  1982. }
  1983. #[test]
  1984. fn test_vm_stxb_chain() {
  1985. let prog = assemble("
  1986. mov r0, r1
  1987. ldxb r9, [r0+0]
  1988. stxb [r0+1], r9
  1989. ldxb r8, [r0+1]
  1990. stxb [r0+2], r8
  1991. ldxb r7, [r0+2]
  1992. stxb [r0+3], r7
  1993. ldxb r6, [r0+3]
  1994. stxb [r0+4], r6
  1995. ldxb r5, [r0+4]
  1996. stxb [r0+5], r5
  1997. ldxb r4, [r0+5]
  1998. stxb [r0+6], r4
  1999. ldxb r3, [r0+6]
  2000. stxb [r0+7], r3
  2001. ldxb r2, [r0+7]
  2002. stxb [r0+8], r2
  2003. ldxb r1, [r0+8]
  2004. stxb [r0+9], r1
  2005. ldxb r0, [r0+9]
  2006. exit").unwrap();
  2007. let mem = &mut [
  2008. 0x2a, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  2009. 0x00, 0x00
  2010. ];
  2011. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  2012. assert_eq!(vm.execute_program(mem).unwrap(), 0x2a);
  2013. }
  2014. #[test]
  2015. fn test_vm_stxdw() {
  2016. let prog = assemble("
  2017. mov r2, -2005440939
  2018. lsh r2, 32
  2019. or r2, 0x44332211
  2020. stxdw [r1+2], r2
  2021. ldxdw r0, [r1+2]
  2022. exit").unwrap();
  2023. let mem = &mut [
  2024. 0xaa, 0xbb, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
  2025. 0xff, 0xff, 0xcc, 0xdd
  2026. ];
  2027. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  2028. assert_eq!(vm.execute_program(mem).unwrap(), 0x8877665544332211);
  2029. }
  2030. #[test]
  2031. fn test_vm_stxh() {
  2032. let prog = assemble("
  2033. mov32 r2, 0x2211
  2034. stxh [r1+2], r2
  2035. ldxh r0, [r1+2]
  2036. exit").unwrap();
  2037. let mem = &mut [
  2038. 0xaa, 0xbb, 0xff, 0xff, 0xcc, 0xdd
  2039. ];
  2040. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  2041. assert_eq!(vm.execute_program(mem).unwrap(), 0x2211);
  2042. }
  2043. #[test]
  2044. fn test_vm_stxw() {
  2045. let prog = assemble("
  2046. mov32 r2, 0x44332211
  2047. stxw [r1+2], r2
  2048. ldxw r0, [r1+2]
  2049. exit").unwrap();
  2050. let mem = &mut [
  2051. 0xaa, 0xbb, 0xff, 0xff, 0xff, 0xff, 0xcc, 0xdd
  2052. ];
  2053. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  2054. assert_eq!(vm.execute_program(mem).unwrap(), 0x44332211);
  2055. }
  2056. #[test]
  2057. fn test_vm_subnet() {
  2058. let prog = assemble("
  2059. mov r2, 0xe
  2060. ldxh r3, [r1+12]
  2061. jne r3, 0x81, +2
  2062. mov r2, 0x12
  2063. ldxh r3, [r1+16]
  2064. and r3, 0xffff
  2065. jne r3, 0x8, +5
  2066. add r1, r2
  2067. mov r0, 0x1
  2068. ldxw r1, [r1+16]
  2069. and r1, 0xffffff
  2070. jeq r1, 0x1a8c0, +1
  2071. mov r0, 0x0
  2072. exit").unwrap();
  2073. let mem = &mut [
  2074. 0x00, 0x00, 0xc0, 0x9f, 0xa0, 0x97, 0x00, 0xa0,
  2075. 0xcc, 0x3b, 0xbf, 0xfa, 0x08, 0x00, 0x45, 0x10,
  2076. 0x00, 0x3c, 0x46, 0x3c, 0x40, 0x00, 0x40, 0x06,
  2077. 0x73, 0x1c, 0xc0, 0xa8, 0x01, 0x02, 0xc0, 0xa8,
  2078. 0x01, 0x01, 0x06, 0x0e, 0x00, 0x17, 0x99, 0xc5,
  2079. 0xa0, 0xec, 0x00, 0x00, 0x00, 0x00, 0xa0, 0x02,
  2080. 0x7d, 0x78, 0xe0, 0xa3, 0x00, 0x00, 0x02, 0x04,
  2081. 0x05, 0xb4, 0x04, 0x02, 0x08, 0x0a, 0x00, 0x9c,
  2082. 0x27, 0x24, 0x00, 0x00, 0x00, 0x00, 0x01, 0x03,
  2083. 0x03, 0x00
  2084. ];
  2085. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  2086. assert_eq!(vm.execute_program(mem).unwrap(), 0x1);
  2087. }
  2088. const PROG_TCP_PORT_80: [u8;152] = [
  2089. 0x71, 0x12, 0x0c, 0x00, 0x00, 0x00, 0x00, 0x00,
  2090. 0x71, 0x13, 0x0d, 0x00, 0x00, 0x00, 0x00, 0x00,
  2091. 0x67, 0x03, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00,
  2092. 0x4f, 0x23, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  2093. 0xb7, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  2094. 0x55, 0x03, 0x0c, 0x00, 0x08, 0x00, 0x00, 0x00,
  2095. 0x71, 0x12, 0x17, 0x00, 0x00, 0x00, 0x00, 0x00,
  2096. 0x55, 0x02, 0x0a, 0x00, 0x06, 0x00, 0x00, 0x00,
  2097. 0x71, 0x12, 0x0e, 0x00, 0x00, 0x00, 0x00, 0x00,
  2098. 0x07, 0x01, 0x00, 0x00, 0x0e, 0x00, 0x00, 0x00,
  2099. 0x57, 0x02, 0x00, 0x00, 0x0f, 0x00, 0x00, 0x00,
  2100. 0x67, 0x02, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00,
  2101. 0x0f, 0x21, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  2102. 0x69, 0x12, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00,
  2103. 0x15, 0x02, 0x02, 0x00, 0x00, 0x50, 0x00, 0x00,
  2104. 0x69, 0x11, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  2105. 0x55, 0x01, 0x01, 0x00, 0x00, 0x50, 0x00, 0x00,
  2106. 0xb7, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00,
  2107. 0x95, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
  2108. ];
  2109. #[test]
  2110. fn test_vm_tcp_port80_match() {
  2111. let mem = &mut [
  2112. 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x00, 0x06,
  2113. 0x07, 0x08, 0x09, 0x0a, 0x08, 0x00, 0x45, 0x00,
  2114. 0x00, 0x56, 0x00, 0x01, 0x00, 0x00, 0x40, 0x06,
  2115. 0xf9, 0x4d, 0xc0, 0xa8, 0x00, 0x01, 0xc0, 0xa8,
  2116. 0x00, 0x02, 0x27, 0x10, 0x00, 0x50, 0x00, 0x00,
  2117. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x50, 0x02,
  2118. 0x20, 0x00, 0xc5, 0x18, 0x00, 0x00, 0x44, 0x44,
  2119. 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44,
  2120. 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44,
  2121. 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44,
  2122. 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44,
  2123. 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44,
  2124. 0x44, 0x44, 0x44, 0x44
  2125. ];
  2126. let prog = &PROG_TCP_PORT_80;
  2127. let vm = rbpf::EbpfVmRaw::new(Some(prog)).unwrap();
  2128. assert_eq!(vm.execute_program(mem).unwrap(), 0x1);
  2129. }
  2130. #[test]
  2131. fn test_vm_tcp_port80_nomatch() {
  2132. let mem = &mut [
  2133. 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x00, 0x06,
  2134. 0x07, 0x08, 0x09, 0x0a, 0x08, 0x00, 0x45, 0x00,
  2135. 0x00, 0x56, 0x00, 0x01, 0x00, 0x00, 0x40, 0x06,
  2136. 0xf9, 0x4d, 0xc0, 0xa8, 0x00, 0x01, 0xc0, 0xa8,
  2137. 0x00, 0x02, 0x00, 0x16, 0x27, 0x10, 0x00, 0x00,
  2138. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x51, 0x02,
  2139. 0x20, 0x00, 0xc5, 0x18, 0x00, 0x00, 0x44, 0x44,
  2140. 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44,
  2141. 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44,
  2142. 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44,
  2143. 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44,
  2144. 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44,
  2145. 0x44, 0x44, 0x44, 0x44
  2146. ];
  2147. let prog = &PROG_TCP_PORT_80;
  2148. let vm = rbpf::EbpfVmRaw::new(Some(prog)).unwrap();
  2149. assert_eq!(vm.execute_program(mem).unwrap(), 0x0);
  2150. }
  2151. #[test]
  2152. fn test_vm_tcp_port80_nomatch_ethertype() {
  2153. let mem = &mut [
  2154. 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x00, 0x06,
  2155. 0x07, 0x08, 0x09, 0x0a, 0x08, 0x01, 0x45, 0x00,
  2156. 0x00, 0x56, 0x00, 0x01, 0x00, 0x00, 0x40, 0x06,
  2157. 0xf9, 0x4d, 0xc0, 0xa8, 0x00, 0x01, 0xc0, 0xa8,
  2158. 0x00, 0x02, 0x27, 0x10, 0x00, 0x50, 0x00, 0x00,
  2159. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x50, 0x02,
  2160. 0x20, 0x00, 0xc5, 0x18, 0x00, 0x00, 0x44, 0x44,
  2161. 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44,
  2162. 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44,
  2163. 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44,
  2164. 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44,
  2165. 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44,
  2166. 0x44, 0x44, 0x44, 0x44
  2167. ];
  2168. let prog = &PROG_TCP_PORT_80;
  2169. let vm = rbpf::EbpfVmRaw::new(Some(prog)).unwrap();
  2170. assert_eq!(vm.execute_program(mem).unwrap(), 0x0);
  2171. }
  2172. #[test]
  2173. fn test_vm_tcp_port80_nomatch_proto() {
  2174. let mem = &mut [
  2175. 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x00, 0x06,
  2176. 0x07, 0x08, 0x09, 0x0a, 0x08, 0x00, 0x45, 0x00,
  2177. 0x00, 0x56, 0x00, 0x01, 0x00, 0x00, 0x40, 0x11,
  2178. 0xf9, 0x4d, 0xc0, 0xa8, 0x00, 0x01, 0xc0, 0xa8,
  2179. 0x00, 0x02, 0x27, 0x10, 0x00, 0x50, 0x00, 0x00,
  2180. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x50, 0x02,
  2181. 0x20, 0x00, 0xc5, 0x18, 0x00, 0x00, 0x44, 0x44,
  2182. 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44,
  2183. 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44,
  2184. 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44,
  2185. 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44,
  2186. 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44, 0x44,
  2187. 0x44, 0x44, 0x44, 0x44
  2188. ];
  2189. let prog = &PROG_TCP_PORT_80;
  2190. let vm = rbpf::EbpfVmRaw::new(Some(prog)).unwrap();
  2191. assert_eq!(vm.execute_program(mem).unwrap(), 0x0);
  2192. }
  2193. #[test]
  2194. fn test_vm_tcp_sack_match() {
  2195. let mut mem = TCP_SACK_MATCH.to_vec();
  2196. let prog = assemble(TCP_SACK_ASM).unwrap();
  2197. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  2198. assert_eq!(vm.execute_program(mem.as_mut_slice()).unwrap(), 0x1);
  2199. }
  2200. #[test]
  2201. fn test_vm_tcp_sack_nomatch() {
  2202. let mut mem = TCP_SACK_NOMATCH.to_vec();
  2203. let prog = assemble(TCP_SACK_ASM).unwrap();
  2204. let vm = rbpf::EbpfVmRaw::new(Some(&prog)).unwrap();
  2205. assert_eq!(vm.execute_program(mem.as_mut_slice()).unwrap(), 0x0);
  2206. }