1 1.10 rin /* $NetBSD: obs200_autoconf.c,v 1.10 2021/03/30 04:53:13 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.10 rin __KERNEL_RCSID(0, "$NetBSD: obs200_autoconf.c,v 1.10 2021/03/30 04:53:13 rin Exp $"); 37 1.1 shige 38 1.10 rin #include <sys/param.h> 39 1.10 rin #include <sys/device.h> 40 1.1 shige #include <sys/systm.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.3 shige /* 48 1.3 shige * Determine device configuration for a machine. 49 1.3 shige */ 50 1.3 shige void 51 1.3 shige cpu_configure(void) 52 1.3 shige { 53 1.3 shige 54 1.3 shige intr_init(); 55 1.3 shige calc_delayconst(); 56 1.3 shige 57 1.3 shige /* Make sure that timers run at CPU frequency */ 58 1.3 shige mtdcr(DCR_CPC0_CR1, mfdcr(DCR_CPC0_CR1) & ~CPC0_CR1_CETE); 59 1.3 shige 60 1.3 shige if (config_rootfound("plb", NULL) == NULL) 61 1.3 shige panic("configure: mainbus not configured"); 62 1.3 shige 63 1.8 rin genppc_cpu_configure(); 64 1.3 shige } 65 1.3 shige 66 1.6 matt void device_register(device_t dev, void *aux) 67 1.1 shige { 68 1.1 shige 69 1.9 rin ibm4xx_device_register(dev, aux, OBS200_COM_FREQ); 70 1.1 shige } 71