xref: /dflybsd-src/sys/dev/misc/cmx/cmx_pccard.c (revision dcb4b80df71308df08858318df7f148fde3b3e1b)
1c4bf625eSHasso Tepper /*-
2c4bf625eSHasso Tepper  * Copyright (c) 2006-2007 Daniel Roethlisberger <daniel@roe.ch>
3c4bf625eSHasso Tepper  * All rights reserved.
4c4bf625eSHasso Tepper  *
5c4bf625eSHasso Tepper  * Redistribution and use in source and binary forms, with or without
6c4bf625eSHasso Tepper  * modification, are permitted provided that the following conditions
7c4bf625eSHasso Tepper  * are met:
8c4bf625eSHasso Tepper  * 1. Redistributions of source code must retain the above copyright
9c4bf625eSHasso Tepper  *    notice unmodified, this list of conditions, and the following
10c4bf625eSHasso Tepper  *    disclaimer.
11c4bf625eSHasso Tepper  * 2. Redistributions in binary form must reproduce the above copyright
12c4bf625eSHasso Tepper  *    notice, this list of conditions and the following disclaimer in the
13c4bf625eSHasso Tepper  *    documentation and/or other materials provided with the distribution.
14c4bf625eSHasso Tepper  *
15c4bf625eSHasso Tepper  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
16c4bf625eSHasso Tepper  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17c4bf625eSHasso Tepper  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18c4bf625eSHasso Tepper  * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
19c4bf625eSHasso Tepper  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
20c4bf625eSHasso Tepper  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
21c4bf625eSHasso Tepper  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
22c4bf625eSHasso Tepper  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
23c4bf625eSHasso Tepper  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
24c4bf625eSHasso Tepper  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
25c4bf625eSHasso Tepper  * SUCH DAMAGE.
26c4bf625eSHasso Tepper  *
27c4bf625eSHasso Tepper  * $FreeBSD: src/sys/dev/cmx/cmx_pccard.c,v 1.1 2008/03/06 08:09:45 rink Exp $
28c4bf625eSHasso Tepper  */
29c4bf625eSHasso Tepper 
30c4bf625eSHasso Tepper #include <sys/param.h>
31c4bf625eSHasso Tepper #include <sys/systm.h>
32c4bf625eSHasso Tepper #include <sys/kernel.h>
33c4bf625eSHasso Tepper #include <sys/socket.h>
34c4bf625eSHasso Tepper #include <sys/lock.h>
355b22f1a7SSamuel J. Greear #include <sys/event.h>
36c4bf625eSHasso Tepper 
37c4bf625eSHasso Tepper #include <sys/module.h>
38c4bf625eSHasso Tepper #include <sys/bus.h>
39c4bf625eSHasso Tepper #include <sys/resource.h>
40c4bf625eSHasso Tepper #include <sys/rman.h>
41c4bf625eSHasso Tepper 
42c4bf625eSHasso Tepper #include "cmxvar.h"
43c4bf625eSHasso Tepper 
44c4bf625eSHasso Tepper #include <bus/pccard/pccardvar.h>
45c4bf625eSHasso Tepper #include <bus/pccard/pccard_cis.h>
46*dcb4b80dSSascha Wildner 
47*dcb4b80dSSascha Wildner #include "pccarddevs.h"
48c4bf625eSHasso Tepper 
49c4bf625eSHasso Tepper static const struct pccard_product cmx_pccard_products[] = {
50c4bf625eSHasso Tepper 	PCMCIA_CARD(OMNIKEY, CM4040, 0),
51c4bf625eSHasso Tepper 	{ NULL }
52c4bf625eSHasso Tepper };
53c4bf625eSHasso Tepper 
54c4bf625eSHasso Tepper /*
55c4bf625eSHasso Tepper  * Probe for the card.
56c4bf625eSHasso Tepper  */
57c4bf625eSHasso Tepper static int
cmx_pccard_probe(device_t dev)58c4bf625eSHasso Tepper cmx_pccard_probe(device_t dev)
59c4bf625eSHasso Tepper {
60c4bf625eSHasso Tepper 	const struct pccard_product *pp;
61c4bf625eSHasso Tepper 	if ((pp = pccard_product_lookup(dev, cmx_pccard_products,
62c4bf625eSHasso Tepper 	    sizeof(cmx_pccard_products[0]), NULL)) != NULL) {
63c4bf625eSHasso Tepper 		if (pp->pp_name != NULL)
64c4bf625eSHasso Tepper 			device_set_desc(dev, pp->pp_name);
65c4bf625eSHasso Tepper 		return 0;
66c4bf625eSHasso Tepper 	}
67c4bf625eSHasso Tepper 	return EIO;
68c4bf625eSHasso Tepper }
69c4bf625eSHasso Tepper 
70c4bf625eSHasso Tepper /*
71c4bf625eSHasso Tepper  * Attach to the pccard, and call bus independant attach and
72c4bf625eSHasso Tepper  * resource allocation routines.
73c4bf625eSHasso Tepper  */
74c4bf625eSHasso Tepper static int
cmx_pccard_attach(device_t dev)75c4bf625eSHasso Tepper cmx_pccard_attach(device_t dev)
76c4bf625eSHasso Tepper {
77c4bf625eSHasso Tepper 	int rv = 0;
78c4bf625eSHasso Tepper 	cmx_init_softc(dev);
79c4bf625eSHasso Tepper 
80c4bf625eSHasso Tepper 	if ((rv = cmx_alloc_resources(dev)) != 0) {
81c4bf625eSHasso Tepper 		device_printf(dev, "cmx_alloc_resources() failed!\n");
82c4bf625eSHasso Tepper 		cmx_release_resources(dev);
83c4bf625eSHasso Tepper 		return rv;
84c4bf625eSHasso Tepper 	}
85c4bf625eSHasso Tepper 
86c4bf625eSHasso Tepper 	if ((rv = cmx_attach(dev)) != 0) {
87c4bf625eSHasso Tepper 		device_printf(dev, "cmx_attach() failed!\n");
88c4bf625eSHasso Tepper 		cmx_release_resources(dev);
89c4bf625eSHasso Tepper 		return rv;
90c4bf625eSHasso Tepper 	}
91c4bf625eSHasso Tepper 
92c4bf625eSHasso Tepper 	device_printf(dev, "attached\n");
93c4bf625eSHasso Tepper 	return 0;
94c4bf625eSHasso Tepper }
95c4bf625eSHasso Tepper 
96c4bf625eSHasso Tepper static device_method_t cmx_pccard_methods[] = {
97c4bf625eSHasso Tepper 	DEVMETHOD(device_probe, cmx_pccard_probe),
98c4bf625eSHasso Tepper 	DEVMETHOD(device_attach, cmx_pccard_attach),
99c4bf625eSHasso Tepper 	DEVMETHOD(device_detach, cmx_detach),
100c4bf625eSHasso Tepper 
101d3c9c58eSSascha Wildner 	DEVMETHOD_END
102c4bf625eSHasso Tepper };
103c4bf625eSHasso Tepper 
104c4bf625eSHasso Tepper static driver_t cmx_pccard_driver = {
105c4bf625eSHasso Tepper 	"cmx",
106c4bf625eSHasso Tepper 	cmx_pccard_methods,
107c4bf625eSHasso Tepper 	sizeof(struct cmx_softc),
108c4bf625eSHasso Tepper };
109c4bf625eSHasso Tepper 
110aa2b9d05SSascha Wildner DRIVER_MODULE(cmx, pccard, cmx_pccard_driver, cmx_devclass, NULL, NULL);
111c4bf625eSHasso Tepper 
112