{"id":807477,"url":"http://patchwork.ozlabs.org/api/1.0/patches/807477/?format=json","project":{"id":7,"url":"http://patchwork.ozlabs.org/api/1.0/projects/7/?format=json","name":"Linux network development","link_name":"netdev","list_id":"netdev.vger.kernel.org","list_email":"netdev@vger.kernel.org","web_url":null,"scm_url":null,"webscm_url":null},"msgid":"<20170830082924.3180-7-antoine.tenart@free-electrons.com>","date":"2017-08-30T08:29:17","name":"[net-next,v4,06/13] net: mvpp2: improve the link management function","commit_ref":null,"pull_url":null,"state":"accepted","archived":true,"hash":"943e80a87735a13c4326e083e1bd00448ebbe36a","submitter":{"id":61603,"url":"http://patchwork.ozlabs.org/api/1.0/people/61603/?format=json","name":"Antoine Tenart","email":"antoine.tenart@free-electrons.com"},"delegate":{"id":34,"url":"http://patchwork.ozlabs.org/api/1.0/users/34/?format=json","username":"davem","first_name":"David","last_name":"Miller","email":"davem@davemloft.net"},"mbox":"http://patchwork.ozlabs.org/project/netdev/patch/20170830082924.3180-7-antoine.tenart@free-electrons.com/mbox/","series":[{"id":550,"url":"http://patchwork.ozlabs.org/api/1.0/series/550/?format=json","date":"2017-08-30T08:29:24","name":"net: mvpp2: comphy configuration","version":4,"mbox":"http://patchwork.ozlabs.org/series/550/mbox/"}],"check":"pending","checks":"http://patchwork.ozlabs.org/api/patches/807477/checks/","tags":{},"headers":{"Return-Path":"<netdev-owner@vger.kernel.org>","X-Original-To":"patchwork-incoming@ozlabs.org","Delivered-To":"patchwork-incoming@ozlabs.org","Authentication-Results":"ozlabs.org;\n\tspf=none (mailfrom) smtp.mailfrom=vger.kernel.org\n\t(client-ip=209.132.180.67; helo=vger.kernel.org;\n\tenvelope-from=netdev-owner@vger.kernel.org;\n\treceiver=<UNKNOWN>)","Received":["from vger.kernel.org (vger.kernel.org [209.132.180.67])\n\tby ozlabs.org (Postfix) with ESMTP id 3xhzKt0YzWz9sRq\n\tfor <patchwork-incoming@ozlabs.org>;\n\tWed, 30 Aug 2017 18:33:22 +1000 (AEST)","(majordomo@vger.kernel.org) by vger.kernel.org via listexpand\n\tid S1751891AbdH3IcP (ORCPT <rfc822;patchwork-incoming@ozlabs.org>);\n\tWed, 30 Aug 2017 04:32:15 -0400","from mail.free-electrons.com ([62.4.15.54]:58126 \"EHLO\n\tmail.free-electrons.com\" rhost-flags-OK-OK-OK-OK) by vger.kernel.org\n\twith ESMTP id S1751330AbdH3I3u (ORCPT\n\t<rfc822;netdev@vger.kernel.org>); Wed, 30 Aug 2017 04:29:50 -0400","by mail.free-electrons.com (Postfix, from userid 110)\n\tid B9A9621FCE; Wed, 30 Aug 2017 10:29:47 +0200 (CEST)","from localhost (LStLambert-657-1-97-87.w90-63.abo.wanadoo.fr\n\t[90.63.216.87])\n\tby mail.free-electrons.com (Postfix) with ESMTPSA id 3A8AD21F6A;\n\tWed, 30 Aug 2017 10:29:29 +0200 (CEST)"],"X-Spam-Checker-Version":"SpamAssassin 3.4.0 (2014-02-07) on\n\tmail.free-electrons.com","X-Spam-Level":"","X-Spam-Status":"No, score=-1.0 required=5.0 tests=ALL_TRUSTED,SHORTCIRCUIT,\n\tURIBL_BLOCKED shortcircuit=ham autolearn=disabled version=3.4.0","From":"Antoine Tenart <antoine.tenart@free-electrons.com>","To":"davem@davemloft.net, kishon@ti.com, andrew@lunn.ch,\n\tjason@lakedaemon.net, sebastian.hesselbarth@gmail.com,\n\tgregory.clement@free-electrons.com","Cc":"Antoine Tenart <antoine.tenart@free-electrons.com>,\n\tthomas.petazzoni@free-electrons.com, nadavh@marvell.com,\n\tlinux@armlinux.org.uk, linux-kernel@vger.kernel.org,\n\tmw@semihalf.com, stefanc@marvell.com,\n\tmiquel.raynal@free-electrons.com, netdev@vger.kernel.org","Subject":"[PATCH net-next v4 06/13] net: mvpp2: improve the link management\n\tfunction","Date":"Wed, 30 Aug 2017 10:29:17 +0200","Message-Id":"<20170830082924.3180-7-antoine.tenart@free-electrons.com>","X-Mailer":"git-send-email 2.13.5","In-Reply-To":"<20170830082924.3180-1-antoine.tenart@free-electrons.com>","References":"<20170830082924.3180-1-antoine.tenart@free-electrons.com>","Sender":"netdev-owner@vger.kernel.org","Precedence":"bulk","List-ID":"<netdev.vger.kernel.org>","X-Mailing-List":"netdev@vger.kernel.org"},"content":"When the link status changes, the phylib calls the link_event function\nin the mvpp2 driver. Before this patch only the egress/ingress transmit\nwas enabled/disabled. This patch adds more functionality to the link\nstatus management code by enabling/disabling the port per-cpu\ninterrupts, and the port itself. The queues are now stopped as well, and\nthe netif carrier helpers are called.\n\nSigned-off-by: Antoine Tenart <antoine.tenart@free-electrons.com>\n---\n drivers/net/ethernet/marvell/mvpp2.c | 11 +++++++++++\n 1 file changed, 11 insertions(+)","diff":"diff --git a/drivers/net/ethernet/marvell/mvpp2.c b/drivers/net/ethernet/marvell/mvpp2.c\nindex 9c0c81e68d55..09cad32734f3 100644\n--- a/drivers/net/ethernet/marvell/mvpp2.c\n+++ b/drivers/net/ethernet/marvell/mvpp2.c\n@@ -5777,14 +5777,25 @@ static void mvpp2_link_event(struct net_device *dev)\n \t\t\tval |= (MVPP2_GMAC_FORCE_LINK_PASS |\n \t\t\t\tMVPP2_GMAC_FORCE_LINK_DOWN);\n \t\t\twritel(val, port->base + MVPP2_GMAC_AUTONEG_CONFIG);\n+\n+\t\t\tmvpp2_interrupts_enable(port);\n+\t\t\tmvpp2_port_enable(port);\n+\n \t\t\tmvpp2_egress_enable(port);\n \t\t\tmvpp2_ingress_enable(port);\n+\t\t\tnetif_carrier_on(dev);\n+\t\t\tnetif_tx_wake_all_queues(dev);\n \t\t} else {\n \t\t\tport->duplex = -1;\n \t\t\tport->speed = 0;\n \n+\t\t\tnetif_tx_stop_all_queues(dev);\n+\t\t\tnetif_carrier_off(dev);\n \t\t\tmvpp2_ingress_disable(port);\n \t\t\tmvpp2_egress_disable(port);\n+\n+\t\t\tmvpp2_port_disable(port);\n+\t\t\tmvpp2_interrupts_disable(port);\n \t\t}\n \n \t\tphy_print_status(phydev);\n","prefixes":["net-next","v4","06/13"]}