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