1*d6a3b51aSRafał Miłecki /*
2*d6a3b51aSRafał Miłecki * Broadcom specific AMBA
3*d6a3b51aSRafał Miłecki * ChipCommon parallel flash
4*d6a3b51aSRafał Miłecki *
5*d6a3b51aSRafał Miłecki * Licensed under the GNU/GPL. See COPYING for details.
6*d6a3b51aSRafał Miłecki */
7*d6a3b51aSRafał Miłecki
8*d6a3b51aSRafał Miłecki #include "bcma_private.h"
9*d6a3b51aSRafał Miłecki
10*d6a3b51aSRafał Miłecki #include <linux/bcma/bcma.h>
11*d6a3b51aSRafał Miłecki #include <linux/mtd/physmap.h>
12*d6a3b51aSRafał Miłecki #include <linux/platform_device.h>
13*d6a3b51aSRafał Miłecki
14*d6a3b51aSRafał Miłecki static const char * const part_probes[] = { "bcm47xxpart", NULL };
15*d6a3b51aSRafał Miłecki
16*d6a3b51aSRafał Miłecki static struct physmap_flash_data bcma_pflash_data = {
17*d6a3b51aSRafał Miłecki .part_probe_types = part_probes,
18*d6a3b51aSRafał Miłecki };
19*d6a3b51aSRafał Miłecki
20*d6a3b51aSRafał Miłecki static struct resource bcma_pflash_resource = {
21*d6a3b51aSRafał Miłecki .name = "bcma_pflash",
22*d6a3b51aSRafał Miłecki .flags = IORESOURCE_MEM,
23*d6a3b51aSRafał Miłecki };
24*d6a3b51aSRafał Miłecki
25*d6a3b51aSRafał Miłecki struct platform_device bcma_pflash_dev = {
26*d6a3b51aSRafał Miłecki .name = "physmap-flash",
27*d6a3b51aSRafał Miłecki .dev = {
28*d6a3b51aSRafał Miłecki .platform_data = &bcma_pflash_data,
29*d6a3b51aSRafał Miłecki },
30*d6a3b51aSRafał Miłecki .resource = &bcma_pflash_resource,
31*d6a3b51aSRafał Miłecki .num_resources = 1,
32*d6a3b51aSRafał Miłecki };
33*d6a3b51aSRafał Miłecki
bcma_pflash_init(struct bcma_drv_cc * cc)34*d6a3b51aSRafał Miłecki int bcma_pflash_init(struct bcma_drv_cc *cc)
35*d6a3b51aSRafał Miłecki {
36*d6a3b51aSRafał Miłecki struct bcma_pflash *pflash = &cc->pflash;
37*d6a3b51aSRafał Miłecki
38*d6a3b51aSRafał Miłecki pflash->present = true;
39*d6a3b51aSRafał Miłecki
40*d6a3b51aSRafał Miłecki if (!(bcma_read32(cc->core, BCMA_CC_FLASH_CFG) & BCMA_CC_FLASH_CFG_DS))
41*d6a3b51aSRafał Miłecki bcma_pflash_data.width = 1;
42*d6a3b51aSRafał Miłecki else
43*d6a3b51aSRafał Miłecki bcma_pflash_data.width = 2;
44*d6a3b51aSRafał Miłecki
45*d6a3b51aSRafał Miłecki bcma_pflash_resource.start = BCMA_SOC_FLASH2;
46*d6a3b51aSRafał Miłecki bcma_pflash_resource.end = BCMA_SOC_FLASH2 + BCMA_SOC_FLASH2_SZ;
47*d6a3b51aSRafał Miłecki
48*d6a3b51aSRafał Miłecki return 0;
49*d6a3b51aSRafał Miłecki }
50