30/10/2019 16:07, Ilya Maximets: > On 29.10.2019 19:50, Thomas Monjalon wrote: > > In a virtual environment, the network controller may have to configure > > some SR-IOV VF parameters for security reasons. > > > > When the PF (host port) is driven by DPDK (OVS-DPDK case), > > we face two different cases: > > - driver is bifurcated (Mellanox case), > > so the VF can be configured via the kernel. > > - driver is on top of UIO or VFIO, so DPDK API is required, > > and PMD-specific APIs were used. > > So, what is wrong with setting VF mac via the representor port as > it done now? From our previous discussion, I thought that we concluded > that is enough to have current API, i.e. just call set_default_mac() > for a representor port and this will lead to setting mac for VF. > This is how it's implemented in Linux kernel and this is how it's > implemented in current DPDK drivers that supports setting mac for > the representor.
I don't know what is done in the Linux kernel. In DPDK, setting the MAC of the representor is really setting the MAC of the representor. Is it crazy? > The only use case for this new API is to be able to control mac of > the representor itself, which doesn't make much sense. At least there > are only hypothetical use cases. And once again, Linux kernel doesn't > support this behavior. I think it is sane to be able to set different MAC addresses for the representor and the VF. > > This new generic API will avoid vendors fragmentation. > > I don't see the fragmentation. Right now you can set VF mac from DPDK > by calling set_default_mac() for representor. This API exists for all > vendors. Not implemented for Intel, but new API is not implemented too. No, the current situation is the following: - for mlx5, VF MAC can be configured with iproute2 or netlink - for ixgbe, rte_pmd_ixgbe_set_vf_mac_addr() - for i40e, rte_pmd_i40e_set_vf_mac_addr() - for bnxt, rte_pmd_bnxt_set_vf_mac_addr() > The this is that this new API will produce conceptual fragmentation > between DPDK and the Linux kernel, because to do the same thing you'll > have to use different ways. I mean, to change mac of VF in kernel you > need to set mac to the representor, but in DPDK changing setting mac to > representor will lead to changing the mac of the representor itself, > not the VF. This will be really confusing for users. I am not responsible of the choices in Linux. But I agree it would be interesting to check the reason of such decision. Rony, please could you explain?