pktgen-dpdk arm编译问题 “Platform must be built with RTE_FORCE_INTRINSICS“

编译报错

/usr/include/rte_atomic_32.h:9:4: error: #error Platform must be built with RTE_FORCE_INTRINSICS

解决办法:
我是在 arm架构服务器上编译出现这个,要定义 RTE_FORCE_INTRINSICS
在meson.build中 增加gcc编译参数

add_project_arguments('-DRTE_FORCE_INTRINSICS', language: 'c')
### 如何使用 Pktgen-DPDK 进行性能测试 为了利用 Pktgen-DPDK 执行高效的网络性能测试,需遵循一系列特定的操作流程来确保环境配置得当并能够顺利运行该应用。 #### 准备工作 安装必要的软件包对于构建和部署至关重要。通过命令 `yum install gcc libpcap-devel kernel-devel kernel-headers` 可以获取所需的依赖库[^4]。这一步骤为后续的源码编译提供了基础支持。 创建一个目录作为项目的根路径,并克隆 DPDKPktgen 的仓库到此位置: ```bash TOPDIR=/devel mkdir -p $TOPDIR cd $TOPDIR git clone http://dpdk.org/git/dpdk git clone http://dpdk.org/git/apps/pktgen-dpdk ``` 设定环境变量以便于识别 SDK 路径以及目标架构: ```bash export RTE_SDK=$TOPDIR/dpdk export RTE_TARGET=x86_64-native-linuxapp-gcc ``` 接着,在指定的目标环境下编译 DPDK 库文件: ```bash $ cd $RTE_SDK $ make install T=x86_64-native-linuxapp-gcc ``` 完成上述步骤之后,进入 Pktgen 项目文件夹继续其自身的编译过程: ```bash $ cd $TOPDIR/pktgen-dpdk $ make ``` #### 绑定网卡与启动服务 在实际操作前,还需将物理网卡绑定至用户空间驱动程序 igb_uio 上,从而允许应用程序直接访问硬件资源而无需经过内核层处理。具体做法是在终端中输入如下指令: ```bash dpdk-devbind -b igb_uio 0000:00:03.0 ``` 这里使用的 PCI 地址可以通过执行 `dpdk-devbind.py -s` 来查询当前系统的设备列表获得确切值[^3]。 最后,启动 Pktgen 工具本身即可开始发送数据流进行压力测试或其他形式的功能验证活动。 #### 配置实例展示 假设现在要向某一台服务器发起流量冲击,则可以在命令行界面里键入下面这段话来初始化会话: ```bash ./build/app/pktgen -c f -n 4 --proc-type auto \ -- -T -m "[1:3].0" -f themes/gray-theme.lua ``` 在此基础上调整参数 `-c`, `-n`, 或者其他选项来自定义线程数、内存通道数目等细节;同时也可以加载不同的主题样式改变图形化界面外观[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值