]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - sys/alpha/include/cpuconf.h
This commit was generated by cvs2svn to compensate for changes in r53564,
[FreeBSD/FreeBSD.git] / sys / alpha / include / cpuconf.h
1 /*      $NetBSD: cpuconf.h,v 1.7 1997/11/06 00:42:03 thorpej Exp $      */
2 #ifndef _ALPHA_CPUCONF_H
3 #define _ALPHA_CPUCONF_H
4 /*
5  * Copyright (c) 1996 Christopher G. Demetriou.  All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  * 1. Redistributions of source code must retain the above copyright
11  *    notice, this list of conditions and the following disclaimer.
12  * 2. Redistributions in binary form must reproduce the above copyright
13  *    notice, this list of conditions and the following disclaimer in the
14  *    documentation and/or other materials provided with the distribution.
15  * 3. All advertising materials mentioning features or use of this software
16  *    must display the following acknowledgement:
17  *      This product includes software developed by Christopher G. Demetriou
18  *      for the NetBSD Project.
19  * 4. The name of the author may not be used to endorse or promote products
20  *    derived from this software without specific prior written permission
21  *
22  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
23  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
24  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
25  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
26  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
27  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
31  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32  */
33 /*
34  * Additional reworking by Matthew Jacob for NASA/Ames Research Center.
35  * Copyright (c) 1997
36  */
37 #ifdef KERNEL
38 /*
39  * Platform Specific Information and Function Hooks.
40  *
41  * The tags family and model information are strings describing the platform.
42  * 
43  * The tag iobus describes the primary iobus for the platform- primarily
44  * to give a hint as to where to start configuring. The likely choices
45  * are one of tcasic, lca, apecs, cia, or tlsb.
46  *
47  */
48 struct device;                  /* XXX */
49
50 extern struct platform {
51         /*
52          * Platform Information.
53          */
54         const char      *family;        /* Family Name */
55         const char      *model;         /* Model (variant) Name */
56         const char      *iobus;         /* Primary iobus name */
57
58         /*
59          * Platform Specific Function Hooks
60          *      cons_init       -       console initialization
61          *      device_register -       boot configuration aid
62          *      iointr          -       I/O interrupt handler
63          *      clockintr       -       Clock Interrupt Handler
64          *      mcheck_handler  -       Platform Specific Machine Check Handler
65          */
66         void    (*cons_init) __P((void));
67         void    (*device_register) __P((struct device *, void *));
68         void    (*iointr) __P((void *, unsigned long));
69         void    (*clockintr) __P((void *));
70         void    (*mcheck_handler) __P((unsigned long, struct trapframe *,
71                 unsigned long, unsigned long));
72         void    (*pci_intr_init) __P((void));
73         void    (*pci_intr_map) __P((void *));
74         void    (*pci_intr_disable) __P((int));
75         void    (*pci_intr_enable) __P((int));
76         int     (*pci_setup_ide_intr) __P((int chan, void (*fn)(void*), void *arg));
77 } platform;
78
79 /*
80  * Lookup table entry for Alpha system variations.
81  */
82 struct alpha_variation_table {
83         u_int64_t       avt_variation;  /* variation, from HWRPB */
84         const char      *avt_model;     /* model string */
85 };
86
87 /*
88  * There is an array of functions to initialize the platform structure.
89  *
90  * It's responsible for filling in the family, model_name and iobus
91  * tags. It may optionally fill in the cons_init, device_register and
92  * mcheck_handler tags.
93  *
94  * The iointr tag is filled in by set_iointr (in interrupt.c).
95  * The clockintr tag is filled in by cpu_initclocks (in clock.c).
96  *
97  * nocpu is function to call when you can't figure what platform you're on.
98  * There's no return from this function.
99  */
100
101 struct cpuinit {
102         void    (*init) __P((int));
103         const char *option;
104 };
105
106 #define cpu_notsupp(st)         { platform_not_supported, st }
107 #define cpu_init(fn, opt)       { fn, opt }
108
109 /*
110  * Misc. support routines.
111  */
112 const char      *alpha_dsr_sysname __P((void));
113 const char      *alpha_variation_name __P((u_int64_t variation,
114     const struct alpha_variation_table *avtp));
115 const char      *alpha_unknown_sysname __P((void));
116
117 extern struct cpuinit cpuinit[];
118 extern int ncpuinit;
119 extern void platform_not_configured __P((int));
120 extern void platform_not_supported __P((int));
121
122 #endif /* KERNEL */
123 #endif /* !_ALPHA_CPUCONF_H */