
i'm in the process of merging the GPIO layer from Linux into the Blackfin port (well, it's already done, so now i'm just converting drivers over to it). as i'm sure you're aware, the GPIO framework in Linux provides a common API across all ports, so anyone who supports asm/gpio.h is going to work. no-arch specific junk here.
some Blackfin boards use GPIOs with the nand_plat driver for the dev_ready pin. so while i can easily convert the board config header to call these gpio funcs, the issue is that i cant really pull in headers like asm/gpio.h in the board config since all files will then pull it in.
what i'm thinking is something like this: --- a/drivers/mtd/nand/nand_plat.c +++ b/drivers/mtd/nand/nand_plat.c @@ -16,6 +16,10 @@
#include <common.h> #include <asm/io.h> +#ifdef NAND_PLAT_GPIO_DEV_READY +# include <asm/gpio.h> +# define NAND_PLAT_DEV_READY(chip) gpio_get_value(NAND_PLAT_GPIO_DEV_READY) +#endif
#include <nand.h>
@@ -43,7 +47,14 @@ static int plat_dev_ready(struct mtd_info *mtd)
int board_nand_init(struct nand_chip *nand) { +#ifdef NAND_PLAT_GPIO_DEV_READY + gpio_request(NAND_PLAT_GPIO_DEV_READY, "nand-plat"); + gpio_direction_input(NAND_PLAT_GPIO_DEV_READY); +#endif + +#ifdef NAND_PLAT_INIT NAND_PLAT_INIT(); +#endif
nand->cmd_ctrl = plat_cmd_ctrl; nand->dev_ready = plat_dev_ready;
now the Blackfin boards merely have to do: #define NAND_PLAT_GPIO_DEV_READY GPIO_PF12
any suggestions about how to approach this ? -mike