Skip to content

Commit

Permalink
mtd: rawnand: omap_elm: u-boot driver model support
Browse files Browse the repository at this point in the history
Support u-boot driver model. We still retain
support legacy way of doing things if ELM_BASE
is defined in <asm/arch/hardware.h>

We could completely get rid of that if all
platforms defining ELM_BASE get rid of that definition
and enable CONFIG_SYS_NAND_SELF_INIT and are verified
to work.

Signed-off-by: Roger Quadros <[email protected]>
Signed-off-by: Michael Trimarchi <[email protected]>
Signed-off-by: Dario Binacchi <[email protected]>
Reviewed-by: Tom Rini <[email protected]>
Link: https://lore.kernel.org/all/[email protected]
Link: https://lore.kernel.org/all/CABGWkvrvKiVA_yaDnHJcHEKwc+pEuLdz=i6HQEY0oJQvohCUsw@mail.gmail.com
  • Loading branch information
rogerq authored and passgat committed Jan 8, 2023
1 parent 8993d5f commit 7363cf0
Show file tree
Hide file tree
Showing 3 changed files with 54 additions and 2 deletions.
38 changes: 37 additions & 1 deletion drivers/mtd/nand/raw/omap_elm.c
Original file line number Diff line number Diff line change
Expand Up @@ -15,9 +15,14 @@
#include <common.h>
#include <asm/io.h>
#include <linux/errno.h>
#include <linux/mtd/omap_elm.h>
#include <asm/arch/hardware.h>

#include <dm.h>
#include <linux/ioport.h>
#include <linux/io.h>

#include "omap_elm.h"

#define DRIVER_NAME "omap-elm"
#define ELM_DEFAULT_POLY (0)

Expand Down Expand Up @@ -180,6 +185,7 @@ void elm_reset(void)
;
}

#ifdef ELM_BASE
/**
* elm_init - Initialize ELM module
*
Expand All @@ -191,3 +197,33 @@ void elm_init(void)
elm_cfg = (struct elm *)ELM_BASE;
elm_reset();
}
#endif

#if CONFIG_IS_ENABLED(SYS_NAND_SELF_INIT)

static int elm_probe(struct udevice *dev)
{
#ifndef ELM_BASE
struct resource res;

dev_read_resource(dev, 0, &res);
elm_cfg = devm_ioremap(dev, res.start, resource_size(&res));
elm_reset();
#endif

return 0;
}

static const struct udevice_id elm_ids[] = {
{ .compatible = "ti,am3352-elm" },
{ .compatible = "ti,am64-elm" },
{ }
};

U_BOOT_DRIVER(gpmc_elm) = {
.name = DRIVER_NAME,
.id = UCLASS_MTD,
.of_match = elm_ids,
.probe = elm_probe,
};
#endif /* CONFIG_SYS_NAND_SELF_INIT */
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,12 @@ int elm_check_error(u8 *syndrome, enum bch_level bch_type, u32 *error_count,
u32 *error_locations);
int elm_config(enum bch_level level);
void elm_reset(void);
#ifdef ELM_BASE
void elm_init(void);
#else
static inline void elm_init(void)
{
}
#endif
#endif /* __ASSEMBLY__ */
#endif /* __ASM_ARCH_ELM_H */
12 changes: 11 additions & 1 deletion drivers/mtd/nand/raw/omap_gpmc.c
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,8 @@
#include <linux/bch.h>
#include <linux/compiler.h>
#include <nand.h>
#include <linux/mtd/omap_elm.h>

#include "omap_elm.h"

#ifndef GPMC_MAX_CS
#define GPMC_MAX_CS 4
Expand Down Expand Up @@ -1249,6 +1250,15 @@ void board_nand_init(void)
struct udevice *dev;
int ret;

#ifdef CONFIG_NAND_OMAP_ELM
ret = uclass_get_device_by_driver(UCLASS_MTD,
DM_DRIVER_GET(gpmc_elm), &dev);
if (ret && ret != -ENODEV) {
pr_err("%s: Failed to get ELM device: %d\n", __func__, ret);
return;
}
#endif

ret = uclass_get_device_by_driver(UCLASS_MTD,
DM_DRIVER_GET(gpmc_nand), &dev);
if (ret && ret != -ENODEV)
Expand Down

0 comments on commit 7363cf0

Please sign in to comment.