xref: /openbmc/linux/drivers/bcma/driver_chipcommon_pflash.c (revision 8c57a5e7b2820f349c95b8c8393fec1e0f4070d2)
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