1.. zephyr:code-sample:: smp_pktqueue 2 :name: SMP pktqueue 3 4 Use SMP to process multiple packet headers in parallel. 5 6Overview 7******** 8 9This sample application performs a simplified network layer forwarding function 10(essentially checksum calculation from IP Header Validation) of the Internet protocol 11suite specified in RFC1812 "Requirements for IP Version 4 Routers" which 12can be found at http://www.faqs.org/rfcs/rfc1812.html. This application 13provides an indication of the potential performance of a microprocessor in an 14IP router system. 15 16At the beginning of the application the array (size defined in SIZE_OF_QUEUE) 17of packet headers is initialized. Each header contains some random data of size 18defined in SIZE_OF_HEADER and calculated crc16 header checksum 19in appropriate field defined by CRC_BYTE_1 and CRC_BYTE_2. The contents of 20header follows: 21 22 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 23 | 0 - 3 | 4 - 7 | 8 - 15 | 16 - 31 | 24 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 25 |Version| IHL |Type of Service| Total Length | 26 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 27 | Identification |Flags| Fragment Offset | 28 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 29 | Time to Live | Protocol | Header Checksum | 30 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 31 | Source Address | 32 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 33 | Destination Address | 34 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 35 | Options | Padding | 36 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 37 38The headers then are stored in multiple "sender" queues (the number is defined 39in QUEUE_NUM). After that for each pair of "sender"/"receiver" queues one thread 40is created, which will control "sender" queue processing. 41 42Then in each queue-related thread several(defined in THREADS_NUM) threads are created. Each 43of them first pick the header from "sender" queue, calculates crc and if 44crc is correct put the header to "receiver" queue. Only one thread in a 45time can access to sender or receiver queue. 46 47As soon as all headers in each pair of queues are moved from "sender" to 48"receiver" queue the execution of threads(related to pair) are terminated. 49 50By changing the value of CONFIG_MP_MAX_NUM_CPUS on SMP systems, you 51can see that using more cores takes almost linearly less time 52to complete the computational task. 53 54You can also edit the sample source code to change the 55number of parallel executed pairs of queues(``QUEUE_NUM``), 56the number of threads per pair of queues(``THREADS_NUM``), 57the number of headers in queue (``SIZE_OF_QUEUE``), and 58size of header in bytes (``SIZE_OF_HEADER``). 59 60Building and Running 61******************** 62 63This project outputs total time required for processing all packet headers. 64It can be built and executed on QEMU as follows: 65 66.. zephyr-app-commands:: 67 :zephyr-app: samples/arch/smp/pktqueue 68 :host-os: unix 69 :board: qemu_x86_64 70 :goals: run 71 :compact: 72 73Sample Output 74============= 75 76.. code-block:: console 77 78 Simulating IP header validation on multiple cores. 79 Each of 2 parallel queues is processed by 3 threads on 2 cores and contain 5000 packet headers. 80 Bytes in packet header: 24 81 82 RESULT: OK 83 Application ran successfully. 84 All 20000 packet headers were processed in 89 msec 85