blob: 9d0424ea9a4fbf4bb41a6cb77c8f6356fdd16800 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * drivers/pcmcia/sa1100_cerf.c
3 *
4 * PCMCIA implementation routines for CerfBoard
5 * Based off the Assabet.
6 *
7 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07008#include <linux/module.h>
9#include <linux/kernel.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070010#include <linux/device.h>
11#include <linux/init.h>
12#include <linux/delay.h>
13
Russell Kinga09e64f2008-08-05 16:14:15 +010014#include <mach/hardware.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070015#include <asm/mach-types.h>
16#include <asm/irq.h>
Russell Kinga09e64f2008-08-05 16:14:15 +010017#include <mach/cerf.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070018#include "sa1100_generic.h"
19
20#define CERF_SOCKET 1
21
Linus Torvalds1da177e2005-04-16 15:20:36 -070022static int cerf_pcmcia_hw_init(struct soc_pcmcia_socket *skt)
23{
Russell Kingf793e3a2012-01-13 23:03:57 +000024 skt->stat[SOC_STAT_CD].gpio = CERF_GPIO_CF_CD;
25 skt->stat[SOC_STAT_CD].name = "CF_CD";
26 skt->stat[SOC_STAT_BVD1].gpio = CERF_GPIO_CF_BVD1;
27 skt->stat[SOC_STAT_BVD1].name = "CF_BVD1";
28 skt->stat[SOC_STAT_BVD2].gpio = CERF_GPIO_CF_BVD2;
29 skt->stat[SOC_STAT_BVD2].name = "CF_BVD2";
30 skt->stat[SOC_STAT_RDY].gpio = CERF_GPIO_CF_IRQ;
31 skt->stat[SOC_STAT_RDY].name = "CF_IRQ";
Linus Torvalds1da177e2005-04-16 15:20:36 -070032
Russell Kingf793e3a2012-01-13 23:03:57 +000033 return 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -070034}
35
36static void
37cerf_pcmcia_socket_state(struct soc_pcmcia_socket *skt, struct pcmcia_state *state)
38{
Linus Torvalds1da177e2005-04-16 15:20:36 -070039 state->wrprot = 0;
40 state->vs_3v = 1;
41 state->vs_Xv = 0;
42}
43
44static int
45cerf_pcmcia_configure_socket(struct soc_pcmcia_socket *skt,
46 const socket_state_t *state)
47{
48 switch (state->Vcc) {
49 case 0:
50 case 50:
51 case 33:
52 break;
53
54 default:
55 printk(KERN_ERR "%s(): unrecognized Vcc %u\n",
Harvey Harrison2e11cb42008-05-01 04:34:54 -070056 __func__, state->Vcc);
Linus Torvalds1da177e2005-04-16 15:20:36 -070057 return -1;
58 }
59
60 if (state->flags & SS_RESET) {
61 GPSR = CERF_GPIO_CF_RESET;
62 } else {
63 GPCR = CERF_GPIO_CF_RESET;
64 }
65
66 return 0;
67}
68
Linus Torvalds1da177e2005-04-16 15:20:36 -070069static struct pcmcia_low_level cerf_pcmcia_ops = {
70 .owner = THIS_MODULE,
71 .hw_init = cerf_pcmcia_hw_init,
Linus Torvalds1da177e2005-04-16 15:20:36 -070072 .socket_state = cerf_pcmcia_socket_state,
73 .configure_socket = cerf_pcmcia_configure_socket,
Linus Torvalds1da177e2005-04-16 15:20:36 -070074};
75
Uwe Kleine-König5b85e042010-11-04 10:46:14 +010076int __devinit pcmcia_cerf_init(struct device *dev)
Linus Torvalds1da177e2005-04-16 15:20:36 -070077{
78 int ret = -ENODEV;
79
80 if (machine_is_cerf())
81 ret = sa11xx_drv_pcmcia_probe(dev, &cerf_pcmcia_ops, CERF_SOCKET, 1);
82
83 return ret;
84}