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