1This document contains some hints to test the function of the VCHIQ driver 2without having additional hardware to the Raspberry Pi. 3 4* Requirements & limitations 5 6Testing the VCHIQ driver requires a Raspberry Pi with one of the following SoC: 7 - BCM2835 ( e.g. Raspberry Pi Zero W ) 8 - BCM2836 ( e.g. Raspberry Pi 2 ) 9 - BCM2837 ( e.g. Raspberry Pi 3 B+ ) 10 11The BCM2711 used in the Raspberry Pi 4 is currently not supported in the 12mainline kernel. 13 14There are no specific requirements to the VideoCore firmware to get VCHIQ 15working. 16 17The test scenarios described in this document based on the tool vchiq_test. 18Its source code is available here: https://github.com/raspberrypi/userland 19 20* Configuration 21 22Here are the most common kernel configurations: 23 24 1. BCM2835 target SoC (ARM 32 bit) 25 26 Just use bcm2835_defconfig which already has VCHIQ enabled. 27 28 2. BCM2836/7 target SoC (ARM 32 bit) 29 30 Use the multi_v7_defconfig as a base and then enable all VCHIQ options. 31 32 3. BCM2837 target SoC (ARM 64 bit) 33 34 Use the defconfig which has most of the VCHIQ options enabled. 35 36* Scenarios 37 38 * Initial test 39 40 Check the driver is probed and /dev/vchiq is created 41 42 * Functional test 43 44 Command: vchiq_test -f 10 45 46 Expected output: 47 Functional test - iters:10 48 ======== iteration 1 ======== 49 Testing bulk transfer for alignment. 50 Testing bulk transfer at PAGE_SIZE. 51 ... 52 53 * Ping test 54 55 Command: vchiq_test -p 1 56 57 Expected output: 58 Ping test - service:echo, iters:1, version 3 59 vchi ping (size 0) -> 57.000000us 60 vchi ping (size 0, 0 async, 0 oneway) -> 122.000000us 61 vchi bulk (size 0, 0 async, 0 oneway) -> 546.000000us 62 vchi bulk (size 0, 0 oneway) -> 230.000000us 63 vchi ping (size 0) -> 49.000000us 64 vchi ping (size 0, 0 async, 0 oneway) -> 70.000000us 65 vchi bulk (size 0, 0 async, 0 oneway) -> 296.000000us 66 vchi bulk (size 0, 0 oneway) -> 266.000000us 67 vchi ping (size 0, 1 async, 0 oneway) -> 65.000000us 68 vchi bulk (size 0, 0 oneway) -> 456.000000us 69 vchi ping (size 0, 2 async, 0 oneway) -> 74.000000us 70 vchi bulk (size 0, 0 oneway) -> 640.000000us 71 vchi ping (size 0, 10 async, 0 oneway) -> 125.000000us 72 vchi bulk (size 0, 0 oneway) -> 2309.000000us 73 vchi ping (size 0, 0 async, 1 oneway) -> 70.000000us 74 vchi ping (size 0, 0 async, 2 oneway) -> 76.000000us 75 vchi ping (size 0, 0 async, 10 oneway) -> 105.000000us 76 vchi ping (size 0, 10 async, 10 oneway) -> 165.000000us 77 vchi ping (size 0, 100 async, 0 oneway) -> nanus 78 vchi bulk (size 0, 0 oneway) -> nanus 79 vchi ping (size 0, 0 async, 100 oneway) -> nanus 80 vchi ping (size 0, 100 async, 100 oneway) -> infus 81 vchi ping (size 0, 200 async, 0 oneway) -> infus 82 ... 83 84 * Debugfs test 85 86 Command: cat /sys/kernel/debug/vchiq/state 87 88 Example output: 89 State 0: CONNECTED 90 tx_pos=0x1e8(@43b0acda), rx_pos=0x170(@05493af8) 91 Version: 8 (min 3) 92 Stats: ctrl_tx_count=7, ctrl_rx_count=7, error_count=0 93 Slots: 30 available (29 data), 0 recyclable, 0 stalls (0 data) 94 Platform: 2835 (VC master) 95 Local: slots 34-64 tx_pos=0x1e8 recycle=0x1f 96 Slots claimed: 97 DEBUG: SLOT_HANDLER_COUNT = 20(0x14) 98 DEBUG: SLOT_HANDLER_LINE = 1937(0x791) 99 DEBUG: PARSE_LINE = 1864(0x748) 100 DEBUG: PARSE_HEADER = -249155224(0xf1263168) 101 DEBUG: PARSE_MSGID = 67362817(0x403e001) 102 DEBUG: AWAIT_COMPLETION_LINE = 0(0x0) 103 DEBUG: DEQUEUE_MESSAGE_LINE = 0(0x0) 104 DEBUG: SERVICE_CALLBACK_LINE = 0(0x0) 105 DEBUG: MSG_QUEUE_FULL_COUNT = 0(0x0) 106 DEBUG: COMPLETION_QUEUE_FULL_COUNT = 0(0x0) 107 Remote: slots 2-32 tx_pos=0x170 recycle=0x1f 108 Slots claimed: 109 2: 10/9 110 DEBUG: SLOT_HANDLER_COUNT = 20(0x14) 111 DEBUG: SLOT_HANDLER_LINE = 1851(0x73b) 112 DEBUG: PARSE_LINE = 1827(0x723) 113 DEBUG: PARSE_HEADER = -150330912(0xf70a21e0) 114 DEBUG: PARSE_MSGID = 67113022(0x400103e) 115 DEBUG: AWAIT_COMPLETION_LINE = 0(0x0) 116 DEBUG: DEQUEUE_MESSAGE_LINE = 0(0x0) 117 DEBUG: SERVICE_CALLBACK_LINE = 0(0x0) 118 DEBUG: MSG_QUEUE_FULL_COUNT = 0(0x0) 119 DEBUG: COMPLETION_QUEUE_FULL_COUNT = 0(0x0) 120 Service 0: LISTENING (ref 1) 'PEEK little-endian (0x4b454550)' remote n/a (msg use 0/3840, slot use 0/15) 121 Bulk: tx_pending=0 (size 0), rx_pending=0 (size 0) 122 Ctrl: tx_count=0, tx_bytes=0, rx_count=0, rx_bytes=0 123 Bulk: tx_count=0, tx_bytes=0, rx_count=0, rx_bytes=0 124 0 quota stalls, 0 slot stalls, 0 bulk stalls, 0 aborted, 0 errors 125 instance b511f60b 126