/* * generate_nlmsg.c Testsuite helper generating nlmsg blob * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version * 2 of the License, or (at your option) any later version. * * Authors: Phil Sutter <phil@nwl.cc> */ #include <netinet/ether.h> #include <libnetlink.h> #include <sys/socket.h> #include <linux/if.h> #include <errno.h> #include <stdio.h> int fill_vf_rate_test(void *buf, size_t buflen) { char bcmac[6] = { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff }; struct ifla_vf_mac vf_mac = { .mac = { 0x0, 0x26, 0x6c, 0xff, 0xb5, 0xc0 }, }; struct ifla_vf_link_state vf_link_state = { 0 }; struct ifla_vf_tx_rate vf_tx_rate = { 0 }; struct ifla_vf_spoofchk vf_spoofchk = { .setting = 1, }; struct ifla_vf_vlan vf_vlan = { 0 }; struct rtattr *vfinfo_list, *vfinfo; struct nlmsghdr *h = buf; struct ifinfomsg *ifi; h->nlmsg_type = RTM_NEWLINK; h->nlmsg_len = NLMSG_LENGTH(sizeof(*ifi)); ifi = NLMSG_DATA(h); ifi->ifi_type = ARPHRD_ETHER; ifi->ifi_index = 1; ifi->ifi_flags = IFF_RUNNING | IFF_BROADCAST | IFF_MULTICAST | IFF_UP | IFF_LOWER_UP; #define ASSERT(x) if (x < 0) return -1 #define ATTR_L(t, v, l) ASSERT(addattr_l(h, buflen, t, v, l)) #define ATTR_8(t, v) ASSERT(addattr8(h, buflen, t, v)) #define ATTR_32(t, v) ASSERT(addattr32(h, buflen, t, v)) #define ATTR_STRZ(t, v) ASSERT(addattrstrz(h, buflen, t, v)) #define NEST(t) addattr_nest(h, buflen, t) #define NEST_END(t) addattr_nest_end(h, t) ATTR_STRZ(IFLA_IFNAME, "eth0"); ATTR_32(IFLA_TXQLEN, 10000); ATTR_8(IFLA_OPERSTATE, 6); ATTR_8(IFLA_LINKMODE, 0); ATTR_32(IFLA_MTU, 9000); ATTR_32(IFLA_GROUP, 0); ATTR_32(IFLA_PROMISCUITY, 0); ATTR_32(IFLA_NUM_TX_QUEUES, 8); ATTR_32(IFLA_NUM_RX_QUEUES, 8); ATTR_8(IFLA_CARRIER, 1); ATTR_STRZ(IFLA_QDISC, "mq"); ATTR_L(IFLA_ADDRESS, vf_mac.mac, ETH_ALEN); ATTR_L(IFLA_BROADCAST, bcmac, sizeof(bcmac)); ATTR_32(IFLA_NUM_VF, 2); vfinfo_list = NEST(IFLA_VFINFO_LIST); vfinfo = NEST(IFLA_VF_INFO); ATTR_L(IFLA_VF_MAC, &vf_mac, sizeof(vf_mac)); ATTR_L(IFLA_VF_VLAN, &vf_vlan, sizeof(vf_vlan)); ATTR_L(IFLA_VF_TX_RATE, &vf_tx_rate, sizeof(vf_tx_rate)); ATTR_L(IFLA_VF_SPOOFCHK, &vf_spoofchk, sizeof(vf_spoofchk)); ATTR_L(IFLA_VF_LINK_STATE, &vf_link_state, sizeof(vf_link_state)); NEST_END(vfinfo); vf_mac.vf = vf_vlan.vf = vf_tx_rate.vf = 1; vf_spoofchk.vf = vf_link_state.vf = 1; vfinfo = NEST(IFLA_VF_INFO); ATTR_L(IFLA_VF_MAC, &vf_mac, sizeof(vf_mac)); ATTR_L(IFLA_VF_VLAN, &vf_vlan, sizeof(vf_vlan)); ATTR_L(IFLA_VF_TX_RATE, &vf_tx_rate, sizeof(vf_tx_rate)); ATTR_L(IFLA_VF_SPOOFCHK, &vf_spoofchk, sizeof(vf_spoofchk)); ATTR_L(IFLA_VF_LINK_STATE, &vf_link_state, sizeof(vf_link_state)); NEST_END(vfinfo); NEST_END(vfinfo_list); return h->nlmsg_len; } int main(void) { char buf[16384] = { 0 }; int msglen; FILE *fp; msglen = fill_vf_rate_test(buf, sizeof(buf)); if (msglen < 0) { fprintf(stderr, "fill_vf_rate_test() failed!\n"); return 1; } fp = fopen("tests/ip/link/dev_wo_vf_rate.nl", "w"); if (!fp) { perror("fopen()"); return 1; } if (fwrite(buf, msglen, 1, fp) != 1) { perror("fwrite()"); return 1; } fclose(fp); return 0; }