X-Git-Url: http://git.droids-corp.org/?a=blobdiff_plain;f=examples%2Fvm_power_manager%2Fmain.c;h=399fbdd43bf0fb9cb0bb91c6ba22349e068ec437;hb=52960057f1d4958b541331ccba88c3241ebe9613;hp=4ffefce93368dff1bcc0df5d78e42c676e57aa3d;hpb=20c78ac9ee23666a0db12fff7a5bd44d7b0a4db0;p=dpdk.git diff --git a/examples/vm_power_manager/main.c b/examples/vm_power_manager/main.c index 4ffefce933..399fbdd43b 100644 --- a/examples/vm_power_manager/main.c +++ b/examples/vm_power_manager/main.c @@ -58,6 +58,9 @@ #include "channel_monitor.h" #include "power_manager.h" #include "vm_power_cli.h" +#include +#include +#include #define RX_RING_SIZE 512 #define TX_RING_SIZE 512 @@ -301,11 +304,49 @@ main(int argc, char **argv) /* Initialize ports. */ for (portid = 0; portid < nb_ports; portid++) { + struct ether_addr eth; + int w, j; + int ret = -ENOTSUP; + if ((enabled_port_mask & (1 << portid)) == 0) continue; + + eth.addr_bytes[0] = 0xe0; + eth.addr_bytes[1] = 0xe0; + eth.addr_bytes[2] = 0xe0; + eth.addr_bytes[3] = 0xe0; + eth.addr_bytes[4] = portid + 0xf0; + if (port_init(portid, mbuf_pool) != 0) rte_exit(EXIT_FAILURE, "Cannot init port %"PRIu8 "\n", portid); + + for (w = 0; w < MAX_VFS; w++) { + eth.addr_bytes[5] = w + 0xf0; + + if (ret == -ENOTSUP) + ret = rte_pmd_ixgbe_set_vf_mac_addr(portid, + w, ð); + if (ret == -ENOTSUP) + ret = rte_pmd_i40e_set_vf_mac_addr(portid, + w, ð); + if (ret == -ENOTSUP) + ret = rte_pmd_bnxt_set_vf_mac_addr(portid, + w, ð); + + switch (ret) { + case 0: + printf("Port %d VF %d MAC: ", + portid, w); + for (j = 0; j < 6; j++) { + printf("%02x", eth.addr_bytes[j]); + if (j < 5) + printf(":"); + } + printf("\n"); + break; + } + } } lcore_id = rte_get_next_lcore(-1, 1, 0);