[03/16] ethdev: remove use of VLAs for Windows built code
Checks
Commit Message
MSVC does not support VLAs, replace VLAs with standard C arrays
or alloca(). alloca() is available for all toolchain/platform
combinations officially supported by DPDK.
Signed-off-by: Tyler Retzlaff <roretzla@linux.microsoft.com>
---
lib/ethdev/rte_ethdev.c | 9 +++++----
1 file changed, 5 insertions(+), 4 deletions(-)
@@ -3241,7 +3241,8 @@ enum {
}
/* Get id-name lookup table */
- struct rte_eth_xstat_name xstats_names[cnt_xstats];
+ struct rte_eth_xstat_name *xstats_names =
+ alloca(sizeof(struct rte_eth_xstat_name) * cnt_xstats);
if (cnt_xstats != rte_eth_xstats_get_names_by_id(
port_id, xstats_names, cnt_xstats, NULL)) {
@@ -3342,7 +3343,7 @@ enum {
return -EINVAL;
if (ids && dev->dev_ops->xstats_get_names_by_id != NULL && size > 0) {
- uint64_t ids_copy[size];
+ uint64_t *ids_copy = alloca(sizeof(uint64_t) * size);
for (i = 0; i < size; i++) {
if (ids[i] < basic_count) {
@@ -3535,7 +3536,7 @@ enum {
if (ret < 0)
return ret;
expected_entries = (uint16_t)ret;
- struct rte_eth_xstat xstats[expected_entries];
+ struct rte_eth_xstat *xstats = alloca(sizeof(struct rte_eth_xstat) * expected_entries);
basic_count = eth_dev_get_xstats_basic_count(dev);
/* Return max number of stats if no ids given */
@@ -3551,7 +3552,7 @@ enum {
if (ids && dev->dev_ops->xstats_get_by_id != NULL && size) {
unsigned int basic_count = eth_dev_get_xstats_basic_count(dev);
- uint64_t ids_copy[size];
+ uint64_t *ids_copy = alloca(sizeof(uint64_t) * size);
for (i = 0; i < size; i++) {
if (ids[i] < basic_count) {