This DLL depends upon a recent copy of the P4API, and upon openssl 3
This DLL is used by the P4API.NET assembly, and works in both .NET framework and .NET core applications.
Since this DLL is now cross-platform, CMake is the "official" build tool of the bridge.
WINDOWS: Visual studio 2019 must be installed with the desktop c++ SDK.
LINUX: gcc 8.1.0 or better
OSX: gcc 8.1.0 or better
There are several P4API setup scripts in the p4api.net root directory which can help with setting up the required libraries.
The p4bridge is cross platform, and (in windows) supports multiple builds from the same directory. The p4api location is dependent on platform and build type
Location | Type of P4API | Download Location |
---|---|---|
../p4api_release | x64 windows static release | P4API x64 static |
../p4api_debug | x64 windows static debug | P4API x64 static debug |
../p4api_x86_release | x86 windows static release | P4API x86 static |
../p4api_x86_debug | x86 windows static debug | P4API x86 static debug |
../p4api | linux (all) | P4API for linux |
../p4api | linuxarm64 (arm64) | P4API for linux |
../p4api | osx (all) | P4API for osx |
The default openssl version is 3 Download the correct openSSL library for your OS and release type, then copy the *.lib files into the "lib" subdirectory of your p4api* location.
OpenSSL binaries can be downloaded from here: OpenSSL Downloads
Download cmake for your platform from here: Cmake Downloads
Cmake presets are stored in CMakePresets.json This file may need some editing to configure build specific options (like compiler location). Ensure that for Windows OS, Visual Studio compiler version matches with the version of the P4API and OpenSSL artifacts used.
Every preset uses a unique build directory under ./out as seen in the table below
Preset | Platform | Architecture | Build Type | OUT_DIRECTORY |
---|---|---|---|---|
x64-Release | Windows | x64 | Release | ./out/x64/Release |
x64-Debug | Windows | x64 | Debug | ./out/x64/Debug |
x86-Release | Windows | x86 | Release | ./out/x86/Release |
x86-Debug | Windows | x86 | Debug | ./out/x86/Debug |
osx-Release | OSX | Universal (x64, aarch64) | Release | ./out/osx-Release |
osx-Debug | OSX | Universal (x64, aarch64) | Debug | ./out/osx-Debug |
linux-Release | Linux | Intel 64 bit | Release | ./out/linux-Release |
linux-Debug | Linux | Intel 64 bit | Debug | ./out/linux-Debug |
linux-Release | Linux | ARM 64 bit | Release | ./out/linux-Release |
linux-Debug | Linux | ARM 64 bit | Debug | ./out/linux-Debug |
- Generate the build environment
cmake --preset=PRESET
. this will create an Cmake build toolchain for the specified preset and initialize its OUT_DIRECTORY. - Build the code within the build directory using
cmake --build OUT_DIRECTORY --config Release
(The "--config Release" option is only needed for windows builds) on Windows it is important to pass a "--config" option ( Release or Debug ) which matches the preset build type. - The DLL and associated files will be created in the OUT_DIRECTORY
You can clean a build environment with cmake --build OUT_DIRECTORY --target clean
I've provided some build scripts which I used to simplify building from the command line. These are samples only and will need to be modified for your environment.
These include buildall.bat, builddebug.bat, builddebug_linux.sh, builddebug_osx.sh, buildall_linux.sh
and buildall_osx.sh