1 /* $NetBSD: mcclock_ioasic.c,v 1.21 2009/03/14 15:36:12 dsl Exp $ */
4 * Copyright (c) 1994, 1995, 1996 Carnegie-Mellon University.
7 * Author: Chris G. Demetriou
9 * Permission to use, copy, modify and distribute this software and
10 * its documentation is hereby granted, provided that both the copyright
11 * notice and this permission notice appear in all copies of the
12 * software, derivative works or modified versions, and any portions
13 * thereof, and that both notices appear in supporting documentation.
15 * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
16 * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND
17 * FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
19 * Carnegie Mellon requests users of this software to return to
21 * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU
22 * School of Computer Science
23 * Carnegie Mellon University
24 * Pittsburgh PA 15213-3890
26 * any improvements or extensions that they make and grant Carnegie the
27 * rights to redistribute these changes.
30 #include <sys/cdefs.h>
31 __KERNEL_RCSID(0, "$NetBSD: mcclock_ioasic.c,v 1.21 2009/03/14 15:36:12 dsl Exp $");
33 #include <sys/param.h>
34 #include <sys/device.h>
35 #include <sys/systm.h>
36 #include <dev/clock_subr.h>
38 #include <dev/dec/mcclockvar.h>
39 #include <dev/dec/mcclock_pad32.h>
41 #include <dev/tc/tcvar.h>
42 #include <dev/tc/ioasicvar.h>
44 static int mcclock_ioasic_match(struct device
*, struct cfdata
*,
46 static void mcclock_ioasic_attach(struct device
*, struct device
*,
49 CFATTACH_DECL(mcclock_ioasic
, sizeof (struct mcclock_pad32_softc
),
50 mcclock_ioasic_match
, mcclock_ioasic_attach
, NULL
, NULL
);
53 mcclock_ioasic_match(struct device
*parent
, struct cfdata
*match
, void *aux
)
55 struct ioasicdev_attach_args
*d
= aux
;
57 if (strcmp("mc146818", d
->iada_modname
) != 0)
60 if (tc_badaddr(d
->iada_addr
))
67 mcclock_ioasic_attach(struct device
*parent
, struct device
*self
, void *aux
)
69 struct ioasicdev_attach_args
*ioasicdev
= aux
;
70 struct mcclock_pad32_softc
*sc
= (struct mcclock_pad32_softc
*)self
;
72 sc
->sc_dp
= (struct mcclock_pad32_clockdatum
*)ioasicdev
->iada_addr
;
74 /* Attach MI driver, using busfns with TC-style register padding */
75 mcclock_attach(&sc
->sc_mcclock
, &mcclock_pad32_busfns
);