mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-16 17:58:23 +00:00
ac67804fbb
This patch adds a unified s3c24x0 cpu header file that selects the header file for the specific s3c24x0 cpu from the SOC and CPU configs defined in board config file. This removes the current chain of s3c24-type #ifdef's from the s3c24x0 code. Signed-off-by: Kevin Morfitt <kevin.morfitt@fearnside-systems.co.uk> Signed-off-by: Minkyu Kang <mk7.kang@samsung.com>
134 lines
2.8 KiB
C
134 lines
2.8 KiB
C
/*
|
|
* (C) Copyright 2002, 2003
|
|
* David Mueller, ELSOFT AG, d.mueller@elsoft.ch
|
|
*
|
|
* See file CREDITS for list of people who contributed to this
|
|
* project.
|
|
*
|
|
* 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.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
|
* MA 02111-1307 USA
|
|
*
|
|
*/
|
|
/****************************************************************************
|
|
* Global routines used for VCMA9
|
|
*****************************************************************************/
|
|
|
|
#include <asm/arch/s3c24x0_cpu.h>
|
|
|
|
extern int mem_test(unsigned long start, unsigned long ramsize,int mode);
|
|
|
|
void print_vcma9_info(void);
|
|
|
|
#if defined(CONFIG_CMD_NAND)
|
|
typedef enum {
|
|
NFCE_LOW,
|
|
NFCE_HIGH
|
|
} NFCE_STATE;
|
|
|
|
static inline void NF_Conf(u16 conf)
|
|
{
|
|
struct s3c2410_nand * const nand = s3c2410_get_base_nand();
|
|
|
|
nand->NFCONF = conf;
|
|
}
|
|
|
|
static inline void NF_Cmd(u8 cmd)
|
|
{
|
|
struct s3c2410_nand * const nand = s3c2410_get_base_nand();
|
|
|
|
nand->NFCMD = cmd;
|
|
}
|
|
|
|
static inline void NF_CmdW(u8 cmd)
|
|
{
|
|
NF_Cmd(cmd);
|
|
udelay(1);
|
|
}
|
|
|
|
static inline void NF_Addr(u8 addr)
|
|
{
|
|
struct s3c2410_nand * const nand = s3c2410_get_base_nand();
|
|
|
|
nand->NFADDR = addr;
|
|
}
|
|
|
|
static inline void NF_SetCE(NFCE_STATE s)
|
|
{
|
|
struct s3c2410_nand * const nand = s3c2410_get_base_nand();
|
|
|
|
switch (s) {
|
|
case NFCE_LOW:
|
|
nand->NFCONF &= ~(1<<11);
|
|
break;
|
|
|
|
case NFCE_HIGH:
|
|
nand->NFCONF |= (1<<11);
|
|
break;
|
|
}
|
|
}
|
|
|
|
static inline void NF_WaitRB(void)
|
|
{
|
|
struct s3c2410_nand * const nand = s3c2410_get_base_nand();
|
|
|
|
while (!(nand->NFSTAT & (1<<0)));
|
|
}
|
|
|
|
static inline void NF_Write(u8 data)
|
|
{
|
|
struct s3c2410_nand * const nand = s3c2410_get_base_nand();
|
|
|
|
nand->NFDATA = data;
|
|
}
|
|
|
|
static inline u8 NF_Read(void)
|
|
{
|
|
struct s3c2410_nand * const nand = s3c2410_get_base_nand();
|
|
|
|
return(nand->NFDATA);
|
|
}
|
|
|
|
static inline void NF_Init_ECC(void)
|
|
{
|
|
struct s3c2410_nand * const nand = s3c2410_get_base_nand();
|
|
|
|
nand->NFCONF |= (1<<12);
|
|
}
|
|
|
|
static inline u32 NF_Read_ECC(void)
|
|
{
|
|
struct s3c2410_nand * const nand = s3c2410_get_base_nand();
|
|
|
|
return(nand->NFECC);
|
|
}
|
|
|
|
#endif
|
|
|
|
/* VCMA9 PLD regsiters */
|
|
typedef struct {
|
|
u8 ID;
|
|
u8 NIC;
|
|
u8 CAN;
|
|
u8 MISC;
|
|
u8 GPCD;
|
|
u8 BOARD;
|
|
u8 SDRAM;
|
|
} /*__attribute__((__packed__))*/ VCMA9_PLD;
|
|
|
|
#define VCMA9_PLD_BASE 0x2C000100
|
|
static inline VCMA9_PLD *VCMA9_get_base_PLD(void)
|
|
{
|
|
return (VCMA9_PLD * const)VCMA9_PLD_BASE;
|
|
}
|