linux_dsm_epyc7002/include/linux/jz4780-nemc.h
Alex Smith 911a888297 memory: jz4780-nemc: driver for the NEMC on JZ4780 SoCs
Add a driver for the NAND/External Memory Controller (NEMC) on JZ4780
and later SoCs.

The primary function of this driver is to configure parameters, such
as timings, for external memory devices using data supplied in the
device tree. Devices connected to the NEMC are represented in the DT
as children of the NEMC node, the driver uses optional properties
specified in these child nodes to configure the parameters of each
bank.

Signed-off-by: Alex Smith <alex@alex-smith.me.uk>
Signed-off-by: Zubair Lutfullah Kakakhel <Zubair.Kakakhel@imgtec.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2015-03-26 23:51:36 +01:00

44 lines
1.2 KiB
C

/*
* JZ4780 NAND/external memory controller (NEMC)
*
* Copyright (c) 2015 Imagination Technologies
* Author: Alex Smith <alex@alex-smith.me.uk>
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the
* Free Software Foundation; either version 2 of the License, or (at your
* option) any later version.
*/
#ifndef __LINUX_JZ4780_NEMC_H__
#define __LINUX_JZ4780_NEMC_H__
#include <linux/types.h>
struct device;
/*
* Number of NEMC banks. Note that there are actually 6, but they are numbered
* from 1.
*/
#define JZ4780_NEMC_NUM_BANKS 7
/**
* enum jz4780_nemc_bank_type - device types which can be connected to a bank
* @JZ4780_NEMC_BANK_SRAM: SRAM
* @JZ4780_NEMC_BANK_NAND: NAND
*/
enum jz4780_nemc_bank_type {
JZ4780_NEMC_BANK_SRAM,
JZ4780_NEMC_BANK_NAND,
};
extern unsigned int jz4780_nemc_num_banks(struct device *dev);
extern void jz4780_nemc_set_type(struct device *dev, unsigned int bank,
enum jz4780_nemc_bank_type type);
extern void jz4780_nemc_assert(struct device *dev, unsigned int bank,
bool assert);
#endif /* __LINUX_JZ4780_NEMC_H__ */