aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMohammad Abdul Awal <mohammad.abdul.awal@intel.com>2016-09-10 11:24:16 +0100
committerMohammad Abdul Awal <mohammad.abdul.awal@intel.com>2016-09-15 09:50:32 +0100
commit258f299a2a152acab4ce497673eb293c5da15f73 (patch)
tree5dce0223129b7997602441e52a6d463727dea273
parente57f675d4de058f99819dd2d228656533961f38a (diff)
udpfw: dynamic allocation of netbe_* structures
This patch allows dynamic allocation of memory for the appliation. The solves the problem of allocating large amount of static memory which caused accessing the momory locations outside of 32-bit address-space duing compile-time. Change-Id: If8031ba846e4ed339d8ce8ebe4fd69325f098d17 Signed-off-by: Mohammad Abdul Awal <mohammad.abdul.awal@intel.com>
-rw-r--r--examples/udpfwd/Makefile1
-rw-r--r--examples/udpfwd/main.c34
-rw-r--r--examples/udpfwd/netbe.h8
-rw-r--r--examples/udpfwd/parse.c11
4 files changed, 43 insertions, 11 deletions
diff --git a/examples/udpfwd/Makefile b/examples/udpfwd/Makefile
index 5274d0f..6816b5e 100644
--- a/examples/udpfwd/Makefile
+++ b/examples/udpfwd/Makefile
@@ -41,6 +41,5 @@ LDLIBS += -ltle_udp
EXTRA_CFLAGS += -O3
CFLAGS_parse.o += -D_GNU_SOURCE
-CFLAGS_main.o += -mcmodel=medium
include $(RTE_SDK)/mk/rte.extapp.mk
diff --git a/examples/udpfwd/main.c b/examples/udpfwd/main.c
index f8a6f1b..1eb4e2a 100644
--- a/examples/udpfwd/main.c
+++ b/examples/udpfwd/main.c
@@ -101,6 +101,16 @@ static const struct option long_opt[] = {
*/
#define RSS_RETA_CONF_ARRAY_SIZE (ETH_RSS_RETA_SIZE_512/RTE_RETA_GROUP_SIZE)
+#define NETBE_REALLOC(loc, n) do { \
+ (loc) = rte_realloc((loc), sizeof(*(loc)) * (n), RTE_CACHE_LINE_SIZE); \
+ if ((loc) == NULL) { \
+ RTE_LOG(ERR, USER1, \
+ "%s: failed to reallocate memory\n", \
+ __func__); \
+ return -ENOMEM; \
+ } \
+} while (0)
+
static volatile int force_quit;
static struct netbe_cfg becfg;
@@ -490,14 +500,16 @@ calculate_nb_prtq(struct netbe_cfg *cfg)
lc = find_initilized_lcore(cfg, prt->lcore[j]);
if (lc == NULL) {
+ NETBE_REALLOC(cfg->cpu, cfg->cpu_num + 1);
lc = &cfg->cpu[cfg->cpu_num];
lc->id = prt->lcore[j];
cfg->cpu_num++;
}
+
+ NETBE_REALLOC(lc->prtq, lc->prtq_num + 1);
lc->prtq[lc->prtq_num].rxqid = j;
lc->prtq[lc->prtq_num].txqid = j;
lc->prtq[lc->prtq_num].port = *prt;
-
lc->prtq_num++;
}
}
@@ -515,10 +527,11 @@ netbe_port_init(struct netbe_cfg *cfg, int argc, char *argv[])
uint32_t i, n, sid, j;
struct netbe_port *prt;
- n = RTE_MIN(RTE_DIM(cfg->prt), (uint32_t)argc);
+ n = (uint32_t)argc;
rc = 0;
for (i = 0; i != n; i++) {
+ NETBE_REALLOC(cfg->prt, cfg->prt_num + 1);
rc = parse_netbe_arg(cfg->prt + i, argv[i]);
if (rc != 0) {
RTE_LOG(ERR, USER1,
@@ -526,8 +539,8 @@ netbe_port_init(struct netbe_cfg *cfg, int argc, char *argv[])
__func__, argv[i], rc);
return rc;
}
+ cfg->prt_num++;
}
- cfg->prt_num = i;
/* calculate number of queues per lcore. */
rc = calculate_nb_prtq(cfg);
@@ -788,6 +801,10 @@ lcore_init(struct netbe_lcore *lc, const struct tle_udp_ctx_param *ctx_prm,
rte_ip_frag_table_destroy(lc->ftbl);
rte_lpm_free(lc->lpm4);
rte_lpm6_free(lc->lpm6);
+ rte_free(lc->prtq[prtqid].port.lcore);
+ lc->prtq[prtqid].port.nb_lcore = 0;
+ rte_free(lc->prtq);
+ lc->prtq_num = 0;
return rc;
}
}
@@ -860,10 +877,19 @@ netbe_lcore_fini(struct netbe_cfg *cfg)
rte_ip_frag_table_destroy(cfg->cpu[i].ftbl);
rte_lpm_free(cfg->cpu[i].lpm4);
rte_lpm6_free(cfg->cpu[i].lpm6);
+
+ rte_free(cfg->cpu[i].prtq);
+ cfg->cpu[i].prtq_num = 0;
}
- memset(cfg->cpu, 0, sizeof(cfg->cpu));
+ rte_free(cfg->cpu);
cfg->cpu_num = 0;
+ for (i = 0; i != cfg->prt_num; i++) {
+ rte_free(cfg->prt[i].lcore);
+ cfg->prt[i].nb_lcore = 0;
+ }
+ rte_free(cfg->prt);
+ cfg->prt_num = 0;
}
static int
diff --git a/examples/udpfwd/netbe.h b/examples/udpfwd/netbe.h
index 577627d..1e5d9a7 100644
--- a/examples/udpfwd/netbe.h
+++ b/examples/udpfwd/netbe.h
@@ -54,7 +54,7 @@
struct netbe_port {
uint32_t id;
uint32_t nb_lcore;
- uint32_t lcore[RTE_MAX_LCORE];
+ uint32_t *lcore;
uint32_t mtu;
uint32_t rx_offload;
uint32_t tx_offload;
@@ -118,7 +118,7 @@ struct netbe_lcore {
uint32_t prtq_num;
uint32_t dst4_num;
uint32_t dst6_num;
- struct netbe_dev prtq[RTE_MAX_ETHPORTS * RTE_MAX_LCORE];
+ struct netbe_dev *prtq;
struct tle_udp_dest dst4[LCORE_MAX_DST];
struct tle_udp_dest dst6[LCORE_MAX_DST];
struct rte_ip_frag_death_row death_row;
@@ -128,8 +128,8 @@ struct netbe_cfg {
uint32_t promisc;
uint32_t prt_num;
uint32_t cpu_num;
- struct netbe_port prt[RTE_MAX_ETHPORTS];
- struct netbe_lcore cpu[RTE_MAX_LCORE];
+ struct netbe_port *prt;
+ struct netbe_lcore *cpu;
};
/*
diff --git a/examples/udpfwd/parse.c b/examples/udpfwd/parse.c
index cc8c0b2..09c4a96 100644
--- a/examples/udpfwd/parse.c
+++ b/examples/udpfwd/parse.c
@@ -201,7 +201,7 @@ int
parse_netbe_arg(struct netbe_port *prt, const char *arg)
{
int32_t rc;
- uint32_t i, j;
+ uint32_t i, j, nc;
static const char *keys_man[] = {
"port",
@@ -237,10 +237,17 @@ parse_netbe_arg(struct netbe_port *prt, const char *arg)
return rc;
prt->id = val[0].u64;
+
+ for (i = 0, nc = 0; i < RTE_MAX_LCORE; i++)
+ nc += CPU_ISSET(i, &val[1].cpuset);
+ prt->lcore = rte_zmalloc(NULL, nc * sizeof(prt->lcore[0]),
+ RTE_CACHE_LINE_SIZE);
+ prt->nb_lcore = nc;
+
for (i = 0, j = 0; i < RTE_MAX_LCORE; i++)
if (CPU_ISSET(i, &val[1].cpuset))
prt->lcore[j++] = i;
- prt->nb_lcore = j;
+
prt->mtu = val[2].u64;
prt->rx_offload = val[3].u64;
prt->tx_offload = val[4].u64;