From nobody Thu Nov 28 17:39:58 2024 Received: from mail-pl1-f181.google.com (mail-pl1-f181.google.com [209.85.214.181]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id E47D9199EB0; Mon, 30 Sep 2024 18:00:47 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.214.181 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1727719249; cv=none; b=GNijrKhdkHXHqBLHNWHYwdZWAp///upfty43QVo8xfyRGH2XQMImvkuYmUb9i+KdlxlrX3Aj4BPvSkc/VwAPaLiqW3mSQfbEyqp/UNa5TCXFnD5wp6ZZSTEaX2TPY76d1LDzaERvfK4aFcJ3h7Aewt2Ote6OsHTIvMf9dzOdufY= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1727719249; c=relaxed/simple; bh=8lBOVvzvGRf+RpMwtTpzh+BQKToFBXpodpfesW9+iz8=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=DyotZgxsEQfWwFfqJZDOZnMQzXbQE0Iex9kW8C3GY/kGmeQleRBhtZyzQLA0elXeg7JDFkX7OsGa18NTIRrH37jQ/XkWW7c3YSmZU00FJUP1r5QCN/H7kr7B1psHZchH9DK5fXRTLydNNVsdP5mE/ChvCDN6Y+izS5diSt7f7rU= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=MV4i8kth; arc=none smtp.client-ip=209.85.214.181 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="MV4i8kth" Received: by mail-pl1-f181.google.com with SMTP id d9443c01a7336-20b86298710so12047465ad.1; Mon, 30 Sep 2024 11:00:47 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1727719247; x=1728324047; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=YXiaXkjRmxS0jNHUrwUuLitPui/qQi7NdietjnRpv7U=; b=MV4i8kth2DkgT1+hsswR/Tr+UOL5QIm6R2ZeNZYKciyYEAdN8R4D3qy0qZ4Rr8XjP/ xH+IF5B+xsjIZNSFII4kFW7ssnY33tnPu9bN3E3bz6ELwjxeekVKjQRw5AGlUjAbr5fX mC1JzToDPPdAapOoxYJ7BbpcWeWH0YhUmGNLm1wQyprYUiyiQOdRi8aBE9LEifivcSVy LFYhv0m3XRN9UE/2h5vwi7DWHdiIWL9lGdDE5hxJolYHZRPpSj4zD6xXz+9aLEbG2dhY dSPYbtclgdkYaxgv3yD7zmy4H/dK7pqktL22kRnehnemL6QujPhrlZJSyKwvA3izGp+e 4nqg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1727719247; x=1728324047; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=YXiaXkjRmxS0jNHUrwUuLitPui/qQi7NdietjnRpv7U=; b=l5JOrLuHFx7aiec/1shLhVIJGLqyOIH0lkYa7xS+po3DEpZwHSOxvL92Nm0B99OQHs qNF0FfyGSNKYkRtPs4BE9ZQiLi2BMSQKEJiMZ3266uiS6Q2Lk7OdHY1L2fY/iZONM2R3 Zp0OtP6YmAfpYwDQ9VQ3S3ax5L6dIP4yYXdY2yJ7exnUWIAlgBGywzhys+unpQ67KUao /CTguJghJ5xTR9drc+zwYNiHtRySf0h/x2pFFoAZ5rJD4jlLPWsfaqclk0DA3I8vxUgD AXhs0oDFoSks8RT7fjLKJLEd5Vx4ygjDRsXeE3vTGMB6o3nJGfHRlcVowonM1R8umev1 hOzg== X-Forwarded-Encrypted: i=1; AJvYcCVYrJxoh9qCs53Y4Ichx4kbgBNYe3W35LeH6K4fW3YbHayEXL6vAGtZ4VIRiTnkiu8CwzRusk3J6juhsvE=@vger.kernel.org X-Gm-Message-State: AOJu0YxIywyEilH1NRxbKxN7NDX0JQvIHCXFzjZ180nEoBCATORDcIRr 2GicvrS5EtGuBSJNARNmI5KFssvC/vLl7y4JwfiE6YX+RcZvs5tngnqfQsgv X-Google-Smtp-Source: AGHT+IHD/1yzjotAV6dt1XZMfm4CmugCKasvgir3TrVHmC+WtZOYvWw8gjBmJfto+tfh8nC9jFNdcw== X-Received: by 2002:a05:6a21:339c:b0:1d4:fc66:8267 with SMTP id adf61e73a8af0-1d4fc668340mr20134350637.4.1727719246970; Mon, 30 Sep 2024 11:00:46 -0700 (PDT) Received: from ryzen.lan ([2601:644:8200:dab8::a86]) by smtp.gmail.com with ESMTPSA id d2e1a72fcca58-71b26524a56sm6740653b3a.149.2024.09.30.11.00.45 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 30 Sep 2024 11:00:46 -0700 (PDT) From: Rosen Penev To: netdev@vger.kernel.org Cc: andrew@lunn.ch, davem@davemloft.net, edumazet@google.com, kuba@kernel.org, pabeni@redhat.com, linux-kernel@vger.kernel.org, jacob.e.keller@intel.com, horms@kernel.org, sd@queasysnail.net, chunkeey@gmail.com Subject: [PATCH net-next 05/13] net: ibm: emac: remove bootlist support Date: Mon, 30 Sep 2024 11:00:28 -0700 Message-ID: <20240930180036.87598-6-rosenp@gmail.com> X-Mailer: git-send-email 2.46.2 In-Reply-To: <20240930180036.87598-1-rosenp@gmail.com> References: <20240930180036.87598-1-rosenp@gmail.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" This seems to be mainly used for deterministic interfaces. systemd already does this in userspace. Allows simplifying the driver with a single module_platform_driver. Signed-off-by: Rosen Penev --- drivers/net/ethernet/ibm/emac/core.c | 117 +++------------------------ 1 file changed, 9 insertions(+), 108 deletions(-) diff --git a/drivers/net/ethernet/ibm/emac/core.c b/drivers/net/ethernet/ib= m/emac/core.c index a55e84eb1d4d..a4701e2f9f73 100644 --- a/drivers/net/ethernet/ibm/emac/core.c +++ b/drivers/net/ethernet/ibm/emac/core.c @@ -95,21 +95,6 @@ MODULE_LICENSE("GPL"); static u32 busy_phy_map; static DEFINE_MUTEX(emac_phy_map_lock); =20 -/* Having stable interface names is a doomed idea. However, it would be ni= ce - * if we didn't have completely random interface names at boot too :-) It's - * just a matter of making everybody's life easier. Since we are doing - * threaded probing, it's a bit harder though. The base idea here is that - * we make up a list of all emacs in the device-tree before we register the - * driver. Every emac will then wait for the previous one in the list to - * initialize before itself. We should also keep that list ordered by - * cell_index. - * That list is only 4 entries long, meaning that additional EMACs don't - * get ordering guarantees unless EMAC_BOOT_LIST_SIZE is increased. - */ - -#define EMAC_BOOT_LIST_SIZE 4 -static struct device_node *emac_boot_list[EMAC_BOOT_LIST_SIZE]; - /* I don't want to litter system log with timeout errors * when we have brain-damaged PHY. */ @@ -2330,14 +2315,12 @@ struct emac_depentry { #define EMAC_DEP_RGMII_IDX 2 #define EMAC_DEP_TAH_IDX 3 #define EMAC_DEP_MDIO_IDX 4 -#define EMAC_DEP_PREV_IDX 5 -#define EMAC_DEP_COUNT 6 +#define EMAC_DEP_COUNT 5 =20 static int emac_check_deps(struct emac_instance *dev, struct emac_depentry *deps) { int i, there =3D 0; - struct device_node *np; =20 for (i =3D 0; i < EMAC_DEP_COUNT; i++) { /* no dependency on that item, allright */ @@ -2345,17 +2328,6 @@ static int emac_check_deps(struct emac_instance *dev, there++; continue; } - /* special case for blist as the dependency might go away */ - if (i =3D=3D EMAC_DEP_PREV_IDX) { - np =3D *(dev->blist - 1); - if (np =3D=3D NULL) { - deps[i].phandle =3D 0; - there++; - continue; - } - if (deps[i].node =3D=3D NULL) - deps[i].node =3D of_node_get(np); - } if (deps[i].node =3D=3D NULL) deps[i].node =3D of_find_node_by_phandle(deps[i].phandle); if (deps[i].node =3D=3D NULL) @@ -2397,8 +2369,6 @@ static int emac_wait_deps(struct emac_instance *dev) deps[EMAC_DEP_TAH_IDX].phandle =3D dev->tah_ph; if (dev->mdio_ph) deps[EMAC_DEP_MDIO_IDX].phandle =3D dev->mdio_ph; - if (dev->blist && dev->blist > emac_boot_list) - deps[EMAC_DEP_PREV_IDX].phandle =3D 0xffffffffu; err =3D emac_check_deps(dev, deps); for (i =3D 0; i < EMAC_DEP_COUNT; i++) { of_node_put(deps[i].node); @@ -2412,7 +2382,6 @@ static int emac_wait_deps(struct emac_instance *dev) dev->tah_dev =3D deps[EMAC_DEP_TAH_IDX].ofdev; dev->mdio_dev =3D deps[EMAC_DEP_MDIO_IDX].ofdev; } - platform_device_put(deps[EMAC_DEP_PREV_IDX].ofdev); return err; } =20 @@ -2993,8 +2962,7 @@ static int emac_probe(struct platform_device *ofdev) struct net_device *ndev; struct emac_instance *dev; struct device_node *np =3D ofdev->dev.of_node; - struct device_node **blist =3D NULL; - int err, i; + int err; =20 /* Skip unused/unwired EMACS. We leave the check for an unused * property here for now, but new flat device trees should set a @@ -3003,21 +2971,14 @@ static int emac_probe(struct platform_device *ofdev) if (of_property_read_bool(np, "unused") || !of_device_is_available(np)) return -ENODEV; =20 - /* Find ourselves in the bootlist if we are there */ - for (i =3D 0; i < EMAC_BOOT_LIST_SIZE; i++) - if (emac_boot_list[i] =3D=3D np) - blist =3D &emac_boot_list[i]; - /* Allocate our net_device structure */ - err =3D -ENOMEM; ndev =3D devm_alloc_etherdev(&ofdev->dev, sizeof(struct emac_instance)); if (!ndev) - goto err_gone; + return -ENOMEM; =20 dev =3D netdev_priv(ndev); dev->ndev =3D ndev; dev->ofdev =3D ofdev; - dev->blist =3D blist; SET_NETDEV_DEV(ndev, &ofdev->dev); =20 /* Initialize some embedded data structures */ @@ -3029,16 +2990,15 @@ static int emac_probe(struct platform_device *ofdev) /* Init various config data based on device-tree */ err =3D emac_init_config(dev); if (err) - goto err_gone; + return err; =20 /* Setup error IRQ handler */ dev->emac_irq =3D platform_get_irq(ofdev, 0); err =3D devm_request_irq(&ofdev->dev, dev->emac_irq, emac_irq, 0, "EMAC", dev); if (err) { - dev_err_probe(&ofdev->dev, err, "failed to request IRQ %d", - dev->emac_irq); - goto err_gone; + return dev_err_probe(&ofdev->dev, err, + "failed to request IRQ %d", dev->emac_irq); } =20 ndev->irq =3D dev->emac_irq; @@ -3046,14 +3006,13 @@ static int emac_probe(struct platform_device *ofdev) dev->emacp =3D devm_platform_ioremap_resource(ofdev, 0); if (IS_ERR(dev->emacp)) { dev_err(&ofdev->dev, "can't map device registers"); - err =3D PTR_ERR(dev->emacp); - goto err_gone; + return PTR_ERR(dev->emacp); } =20 /* Wait for dependent devices */ err =3D emac_wait_deps(dev); if (err) - goto err_gone; + return err; dev->mal =3D platform_get_drvdata(dev->mal_dev); if (dev->mdio_dev !=3D NULL) dev->mdio_instance =3D platform_get_drvdata(dev->mdio_dev); @@ -3181,9 +3140,6 @@ static int emac_probe(struct platform_device *ofdev) mal_unregister_commac(dev->mal, &dev->commac); err_rel_deps: emac_put_deps(dev); - err_gone: - if (blist) - *blist =3D NULL; return err; } =20 @@ -3237,59 +3193,4 @@ static struct platform_driver emac_driver =3D { .remove_new =3D emac_remove, }; =20 -static void __init emac_make_bootlist(void) -{ - struct device_node *np =3D NULL; - int j, max, i =3D 0; - int cell_indices[EMAC_BOOT_LIST_SIZE]; - - /* Collect EMACs */ - while((np =3D of_find_all_nodes(np)) !=3D NULL) { - u32 idx; - - if (of_match_node(emac_match, np) =3D=3D NULL) - continue; - if (of_property_read_bool(np, "unused")) - continue; - if (of_property_read_u32(np, "cell-index", &idx)) - continue; - cell_indices[i] =3D idx; - emac_boot_list[i++] =3D of_node_get(np); - if (i >=3D EMAC_BOOT_LIST_SIZE) { - of_node_put(np); - break; - } - } - max =3D i; - - /* Bubble sort them (doh, what a creative algorithm :-) */ - for (i =3D 0; max > 1 && (i < (max - 1)); i++) - for (j =3D i; j < max; j++) { - if (cell_indices[i] > cell_indices[j]) { - swap(emac_boot_list[i], emac_boot_list[j]); - swap(cell_indices[i], cell_indices[j]); - } - } -} - -static int __init emac_init(void) -{ - /* Build EMAC boot list */ - emac_make_bootlist(); - - return platform_driver_register(&emac_driver); -} - -static void __exit emac_exit(void) -{ - int i; - - platform_driver_unregister(&emac_driver); - - /* Destroy EMAC boot list */ - for (i =3D 0; i < EMAC_BOOT_LIST_SIZE; i++) - of_node_put(emac_boot_list[i]); -} - -module_init(emac_init); -module_exit(emac_exit); +module_platform_driver(emac_driver); --=20 2.46.2