Commit f8b30859 authored by Asbjoern Sloth Toennesen's avatar Asbjoern Sloth Toennesen Committed by Greg Kroah-Hartman

staging: octeon: use defines instead of magic numbers

The ugly magic number 65392 is waiting for CVMX_IPD_MAX_MTU
to appear in the mips tree.
Signed-off-by: default avatarAsbjoern Sloth Toennesen <asbjorn@asbjorn.st>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 08441a93
...@@ -17,6 +17,8 @@ ...@@ -17,6 +17,8 @@
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/interrupt.h> #include <linux/interrupt.h>
#include <linux/of_net.h> #include <linux/of_net.h>
#include <linux/if_ether.h>
#include <linux/if_vlan.h>
#include <net/dst.h> #include <net/dst.h>
...@@ -39,6 +41,8 @@ ...@@ -39,6 +41,8 @@
#include <asm/octeon/cvmx-gmxx-defs.h> #include <asm/octeon/cvmx-gmxx-defs.h>
#include <asm/octeon/cvmx-smix-defs.h> #include <asm/octeon/cvmx-smix-defs.h>
#define OCTEON_MAX_MTU 65392
static int num_packet_buffers = 1024; static int num_packet_buffers = 1024;
module_param(num_packet_buffers, int, 0444); module_param(num_packet_buffers, int, 0444);
MODULE_PARM_DESC(num_packet_buffers, "\n" MODULE_PARM_DESC(num_packet_buffers, "\n"
...@@ -249,19 +253,21 @@ static int cvm_oct_common_change_mtu(struct net_device *dev, int new_mtu) ...@@ -249,19 +253,21 @@ static int cvm_oct_common_change_mtu(struct net_device *dev, int new_mtu)
struct octeon_ethernet *priv = netdev_priv(dev); struct octeon_ethernet *priv = netdev_priv(dev);
int interface = INTERFACE(priv->port); int interface = INTERFACE(priv->port);
#if IS_ENABLED(CONFIG_VLAN_8021Q) #if IS_ENABLED(CONFIG_VLAN_8021Q)
int vlan_bytes = 4; int vlan_bytes = VLAN_HLEN;
#else #else
int vlan_bytes = 0; int vlan_bytes = 0;
#endif #endif
int mtu_overhead = ETH_HLEN + ETH_FCS_LEN + vlan_bytes;
/* /*
* Limit the MTU to make sure the ethernet packets are between * Limit the MTU to make sure the ethernet packets are between
* 64 bytes and 65535 bytes. * 64 bytes and 65535 bytes.
*/ */
if ((new_mtu + 14 + 4 + vlan_bytes < 64) || if ((new_mtu + mtu_overhead < VLAN_ETH_ZLEN) ||
(new_mtu + 14 + 4 + vlan_bytes > 65392)) { (new_mtu + mtu_overhead > OCTEON_MAX_MTU)) {
pr_err("MTU must be between %d and %d.\n", pr_err("MTU must be between %d and %d.\n",
64 - 14 - 4 - vlan_bytes, 65392 - 14 - 4 - vlan_bytes); VLAN_ETH_ZLEN - mtu_overhead,
OCTEON_MAX_MTU - mtu_overhead);
return -EINVAL; return -EINVAL;
} }
dev->mtu = new_mtu; dev->mtu = new_mtu;
...@@ -271,7 +277,7 @@ static int cvm_oct_common_change_mtu(struct net_device *dev, int new_mtu) ...@@ -271,7 +277,7 @@ static int cvm_oct_common_change_mtu(struct net_device *dev, int new_mtu)
CVMX_HELPER_INTERFACE_MODE_SPI)) { CVMX_HELPER_INTERFACE_MODE_SPI)) {
int index = INDEX(priv->port); int index = INDEX(priv->port);
/* Add ethernet header and FCS, and VLAN if configured. */ /* Add ethernet header and FCS, and VLAN if configured. */
int max_packet = new_mtu + 14 + 4 + vlan_bytes; int max_packet = new_mtu + mtu_overhead;
if (OCTEON_IS_MODEL(OCTEON_CN3XXX) || if (OCTEON_IS_MODEL(OCTEON_CN3XXX) ||
OCTEON_IS_MODEL(OCTEON_CN58XX)) { OCTEON_IS_MODEL(OCTEON_CN58XX)) {
...@@ -286,7 +292,7 @@ static int cvm_oct_common_change_mtu(struct net_device *dev, int new_mtu) ...@@ -286,7 +292,7 @@ static int cvm_oct_common_change_mtu(struct net_device *dev, int new_mtu)
union cvmx_pip_frm_len_chkx frm_len_chk; union cvmx_pip_frm_len_chkx frm_len_chk;
frm_len_chk.u64 = 0; frm_len_chk.u64 = 0;
frm_len_chk.s.minlen = 64; frm_len_chk.s.minlen = VLAN_ETH_ZLEN;
frm_len_chk.s.maxlen = max_packet; frm_len_chk.s.maxlen = max_packet;
cvmx_write_csr(CVMX_PIP_FRM_LEN_CHKX(interface), cvmx_write_csr(CVMX_PIP_FRM_LEN_CHKX(interface),
frm_len_chk.u64); frm_len_chk.u64);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment