Blame view

kernel/linux-imx6_3.14.28/arch/mips/bcm63xx/dev-spi.c 2.56 KB
6b13f685e   김민수   BSP 최초 추가
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
  /*
   * This file is subject to the terms and conditions of the GNU General Public
   * License.  See the file "COPYING" in the main directory of this archive
   * for more details.
   *
   * Copyright (C) 2009-2011 Florian Fainelli <florian@openwrt.org>
   * Copyright (C) 2010 Tanguy Bouzeloc <tanguy.bouzeloc@efixo.com>
   */
  
  #include <linux/init.h>
  #include <linux/kernel.h>
  #include <linux/export.h>
  #include <linux/platform_device.h>
  #include <linux/err.h>
  #include <linux/clk.h>
  
  #include <bcm63xx_cpu.h>
  #include <bcm63xx_dev_spi.h>
  #include <bcm63xx_regs.h>
  
  #ifdef BCMCPU_RUNTIME_DETECT
  /*
   * register offsets
   */
  static const unsigned long bcm6348_regs_spi[] = {
  	__GEN_SPI_REGS_TABLE(6348)
  };
  
  static const unsigned long bcm6358_regs_spi[] = {
  	__GEN_SPI_REGS_TABLE(6358)
  };
  
  const unsigned long *bcm63xx_regs_spi;
  EXPORT_SYMBOL(bcm63xx_regs_spi);
  
  static __init void bcm63xx_spi_regs_init(void)
  {
  	if (BCMCPU_IS_6338() || BCMCPU_IS_6348())
  		bcm63xx_regs_spi = bcm6348_regs_spi;
  	if (BCMCPU_IS_3368() || BCMCPU_IS_6358() ||
  		BCMCPU_IS_6362() || BCMCPU_IS_6368())
  		bcm63xx_regs_spi = bcm6358_regs_spi;
  }
  #else
  static __init void bcm63xx_spi_regs_init(void) { }
  #endif
  
  static struct resource spi_resources[] = {
  	{
  		.start		= -1, /* filled at runtime */
  		.end		= -1, /* filled at runtime */
  		.flags		= IORESOURCE_MEM,
  	},
  	{
  		.start		= -1, /* filled at runtime */
  		.flags		= IORESOURCE_IRQ,
  	},
  };
  
  static struct bcm63xx_spi_pdata spi_pdata = {
  	.bus_num		= 0,
  	.num_chipselect		= 8,
  };
  
  static struct platform_device bcm63xx_spi_device = {
  	.name		= "bcm63xx-spi",
  	.id		= -1,
  	.num_resources	= ARRAY_SIZE(spi_resources),
  	.resource	= spi_resources,
  	.dev		= {
  		.platform_data = &spi_pdata,
  	},
  };
  
  int __init bcm63xx_spi_register(void)
  {
  	if (BCMCPU_IS_6328() || BCMCPU_IS_6345())
  		return -ENODEV;
  
  	spi_resources[0].start = bcm63xx_regset_address(RSET_SPI);
  	spi_resources[0].end = spi_resources[0].start;
  	spi_resources[1].start = bcm63xx_get_irq_number(IRQ_SPI);
  
  	if (BCMCPU_IS_6338() || BCMCPU_IS_6348()) {
  		spi_resources[0].end += BCM_6348_RSET_SPI_SIZE - 1;
  		spi_pdata.fifo_size = SPI_6348_MSG_DATA_SIZE;
  		spi_pdata.msg_type_shift = SPI_6348_MSG_TYPE_SHIFT;
  		spi_pdata.msg_ctl_width = SPI_6348_MSG_CTL_WIDTH;
  	}
  
  	if (BCMCPU_IS_3368() || BCMCPU_IS_6358() || BCMCPU_IS_6362() ||
  		BCMCPU_IS_6368()) {
  		spi_resources[0].end += BCM_6358_RSET_SPI_SIZE - 1;
  		spi_pdata.fifo_size = SPI_6358_MSG_DATA_SIZE;
  		spi_pdata.msg_type_shift = SPI_6358_MSG_TYPE_SHIFT;
  		spi_pdata.msg_ctl_width = SPI_6358_MSG_CTL_WIDTH;
  	}
  
  	bcm63xx_spi_regs_init();
  
  	return platform_device_register(&bcm63xx_spi_device);
  }