#include <sys/param.h>
#include <sys/systm.h>
#include <sys/ioctl.h>
#include <sys/tty.h>
#include <sys/conf.h>
#include <sys/uio.h>
#include <sys/kernel.h>
#include <sys/syslog.h>
#include <sys/device.h>
#include <machine/intr.h>
#include <machine/bus.h>
#include <dev/pci/pucvar.h>
#include "com.h"
#include <dev/ic/comreg.h>
#include <dev/ic/comvar.h>
#include <dev/ic/ns16550reg.h>
#define com_lcr com_cfcr
int com_puc_match(struct device *, void *, void *);
void com_puc_attach(struct device *, struct device *, void *);
int com_puc_detach(struct device *, int);
const struct cfattach com_puc_ca = {
sizeof(struct com_softc), com_puc_match,
com_puc_attach, com_puc_detach, com_activate
};
int
com_puc_match(struct device *parent, void *match, void *aux)
{
struct puc_attach_args *pa = aux;
if (PUC_IS_COM(pa->type))
return(1);
return(0);
}
void
com_puc_attach(struct device *parent, struct device *self, void *aux)
{
struct com_softc *sc = (void *)self;
struct puc_attach_args *pa = aux;
const char *intrstr;
int i;
intrstr = pa->intr_string(pa);
sc->sc_ih = pa->intr_establish(pa, IPL_TTY, comintr, sc,
sc->sc_dev.dv_xname);
if (sc->sc_ih == NULL) {
printf(": couldn't establish interrupt");
if (intrstr != NULL)
printf(" at %s", intrstr);
printf("\n");
return;
}
printf(" %s", intrstr);
sc->sc_iot = pa->t;
sc->sc_ioh = pa->h;
sc->sc_iobase = pa->a;
sc->sc_frequency = COM_FREQ;
for (i = 0; i < nitems(puc_port_types); i++)
if (puc_port_types[i].type == pa->type) {
sc->sc_frequency = puc_port_types[i].freq;
break;
}
if (pa->type == PUC_PORT_COM_XR17V35X)
sc->sc_uarttype = COM_UART_XR17V35X;
com_attach_subr(sc);
}
int
com_puc_detach(struct device *self, int flags)
{
return com_detach(self, flags);
}