Blame view

drivers/pcmcia/sa1111_jornada720.c 2.33 KB
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1
2
3
4
5
6
7
8
  /*
   * drivers/pcmcia/sa1100_jornada720.c
   *
   * Jornada720 PCMCIA specific routines
   *
   */
  #include <linux/module.h>
  #include <linux/kernel.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
9
10
11
  #include <linux/device.h>
  #include <linux/errno.h>
  #include <linux/init.h>
58409f9d2   Arnd Bergmann   pcmcia: journada7...
12
  #include <linux/io.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
13

a09e64fbc   Russell King   [ARM] Move includ...
14
  #include <mach/hardware.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
15
16
17
18
  #include <asm/hardware/sa1111.h>
  #include <asm/mach-types.h>
  
  #include "sa1111_generic.h"
02e87d1a9   Kristoffer Ericson   pcmcia: cleanup/f...
19
20
21
22
  /* Does SOCKET1_3V actually do anything? */
  #define SOCKET0_POWER	GPIO_GPIO0
  #define SOCKET0_3V	GPIO_GPIO2
  #define SOCKET1_POWER	(GPIO_GPIO1 | GPIO_GPIO3)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
23
  #define SOCKET1_3V	GPIO_GPIO3
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
24
25
26
  static int
  jornada720_pcmcia_configure_socket(struct soc_pcmcia_socket *skt, const socket_state_t *state)
  {
701a5dc05   Russell King - ARM Linux   PCMCIA: sa1111: w...
27
  	struct sa1111_pcmcia_socket *s = to_skt(skt);
02e87d1a9   Kristoffer Ericson   pcmcia: cleanup/f...
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
  	unsigned int pa_dwr_mask, pa_dwr_set;
  	int ret;
  
  	printk(KERN_INFO "%s(): config socket %d vcc %d vpp %d
  ", __func__,
  		skt->nr, state->Vcc, state->Vpp);
  
  	switch (skt->nr) {
  	case 0:
  		pa_dwr_mask = SOCKET0_POWER | SOCKET0_3V;
  
  		switch (state->Vcc) {
  		default:
  		case  0:
  			pa_dwr_set = 0;
  			break;
  		case 33:
  			pa_dwr_set = SOCKET0_POWER | SOCKET0_3V;
  			break;
  		case 50:
  			pa_dwr_set = SOCKET0_POWER;
  			break;
  		}
  		break;
  
  	case 1:
  		pa_dwr_mask = SOCKET1_POWER;
  
  		switch (state->Vcc) {
  		default:
  		case 0:
  			pa_dwr_set = 0;
  			break;
  		case 33:
  			pa_dwr_set = SOCKET1_POWER;
  			break;
  		case 50:
  			pa_dwr_set = SOCKET1_POWER;
  			break;
  		}
  		break;
  
  	default:
  		return -1;
  	}
  
  	if (state->Vpp != state->Vcc && state->Vpp != 0) {
  		printk(KERN_ERR "%s(): slot cannot support VPP %u
  ",
  			__func__, state->Vpp);
  		return -EPERM;
  	}
  
  	ret = sa1111_pcmcia_configure_socket(skt, state);
e2adbecfc   Russell King   PCMCIA: sa1111: j...
82
  	if (ret == 0)
701a5dc05   Russell King - ARM Linux   PCMCIA: sa1111: w...
83
  		sa1111_set_io(s->dev, pa_dwr_mask, pa_dwr_set);
02e87d1a9   Kristoffer Ericson   pcmcia: cleanup/f...
84
85
  
  	return ret;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
86
87
88
  }
  
  static struct pcmcia_low_level jornada720_pcmcia_ops = {
02e87d1a9   Kristoffer Ericson   pcmcia: cleanup/f...
89
  	.owner			= THIS_MODULE,
02e87d1a9   Kristoffer Ericson   pcmcia: cleanup/f...
90
  	.configure_socket	= jornada720_pcmcia_configure_socket,
701a5dc05   Russell King - ARM Linux   PCMCIA: sa1111: w...
91
92
  	.first			= 0,
  	.nr			= 2,
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
93
  };
4bc9ef297   Dmitry Eremin-Solenikov   pcmcia: sa1111: p...
94
  int pcmcia_jornada720_init(struct sa1111_dev *sadev)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
95
96
  {
  	int ret = -ENODEV;
701a5dc05   Russell King - ARM Linux   PCMCIA: sa1111: w...
97
  	if (machine_is_jornada720()) {
dabd14684   Russell King - ARM Linux   PCMCIA: sa1111: r...
98
99
100
101
102
  		unsigned int pin = GPIO_A0 | GPIO_A1 | GPIO_A2 | GPIO_A3;
  
  		GRER |= 0x00000002;
  
  		/* Set GPIO_A<3:1> to be outputs for PCMCIA/CF power controller: */
58409f9d2   Arnd Bergmann   pcmcia: journada7...
103
104
105
  		sa1111_set_io_dir(sadev, pin, 0, 0);
  		sa1111_set_io(sadev, pin, 0);
  		sa1111_set_sleep_io(sadev, pin, 0);
dabd14684   Russell King - ARM Linux   PCMCIA: sa1111: r...
106

701a5dc05   Russell King - ARM Linux   PCMCIA: sa1111: w...
107
  		sa11xx_drv_pcmcia_ops(&jornada720_pcmcia_ops);
58409f9d2   Arnd Bergmann   pcmcia: journada7...
108
  		ret = sa1111_pcmcia_add(sadev, &jornada720_pcmcia_ops,
701a5dc05   Russell King - ARM Linux   PCMCIA: sa1111: w...
109
110
  				sa11xx_drv_pcmcia_add_one);
  	}
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
111
112
113
  
  	return ret;
  }