blob: c692ad70920b72f25efbf71a44b84b44d7055eb4 [file] [log] [blame]
*** Variables ***
${LINUX_UART} sysbus.uart1
${UBOOT_UART} sysbus.uart1
${ZEPHYR_UART} sysbus.uart0
${LINUX_PROMPT} \#${SPACE}
${ZEPHYR_PROMPT} uart:~$
${UBOOT_PROMPT} ZynqMP r5>
${I2C_ECHO_ADDRESS} 0x10
${URL_BASE} https://dl.antmicro.com/projects/renode
${ZEPHYR_BASIC_SYS_HEAP} @${URL_BASE}/zephyr-basic_sys_heap-xilinx_zynqmp_r5.elf-s_438388-8991d33506751fe196ee3eb488144583ba0ccbd7
${ZEPHYR_COMPRESSION_LZ4} @${URL_BASE}/zephyr-compression_lz4-xilinx_zynqmp_r5.elf-s_862900-fbcf30b0880cabd5e807d9b166edb30af6292724
${ZEPHYR_CPP_SYNCHRONIZATION} @${URL_BASE}/zephyr-cpp_cpp_synchronization-xilinx_zynqmp_r5.elf-s_493632-f7cd8210dde1935690ba706dd4d56f51c369be37
${ZEPHYR_HELLO_WORLD} @${URL_BASE}/zephyr-hello_world-xilinx_zynqmp_r5.elf-s_388044-7673bd83fa331e9cab9281a0c000d9774479d4c4
${ZEPHYR_KERNEL_CONDITION_VARIABLES_CONDVAR} @${URL_BASE}/zephyr-kernel_condition_variables_condvar-xilinx_zynqmp_r5.elf-s_495360-20c5dc4d6c886c51fde9ce2d4057966762d410c9
${ZEPHYR_KERNEL_CONDITION_VARIABLES_SIMPLE} @${URL_BASE}/zephyr-kernel_condition_variables_simple-xilinx_zynqmp_r5.elf-s_493588-ff54eafc5f0aca434358a5c715058ad77166346b
${ZEPHYR_KERNEL_METAIRQ_DISPATCH} @${URL_BASE}/zephyr-kernel_metairq_dispatch-xilinx_zynqmp_r5.elf-s_551952-d4792b65f1cb6e172cd4d653d4b373abd1366b92
${ZEPHYR_PHILOSOPHERS} @${URL_BASE}/zephyr-philosophers-xilinx_zynqmp_r5.elf-s_515508-f1bcfa0adcf29714365ae53609420644614298c9
${ZEPHYR_SYNCHRONIZATION} @${URL_BASE}/zephyr-synchronization-xilinx_zynqmp_r5.elf-s_409936-c67fa8fb36a0318e82a45e57f0c8436c6af4740d
${ZEPHYR_SHELL} @${URL_BASE}/zephyr-subsys_shell_shell_module-xilinx_zynqmp_r5.elf-s_1310204-e0e970d25e7c5d471c1d2d308e3f30944c414490
${ZEPHYR_USERSPACE_HELLO_WORLD_NO_MPU} @${URL_BASE}/zephyr-userspace_hello_world_user-xilinx_zynqmp_r5-no_mpu.elf-s_411848-1b3bc43849411db05745b5226bb64350ece53500
${ZEPHYR_TESTS_KERNEL_FPU_SHARING} @${URL_BASE}/zephyr-kernel_fpu_sharing_generic-xilinx_zynqmp_r5.elf-s_515064-6f0345a25b12e1e8e5c130266ddd2568e3e7138f
${ZEPHYR_USERSPACE_HELLO_WORLD} @${URL_BASE}/zephyr-userspace_hello_world_user-xilinx_zynqmp_r5.elf-s_1032888-0009042615539a30dbe799896b96501d0f90ae84
${ZEPHYR_MPU_TEST} @${URL_BASE}/zephyr-arch_mpu_mpu_test-xilinx_zynqmp_r5.elf-s_1149568-ae2c8f6e5e8219564e4640c47cfef5e33fcf2ea4
${ZEPHYR_USERSPACE_PROD_CONSUMER} @${URL_BASE}/zephyr-userspace_prod_consumer-xilinx_zynqmp_r5.elf-s_1343804-9f7520160bb347a15f01e1a25bd94c87007335af
${ZEPHYR_USERSPACE_SHARED_MEM} @${URL_BASE}/zephyr-userspace_shared_mem-xilinx_zynqmp_r5.elf-s_1081056-a43ec0a1353e21c55908bbed997d6a52b8d031fb
${UBOOT} @${URL_BASE}/xilinx_zynqmp_r5--u-boot.elf-s_2227172-4d77b9622e19b3dcf205efffde87321422b5294c
*** Keywords ***
Create Linux Machine
Execute Command include @scripts/single-node/zynqmp_linux.resc
Execute Command machine SetSerialExecution True
${linux_tester}= Create Terminal Tester ${LINUX_UART} defaultPauseEmulation=true
Create Linux Remoteproc Machine
Execute Command include @scripts/single-node/zynqmp_remoteproc.resc
Execute Command machine SetSerialExecution True
${linux_tester}= Create Terminal Tester ${LINUX_UART} defaultPauseEmulation=true
${zephyr_tester}= Create Terminal Tester ${ZEPHYR_UART} defaultPauseEmulation=true
RETURN ${linux_tester} ${zephyr_tester}
Create Zephyr Machine
[Arguments] ${elf} ${uart}=${ZEPHYR_UART}
Execute Command set bin ${elf}
Execute Command include @scripts/single-node/zynqmp_zephyr.resc
Execute Command machine SetSerialExecution True
${zephyr_tester}= Create Terminal Tester ${uart} defaultPauseEmulation=true
Boot U-Boot And Launch Linux
Wait For Line On Uart U-Boot 2023.01
Wait For Line On Uart Starting kernel ...
Boot Linux And Login
[Arguments] ${testerId}=0
# Verify that SMP works
Wait For Line On Uart SMP: Total of 4 processors activated testerId=${testerId} includeUnfinishedLine=true
Wait For Prompt On Uart buildroot login: testerId=${testerId} timeout=50
Write Line To Uart root testerId=${testerId}
Wait For Prompt On Uart ${LINUX_PROMPT} testerId=${testerId}
Check Exit Code
[Arguments] ${testerId}=0
Write Line To Uart echo $? testerId=${testerId}
Wait For Line On Uart 0 testerId=${testerId}
Wait For Prompt On Uart ${LINUX_PROMPT} testerId=${testerId}
Execute Linux Command
[Arguments] ${command} ${testerId}=0 ${timeout}=5
Write Line To Uart ${command} testerId=${testerId}
Wait For Prompt On Uart ${LINUX_PROMPT} testerId=${testerId} timeout=${timeout}
Check Exit Code testerId=${testerId}
Should Pass Zephyr Test Suite
[Arguments] ${testerId}=0
Wait For Line On Uart SUITE PASS - 100.00% testerId=${testerId} timeout=40
*** Test Cases ***
Should Boot And Login
Create Linux Machine
Boot U-Boot And Launch Linux
Boot Linux And Login
# Check if we see the other CPUs
Write Line To Uart nproc
Wait For Line On Uart 4
Should Detect I2C Peripherals
Create Linux Machine
Execute Command machine LoadPlatformDescriptionFromString "i2cEcho: Mocks.EchoI2CDevice @ i2c1 ${I2C_ECHO_ADDRESS}"
Boot U-Boot And Launch Linux
Boot Linux And Login
# Suppress messages from the kernel space
Execute Linux Command echo 0 > /proc/sys/kernel/printk
Write Line To Uart i2cdetect -yar 1
Wait For Line On Uart 10: 10 --
Wait For Prompt On Uart ${LINUX_PROMPT}
Check Exit Code
Should Communicate With I2C Echo Peripheral
Create Linux Machine
Execute Command machine LoadPlatformDescriptionFromString "i2cEcho: Mocks.EchoI2CDevice @ i2c1 ${I2C_ECHO_ADDRESS}"
Boot U-Boot And Launch Linux
Boot Linux And Login
# Suppress messages from the kernel space
Execute Linux Command echo 0 > /proc/sys/kernel/printk
Write Line To Uart i2ctransfer -ya 1 w3@${I2C_ECHO_ADDRESS} 0x01 0x23 0x45 r2
Wait For Line On Uart 0x01 0x23
Wait For Prompt On Uart ${LINUX_PROMPT}
Check Exit Code
Should Display Output on GPIO
Create Linux Machine
Execute Command machine LoadPlatformDescriptionFromString "gpio: { 7 -> heartbeat@0 }; heartbeat: Miscellaneous.LED @ gpio 7"
Create LED Tester sysbus.gpio.heartbeat defaultTimeout=2
Boot U-Boot And Launch Linux
Boot Linux And Login
# Suppress messages from the kernel space
Execute Linux Command echo 0 > /proc/sys/kernel/printk
Write Line To Uart echo none > /sys/class/leds/heartbeat/trigger
Write Line To Uart echo 1 > /sys/class/leds/heartbeat/brightness
Assert LED State true
Write Line To Uart echo 0 > /sys/class/leds/heartbeat/brightness
Assert LED State false
Should Boot Zephyr
Create Zephyr Machine ${ZEPHYR_HELLO_WORLD}
Wait For Line On Uart *** Booting Zephyr OS build${SPACE*2}***
Should Print Hello World
Create Zephyr Machine ${ZEPHYR_HELLO_WORLD}
Wait For Line On Uart Hello World! qemu_cortex_r5
Should Decompress Lorem Ipsum
Create Zephyr Machine ${ZEPHYR_COMPRESSION_LZ4}
Wait For Line On Uart Original Data size: 1160
Wait For Line On Uart Compressed Data size : 895
Wait For Line On Uart Successfully decompressed some data
Wait For Line On Uart Validation done. The string we ended up with is:
Wait For Line On Uart Lorem ipsum dolor sit amet, consectetur adipiscing elit. Quisque sodales lorem lorem, sed congue enim vehicula a. Sed finibus diam sed odio ultrices pharetra. Nullam dictum arcu ultricies turpis congue,vel venenatis turpis venenatis. Nam tempus arcu eros, ac congue libero tristique congue. Proin velit lectus, euismod sit amet quam in, maximus condimentum urna. Cras vel erat luctus, mattis orci ut, varius urna. Nam eu lobortis velit.
Wait For Line On Uart Nullam sit amet diam vel odio sodales cursus vehicula eu arcu. Proin fringilla, enim nec consectetur mollis, lorem orci interdum nisi, vitae suscipit nisi mauris eu mi. Proin diam enim, mollis ac rhoncus vitae, placerat et eros. Suspendisse convallis, ipsum nec rhoncus aliquam, ex augue ultrices nisl, id aliquet mi diam quis ante. Pellentesque venenatis ornare ultrices. Quisque et porttitor lectus. Ut venenatis nunc et urna imperdiet porttitor non laoreet massa.Donec eleifend eros in mi sagittis egestas. Sed et mi nunc. Nunc vulputate,mauris non ullamcorper viverra, lorem nulla vulputate diam, et congue dui velit non erat. Duis interdum leo et ipsum tempor consequat. In faucibus enim quis purus vulputate nullam.
Should Run System Heap Sample
Create Zephyr Machine ${ZEPHYR_BASIC_SYS_HEAP}
Wait For Line On Uart System heap sample
Wait For Line On Uart allocated 0, free 196, max allocated 0, heap size 256
Wait For Line On Uart allocated 156, free 36, max allocated 156, heap size 256
Wait For Line On Uart allocated 100, free 92, max allocated 156, heap size 256
Wait For Line On Uart allocated 0, free 196, max allocated 156, heap size 256
Should Complete MetaIRQ Test
Create Zephyr Machine ${ZEPHYR_KERNEL_METAIRQ_DISPATCH}
Wait For Line On Uart I: Starting Thread0 at priority -2
Wait For Line On Uart I: Starting Thread1 at priority -1
Wait For Line On Uart I: Starting Thread2 at priority 0
Wait For Line On Uart I: Starting Thread3 at priority 1
Wait For Line On Uart I: M0 T[0-3] mirq \\d+ disp \\d+ proc \\d+ real \\d+ treatAsRegex=true
Wait For Line On Uart I: M7 T[0-3] mirq \\d+ disp \\d+ proc \\d+ real \\d+ treatAsRegex=true
Wait For Line On Uart I: M15 T[0-3] mirq \\d+ disp \\d+ proc \\d+ real \\d+ treatAsRegex=true
Wait For Line On Uart I:${SPACE*9}---------- Latency (cyc) ----------
Wait For Line On Uart I:${SPACE*13}Best${SPACE*4}Worst${SPACE*5}Mean${SPACE*4}Stdev
Wait For Line On Uart I: MetaIRQ +\\d+ +\\d+ +\\d+ +\\d+ treatAsRegex=true
Wait For Line On Uart I: Thread0 +\\d+ +\\d+ +\\d+ +\\d+ treatAsRegex=true
Wait For Line On Uart I: Thread1 +\\d+ +\\d+ +\\d+ +\\d+ treatAsRegex=true
Wait For Line On Uart I: Thread2 +\\d+ +\\d+ +\\d+ +\\d+ treatAsRegex=true
Wait For Line On Uart I: Thread3 +\\d+ +\\d+ +\\d+ +\\d+ treatAsRegex=true
Wait For Line On Uart I: MetaIRQ Test Complete
Should Interleave Main And Cooperative Thread
Create Zephyr Machine ${ZEPHYR_CPP_SYNCHRONIZATION}
Wait For Line On Uart Create semaphore 0x[a-f0-9]+ treatAsRegex=true
Wait For Line On Uart Create semaphore 0x[a-f0-9]+ treatAsRegex=true
Wait For Line On Uart main: Hello World!
Wait For Line On Uart coop_thread_entry: Hello World!
Wait For Line On Uart main: Hello World!
Wait For Line On Uart coop_thread_entry: Hello World!
Wait For Line On Uart main: Hello World!
Wait For Line On Uart coop_thread_entry: Hello World!
Wait For Line On Uart main: Hello World!
Wait For Line On Uart coop_thread_entry: Hello World!
Wait For Line On Uart main: Hello World!
Wait For Line On Uart coop_thread_entry: Hello World!
Should Interleave Concurrent Threads
Create Zephyr Machine ${ZEPHYR_SYNCHRONIZATION}
Wait For Line On Uart thread_a: Hello World from cpu 0 on qemu_cortex_r5!
Wait For Line On Uart thread_b: Hello World from cpu 0 on qemu_cortex_r5!
Wait For Line On Uart thread_a: Hello World from cpu 0 on qemu_cortex_r5!
Wait For Line On Uart thread_b: Hello World from cpu 0 on qemu_cortex_r5!
Wait For Line On Uart thread_a: Hello World from cpu 0 on qemu_cortex_r5!
Wait For Line On Uart thread_b: Hello World from cpu 0 on qemu_cortex_r5!
Wait For Line On Uart thread_a: Hello World from cpu 0 on qemu_cortex_r5!
Wait For Line On Uart thread_b: Hello World from cpu 0 on qemu_cortex_r5!
Wait For Line On Uart thread_a: Hello World from cpu 0 on qemu_cortex_r5!
Wait For Line On Uart thread_b: Hello World from cpu 0 on qemu_cortex_r5!
Should Run Kernel Condition Variables Condvar Sample
Create Zephyr Machine ${ZEPHYR_KERNEL_CONDITION_VARIABLES_CONDVAR}
Wait For Line On Uart Starting watch_count: thread 1
Wait For Line On Uart watch_count: thread 1 Count= 0. Going into wait...
Wait For Line On Uart inc_count: thread 2, count = 1, unlocking mutex
Wait For Line On Uart inc_count: thread 3, count = 2, unlocking mutex
Wait For Line On Uart inc_count: thread 2, count = 3, unlocking mutex
Wait For Line On Uart inc_count: thread 3, count = 4, unlocking mutex
Wait For Line On Uart inc_count: thread 2, count = 5, unlocking mutex
Wait For Line On Uart inc_count: thread 3, count = 6, unlocking mutex
Wait For Line On Uart inc_count: thread 2, count = 7, unlocking mutex
Wait For Line On Uart inc_count: thread 3, count = 8, unlocking mutex
Wait For Line On Uart inc_count: thread 2, count = 9, unlocking mutex
Wait For Line On Uart inc_count: thread 3, count = 10, unlocking mutex
Wait For Line On Uart inc_count: thread 2, count = 11, unlocking mutex
Wait For Line On Uart inc_count: thread 3, count = 12${SPACE*2}Threshold reached.Just sent signal.
Wait For Line On Uart inc_count: thread 3, count = 12, unlocking mutex
Wait For Line On Uart watch_count: thread 1 Condition signal received. Count= 12
Wait For Line On Uart watch_count: thread 1 Updating the value of count...
Wait For Line On Uart watch_count: thread 1 count now = 137.
Wait For Line On Uart watch_count: thread 1 Unlocking mutex.
Wait For Line On Uart inc_count: thread 2, count = 138, unlocking mutex
Wait For Line On Uart inc_count: thread 3, count = 139, unlocking mutex
Wait For Line On Uart inc_count: thread 2, count = 140, unlocking mutex
Wait For Line On Uart inc_count: thread 3, count = 141, unlocking mutex
Wait For Line On Uart inc_count: thread 2, count = 142, unlocking mutex
Wait For Line On Uart inc_count: thread 3, count = 143, unlocking mutex
Wait For Line On Uart inc_count: thread 2, count = 144, unlocking mutex
Wait For Line On Uart inc_count: thread 3, count = 145, unlocking mutex
Wait For Line On Uart Main(): Waited and joined with 3 threads. Final value of count = 145. Done.
Should Run Kernel Condition Variables Simple Sample
Create Zephyr Machine ${ZEPHYR_KERNEL_CONDITION_VARIABLES_SIMPLE}
FOR ${i} IN RANGE 0 1
FOR ${t} IN RANGE 0 19
Wait For Line On Uart [thread ${t}] working (${i}/5)
END
END
Wait For Line On Uart [thread main] done is 0 which is < 20 so waiting on cond
FOR ${i} IN RANGE 2 4
FOR ${t} IN RANGE 0 19
Wait For Line On Uart [thread ${t}] working (${i}/5)
END
END
FOR ${t} IN RANGE 0 18
Wait For Line On Uart [thread ${t}] done is now ${t + 1}. Signalling cond.
Wait For Line On Uart [thread main] wake - cond was signalled.
Wait For Line On Uart [thread main] done is ${t + 1} which is < 20 so waiting on cond
END
Wait For Line On Uart [thread 19] done is now 20. Signalling cond.
Wait For Line On Uart [thread main] wake - cond was signalled.
Wait For Line On Uart [thread main] done == 20 so everyone is done
Should Run Philosophers Sample
Create Zephyr Machine ${ZEPHYR_PHILOSOPHERS}
FOR ${p} IN RANGE 0 5
Wait For Line On Uart Philosopher ${p} \\[[PC]:[ -]\\d\\] ${SPACE*7}STARVING${SPACE*7} treatAsRegex=true
Wait For Line On Uart Philosopher ${p} \\[[PC]:[ -]\\d\\] ${SPACE*3}HOLDING ONE FORK${SPACE*3} treatAsRegex=true
Wait For Line On Uart Philosopher ${p} \\[[PC]:[ -]\\d\\] ${SPACE*2}EATING${SPACE*2}\\[ ${SPACE}?\\d{1,3} ms \\]${SPACE} treatAsRegex=true
Wait For Line On Uart Philosopher ${p} \\[[PC]:[ -]\\d\\] ${SPACE*3}DROPPED ONE FORK${SPACE*3} treatAsRegex=true
Wait For Line On Uart Philosopher ${p} \\[[PC]:[ -]\\d\\] ${SPACE}THINKING \\[ ${SPACE}?\\d{1,3} ms \\]${SPACE} treatAsRegex=true
END
Should Interact Via Shell
Create Zephyr Machine ${ZEPHYR_SHELL}
Wait For Prompt On Uart ${ZEPHYR_PROMPT}
Write Line To Uart version
Wait For Line On Uart Zephyr version \\d+.\\d+.\\d+ treatAsRegex=true
Wait For Prompt On Uart ${ZEPHYR_PROMPT}
Write Line To Uart device list
Wait For Line On Uart devices:
Wait For Line On Uart - uart@ff000000 (READY)
Wait For Prompt On Uart ${ZEPHYR_PROMPT}
Write Line To Uart demo ping
Wait For Line On Uart pong
Wait For Prompt On Uart ${ZEPHYR_PROMPT}
Write Line To Uart history
Wait For Line On Uart [${SPACE*2}0] history
Wait For Line On Uart [${SPACE*2}1] demo ping
Wait For Line On Uart [${SPACE*2}2] device list
Wait For Line On Uart [${SPACE*2}3] version
Wait For Prompt On Uart ${ZEPHYR_PROMPT}
Write Line To Uart log_test start demo
FOR ${i} IN RANGE 0 7
Wait For Line On Uart <inf> app: Timer expired. treatAsRegex=true
Wait For Line On Uart <inf> app_test: info message treatAsRegex=true
Wait For Line On Uart <wrn> app_test: warning message treatAsRegex=true
Wait For Line On Uart <err> app_test: err message treatAsRegex=true
END
Write Line To Uart log_test stop
Wait For Prompt On Uart ${ZEPHYR_PROMPT}
Write Line To Uart date get
Wait For Line On Uart 1970-01-01 \\d{2}:\\d{2}:\\d{2} UTC treatAsRegex=true
Write Line To Uart date set 2023-12-31 12:00:59
Write Line To Uart date get
Wait For Line On Uart 2023-12-31 12:\\d{2}:\\d{2} UTC treatAsRegex=true
Should Fail To Enter Userspace Without MPU
Create Zephyr Machine ${ZEPHYR_USERSPACE_HELLO_WORLD_NO_MPU}
Wait For Line On Uart Hello World from privileged mode. (qemu_cortex_r5)
Wait For Line On Uart ASSERTION FAIL [k_is_user_context()]
Wait For Line On Uart User mode execution was expected
Wait For Line On Uart E: >>> ZEPHYR FATAL ERROR 4: Kernel panic on CPU 0
Wait For Line On Uart E: Halting system
Should Print Hello World From Userspace
Create Zephyr Machine ${ZEPHYR_USERSPACE_HELLO_WORLD}
Wait For Line On Uart Hello World from UserSpace! (qemu_cortex_r5)
Should Pass Zephyr FPU Sharing Test
Create Zephyr Machine ${ZEPHYR_TESTS_KERNEL_FPU_SHARING}
Should Pass Zephyr Test Suite
Should Rise Permission Fault On MPU Test Read
Create Zephyr Machine ${ZEPHYR_MPU_TEST}
Wait For Prompt On Uart ${ZEPHYR_PROMPT}
Write Line To Uart mpu write
Wait For Line On Uart write address: 0xc0004000
Wait For Line On Uart <err> os: ***** DATA ABORT *****
Wait For Line On Uart <err> os: Permission Fault @ 0xc0004000
Wait For Line On Uart <err> os: r0/a1:${SPACE*2}0x00000000${SPACE*2}r1/a2:${SPACE*2}0x0000000e${SPACE*2}r2/a3:${SPACE*2}0x00010538
Wait For Line On Uart <err> os: r3/a4:${SPACE*2}0x0badc0de r12/ip:${SPACE*2}0x[a-f0-9]+ r14/lr:${SPACE*2}0x00000f8f treatAsRegex=true
Wait For Line On Uart <err> os:${SPACE*2}xpsr:${SPACE*2}0x6000013f
Wait For Line On Uart <err> os: fpscr:${SPACE*2}0x00000000
Wait For Line On Uart <err> os: Faulting instruction address (r15/pc): 0x00000f90
Wait For Line On Uart <err> os: >>> ZEPHYR FATAL ERROR 48: Unknown error on CPU 0
Wait For Line On Uart <err> os: Current thread: 0x10538 (shell_uart)
Wait For Line On Uart <err> os: Halting system
Should Rise Background Fault On MPU Test Write
Create Zephyr Machine ${ZEPHYR_MPU_TEST}
Wait For Prompt On Uart ${ZEPHYR_PROMPT}
Write Line To Uart mpu read
Wait For Line On Uart <err> os: ***** DATA ABORT *****
Wait For Line On Uart <err> os: Background Fault @ 0x04000000
Wait For Line On Uart <err> os: r0/a1:${SPACE*2}0x0000a3bc${SPACE*2}r1/a2:${SPACE*2}0x00000008${SPACE*2}r2/a3:${SPACE*2}0x0000ace5
Wait For Line On Uart <err> os: r3/a4:${SPACE*2}0x04000000 r12/ip:${SPACE*2}0x[a-f0-9]+ r14/lr:${SPACE*2}0x0000371b treatAsRegex=true
Wait For Line On Uart <err> os:${SPACE*2}xpsr:${SPACE*2}0x2000013f
Wait For Line On Uart <err> os: fpscr:${SPACE*2}0x00000000
Wait For Line On Uart <err> os: Faulting instruction address (r15/pc): 0x00000fae
Wait For Line On Uart <err> os: >>> ZEPHYR FATAL ERROR 47: Unknown error on CPU 0
Wait For Line On Uart <err> os: Current thread: 0x10538 (shell_uart)
Wait For Line On Uart <err> os: Halting system
Should Successfully Run Producer Consumer Sample In Userspace
Create Zephyr Machine ${ZEPHYR_USERSPACE_PROD_CONSUMER}
Wait For Line On Uart I: SUCCESS
Should Pass Messages Between Threads
Create Zephyr Machine ${ZEPHYR_USERSPACE_SHARED_MEM}
Wait For Line On Uart ENC Thread Created 0x104e0
Wait For Line On Uart Partitions added to enc_domain
Wait For Line On Uart enc_domain Created
Wait For Line On Uart PT Thread Created 0x103e0
Wait For Line On Uart pt_domain Created
Wait For Line On Uart CT Thread Created 0x102e0
Wait For Line On Uart ct partitions installed
Wait For Line On Uart blk partitions installed
Wait For Line On Uart ENC thread started
Wait For Line On Uart PT thread started
FOR ${i} IN RANGE 0 3
Wait For Line On Uart PT Sending Message 1
Wait For Line On Uart ENC Thread Received Data
Wait For Line On Uart ENC PT MSG: PT: message to encrypt
Wait For Line On Uart CT Thread Received Message
Wait For Line On Uart CT MSG: ofttbhfspgmeqzos
Wait For Line On Uart PT Sending Message 1'
Wait For Line On Uart ENC Thread Received Data
Wait For Line On Uart ENC PT MSG: ofttbhfspgmeqzos
Wait For Line On Uart CT Thread Received Message
Wait For Line On Uart CT MSG: messagetoencrypt
END
Provides userspace_shared_mem-zephyr Reexecution
Should Pass Messages Between Threads From Serialized State
Requires userspace_shared_mem-zephyr
Clear Terminal Tester Report
Wait For Line On Uart PT Sending Message 1
Wait For Line On Uart ENC Thread Received Data
Wait For Line On Uart ENC PT MSG: PT: message to encrypt
Wait For Line On Uart CT Thread Received Message
Wait For Line On Uart CT MSG: ofttbhfspgmeqzos
Wait For Line On Uart PT Sending Message 1'
Wait For Line On Uart ENC Thread Received Data
Wait For Line On Uart ENC PT MSG: ofttbhfspgmeqzos
Wait For Line On Uart CT Thread Received Message
Wait For Line On Uart CT MSG: messagetoencrypt
Should Provide Booted U-Boot And Run Version Command
Create Zephyr Machine ${UBOOT} ${UBOOT_UART}
Wait For Prompt On Uart ${UBOOT_PROMPT}
Provides booted-uboot Reexecution
Write Line To Uart version
Wait For Line On Uart U-Boot
Wait For Prompt On Uart ${UBOOT_PROMPT}
Should Run Version Command On Provided U-Boot
Requires booted-uboot
Write Line To Uart version
Wait For Line On Uart U-Boot
Wait For Prompt On Uart ${UBOOT_PROMPT}
Should Start And Stop Remoteproc
${linux_tester} ${zephyr_tester}= Create Linux Remoteproc Machine
Boot Linux And Login testerId=${linux_tester}
# Load remoteproc kernel module and start demo
Execute Linux Command modprobe zynqmp_r5_remoteproc testerId=${linux_tester}
Execute Linux Command mkdir /lib/firmware testerId=${linux_tester}
Execute Linux Command cp /elfs/philosophers.elf /lib/firmware testerId=${linux_tester}
Execute Linux Command echo philosophers.elf > /sys/class/remoteproc/remoteproc0/firmware testerId=${linux_tester}
Execute Linux Command echo start > /sys/class/remoteproc/remoteproc0/state testerId=${linux_tester}
# Check if demo works correctly
FOR ${p} IN RANGE 0 5
Wait For Line On Uart Philosopher ${p} \\[[PC]:[ -]\\d\\] ${SPACE*7}STARVING${SPACE*7} testerId=${zephyr_tester} treatAsRegex=true
Wait For Line On Uart Philosopher ${p} \\[[PC]:[ -]\\d\\] ${SPACE*3}HOLDING ONE FORK${SPACE*3} testerId=${zephyr_tester} treatAsRegex=true
Wait For Line On Uart Philosopher ${p} \\[[PC]:[ -]\\d\\] ${SPACE*2}EATING${SPACE*2}\\[ ${SPACE}?\\d{1,3} ms \\]${SPACE} testerId=${zephyr_tester} treatAsRegex=true
Wait For Line On Uart Philosopher ${p} \\[[PC]:[ -]\\d\\] ${SPACE*3}DROPPED ONE FORK${SPACE*3} testerId=${zephyr_tester} treatAsRegex=true
Wait For Line On Uart Philosopher ${p} \\[[PC]:[ -]\\d\\] ${SPACE}THINKING \\[ ${SPACE}?\\d{1,3} ms \\]${SPACE} testerId=${zephyr_tester} treatAsRegex=true
END
# Stop demo
Execute Linux Command echo stop > /sys/class/remoteproc/remoteproc0/state testerId=${linux_tester}
${is_halted}= Execute Command rpu0 IsHalted
Should Contain ${is_halted} True