2004-09-13 16:55:47 +04:00
|
|
|
/* $NetBSD: cardslotvar.h,v 1.8 2004/09/13 12:55:47 drochner Exp $ */
|
1999-10-15 10:07:17 +04:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Copyright (c) 1999
|
|
|
|
* HAYAKAWA Koichi. All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
* 3. All advertising materials mentioning features or use of this software
|
|
|
|
* must display the following acknowledgement:
|
|
|
|
* This product includes software developed by the author.
|
|
|
|
* 4. The name of the author may not be used to endorse or promote products
|
|
|
|
* derived from this software without specific prior written permission.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
|
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
|
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
|
|
* DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
|
|
|
|
* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
|
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
|
|
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
|
|
|
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
|
|
|
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
* POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
1999-12-15 15:28:54 +03:00
|
|
|
#ifndef _DEV_CARDBUS_CARDSLOTVAR_H_
|
|
|
|
#define _DEV_CARDBUS_CARDSLOTVAR_H_
|
1999-10-15 10:07:17 +04:00
|
|
|
|
|
|
|
/* require sys/device.h */
|
|
|
|
/* require sys/queue.h */
|
|
|
|
|
|
|
|
struct cardslot_event;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The data structure cardslot_attach_args is the attach argument for
|
|
|
|
* PCMCIA (including CardBus and 16-bit card) slot.
|
|
|
|
*/
|
|
|
|
struct cardslot_attach_args {
|
2001-05-30 13:21:47 +04:00
|
|
|
char *caa_busname;
|
1999-10-15 10:07:17 +04:00
|
|
|
|
2001-05-30 13:21:47 +04:00
|
|
|
int caa_slot;
|
1999-10-15 10:07:17 +04:00
|
|
|
|
2001-05-30 13:21:47 +04:00
|
|
|
/* for cardbus... */
|
|
|
|
struct cbslot_attach_args *caa_cb_attach;
|
1999-10-15 10:07:17 +04:00
|
|
|
|
2001-05-30 13:21:47 +04:00
|
|
|
/* for 16-bit pcmcia */
|
|
|
|
struct pcmciabus_attach_args *caa_16_attach;
|
1999-10-15 10:07:17 +04:00
|
|
|
|
2001-05-30 13:21:47 +04:00
|
|
|
/*
|
|
|
|
* XXX: for 16-bit pcmcia. dirty! This should be removed to
|
|
|
|
* achieve MI.
|
|
|
|
*/
|
|
|
|
struct pcic_handle *caa_ph;
|
1999-10-15 10:07:17 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The data structure cardslot_attach_args is the attach argument for
|
|
|
|
* PCMCIA (including CardBus and 16-bit card) slot.
|
|
|
|
*/
|
|
|
|
struct cardslot_softc {
|
2001-05-30 13:21:47 +04:00
|
|
|
struct device sc_dev;
|
1999-10-15 10:07:17 +04:00
|
|
|
|
2001-05-30 13:21:47 +04:00
|
|
|
int sc_slot; /* slot number */
|
|
|
|
int sc_status; /* the status of slot */
|
1999-10-15 10:07:17 +04:00
|
|
|
|
2001-05-30 13:21:47 +04:00
|
|
|
struct cardbus_softc *sc_cb_softc;
|
|
|
|
struct pcmcia_softc *sc_16_softc;
|
1999-10-15 10:07:17 +04:00
|
|
|
|
2001-05-30 13:21:47 +04:00
|
|
|
struct proc *sc_event_thread;
|
|
|
|
int sc_th_enable; /* true if the thread is enabled */
|
1999-10-15 10:07:17 +04:00
|
|
|
|
2001-05-30 13:21:47 +04:00
|
|
|
/* An event queue for the thread which processes slot state events. */
|
1999-10-15 10:07:17 +04:00
|
|
|
|
2001-05-30 13:21:47 +04:00
|
|
|
SIMPLEQ_HEAD(, cardslot_event) sc_events;
|
1999-10-15 10:07:17 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
#define CARDSLOT_STATUS_CARD_MASK 0x07
|
|
|
|
#define CARDSLOT_STATUS_CARD_NONE 0x00 /* NO card inserted */
|
|
|
|
#define CARDSLOT_STATUS_CARD_16 0x01 /* 16-bit pcmcia card inserted */
|
|
|
|
#define CARDSLOT_STATUS_CARD_CB 0x02 /* CardBus pcmcia card inserted */
|
|
|
|
#define CARDSLOT_STATUS_UNKNOWN 0x07 /* Unknown card inserted */
|
|
|
|
|
|
|
|
#define CARDSLOT_CARDTYPE(x) ((x) & CARDSLOT_STATUS_CARD_MASK)
|
|
|
|
#define CARDSLOT_SET_CARDTYPE(x, type) \
|
|
|
|
do {(x) &= ~CARDSLOT_STATUS_CARD_MASK;\
|
|
|
|
(x) |= (CARDSLOT_STATUS_CARD_MASK & (type));} while(0)
|
|
|
|
|
|
|
|
#define CARDSLOT_STATUS_WORK_MASK 0x08
|
|
|
|
#define CARDSLOT_STATUS_WORKING 0x08 /* at least one function works */
|
|
|
|
#define CARDSLOT_STATUS_NOTWORK 0x00 /* no functions are working */
|
|
|
|
|
1999-11-15 09:08:02 +03:00
|
|
|
#define CARDSLOT_WORK(x) ((x) & CARDSLOT_STATUS_WORK_MASK)
|
|
|
|
#define CARDSLOT_SET_WORK(x, type) \
|
|
|
|
do {(x) &= ~CARDSLOT_STATUS_WORK_MASK;\
|
|
|
|
(x) |= (CARDSLOT_STATUS_WORK_MASK & (type));} while(0)
|
|
|
|
|
1999-10-15 10:07:17 +04:00
|
|
|
|
|
|
|
struct cardslot_event {
|
2001-05-30 13:21:47 +04:00
|
|
|
SIMPLEQ_ENTRY(cardslot_event) ce_q;
|
1999-10-15 10:07:17 +04:00
|
|
|
|
2001-05-30 13:21:47 +04:00
|
|
|
int ce_type;
|
1999-10-15 10:07:17 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
typedef struct cardslot_softc *cardslot_t;
|
|
|
|
|
|
|
|
/* ce_type */
|
|
|
|
#define CARDSLOT_EVENT_INSERTION_16 0
|
|
|
|
#define CARDSLOT_EVENT_REMOVAL_16 1
|
|
|
|
|
|
|
|
#define CARDSLOT_EVENT_INSERTION_CB 2
|
|
|
|
#define CARDSLOT_EVENT_REMOVAL_CB 3
|
|
|
|
|
|
|
|
#define IS_CARDSLOT_INSERT_REMOVE_EV(x) (0 <= (x) && (x) <= 3)
|
|
|
|
|
2003-07-08 14:06:28 +04:00
|
|
|
void cardslot_event_throw __P((cardslot_t, int));
|
1999-10-15 10:07:17 +04:00
|
|
|
|
1999-12-15 15:28:54 +03:00
|
|
|
#endif /* !_DEV_CARDBUS_CARDSLOTVAR_H_ */
|