2 * Copyright 2011, Netlogic Microsystems.
3 * Copyright 2004, Matt Porter <mporter@kernel.crashing.org>
5 * This file is licensed under the terms of the GNU General Public
6 * License version 2. This program is licensed "as is" without any
7 * warranty of any kind, whether express or implied.
10 #include <linux/device.h>
11 #include <linux/platform_device.h>
12 #include <linux/kernel.h>
13 #include <linux/init.h>
15 #include <linux/delay.h>
16 #include <linux/ioport.h>
17 #include <linux/resource.h>
18 #include <linux/spi/flash.h>
20 #include <linux/mtd/mtd.h>
21 #include <linux/mtd/physmap.h>
22 #include <linux/mtd/platnand.h>
24 #include <asm/netlogic/haldefs.h>
25 #include <asm/netlogic/xlr/iomap.h>
26 #include <asm/netlogic/xlr/flash.h>
27 #include <asm/netlogic/xlr/bridge.h>
28 #include <asm/netlogic/xlr/gpio.h>
29 #include <asm/netlogic/xlr/xlr.h>
32 * Default NOR partition layout
34 static struct mtd_partition xlr_nor_parts
[] = {
38 .size
= MTDPART_SIZ_FULL
,
43 * Default NAND partition layout
45 static struct mtd_partition xlr_nand_parts
[] = {
47 .name
= "Root Filesystem",
48 .offset
= 64 * 64 * 2048,
49 .size
= 432 * 64 * 2048,
52 .name
= "Home Filesystem",
53 .offset
= MTDPART_OFS_APPEND
,
54 .size
= MTDPART_SIZ_FULL
,
58 /* Use PHYSMAP flash for NOR */
59 struct physmap_flash_data xlr_nor_data
= {
61 .parts
= xlr_nor_parts
,
62 .nr_parts
= ARRAY_SIZE(xlr_nor_parts
),
65 static struct resource xlr_nor_res
[] = {
67 .flags
= IORESOURCE_MEM
,
71 static struct platform_device xlr_nor_dev
= {
72 .name
= "physmap-flash",
74 .platform_data
= &xlr_nor_data
,
76 .num_resources
= ARRAY_SIZE(xlr_nor_res
),
77 .resource
= xlr_nor_res
,
81 * Use "gen_nand" driver for NAND flash
83 * There seems to be no way to store a private pointer containing
84 * platform specific info in gen_nand drivier. We will use a global
85 * struct for now, since we currently have only one NAND chip per board.
87 struct xlr_nand_flash_priv
{
92 static struct xlr_nand_flash_priv nand_priv
;
94 static void xlr_nand_ctrl(struct nand_chip
*chip
, int cmd
,
98 nlm_write_reg(nand_priv
.flash_mmio
,
99 FLASH_NAND_CLE(nand_priv
.cs
), cmd
);
100 else if (ctrl
& NAND_ALE
)
101 nlm_write_reg(nand_priv
.flash_mmio
,
102 FLASH_NAND_ALE(nand_priv
.cs
), cmd
);
105 struct platform_nand_data xlr_nand_data
= {
108 .nr_partitions
= ARRAY_SIZE(xlr_nand_parts
),
110 .partitions
= xlr_nand_parts
,
113 .cmd_ctrl
= xlr_nand_ctrl
,
117 static struct resource xlr_nand_res
[] = {
119 .flags
= IORESOURCE_MEM
,
123 static struct platform_device xlr_nand_dev
= {
126 .num_resources
= ARRAY_SIZE(xlr_nand_res
),
127 .resource
= xlr_nand_res
,
129 .platform_data
= &xlr_nand_data
,
134 * XLR/XLS supports upto 8 devices on its FLASH interface. The value in
135 * FLASH_BAR (on the MEM/IO bridge) gives the base for mapping all the
137 * Under this, each flash device has an offset and size given by the
138 * CSBASE_ADDR and CSBASE_MASK registers for the device.
140 * The CSBASE_ registers are expected to be setup by the bootloader.
142 static void setup_flash_resource(uint64_t flash_mmio
,
143 uint64_t flash_map_base
, int cs
, struct resource
*res
)
147 base
= nlm_read_reg(flash_mmio
, FLASH_CSBASE_ADDR(cs
));
148 mask
= nlm_read_reg(flash_mmio
, FLASH_CSADDR_MASK(cs
));
150 res
->start
= flash_map_base
+ ((unsigned long)base
<< 16);
151 res
->end
= res
->start
+ (mask
+ 1) * 64 * 1024;
154 static int __init
xlr_flash_init(void)
156 uint64_t gpio_mmio
, flash_mmio
, flash_map_base
;
157 u32 gpio_resetcfg
, flash_bar
;
158 int cs
, boot_nand
, boot_nor
;
160 /* Flash address bits 39:24 is in bridge flash BAR */
161 flash_bar
= nlm_read_reg(nlm_io_base
, BRIDGE_FLASH_BAR
);
162 flash_map_base
= (flash_bar
& 0xffff0000) << 8;
164 gpio_mmio
= nlm_mmio_base(NETLOGIC_IO_GPIO_OFFSET
);
165 flash_mmio
= nlm_mmio_base(NETLOGIC_IO_FLASH_OFFSET
);
167 /* Get the chip reset config */
168 gpio_resetcfg
= nlm_read_reg(gpio_mmio
, GPIO_PWRON_RESET_CFG_REG
);
170 /* Check for boot flash type */
171 boot_nor
= boot_nand
= 0;
172 if (nlm_chip_is_xls()) {
173 /* On XLS, check boot from NAND bit (GPIO reset reg bit 16) */
174 if (gpio_resetcfg
& (1 << 16))
177 /* check boot from PCMCIA, (GPIO reset reg bit 15 */
178 if ((gpio_resetcfg
& (1 << 15)) == 0)
179 boot_nor
= 1; /* not set, booted from NOR */
181 /* check boot from PCMCIA (bit 16 in GPIO reset on XLR) */
182 if ((gpio_resetcfg
& (1 << 16)) == 0)
183 boot_nor
= 1; /* not set, booted from NOR */
186 /* boot flash at chip select 0 */
191 nand_priv
.flash_mmio
= flash_mmio
;
192 setup_flash_resource(flash_mmio
, flash_map_base
, cs
,
195 /* Initialize NAND flash at CS 0 */
196 nlm_write_reg(flash_mmio
, FLASH_CSDEV_PARM(cs
),
197 FLASH_NAND_CSDEV_PARAM
);
198 nlm_write_reg(flash_mmio
, FLASH_CSTIME_PARMA(cs
),
199 FLASH_NAND_CSTIME_PARAMA
);
200 nlm_write_reg(flash_mmio
, FLASH_CSTIME_PARMB(cs
),
201 FLASH_NAND_CSTIME_PARAMB
);
203 pr_info("ChipSelect %d: NAND Flash %pR\n", cs
, xlr_nand_res
);
204 return platform_device_register(&xlr_nand_dev
);
208 setup_flash_resource(flash_mmio
, flash_map_base
, cs
,
210 pr_info("ChipSelect %d: NOR Flash %pR\n", cs
, xlr_nor_res
);
211 return platform_device_register(&xlr_nor_dev
);
216 arch_initcall(xlr_flash_init
);