net/ixgbe: build on Windows
This patch enables building the ixgbe driver for Windows. It also enables its dependencies on security and cryptodev. I tested on AWS using ixgbe VF device, using dpdk-testpmd. Signed-off-by: William Tu <u9012063@gmail.com> Acked-by: Pallavi Kadam <pallavi.kadam@intel.com> Acked-by: Dmitry Kozlyuk <dmitry.kozliuk@gmail.com>
This commit is contained in:
parent
56d2c1aa0b
commit
6be6690127
@ -52,6 +52,7 @@ Registers dump = Y
|
|||||||
Multiprocess aware = Y
|
Multiprocess aware = Y
|
||||||
FreeBSD = Y
|
FreeBSD = Y
|
||||||
Linux = Y
|
Linux = Y
|
||||||
|
Windows = Y
|
||||||
ARMv8 = Y
|
ARMv8 = Y
|
||||||
x86-32 = Y
|
x86-32 = Y
|
||||||
x86-64 = Y
|
x86-64 = Y
|
||||||
|
@ -36,6 +36,7 @@ Registers dump = Y
|
|||||||
Multiprocess aware = Y
|
Multiprocess aware = Y
|
||||||
FreeBSD = Y
|
FreeBSD = Y
|
||||||
Linux = Y
|
Linux = Y
|
||||||
|
Windows = Y
|
||||||
ARMv8 = Y
|
ARMv8 = Y
|
||||||
x86-32 = Y
|
x86-32 = Y
|
||||||
x86-64 = Y
|
x86-64 = Y
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
.. SPDX-License-Identifier: BSD-3-Clause
|
.. SPDX-License-Identifier: BSD-3-Clause
|
||||||
Copyright(c) 2010-2016 Intel Corporation.
|
Copyright(c) 2010-2016 Intel Corporation.
|
||||||
|
|
||||||
|
.. include:: <isonum.txt>
|
||||||
|
|
||||||
IXGBE Driver
|
IXGBE Driver
|
||||||
============
|
============
|
||||||
|
|
||||||
@ -22,8 +24,8 @@ The following sections explain RX and TX constraints in the vPMD.
|
|||||||
RX Constraints
|
RX Constraints
|
||||||
~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~
|
||||||
|
|
||||||
Prerequisites and Pre-conditions
|
Linux Prerequisites and Pre-conditions
|
||||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
The following prerequisites apply:
|
The following prerequisites apply:
|
||||||
|
|
||||||
@ -47,6 +49,24 @@ vPMD for RX would be disabled.
|
|||||||
|
|
||||||
By default, IXGBE_MAX_RING_DESC is set to 4096 and RTE_PMD_IXGBE_RX_MAX_BURST is set to 32.
|
By default, IXGBE_MAX_RING_DESC is set to 4096 and RTE_PMD_IXGBE_RX_MAX_BURST is set to 32.
|
||||||
|
|
||||||
|
Windows Prerequisites and Pre-conditions
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
- Follow the :doc:`guide for Windows <../windows_gsg/run_apps>`
|
||||||
|
to setup the basic DPDK environment.
|
||||||
|
|
||||||
|
- Identify the Intel\ |reg| Ethernet adapter and get the latest NVM/FW version.
|
||||||
|
|
||||||
|
- To access any Intel\ |reg| Ethernet hardware,
|
||||||
|
load the NetUIO driver in place of existing built-in (inbox) driver.
|
||||||
|
|
||||||
|
- To load NetUIO driver, follow the steps mentioned in `dpdk-kmods repository
|
||||||
|
<https://git.dpdk.org/dpdk-kmods/tree/windows/netuio/README.rst>`_.
|
||||||
|
|
||||||
|
- Loading of private Dynamic Device Personalization (DDP) package
|
||||||
|
is not supported on Windows.
|
||||||
|
|
||||||
|
|
||||||
Feature not Supported by RX Vector PMD
|
Feature not Supported by RX Vector PMD
|
||||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
@ -85,6 +85,10 @@ New Features
|
|||||||
* Added DEV_RX_OFFLOAD_TIMESTAMP support.
|
* Added DEV_RX_OFFLOAD_TIMESTAMP support.
|
||||||
* Added timesync API support under scalar path.
|
* Added timesync API support under scalar path.
|
||||||
|
|
||||||
|
* **Updated Intel ixgbe driver.**
|
||||||
|
|
||||||
|
* Added Intel ixgbe support on Windows.
|
||||||
|
|
||||||
* **Updated Marvell cnxk ethdev driver.**
|
* **Updated Marvell cnxk ethdev driver.**
|
||||||
|
|
||||||
* Added rte_flow support for dual VLAN insert and strip actions.
|
* Added rte_flow support for dual VLAN insert and strip actions.
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
|
|
||||||
#include "ixgbe_vf.h"
|
#include "ixgbe_vf.h"
|
||||||
#include "ixgbe_hv_vf.h"
|
#include "ixgbe_hv_vf.h"
|
||||||
|
#include "ixgbe_osdep.h"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Hyper-V variant - just a stub.
|
* Hyper-V variant - just a stub.
|
||||||
|
@ -16,10 +16,15 @@
|
|||||||
#include <rte_log.h>
|
#include <rte_log.h>
|
||||||
#include <rte_byteorder.h>
|
#include <rte_byteorder.h>
|
||||||
#include <rte_io.h>
|
#include <rte_io.h>
|
||||||
|
#include <rte_ip.h>
|
||||||
|
|
||||||
#include "../ixgbe_logs.h"
|
#include "../ixgbe_logs.h"
|
||||||
#include "../ixgbe_bypass_defines.h"
|
#include "../ixgbe_bypass_defines.h"
|
||||||
|
|
||||||
|
#ifndef IPPROTO_SCTP
|
||||||
|
#define IPPROTO_SCTP 132
|
||||||
|
#endif
|
||||||
|
|
||||||
#define ASSERT(x) if(!(x)) rte_panic("IXGBE: x")
|
#define ASSERT(x) if(!(x)) rte_panic("IXGBE: x")
|
||||||
|
|
||||||
#define DELAY(x) rte_delay_us_sleep(x)
|
#define DELAY(x) rte_delay_us_sleep(x)
|
||||||
@ -43,12 +48,16 @@
|
|||||||
|
|
||||||
#define false 0
|
#define false 0
|
||||||
#define true 1
|
#define true 1
|
||||||
|
#ifndef RTE_EXEC_ENV_WINDOWS
|
||||||
#define min(a,b) RTE_MIN(a,b)
|
#define min(a,b) RTE_MIN(a,b)
|
||||||
|
#endif
|
||||||
|
|
||||||
#define EWARN(hw, S, args...) DEBUGOUT1(S, ##args)
|
#define EWARN(hw, S, args...) DEBUGOUT1(S, ##args)
|
||||||
|
|
||||||
/* Bunch of defines for shared code bogosity */
|
/* Bunch of defines for shared code bogosity */
|
||||||
|
#ifndef UNREFERENCED_PARAMETER
|
||||||
#define UNREFERENCED_PARAMETER(_p)
|
#define UNREFERENCED_PARAMETER(_p)
|
||||||
|
#endif
|
||||||
#define UNREFERENCED_1PARAMETER(_p)
|
#define UNREFERENCED_1PARAMETER(_p)
|
||||||
#define UNREFERENCED_2PARAMETER(_p, _q)
|
#define UNREFERENCED_2PARAMETER(_p, _q)
|
||||||
#define UNREFERENCED_3PARAMETER(_p, _q, _r)
|
#define UNREFERENCED_3PARAMETER(_p, _q, _r)
|
||||||
|
@ -29,6 +29,6 @@ foreach flag: error_cflags
|
|||||||
endforeach
|
endforeach
|
||||||
|
|
||||||
base_lib = static_library('ixgbe_base', sources,
|
base_lib = static_library('ixgbe_base', sources,
|
||||||
dependencies: static_rte_eal,
|
dependencies: [static_rte_eal, static_rte_net],
|
||||||
c_args: c_args)
|
c_args: c_args)
|
||||||
base_objs = base_lib.extract_all_objects(recursive: true)
|
base_objs = base_lib.extract_all_objects(recursive: true)
|
||||||
|
@ -10,7 +10,6 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
#include <inttypes.h>
|
#include <inttypes.h>
|
||||||
#include <netinet/in.h>
|
|
||||||
#include <rte_string_fns.h>
|
#include <rte_string_fns.h>
|
||||||
#include <rte_byteorder.h>
|
#include <rte_byteorder.h>
|
||||||
#include <rte_common.h>
|
#include <rte_common.h>
|
||||||
@ -46,6 +45,7 @@
|
|||||||
#include "ixgbe_rxtx.h"
|
#include "ixgbe_rxtx.h"
|
||||||
#include "base/ixgbe_type.h"
|
#include "base/ixgbe_type.h"
|
||||||
#include "base/ixgbe_phy.h"
|
#include "base/ixgbe_phy.h"
|
||||||
|
#include "base/ixgbe_osdep.h"
|
||||||
#include "ixgbe_regs.h"
|
#include "ixgbe_regs.h"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
#define _IXGBE_ETHDEV_H_
|
#define _IXGBE_ETHDEV_H_
|
||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
#include <sys/queue.h>
|
||||||
|
|
||||||
#include "base/ixgbe_type.h"
|
#include "base/ixgbe_type.h"
|
||||||
#include "base/ixgbe_dcb.h"
|
#include "base/ixgbe_dcb.h"
|
||||||
|
@ -10,7 +10,6 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
#include <inttypes.h>
|
#include <inttypes.h>
|
||||||
#include <netinet/in.h>
|
|
||||||
#include <rte_byteorder.h>
|
#include <rte_byteorder.h>
|
||||||
#include <rte_common.h>
|
#include <rte_common.h>
|
||||||
#include <rte_cycles.h>
|
#include <rte_cycles.h>
|
||||||
@ -37,6 +36,7 @@
|
|||||||
#include "base/ixgbe_api.h"
|
#include "base/ixgbe_api.h"
|
||||||
#include "base/ixgbe_vf.h"
|
#include "base/ixgbe_vf.h"
|
||||||
#include "base/ixgbe_common.h"
|
#include "base/ixgbe_common.h"
|
||||||
|
#include "base/ixgbe_osdep.h"
|
||||||
#include "ixgbe_ethdev.h"
|
#include "ixgbe_ethdev.h"
|
||||||
#include "ixgbe_bypass.h"
|
#include "ixgbe_bypass.h"
|
||||||
#include "ixgbe_rxtx.h"
|
#include "ixgbe_rxtx.h"
|
||||||
|
@ -665,7 +665,7 @@ ixgbe_node_add(struct rte_eth_dev *dev, uint32_t node_id,
|
|||||||
}
|
}
|
||||||
/* check level */
|
/* check level */
|
||||||
if (level_id != RTE_TM_NODE_LEVEL_ID_ANY &&
|
if (level_id != RTE_TM_NODE_LEVEL_ID_ANY &&
|
||||||
level_id != parent_node_type + 1) {
|
level_id != (uint32_t)parent_node_type + 1) {
|
||||||
error->type = RTE_TM_ERROR_TYPE_NODE_PARAMS;
|
error->type = RTE_TM_ERROR_TYPE_NODE_PARAMS;
|
||||||
error->message = "Wrong level";
|
error->message = "Wrong level";
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
@ -1,12 +1,6 @@
|
|||||||
# SPDX-License-Identifier: BSD-3-Clause
|
# SPDX-License-Identifier: BSD-3-Clause
|
||||||
# Copyright(c) 2017 Intel Corporation
|
# Copyright(c) 2017 Intel Corporation
|
||||||
|
|
||||||
if is_windows
|
|
||||||
build = false
|
|
||||||
reason = 'not supported on Windows'
|
|
||||||
subdir_done()
|
|
||||||
endif
|
|
||||||
|
|
||||||
cflags += ['-DRTE_LIBRTE_IXGBE_BYPASS']
|
cflags += ['-DRTE_LIBRTE_IXGBE_BYPASS']
|
||||||
|
|
||||||
subdir('base')
|
subdir('base')
|
||||||
@ -30,6 +24,9 @@ deps += ['hash', 'security']
|
|||||||
|
|
||||||
if arch_subdir == 'x86'
|
if arch_subdir == 'x86'
|
||||||
sources += files('ixgbe_rxtx_vec_sse.c')
|
sources += files('ixgbe_rxtx_vec_sse.c')
|
||||||
|
if is_windows and cc.get_id() != 'clang'
|
||||||
|
cflags += ['-fno-asynchronous-unwind-tables']
|
||||||
|
endif
|
||||||
elif arch_subdir == 'arm'
|
elif arch_subdir == 'arm'
|
||||||
sources += files('ixgbe_rxtx_vec_neon.c')
|
sources += files('ixgbe_rxtx_vec_neon.c')
|
||||||
endif
|
endif
|
||||||
|
Loading…
Reference in New Issue
Block a user