mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2024-11-01 17:08:10 +00:00
e95d8aafa5
This patch does the following: -const int of_get_nand_ecc_mode(struct device_node *np) +int of_get_nand_ecc_mode(struct device_node *np) because: 1. it is probably just a typo? 2. it causes warnings like this when people assing the returned value to an 'int' variable: include/linux/of_mtd.h:14:18: warning: type qualifiers ignored on functi= on return type [-Wignored-qualifiers] Remove also the unnecessary "extern" qualifier to be consistent with other declarations in this file. Signed-off-by: Artem Bityutskiy <artem.bityutskiy@linux.intel.com> Signed-off-by: Rob Herring <rob.herring@calxeda.com>
85 lines
2 KiB
C
85 lines
2 KiB
C
/*
|
|
* Copyright 2012 Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com>
|
|
*
|
|
* OF helpers for mtd.
|
|
*
|
|
* This file is released under the GPLv2
|
|
*
|
|
*/
|
|
#include <linux/kernel.h>
|
|
#include <linux/of_mtd.h>
|
|
#include <linux/mtd/nand.h>
|
|
#include <linux/export.h>
|
|
|
|
/**
|
|
* It maps 'enum nand_ecc_modes_t' found in include/linux/mtd/nand.h
|
|
* into the device tree binding of 'nand-ecc', so that MTD
|
|
* device driver can get nand ecc from device tree.
|
|
*/
|
|
static const char *nand_ecc_modes[] = {
|
|
[NAND_ECC_NONE] = "none",
|
|
[NAND_ECC_SOFT] = "soft",
|
|
[NAND_ECC_HW] = "hw",
|
|
[NAND_ECC_HW_SYNDROME] = "hw_syndrome",
|
|
[NAND_ECC_HW_OOB_FIRST] = "hw_oob_first",
|
|
[NAND_ECC_SOFT_BCH] = "soft_bch",
|
|
};
|
|
|
|
/**
|
|
* of_get_nand_ecc_mode - Get nand ecc mode for given device_node
|
|
* @np: Pointer to the given device_node
|
|
*
|
|
* The function gets ecc mode string from property 'nand-ecc-mode',
|
|
* and return its index in nand_ecc_modes table, or errno in error case.
|
|
*/
|
|
int of_get_nand_ecc_mode(struct device_node *np)
|
|
{
|
|
const char *pm;
|
|
int err, i;
|
|
|
|
err = of_property_read_string(np, "nand-ecc-mode", &pm);
|
|
if (err < 0)
|
|
return err;
|
|
|
|
for (i = 0; i < ARRAY_SIZE(nand_ecc_modes); i++)
|
|
if (!strcasecmp(pm, nand_ecc_modes[i]))
|
|
return i;
|
|
|
|
return -ENODEV;
|
|
}
|
|
EXPORT_SYMBOL_GPL(of_get_nand_ecc_mode);
|
|
|
|
/**
|
|
* of_get_nand_bus_width - Get nand bus witdh for given device_node
|
|
* @np: Pointer to the given device_node
|
|
*
|
|
* return bus width option, or errno in error case.
|
|
*/
|
|
int of_get_nand_bus_width(struct device_node *np)
|
|
{
|
|
u32 val;
|
|
|
|
if (of_property_read_u32(np, "nand-bus-width", &val))
|
|
return 8;
|
|
|
|
switch(val) {
|
|
case 8:
|
|
case 16:
|
|
return val;
|
|
default:
|
|
return -EIO;
|
|
}
|
|
}
|
|
EXPORT_SYMBOL_GPL(of_get_nand_bus_width);
|
|
|
|
/**
|
|
* of_get_nand_on_flash_bbt - Get nand on flash bbt for given device_node
|
|
* @np: Pointer to the given device_node
|
|
*
|
|
* return true if present false other wise
|
|
*/
|
|
bool of_get_nand_on_flash_bbt(struct device_node *np)
|
|
{
|
|
return of_property_read_bool(np, "nand-on-flash-bbt");
|
|
}
|
|
EXPORT_SYMBOL_GPL(of_get_nand_on_flash_bbt);
|