blob: 479ab9be784db8511ccb9200b1956221b71c308f [file] [log] [blame]
Thomas Gleixnerd2912cb2019-06-04 10:11:33 +02001// SPDX-License-Identifier: GPL-2.0-only
Paul Walmsley31cde042012-04-13 06:34:31 -06002/*
3 * linux/arch/arm/mach-omap1/board-nand.c
4 *
5 * Common OMAP1 board NAND code
6 *
7 * Copyright (C) 2004, 2012 Texas Instruments, Inc.
8 * Copyright (C) 2002 MontaVista Software, Inc.
9 * Copyright (C) 2001 RidgeRun, Inc.
10 * Author: RidgeRun, Inc.
11 * Greg Lonnon (glonnon@ridgerun.com) or info@ridgerun.com
Paul Walmsley31cde042012-04-13 06:34:31 -060012 */
13#include <linux/kernel.h>
14#include <linux/io.h>
15#include <linux/mtd/mtd.h>
Boris Brezillond4092d72017-08-04 17:29:10 +020016#include <linux/mtd/rawnand.h>
Paul Walmsley31cde042012-04-13 06:34:31 -060017
18#include "common.h"
19
Boris Brezillon47bd59e2018-09-06 14:05:13 +020020void omap1_nand_cmd_ctl(struct nand_chip *this, int cmd, unsigned int ctrl)
Paul Walmsley31cde042012-04-13 06:34:31 -060021{
Paul Walmsley31cde042012-04-13 06:34:31 -060022 unsigned long mask;
23
24 if (cmd == NAND_CMD_NONE)
25 return;
26
27 mask = (ctrl & NAND_CLE) ? 0x02 : 0;
28 if (ctrl & NAND_ALE)
29 mask |= 0x04;
30
Boris Brezillon82fc5092018-09-07 00:38:34 +020031 writeb(cmd, this->legacy.IO_ADDR_W + mask);
Paul Walmsley31cde042012-04-13 06:34:31 -060032}
33