2008-04-15 19:02:28 +04:00
|
|
|
/* $NetBSD: ppbus_device.h,v 1.6 2008/04/15 15:02:29 cegger Exp $ */
|
2004-01-21 03:33:37 +03:00
|
|
|
|
2004-01-20 02:22:23 +03:00
|
|
|
#ifndef __PPBUS_DEVICE_H
|
|
|
|
#define __PPBUS_DEVICE_H
|
|
|
|
|
|
|
|
#include <sys/device.h>
|
|
|
|
|
|
|
|
#include <dev/ppbus/ppbus_msq.h>
|
|
|
|
|
|
|
|
|
|
|
|
/* Parallel Port Bus Device context. */
|
2005-02-27 03:26:58 +03:00
|
|
|
struct ppbus_context {
|
2004-01-20 02:22:23 +03:00
|
|
|
int valid; /* 1 if the struct is valid */
|
|
|
|
int mode; /* XXX chipset operating mode */
|
|
|
|
struct microseq *curpc; /* pc in curmsq */
|
|
|
|
struct microseq *curmsq; /* currently executed microseqence */
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Parallel Port Bus Device structure. */
|
2005-02-27 03:26:58 +03:00
|
|
|
struct ppbus_device_softc {
|
2008-04-15 19:02:28 +04:00
|
|
|
device_t sc_dev;
|
2004-01-20 02:22:23 +03:00
|
|
|
|
|
|
|
u_int16_t mode; /* current mode of the device */
|
|
|
|
u_int16_t capabilities; /* ppbus capabilities */
|
2005-02-27 03:26:58 +03:00
|
|
|
|
|
|
|
/* uint flags; flags */
|
2004-01-20 02:22:23 +03:00
|
|
|
struct ppbus_context ctx; /* context of the device */
|
|
|
|
|
|
|
|
/* mode dependent get msq. If NULL,
|
|
|
|
* IEEE1284 code is used */
|
|
|
|
struct ppbus_xfer
|
|
|
|
get_xfer[PPBUS_MAX_XFER];
|
|
|
|
|
|
|
|
/* mode dependent put msq. If NULL,
|
|
|
|
* IEEE1284 code is used */
|
|
|
|
struct ppbus_xfer
|
|
|
|
put_xfer[PPBUS_MAX_XFER];
|
|
|
|
|
|
|
|
/* Each structure is a node in a list of child devices */
|
|
|
|
SLIST_ENTRY(ppbus_device_softc) entries;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct ppbus_attach_args {
|
|
|
|
/* Available IEEE1284 modes */
|
|
|
|
u_int16_t capabilities;
|
|
|
|
|
2005-02-27 03:26:58 +03:00
|
|
|
/* Flags?
|
2004-01-20 02:22:23 +03:00
|
|
|
u_int16_t flags;*/
|
|
|
|
};
|
|
|
|
|
2004-01-28 20:11:48 +03:00
|
|
|
#endif /* __PPBUS_DEVICE_H */
|