mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-03 20:44:18 +00:00
164 lines
4.9 KiB
Diff
164 lines
4.9 KiB
Diff
|
From 4bc5cec5361dd6a2ae3bd044c79a4b5227bb9627 Mon Sep 17 00:00:00 2001
|
||
|
From: Samuel Holland <samuel@sholland.org>
|
||
|
Date: Mon, 16 May 2022 00:47:32 -0500
|
||
|
Subject: [PATCH 35/90] mtd: nand: sunxi: Pass the device to the init function
|
||
|
|
||
|
This more closely matches the U-Boot driver to the Linux version.
|
||
|
|
||
|
Series-to: sunxi
|
||
|
|
||
|
Cover-letter:
|
||
|
mtd: nand: sunxi: Convert to devicetree and the driver model
|
||
|
This series converts the sunxi NAND driver to get its resources (clocks,
|
||
|
resets, pins) from the devicetree, and probe using the driver model.
|
||
|
|
||
|
In addition to the immediate cleanup, this allows backporting more
|
||
|
patches (bugfixes, newer SoC support) from the Linux driver.
|
||
|
END
|
||
|
|
||
|
Signed-off-by: Samuel Holland <samuel@sholland.org>
|
||
|
---
|
||
|
drivers/mtd/nand/raw/sunxi_nand.c | 39 ++++++++++++++++---------------
|
||
|
1 file changed, 20 insertions(+), 19 deletions(-)
|
||
|
|
||
|
--- a/drivers/mtd/nand/raw/sunxi_nand.c
|
||
|
+++ b/drivers/mtd/nand/raw/sunxi_nand.c
|
||
|
@@ -1604,7 +1604,8 @@ static int sunxi_nand_ecc_init(struct mt
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
-static int sunxi_nand_chip_init(ofnode np, struct sunxi_nfc *nfc, int devnum)
|
||
|
+static int sunxi_nand_chip_init(struct udevice *dev, struct sunxi_nfc *nfc,
|
||
|
+ ofnode np, int devnum)
|
||
|
{
|
||
|
const struct nand_sdr_timings *timings;
|
||
|
struct sunxi_nand_chip *chip;
|
||
|
@@ -1620,7 +1621,7 @@ static int sunxi_nand_chip_init(ofnode n
|
||
|
|
||
|
nsels /= sizeof(u32);
|
||
|
if (!nsels || nsels > 8) {
|
||
|
- dev_err(nfc->dev, "invalid reg property size\n");
|
||
|
+ dev_err(dev, "invalid reg property size\n");
|
||
|
return -EINVAL;
|
||
|
}
|
||
|
|
||
|
@@ -1628,7 +1629,7 @@ static int sunxi_nand_chip_init(ofnode n
|
||
|
(nsels * sizeof(struct sunxi_nand_chip_sel)),
|
||
|
GFP_KERNEL);
|
||
|
if (!chip) {
|
||
|
- dev_err(nfc->dev, "could not allocate chip\n");
|
||
|
+ dev_err(dev, "could not allocate chip\n");
|
||
|
return -ENOMEM;
|
||
|
}
|
||
|
|
||
|
@@ -1638,19 +1639,19 @@ static int sunxi_nand_chip_init(ofnode n
|
||
|
for (i = 0; i < nsels; i++) {
|
||
|
ret = ofnode_read_u32_index(np, "reg", i, &tmp);
|
||
|
if (ret) {
|
||
|
- dev_err(nfc->dev, "could not retrieve reg property: %d\n",
|
||
|
+ dev_err(dev, "could not retrieve reg property: %d\n",
|
||
|
ret);
|
||
|
return ret;
|
||
|
}
|
||
|
|
||
|
if (tmp > NFC_MAX_CS) {
|
||
|
- dev_err(nfc->dev,
|
||
|
+ dev_err(dev,
|
||
|
"invalid reg value: %u (max CS = 7)\n", tmp);
|
||
|
return -EINVAL;
|
||
|
}
|
||
|
|
||
|
if (test_and_set_bit(tmp, &nfc->assigned_cs)) {
|
||
|
- dev_err(nfc->dev, "CS %d already assigned\n", tmp);
|
||
|
+ dev_err(dev, "CS %d already assigned\n", tmp);
|
||
|
return -EINVAL;
|
||
|
}
|
||
|
|
||
|
@@ -1661,9 +1662,9 @@ static int sunxi_nand_chip_init(ofnode n
|
||
|
chip->sels[i].rb.type = RB_NATIVE;
|
||
|
chip->sels[i].rb.info.nativeid = tmp;
|
||
|
} else {
|
||
|
- ret = gpio_request_by_name_nodev(np, "rb-gpios", i,
|
||
|
- &chip->sels[i].rb.info.gpio,
|
||
|
- GPIOD_IS_IN);
|
||
|
+ ret = gpio_request_by_name(dev, "rb-gpios", i,
|
||
|
+ &chip->sels[i].rb.info.gpio,
|
||
|
+ GPIOD_IS_IN);
|
||
|
if (ret)
|
||
|
chip->sels[i].rb.type = RB_GPIO;
|
||
|
else
|
||
|
@@ -1674,7 +1675,7 @@ static int sunxi_nand_chip_init(ofnode n
|
||
|
timings = onfi_async_timing_mode_to_sdr_timings(0);
|
||
|
if (IS_ERR(timings)) {
|
||
|
ret = PTR_ERR(timings);
|
||
|
- dev_err(nfc->dev,
|
||
|
+ dev_err(dev,
|
||
|
"could not retrieve timings for ONFI mode 0: %d\n",
|
||
|
ret);
|
||
|
return ret;
|
||
|
@@ -1682,7 +1683,7 @@ static int sunxi_nand_chip_init(ofnode n
|
||
|
|
||
|
ret = sunxi_nand_chip_set_timings(nfc, chip, timings);
|
||
|
if (ret) {
|
||
|
- dev_err(nfc->dev, "could not configure chip timings: %d\n", ret);
|
||
|
+ dev_err(dev, "could not configure chip timings: %d\n", ret);
|
||
|
return ret;
|
||
|
}
|
||
|
|
||
|
@@ -1717,25 +1718,25 @@ static int sunxi_nand_chip_init(ofnode n
|
||
|
|
||
|
ret = sunxi_nand_chip_init_timings(nfc, chip);
|
||
|
if (ret) {
|
||
|
- dev_err(nfc->dev, "could not configure chip timings: %d\n", ret);
|
||
|
+ dev_err(dev, "could not configure chip timings: %d\n", ret);
|
||
|
return ret;
|
||
|
}
|
||
|
|
||
|
ret = sunxi_nand_ecc_init(mtd, &nand->ecc);
|
||
|
if (ret) {
|
||
|
- dev_err(nfc->dev, "ECC init failed: %d\n", ret);
|
||
|
+ dev_err(dev, "ECC init failed: %d\n", ret);
|
||
|
return ret;
|
||
|
}
|
||
|
|
||
|
ret = nand_scan_tail(mtd);
|
||
|
if (ret) {
|
||
|
- dev_err(nfc->dev, "nand_scan_tail failed: %d\n", ret);
|
||
|
+ dev_err(dev, "nand_scan_tail failed: %d\n", ret);
|
||
|
return ret;
|
||
|
}
|
||
|
|
||
|
ret = nand_register(devnum, mtd);
|
||
|
if (ret) {
|
||
|
- dev_err(nfc->dev, "failed to register mtd device: %d\n", ret);
|
||
|
+ dev_err(dev, "failed to register mtd device: %d\n", ret);
|
||
|
return ret;
|
||
|
}
|
||
|
|
||
|
@@ -1744,13 +1745,13 @@ static int sunxi_nand_chip_init(ofnode n
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
-static int sunxi_nand_chips_init(ofnode node, struct sunxi_nfc *nfc)
|
||
|
+static int sunxi_nand_chips_init(struct udevice *dev, struct sunxi_nfc *nfc)
|
||
|
{
|
||
|
ofnode nand_np;
|
||
|
int ret, i = 0;
|
||
|
|
||
|
- ofnode_for_each_subnode(nand_np, node) {
|
||
|
- ret = sunxi_nand_chip_init(nand_np, nfc, i++);
|
||
|
+ dev_for_each_subnode(nand_np, dev) {
|
||
|
+ ret = sunxi_nand_chip_init(dev, nfc, nand_np, i++);
|
||
|
if (ret)
|
||
|
return ret;
|
||
|
}
|
||
|
@@ -1802,7 +1803,7 @@ static int sunxi_nand_probe(struct udevi
|
||
|
if (ret)
|
||
|
return ret;
|
||
|
|
||
|
- ret = sunxi_nand_chips_init(dev_ofnode(dev), nfc);
|
||
|
+ ret = sunxi_nand_chips_init(dev, nfc);
|
||
|
if (ret) {
|
||
|
dev_err(dev, "failed to init nand chips\n");
|
||
|
return ret;
|