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