61934c0956
Convert the ring driver to use the PMD_REGISTER_DRIVER macro and fix up the Makefile so that its linkage is only done if we are building static libraries. This means that the test applications now have no reference to the ring library when building DSO's and must specify its use on the command line with the -d option. Static linking will still initalize the driver automatically. Note that the ring driver was also written in such a way that it violated some general layering principles, several functions were contained in the pmd which were being called by example from the test application in the app/test directory. Specifically it was calling eth_ring_pair_attach, eth_ring_pair_create and rte_eth_ring_devinit, which should only be called internally to the dpdk core library. To correct this I've removed those functions, and instead allowed them to be called indirectly at initalization time using the vdev command line argument key nodeaction=<name>:<node>:<action> where action is one of ATTACH or CREATE. I've tested out the functionality of the command line with the testpmd utility, with success, and have removed the called functions from the test utility. This will affect how the test utility is invoked (the -d and --vdev option will need to be specified on the command line now), but honestly, given the way it was coded, I think the testing of the ring pmd was not the best example of how to code with dpdk to begin with. I have also left the two layer violating functions in place, so as not to break existing applications, but added deprecation warnings to them so that apps can migrate off them. Signed-off-by: Neil Horman <nhorman@tuxdriver.com> Acked-by: Thomas Monjalon <thomas.monjalon@6wind.com> |
||
---|---|---|
.. | ||
autotest_data.py | ||
autotest_runner.py | ||
autotest_test_funcs.py | ||
autotest.py | ||
commands.c | ||
Makefile | ||
process.h | ||
test_acl.c | ||
test_acl.h | ||
test_alarm.c | ||
test_atomic.c | ||
test_byteorder.c | ||
test_cmdline_cirbuf.c | ||
test_cmdline_etheraddr.c | ||
test_cmdline_ipaddr.c | ||
test_cmdline_lib.c | ||
test_cmdline_num.c | ||
test_cmdline_portlist.c | ||
test_cmdline_string.c | ||
test_cmdline.c | ||
test_cmdline.h | ||
test_common.c | ||
test_cpuflags.c | ||
test_cycles.c | ||
test_debug.c | ||
test_devargs.c | ||
test_eal_flags.c | ||
test_eal_fs.c | ||
test_errno.c | ||
test_func_reentrancy.c | ||
test_hash_perf.c | ||
test_hash.c | ||
test_interrupts.c | ||
test_ivshmem.c | ||
test_kni.c | ||
test_kvargs.c | ||
test_logs.c | ||
test_lpm6_routes.h | ||
test_lpm6.c | ||
test_lpm_routes.h | ||
test_lpm.c | ||
test_malloc.c | ||
test_mbuf.c | ||
test_memcpy_perf.c | ||
test_memcpy.c | ||
test_memory.c | ||
test_mempool_perf.c | ||
test_mempool.c | ||
test_memzone.c | ||
test_meter.c | ||
test_mp_secondary.c | ||
test_pci.c | ||
test_per_lcore.c | ||
test_pmd_ring.c | ||
test_power.c | ||
test_prefetch.c | ||
test_red.c | ||
test_ring_perf.c | ||
test_ring.c | ||
test_rwlock.c | ||
test_sched.c | ||
test_spinlock.c | ||
test_string_fns.c | ||
test_tailq.c | ||
test_timer_perf.c | ||
test_timer.c | ||
test_version.c | ||
test.c | ||
test.h |