obs200_autoconf.c revision 1.9 1 1.9 rin /* $NetBSD: obs200_autoconf.c,v 1.9 2021/03/29 13:38:31 rin Exp $ */
2 1.1 shige
3 1.1 shige /*
4 1.1 shige * Copyright 2004 Shigeyuki Fukushima.
5 1.1 shige * All rights reserved.
6 1.1 shige *
7 1.1 shige * Written by Shigeyuki Fukushima for The NetBSD Project.
8 1.1 shige *
9 1.1 shige * Redistribution and use in source and binary forms, with or without
10 1.1 shige * modification, are permitted provided that the following conditions
11 1.1 shige * are met:
12 1.1 shige * 1. Redistributions of source code must retain the above copyright
13 1.1 shige * notice, this list of conditions and the following disclaimer.
14 1.1 shige * 2. Redistributions in binary form must reproduce the above
15 1.1 shige * copyright notice, this list of conditions and the following
16 1.1 shige * disclaimer in the documentation and/or other materials provided
17 1.1 shige * with the distribution.
18 1.1 shige * 3. The name of the author may not be used to endorse or promote
19 1.1 shige * products derived from this software without specific prior
20 1.1 shige * written permission.
21 1.1 shige *
22 1.1 shige * THIS SOFTWARE IS PROVIDED THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
23 1.1 shige * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
24 1.1 shige * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
25 1.1 shige * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE
26 1.1 shige * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
27 1.1 shige * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
28 1.1 shige * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
29 1.1 shige * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
30 1.1 shige * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
31 1.1 shige * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
32 1.1 shige * USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
33 1.1 shige * DAMAGE.
34 1.1 shige */
35 1.1 shige #include <sys/cdefs.h>
36 1.9 rin __KERNEL_RCSID(0, "$NetBSD: obs200_autoconf.c,v 1.9 2021/03/29 13:38:31 rin Exp $");
37 1.1 shige
38 1.1 shige #include <sys/systm.h>
39 1.1 shige #include <sys/device.h>
40 1.6 matt #include <sys/cpu.h>
41 1.1 shige
42 1.1 shige #include <machine/obs200.h>
43 1.1 shige
44 1.5 kiyohara #include <powerpc/ibm4xx/cpu.h>
45 1.5 kiyohara #include <powerpc/ibm4xx/dcr4xx.h>
46 1.5 kiyohara
47 1.5 kiyohara #include <dev/ic/comreg.h>
48 1.3 shige
49 1.3 shige
50 1.3 shige /*
51 1.3 shige * Determine device configuration for a machine.
52 1.3 shige */
53 1.3 shige void
54 1.3 shige cpu_configure(void)
55 1.3 shige {
56 1.3 shige
57 1.3 shige intr_init();
58 1.3 shige calc_delayconst();
59 1.3 shige
60 1.3 shige /* Make sure that timers run at CPU frequency */
61 1.3 shige mtdcr(DCR_CPC0_CR1, mfdcr(DCR_CPC0_CR1) & ~CPC0_CR1_CETE);
62 1.3 shige
63 1.3 shige if (config_rootfound("plb", NULL) == NULL)
64 1.3 shige panic("configure: mainbus not configured");
65 1.3 shige
66 1.8 rin genppc_cpu_configure();
67 1.3 shige }
68 1.3 shige
69 1.6 matt void device_register(device_t dev, void *aux)
70 1.1 shige {
71 1.1 shige
72 1.9 rin ibm4xx_device_register(dev, aux, OBS200_COM_FREQ);
73 1.1 shige }
74