Home | History | Annotate | Line # | Download | only in alchemy
      1  1.6      matt /* $NetBSD: genericbd.c,v 1.6 2015/06/09 22:49:55 matt Exp $ */
      2  1.1   gdamore 
      3  1.1   gdamore /*-
      4  1.1   gdamore  * Copyright (c) 2006 Itronix Inc.
      5  1.1   gdamore  * All rights reserved.
      6  1.1   gdamore  *
      7  1.1   gdamore  * Written by Garrett D'Amore for Itronix Inc.
      8  1.1   gdamore  *
      9  1.1   gdamore  * Redistribution and use in source and binary forms, with or without
     10  1.1   gdamore  * modification, are permitted provided that the following conditions
     11  1.1   gdamore  * are met:
     12  1.1   gdamore  * 1. Redistributions of source code must retain the above copyright
     13  1.1   gdamore  *    notice, this list of conditions and the following disclaimer.
     14  1.1   gdamore  * 2. Redistributions in binary form must reproduce the above copyright
     15  1.1   gdamore  *    notice, this list of conditions and the following disclaimer in the
     16  1.1   gdamore  *    documentation and/or other materials provided with the distribution.
     17  1.1   gdamore  * 3. The name of Itronix Inc. may not be used to endorse
     18  1.1   gdamore  *    or promote products derived from this software without specific
     19  1.1   gdamore  *    prior written permission.
     20  1.1   gdamore  *
     21  1.1   gdamore  * THIS SOFTWARE IS PROVIDED BY ITRONIX INC. ``AS IS'' AND
     22  1.1   gdamore  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     23  1.1   gdamore  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     24  1.1   gdamore  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL ITRONIX INC. BE LIABLE FOR ANY
     25  1.1   gdamore  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
     26  1.1   gdamore  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
     27  1.1   gdamore  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
     28  1.1   gdamore  * ON ANY THEORY OF LIABILITY, WHETHER IN
     29  1.1   gdamore  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     30  1.1   gdamore  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     31  1.1   gdamore  * POSSIBILITY OF SUCH DAMAGE.
     32  1.1   gdamore  */
     33  1.1   gdamore 
     34  1.1   gdamore #include <sys/cdefs.h>
     35  1.6      matt __KERNEL_RCSID(0, "$NetBSD: genericbd.c,v 1.6 2015/06/09 22:49:55 matt Exp $");
     36  1.1   gdamore 
     37  1.1   gdamore #include <sys/param.h>
     38  1.3    dyoung #include <sys/bus.h>
     39  1.6      matt #include <sys/cpu.h>
     40  1.4      matt 
     41  1.4      matt #include <mips/locore.h>
     42  1.4      matt 
     43  1.1   gdamore #include <evbmips/alchemy/obiovar.h>
     44  1.1   gdamore #include <evbmips/alchemy/board.h>
     45  1.1   gdamore 
     46  1.1   gdamore static void genericbd_init(void);
     47  1.1   gdamore 
     48  1.1   gdamore /*
     49  1.1   gdamore  * Generically, we have no OBIO devices.
     50  1.1   gdamore  */
     51  1.1   gdamore static const struct obiodev genericbd_devices[] = {
     52  1.1   gdamore 	{ NULL },
     53  1.1   gdamore };
     54  1.1   gdamore 
     55  1.1   gdamore static struct alchemy_board genericbd_info = {
     56  1.1   gdamore 	NULL,
     57  1.1   gdamore 	genericbd_devices,
     58  1.1   gdamore 	genericbd_init,
     59  1.1   gdamore 	NULL,	/* no PCI */
     60  1.1   gdamore };
     61  1.1   gdamore 
     62  1.1   gdamore /*
     63  1.1   gdamore  * XXX: A cleaner way would be to get this from the cpu table in the MIPS
     64  1.5  christos  * CPU handler code (or even better, have *that* code fill in cpu model.)
     65  1.1   gdamore  */
     66  1.1   gdamore static struct {
     67  1.1   gdamore 	int		id;
     68  1.1   gdamore 	const char 	*name;
     69  1.1   gdamore } cpus[] = {
     70  1.1   gdamore 	{ MIPS_AU1000,	"Generic Alchemy Au1000" },
     71  1.1   gdamore 	{ MIPS_AU1100,	"Generic Alchemy Au1100" },
     72  1.1   gdamore 	{ MIPS_AU1500,  "Generic Alchemy Au1500" },
     73  1.1   gdamore 	{ MIPS_AU1550,	"Generic Alchemy Au1550" },
     74  1.1   gdamore 	{ 0, NULL },
     75  1.1   gdamore };
     76  1.1   gdamore 
     77  1.1   gdamore const struct alchemy_board *
     78  1.1   gdamore board_info(void)
     79  1.1   gdamore {
     80  1.2      matt 	const mips_prid_t cpu_id = mips_options.mips_cpu_id;
     81  1.2      matt 
     82  1.1   gdamore 	/* at least try to report the correct processor name */
     83  1.1   gdamore 	if (genericbd_info.ab_name == NULL) {
     84  1.1   gdamore 		int	i;
     85  1.1   gdamore 		for (i = 0; cpus[i].name; i++) {
     86  1.1   gdamore 			if (cpus[i].id == MIPS_PRID_COPTS(cpu_id)) {
     87  1.1   gdamore 				genericbd_info.ab_name = cpus[i].name;
     88  1.1   gdamore 				break;
     89  1.1   gdamore 			}
     90  1.1   gdamore 		}
     91  1.1   gdamore 		if (genericbd_info.ab_name == NULL)
     92  1.1   gdamore 			genericbd_info.ab_name = "Unknown Alchemy";
     93  1.1   gdamore 	}
     94  1.1   gdamore 
     95  1.1   gdamore 	return &genericbd_info;
     96  1.1   gdamore }
     97  1.1   gdamore 
     98  1.1   gdamore void
     99  1.1   gdamore genericbd_init(void)
    100  1.1   gdamore {
    101  1.1   gdamore 
    102  1.1   gdamore 	/* leave console and clocks alone -- YAMON should have got it right! */
    103  1.1   gdamore }
    104