add examples

This commit is contained in:
2021-10-24 13:19:14 +02:00
parent 9e966c8e05
commit de2cfbde73
10 changed files with 738 additions and 0 deletions

View File

@@ -0,0 +1,81 @@
/* SPDX-License-Identifier: BSD-3-Clause
* Copyright(c) 2010-2014 Intel Corporation
*/
#include <errno.h>
#include <rte_debug.h>
#include <rte_eal.h>
#include <rte_launch.h>
#include <rte_lcore.h>
#include <rte_memory.h>
#include <rte_per_lcore.h>
#include <stdint.h>
#include <stdio.h>
#include <string.h>
#include <sys/queue.h>
#include <rte_cycles.h>
static int lcore_hello(__rte_unused void *arg) {
unsigned lcore_id;
lcore_id = rte_lcore_id();
printf("hello from core %u\n", lcore_id);
return 0;
}
int main(int argc, char **argv) {
int socket_count;
int lcore_count;
int ret;
unsigned lcore_id;
ret = rte_eal_init(argc, argv);
if (ret < 0)
rte_panic("Cannot init EAL\n");
/* call lcore_hello() on every worker lcore */
RTE_LCORE_FOREACH_WORKER(lcore_id) {
rte_eal_remote_launch(lcore_hello, NULL, lcore_id);
}
/* call it on main lcore too */
lcore_hello(NULL);
// print socket count
socket_count = rte_socket_count();
printf("number of sockets:%i", socket_count);
// print lcore count
lcore_count = rte_lcore_count();
printf("number of lcores:%i", lcore_count);
// test timer
uint32_t seconds = 0;
uint64_t cycles_old = rte_get_tsc_cycles();
for (;;) {
uint64_t hz = rte_get_tsc_hz();
uint64_t cycles = rte_get_tsc_cycles();
uint64_t delta_cycles = cycles - cycles_old;
if (delta_cycles >= hz) {
++seconds;
cycles_old = cycles - (delta_cycles % hz);
}
printf("seconds : %u\n", seconds);
}
rte_eal_mp_wait_lcore();
/* clean up the EAL */
rte_eal_cleanup();
return 0;
}
uint64_t int_divide(uint64_t a, uint64_t b) {
uint64_t c = 0;
while (a >= b) {
a -= b;
++c;
}
return c;
}

View File

@@ -0,0 +1,112 @@
/* SPDX-License-Identifier: BSD-3-Clause
* Copyright(c) 2010-2014 Intel Corporation
*/
#include <chrono>
#include <cmath>
#include <errno.h>
#include <iostream>
#include <rte_cycles.h>
#include <rte_debug.h>
#include <rte_eal.h>
#include <rte_launch.h>
#include <rte_lcore.h>
#include <rte_memory.h>
#include <rte_per_lcore.h>
#include <stdint.h>
#include <stdio.h>
#include <string.h>
#include <sys/queue.h>
static int lcore_hello(__rte_unused void* arg) {
unsigned lcore_id;
lcore_id = rte_lcore_id();
printf("hello from core %u\n", lcore_id);
return 0;
}
int main(int argc, char** argv) {
int socket_count;
int lcore_count;
int ret;
unsigned lcore_id;
ret = rte_eal_init(argc, argv);
if (ret < 0)
rte_panic("Cannot init EAL\n");
/* call lcore_hello() on every worker lcore */
RTE_LCORE_FOREACH_WORKER(lcore_id) {
rte_eal_remote_launch(lcore_hello, NULL, lcore_id);
}
/* call it on main lcore too */
lcore_hello(NULL);
// print socket count
socket_count = rte_socket_count();
printf("number of sockets:%i", socket_count);
// print lcore count
lcore_count = rte_lcore_count();
printf("number of lcores:%i", lcore_count);
// test timer
int hz_mean = 0;
int n = 1;
int hz_cycles = -1;
std::chrono::time_point<std::chrono::system_clock> start, end;
start = std::chrono::system_clock::now();
end = std::chrono::system_clock::now();
std::chrono::duration<double> elapsed_seconds = end - start;
std::chrono::seconds sec(30);
do {
hz_mean = (hz_mean + rte_get_tsc_hz() / n) * n / (n + 1);
end = std::chrono::system_clock::now();
elapsed_seconds = end - start;
} while (elapsed_seconds <= sec);
int cycles_old = rte_get_tsc_cycles();
do {
end = std::chrono::system_clock::now();
elapsed_seconds = end - start;
} while (elapsed_seconds <= sec);
hz_cycles = (rte_get_tsc_cycles() - cycles_old) / 30;
std::cout << std::endl << "hz : " << rte_get_tsc_hz() << std::endl;
std::cout << "hz_cycles : " << hz_cycles << std::endl;
std::cout << "hz_mean : " << hz_mean << std::endl;
int length = 1000;
int hz_cycles_diff[length];
int hz_mean_diff[length];
int hz_cycles_diff_max = -1;
int hz_mean_diff_max = -1;
int hz = -1;
for (int i = 0; i < length; i++) {
hz = rte_get_tsc_hz();
hz_cycles_diff[i] = abs(hz - hz_cycles);
hz_mean_diff[i] = abs(hz - hz_mean);
if (hz_cycles_diff[i] > hz_cycles_diff_max) {
hz_cycles_diff_max = hz_cycles_diff[i];
}
if (hz_mean_diff[i] > hz_mean_diff_max) {
hz_mean_diff_max = hz_mean_diff[i];
}
}
std::cout << "hz_cycles_diff_max : " << hz_cycles_diff_max << std::endl;
std::cout << "hz_mean_diff_max : " << hz_mean_diff_max << std::endl;
rte_eal_mp_wait_lcore();
/* clean up the EAL */
rte_eal_cleanup();
return 0;
}

View File

@@ -0,0 +1,5 @@
project('dpdk-app', 'cpp')
dpdk = dependency('libdpdk')
sources = files('main.cpp')
executable('dpdk-app', sources, dependencies: dpdk)