Re-shuffle comparisons in order to avoid having to check for FEC_RBD_ERR in bd_status more than once. Signed-off-by: Andrey Smirnov <andrew.smirnov@xxxxxxxxx> --- drivers/net/fec_imx.c | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) diff --git a/drivers/net/fec_imx.c b/drivers/net/fec_imx.c index 904eba30a..25e2425d6 100644 --- a/drivers/net/fec_imx.c +++ b/drivers/net/fec_imx.c @@ -571,9 +571,11 @@ static int fec_recv(struct eth_device *dev) if (bd_status & FEC_RBD_EMPTY) return 0; - if ((bd_status & FEC_RBD_LAST) && !(bd_status & FEC_RBD_ERR) && - ((readw(&rbd->data_length) - 4) > 14)) { - + if (bd_status & FEC_RBD_ERR) { + dev_warn(&dev->dev, "error frame: 0x%p 0x%08x\n", + rbd, bd_status); + } else if ((bd_status & FEC_RBD_LAST) && + ((readw(&rbd->data_length) - 4) > 14)) { if (fec_is_imx28(fec)) imx28_fix_endianess_rd( phys_to_virt(readl(&rbd->data_pointer)), @@ -586,10 +588,6 @@ static int fec_recv(struct eth_device *dev) frame_length = readw(&rbd->data_length) - 4; net_receive(dev, frame->data, frame_length); len = frame_length; - } else { - if (bd_status & FEC_RBD_ERR) { - dev_warn(&dev->dev, "error frame: 0x%p 0x%08x\n", rbd, bd_status); - } } /* * free the current buffer, restart the engine -- 2.17.1 _______________________________________________ barebox mailing list barebox@xxxxxxxxxxxxxxxxxxx http://lists.infradead.org/mailman/listinfo/barebox