1 // SPDX-License-Identifier: GPL-2.0
3 * drivers/pcmcia/sa1100_cerf.c
5 * PCMCIA implementation routines for CerfBoard
6 * Based off the Assabet.
9 #include <linux/module.h>
10 #include <linux/kernel.h>
11 #include <linux/device.h>
12 #include <linux/init.h>
13 #include <linux/delay.h>
14 #include <linux/gpio.h>
16 #include <mach/hardware.h>
17 #include <asm/mach-types.h>
19 #include <mach/cerf.h>
20 #include "sa1100_generic.h"
24 static int cerf_pcmcia_hw_init(struct soc_pcmcia_socket
*skt
)
28 ret
= gpio_request_one(CERF_GPIO_CF_RESET
, GPIOF_OUT_INIT_LOW
, "CF_RESET");
32 skt
->stat
[SOC_STAT_CD
].gpio
= CERF_GPIO_CF_CD
;
33 skt
->stat
[SOC_STAT_CD
].name
= "CF_CD";
34 skt
->stat
[SOC_STAT_BVD1
].gpio
= CERF_GPIO_CF_BVD1
;
35 skt
->stat
[SOC_STAT_BVD1
].name
= "CF_BVD1";
36 skt
->stat
[SOC_STAT_BVD2
].gpio
= CERF_GPIO_CF_BVD2
;
37 skt
->stat
[SOC_STAT_BVD2
].name
= "CF_BVD2";
38 skt
->stat
[SOC_STAT_RDY
].gpio
= CERF_GPIO_CF_IRQ
;
39 skt
->stat
[SOC_STAT_RDY
].name
= "CF_IRQ";
44 static void cerf_pcmcia_hw_shutdown(struct soc_pcmcia_socket
*skt
)
46 gpio_free(CERF_GPIO_CF_RESET
);
50 cerf_pcmcia_configure_socket(struct soc_pcmcia_socket
*skt
,
51 const socket_state_t
*state
)
60 printk(KERN_ERR
"%s(): unrecognized Vcc %u\n",
61 __func__
, state
->Vcc
);
65 gpio_set_value(CERF_GPIO_CF_RESET
, !!(state
->flags
& SS_RESET
));
70 static struct pcmcia_low_level cerf_pcmcia_ops
= {
72 .hw_init
= cerf_pcmcia_hw_init
,
73 .hw_shutdown
= cerf_pcmcia_hw_shutdown
,
74 .socket_state
= soc_common_cf_socket_state
,
75 .configure_socket
= cerf_pcmcia_configure_socket
,
78 int pcmcia_cerf_init(struct device
*dev
)
82 if (machine_is_cerf())
83 ret
= sa11xx_drv_pcmcia_probe(dev
, &cerf_pcmcia_ops
, CERF_SOCKET
, 1);