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> 46c4bf625eSHasso Tepper #include <bus/pccard/pccarddevs.h> 47c4bf625eSHasso Tepper 48c4bf625eSHasso Tepper static const struct pccard_product cmx_pccard_products[] = { 49c4bf625eSHasso Tepper PCMCIA_CARD(OMNIKEY, CM4040, 0), 50c4bf625eSHasso Tepper { NULL } 51c4bf625eSHasso Tepper }; 52c4bf625eSHasso Tepper 53c4bf625eSHasso Tepper /* 54c4bf625eSHasso Tepper * Probe for the card. 55c4bf625eSHasso Tepper */ 56c4bf625eSHasso Tepper static int 57c4bf625eSHasso Tepper cmx_pccard_probe(device_t dev) 58c4bf625eSHasso Tepper { 59c4bf625eSHasso Tepper const struct pccard_product *pp; 60c4bf625eSHasso Tepper if ((pp = pccard_product_lookup(dev, cmx_pccard_products, 61c4bf625eSHasso Tepper sizeof(cmx_pccard_products[0]), NULL)) != NULL) { 62c4bf625eSHasso Tepper if (pp->pp_name != NULL) 63c4bf625eSHasso Tepper device_set_desc(dev, pp->pp_name); 64c4bf625eSHasso Tepper return 0; 65c4bf625eSHasso Tepper } 66c4bf625eSHasso Tepper return EIO; 67c4bf625eSHasso Tepper } 68c4bf625eSHasso Tepper 69c4bf625eSHasso Tepper /* 70c4bf625eSHasso Tepper * Attach to the pccard, and call bus independant attach and 71c4bf625eSHasso Tepper * resource allocation routines. 72c4bf625eSHasso Tepper */ 73c4bf625eSHasso Tepper static int 74c4bf625eSHasso Tepper cmx_pccard_attach(device_t dev) 75c4bf625eSHasso Tepper { 76c4bf625eSHasso Tepper int rv = 0; 77c4bf625eSHasso Tepper cmx_init_softc(dev); 78c4bf625eSHasso Tepper 79c4bf625eSHasso Tepper if ((rv = cmx_alloc_resources(dev)) != 0) { 80c4bf625eSHasso Tepper device_printf(dev, "cmx_alloc_resources() failed!\n"); 81c4bf625eSHasso Tepper cmx_release_resources(dev); 82c4bf625eSHasso Tepper return rv; 83c4bf625eSHasso Tepper } 84c4bf625eSHasso Tepper 85c4bf625eSHasso Tepper if ((rv = cmx_attach(dev)) != 0) { 86c4bf625eSHasso Tepper device_printf(dev, "cmx_attach() failed!\n"); 87c4bf625eSHasso Tepper cmx_release_resources(dev); 88c4bf625eSHasso Tepper return rv; 89c4bf625eSHasso Tepper } 90c4bf625eSHasso Tepper 91c4bf625eSHasso Tepper device_printf(dev, "attached\n"); 92c4bf625eSHasso Tepper return 0; 93c4bf625eSHasso Tepper } 94c4bf625eSHasso Tepper 95c4bf625eSHasso Tepper static device_method_t cmx_pccard_methods[] = { 96c4bf625eSHasso Tepper DEVMETHOD(device_probe, cmx_pccard_probe), 97c4bf625eSHasso Tepper DEVMETHOD(device_attach, cmx_pccard_attach), 98c4bf625eSHasso Tepper DEVMETHOD(device_detach, cmx_detach), 99c4bf625eSHasso Tepper 100*d3c9c58eSSascha Wildner DEVMETHOD_END 101c4bf625eSHasso Tepper }; 102c4bf625eSHasso Tepper 103c4bf625eSHasso Tepper static driver_t cmx_pccard_driver = { 104c4bf625eSHasso Tepper "cmx", 105c4bf625eSHasso Tepper cmx_pccard_methods, 106c4bf625eSHasso Tepper sizeof(struct cmx_softc), 107c4bf625eSHasso Tepper }; 108c4bf625eSHasso Tepper 109aa2b9d05SSascha Wildner DRIVER_MODULE(cmx, pccard, cmx_pccard_driver, cmx_devclass, NULL, NULL); 110c4bf625eSHasso Tepper 111