Jan Engelhardt | ec98c68 | 2007-04-19 16:21:41 -0500 | [diff] [blame] | 1 | menuconfig MTD_ONENAND |
Kyungmin Park | cd5f634 | 2005-07-11 11:41:53 +0100 | [diff] [blame] | 2 | tristate "OneNAND Device Support" |
| 3 | depends on MTD |
Richard Weinberger | 9310da0 | 2012-02-07 01:22:50 +0100 | [diff] [blame^] | 4 | depends on HAS_IOMEM |
Kyungmin Park | cd5f634 | 2005-07-11 11:41:53 +0100 | [diff] [blame] | 5 | help |
| 6 | This enables support for accessing all type of OneNAND flash |
| 7 | devices. For further information see |
Kyungmin Park | c19df27 | 2007-04-25 11:05:48 +0100 | [diff] [blame] | 8 | <http://www.samsung.com/Products/Semiconductor/OneNAND/index.htm> |
Kyungmin Park | cd5f634 | 2005-07-11 11:41:53 +0100 | [diff] [blame] | 9 | |
Jan Engelhardt | ec98c68 | 2007-04-19 16:21:41 -0500 | [diff] [blame] | 10 | if MTD_ONENAND |
| 11 | |
Kyungmin Park | cd5f634 | 2005-07-11 11:41:53 +0100 | [diff] [blame] | 12 | config MTD_ONENAND_VERIFY_WRITE |
| 13 | bool "Verify OneNAND page writes" |
Kyungmin Park | cd5f634 | 2005-07-11 11:41:53 +0100 | [diff] [blame] | 14 | help |
| 15 | This adds an extra check when data is written to the flash. The |
| 16 | OneNAND flash device internally checks only bits transitioning |
| 17 | from 1 to 0. There is a rare possibility that even though the |
| 18 | device thinks the write was successful, a bit could have been |
Matt LaPlante | 0950960 | 2006-10-03 22:31:37 +0200 | [diff] [blame] | 19 | flipped accidentally due to device wear or something else. |
Kyungmin Park | cd5f634 | 2005-07-11 11:41:53 +0100 | [diff] [blame] | 20 | |
Kyungmin Park | 68ee4b1 | 2005-09-09 07:39:50 +0100 | [diff] [blame] | 21 | config MTD_ONENAND_GENERIC |
Thomas Gleixner | 46d0d0f | 2005-11-07 01:14:05 +0100 | [diff] [blame] | 22 | tristate "OneNAND Flash device via platform device driver" |
Kyungmin Park | 68ee4b1 | 2005-09-09 07:39:50 +0100 | [diff] [blame] | 23 | help |
Thomas Gleixner | 46d0d0f | 2005-11-07 01:14:05 +0100 | [diff] [blame] | 24 | Support for OneNAND flash via platform device driver. |
Kyungmin Park | 68ee4b1 | 2005-09-09 07:39:50 +0100 | [diff] [blame] | 25 | |
Adrian Hunter | 36cd4fb | 2008-08-06 10:08:46 +0300 | [diff] [blame] | 26 | config MTD_ONENAND_OMAP2 |
| 27 | tristate "OneNAND on OMAP2/OMAP3 support" |
Kyle Spaans | 8c1a115 | 2010-06-08 09:48:22 -0400 | [diff] [blame] | 28 | depends on ARCH_OMAP2 || ARCH_OMAP3 |
Adrian Hunter | 36cd4fb | 2008-08-06 10:08:46 +0300 | [diff] [blame] | 29 | help |
| 30 | Support for a OneNAND flash device connected to an OMAP2/OMAP3 CPU |
| 31 | via the GPMC memory controller. |
| 32 | |
Kyungmin Park | 46f3e88 | 2010-04-28 17:46:49 +0200 | [diff] [blame] | 33 | config MTD_ONENAND_SAMSUNG |
| 34 | tristate "OneNAND on Samsung SOC controller support" |
Kukjin Kim | fc406cd | 2011-02-14 16:52:45 +0900 | [diff] [blame] | 35 | depends on ARCH_S3C64XX || ARCH_S5PC100 || ARCH_S5PV210 || ARCH_EXYNOS4 |
Kyungmin Park | 46f3e88 | 2010-04-28 17:46:49 +0200 | [diff] [blame] | 36 | help |
Kyungmin Park | 861fae1 | 2010-09-29 14:32:05 +0900 | [diff] [blame] | 37 | Support for a OneNAND flash device connected to an Samsung SOC. |
| 38 | S3C64XX/S5PC100 use command mapping method. |
| 39 | S5PC110/S5PC210 use generic OneNAND method. |
Kyungmin Park | 46f3e88 | 2010-04-28 17:46:49 +0200 | [diff] [blame] | 40 | |
Kyungmin Park | 493c646 | 2006-05-12 17:03:07 +0300 | [diff] [blame] | 41 | config MTD_ONENAND_OTP |
| 42 | bool "OneNAND OTP Support" |
David Brownell | 34a8244 | 2008-07-30 12:35:05 -0700 | [diff] [blame] | 43 | select HAVE_MTD_OTP |
Kyungmin Park | 493c646 | 2006-05-12 17:03:07 +0300 | [diff] [blame] | 44 | help |
| 45 | One Block of the NAND Flash Array memory is reserved as |
| 46 | a One-Time Programmable Block memory area. |
| 47 | Also, 1st Block of NAND Flash Array can be used as OTP. |
| 48 | |
| 49 | The OTP block can be read, programmed and locked using the same |
| 50 | operations as any other NAND Flash Array memory block. |
| 51 | OTP block cannot be erased. |
| 52 | |
| 53 | OTP block is fully-guaranteed to be a valid block. |
| 54 | |
Kyungmin Park | ee9745f | 2007-06-30 13:57:49 +0900 | [diff] [blame] | 55 | config MTD_ONENAND_2X_PROGRAM |
| 56 | bool "OneNAND 2X program support" |
| 57 | help |
| 58 | The 2X Program is an extension of Program Operation. |
| 59 | Since the device is equipped with two DataRAMs, and two-plane NAND |
| 60 | Flash memory array, these two component enables simultaneous program |
| 61 | of 4KiB. Plane1 has only even blocks such as block0, block2, block4 |
| 62 | while Plane2 has only odd blocks such as block1, block3, block5. |
| 63 | So MTD regards it as 4KiB page size and 256KiB block size |
| 64 | |
| 65 | Now the following chips support it. (KFXXX16Q2M) |
| 66 | Demux: KFG2G16Q2M, KFH4G16Q2M, KFW8G16Q2M, |
| 67 | Mux: KFM2G16Q2M, KFN4G16Q2M, |
| 68 | |
| 69 | And more recent chips |
| 70 | |
Kyungmin Park | 8dab169 | 2007-06-30 14:14:43 +0900 | [diff] [blame] | 71 | config MTD_ONENAND_SIM |
| 72 | tristate "OneNAND simulator support" |
Kyungmin Park | 8dab169 | 2007-06-30 14:14:43 +0900 | [diff] [blame] | 73 | help |
| 74 | The simulator may simulate various OneNAND flash chips for the |
| 75 | OneNAND MTD layer. |
| 76 | |
Jan Engelhardt | ec98c68 | 2007-04-19 16:21:41 -0500 | [diff] [blame] | 77 | endif # MTD_ONENAND |