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