From: Øyvind H. <go...@us...> - 2010-01-14 21:08:17
|
This is an automated email from the git hooks/post-receive script. It was generated because a ref change was pushed to the repository containing the project "Main OpenOCD repository". The branch, master has been updated via 000a1cfd011d0b1e9ae30446df4eabe269202550 (commit) from 24653c950a18c49d267efb17a36423d9c455a886 (commit) Those revisions listed above that are new to this repository have not appeared on any other notification email; so we list those revisions in full, below. - Log ----------------------------------------------------------------- commit 000a1cfd011d0b1e9ae30446df4eabe269202550 Author: Peter Korsgaard <ja...@su...> Date: Mon Jan 11 22:59:29 2010 +0100 nand flash support for s3c64xx Identical to the existing 2412/2443 support except for the base address and NFCONF value (bit 2 is reserved and should be written as 1 ref UM). Tested on a s3c6410 board, but controller is identical in 6400/6410 except for 8bit MLC ECC support in 6410 which isn't supported by the driver. Signed-off-by: Peter Korsgaard <ja...@su...> Signed-off-by: Ãyvind Harboe <oyv...@zy...> diff --git a/doc/openocd.texi b/doc/openocd.texi index 4446046..a0fc0fb 100644 --- a/doc/openocd.texi +++ b/doc/openocd.texi @@ -5041,7 +5041,8 @@ change any behavior. @deffnx {NAND Driver} s3c2412 @deffnx {NAND Driver} s3c2440 @deffnx {NAND Driver} s3c2443 -These S3C24xx family controllers don't have any special +@deffnx {NAND Driver} s3c6400 +These S3C family controllers don't have any special @command{nand device} options, and don't define any specialized commands. At this writing, their drivers don't include @code{write_page} diff --git a/src/flash/nand/Makefile.am b/src/flash/nand/Makefile.am index 2ffa4c4..a495dfd 100644 --- a/src/flash/nand/Makefile.am +++ b/src/flash/nand/Makefile.am @@ -25,6 +25,7 @@ NAND_DRIVERS = \ s3c2412.c \ s3c2440.c \ s3c2443.c \ + s3c6400.c \ at91sam9.c noinst_HEADERS = \ diff --git a/src/flash/nand/driver.c b/src/flash/nand/driver.c index 0e174b2..1c28dbc 100644 --- a/src/flash/nand/driver.c +++ b/src/flash/nand/driver.c @@ -36,6 +36,7 @@ extern struct nand_flash_controller s3c2410_nand_controller; extern struct nand_flash_controller s3c2412_nand_controller; extern struct nand_flash_controller s3c2440_nand_controller; extern struct nand_flash_controller s3c2443_nand_controller; +extern struct nand_flash_controller s3c6400_nand_controller; extern struct nand_flash_controller imx31_nand_flash_controller; extern struct nand_flash_controller at91sam9_nand_controller; @@ -51,6 +52,7 @@ static struct nand_flash_controller *nand_flash_controllers[] = &s3c2412_nand_controller, &s3c2440_nand_controller, &s3c2443_nand_controller, + &s3c6400_nand_controller, &imx31_nand_flash_controller, &at91sam9_nand_controller, /* &boundary_scan_nand_controller, */ diff --git a/src/flash/nand/s3c6400.c b/src/flash/nand/s3c6400.c new file mode 100644 index 0000000..20b6cc1 --- /dev/null +++ b/src/flash/nand/s3c6400.c @@ -0,0 +1,76 @@ +/*************************************************************************** + * Copyright (C) 2010 by Peter Korsgaard <ja...@su...> * + * Heavily based on s3c2412.c by Ben Dooks <be...@fl...> * + * * + * 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. * + ***************************************************************************/ + +#ifdef HAVE_CONFIG_H +#include "config.h" +#endif + +#include "s3c24xx.h" +/* s3c64xx uses another base address for the nand controller than 24xx */ +#undef S3C2410_NFREG +#define S3C2410_NFREG(x) ((x) + 0x70200000) + +NAND_DEVICE_COMMAND_HANDLER(s3c6400_nand_device_command) +{ + struct s3c24xx_nand_controller *info; + CALL_S3C24XX_DEVICE_COMMAND(nand, &info); + + /* fill in the address fields for the core device */ + info->cmd = S3C2440_NFCMD; + info->addr = S3C2440_NFADDR; + info->data = S3C2440_NFDATA; + info->nfstat = S3C2412_NFSTAT; + + return ERROR_OK; +} + +static int s3c6400_init(struct nand_device *nand) +{ + struct s3c24xx_nand_controller *s3c24xx_info = nand->controller_priv; + struct target *target = s3c24xx_info->target; + + target_write_u32(target, S3C2410_NFCONF, + S3C2440_NFCONF_TACLS(3) | + S3C2440_NFCONF_TWRPH0(7) | + S3C2440_NFCONF_TWRPH1(7) | 4); + + target_write_u32(target, S3C2440_NFCONT, + S3C2412_NFCONT_INIT_MAIN_ECC | + S3C2440_NFCONT_ENABLE); + + return ERROR_OK; +} + +struct nand_flash_controller s3c6400_nand_controller = { + .name = "s3c6400", + .nand_device_command = &s3c6400_nand_device_command, + .init = &s3c6400_init, + .reset = &s3c24xx_reset, + .command = &s3c24xx_command, + .address = &s3c24xx_address, + .write_data = &s3c24xx_write_data, + .read_data = &s3c24xx_read_data, + .write_page = s3c24xx_write_page, + .read_page = s3c24xx_read_page, + .write_block_data = &s3c2440_write_block_data, + .read_block_data = &s3c2440_read_block_data, + .controller_ready = &s3c24xx_controller_ready, + .nand_ready = &s3c2440_nand_ready, + }; ----------------------------------------------------------------------- Summary of changes: doc/openocd.texi | 3 ++- src/flash/nand/Makefile.am | 1 + src/flash/nand/driver.c | 2 ++ src/flash/nand/{s3c2443.c => s3c6400.c} | 28 ++++++++++++---------------- 4 files changed, 17 insertions(+), 17 deletions(-) copy src/flash/nand/{s3c2443.c => s3c6400.c} (81%) hooks/post-receive -- Main OpenOCD repository |