diff --git a/drivers/net/ethernet/nvidia/nvethernet/ether_export.h b/drivers/net/ethernet/nvidia/nvethernet/ether_export.h index 07ef02e9..b8e72a09 100644 --- a/drivers/net/ethernet/nvidia/nvethernet/ether_export.h +++ b/drivers/net/ethernet/nvidia/nvethernet/ether_export.h @@ -39,6 +39,10 @@ struct ether_l2_filter { nveu32_t index; /** Ethernet MAC address to be added */ nveu8_t mac_addr[OSI_ETH_ALEN]; + /** packet duplication */ + nveu32_t pkt_dup; + /** dma channel */ + nveu32_t dma_chan; }; /** diff --git a/drivers/net/ethernet/nvidia/nvethernet/ether_linux.c b/drivers/net/ethernet/nvidia/nvethernet/ether_linux.c index b5e76e8e..4f478560 100644 --- a/drivers/net/ethernet/nvidia/nvethernet/ether_linux.c +++ b/drivers/net/ethernet/nvidia/nvethernet/ether_linux.c @@ -2461,6 +2461,7 @@ static int ether_update_mac_addr_filter(struct ether_priv_data *pdata, } ioctl_data->l2_filter.index = BC_index[osi_core->mac]; memcpy(ioctl_data->l2_filter.mac_addr, bc_addr, ETH_ALEN); + ioctl_data->l2_filter.pkt_dup = OSI_ENABLE; } ioctl_data->l2_filter.dma_routing = OSI_ENABLE; ioctl_data->l2_filter.dma_chan = dma_channel; diff --git a/drivers/net/ethernet/nvidia/nvethernet/sysfs.c b/drivers/net/ethernet/nvidia/nvethernet/sysfs.c index 77cad1ae..aa92f1da 100644 --- a/drivers/net/ethernet/nvidia/nvethernet/sysfs.c +++ b/drivers/net/ethernet/nvidia/nvethernet/sysfs.c @@ -2803,7 +2803,7 @@ static ssize_t ether_mac_frp_show(struct device *dev, entry = &osi_core->frp_table[i]; data = &entry->data; j += scnprintf((buf + j), (PAGE_SIZE - j), - "[%d] ID:%d MD:0x%x ME:0x%x AF:%d RF:%d IM:%d NIC:%d FO:%d OKI:%d DCH:x%x\n", + "[%d] ID:%d MD:0x%x ME:0x%x AF:%d RF:%d IM:%d NIC:%d FO:%d OKI:%d DCH:x%lx\n", i, entry->frp_id, data->match_data, data->match_en, data->accept_frame, data->reject_frame, data->inverse_match,