Initial commit of OpenSPARC T2 architecture model.
[OpenSPARC-T2-SAM] / hypervisor / src / greatlakes / ontario / src / init_ontario.c
CommitLineData
920dae64
AT
1/*
2* ========== Copyright Header Begin ==========================================
3*
4* Hypervisor Software File: init_ontario.c
5*
6* Copyright (c) 2006 Sun Microsystems, Inc. All Rights Reserved.
7*
8* - Do no alter or remove copyright notices
9*
10* - Redistribution and use of this software in source and binary forms, with
11* or without modification, are permitted provided that the following
12* conditions are met:
13*
14* - Redistribution of source code must retain the above copyright notice,
15* this list of conditions and the following disclaimer.
16*
17* - Redistribution in binary form must reproduce the above copyright notice,
18* this list of conditions and the following disclaimer in the
19* documentation and/or other materials provided with the distribution.
20*
21* Neither the name of Sun Microsystems, Inc. or the names of contributors
22* may be used to endorse or promote products derived from this software
23* without specific prior written permission.
24*
25* This software is provided "AS IS," without a warranty of any kind.
26* ALL EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES,
27* INCLUDING ANY IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A
28* PARTICULAR PURPOSE OR NON-INFRINGEMENT, ARE HEREBY EXCLUDED. SUN
29* MICROSYSTEMS, INC. ("SUN") AND ITS LICENSORS SHALL NOT BE LIABLE FOR
30* ANY DAMAGES SUFFERED BY LICENSEE AS A RESULT OF USING, MODIFYING OR
31* DISTRIBUTING THIS SOFTWARE OR ITS DERIVATIVES. IN NO EVENT WILL SUN
32* OR ITS LICENSORS BE LIABLE FOR ANY LOST REVENUE, PROFIT OR DATA, OR
33* FOR DIRECT, INDIRECT, SPECIAL, CONSEQUENTIAL, INCIDENTAL OR PUNITIVE
34* DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY,
35* ARISING OUT OF THE USE OF OR INABILITY TO USE THIS SOFTWARE, EVEN IF
36* SUN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
37*
38* You acknowledge that this software is not designed, licensed or
39* intended for use in the design, construction, operation or maintenance of
40* any nuclear facility.
41*
42* ========== Copyright Header End ============================================
43*/
44/*
45 * Copyright 2007 Sun Microsystems, Inc. All rights reserved.
46 * Use is subject to license terms.
47 */
48
49#pragma ident "@(#)init_ontario.c 1.2 07/05/07 SMI"
50
51#include <stdarg.h>
52
53#include <sys/htypes.h>
54#include <hypervisor.h>
55#include <traps.h>
56#include <cache.h>
57#include <mmu.h>
58#include <sun4v/asi.h>
59#include <sun4v/errs_defs.h>
60#include <cpu_errs_defs.h>
61#include <cpu_errs.h>
62#include <vpci_errs_defs.h>
63#include <vdev_ops.h>
64#include <vdev_intr.h>
65#include <ncs.h>
66#include <cyclic.h>
67#include <config.h>
68#include <vcpu.h>
69#include <strand.h>
70#include <guest.h>
71#include <memory.h>
72#include <pcie.h>
73#include <support.h>
74#include <fpga.h>
75#include <svc.h>
76#include <ldc.h>
77#include <hvctl.h>
78#include <md.h>
79#include <abort.h>
80#include <proto.h>
81#ifdef CONFIG_FIRE
82#include <fire.h>
83#endif
84
85#ifdef CONFIG_CRYPTO /* { */
86extern void init_mau_crypto_units();
87#endif /* } */
88
89#ifdef CONFIG_FIRE
90extern const struct fire_cookie fire_dev[];
91void c_fire_leaf_soft_reset(const struct fire_cookie *, int root);
92#endif
93
94/*
95 * FIXME: This needs to be moved into a platform
96 * specific file.
97 */
98void
99reloc_plat_devops()
100{
101 extern devopsvec_t vdev_ops;
102#ifdef CONFIG_FIRE /* { */
103 extern devopsvec_t fire_dev_ops;
104 extern devopsvec_t fire_int_ops;
105 extern devopsvec_t fire_msi_ops;
106 extern devopsvec_t fire_err_int_ops;
107#endif /* } */
108 extern devopsvec_t cdev_ops;
109
110 reloc_devopsvec(&vdev_ops);
111#ifdef CONFIG_FIRE
112 reloc_devopsvec(&fire_dev_ops);
113 reloc_devopsvec(&fire_int_ops);
114 reloc_devopsvec(&fire_msi_ops);
115 reloc_devopsvec(&fire_err_int_ops);
116#endif
117 reloc_devopsvec(&cdev_ops);
118}
119
120void
121config_a_guest_niu(guest_t *guestp)
122{
123 DBG(c_printf("\tWARNING NIU not supported for guest 0x%x\n",
124 guestp->guestid));
125 /* should probably panic here */
126}
127
128#ifdef CONFIG_CRYPTO
129/*
130 * cwq support functions.
131 */
132void
133res_cwq_prep()
134{
135}
136
137hvctl_status_t
138res_cwq_parse(bin_md_t *mdp, hvctl_res_error_t *fail_codep,
139 md_element_t **failnodepp, int *fail_res_idp)
140{
141 DBG(c_printf("CWQ NOT SUPPORTED\n"));
142 return (HVctl_st_ok);
143}
144
145void
146res_cwq_commit(int flag)
147{
148 DBG(c_printf("CWQ NOT SUPPORTED\n"));
149}
150
151hvctl_status_t
152res_cwq_postparse(hvctl_res_error_t *res_error, int *fail_res_id)
153{
154 DBG(c_printf("CWQS in HVMD - NOT SUPPORTED\n"));
155 return (HVctl_st_ok);
156}
157#endif /* CONFIG_CRYPTO */
158
159
160void
161init_plat_hook(void)
162{
163#ifdef CONFIG_CRYPTO
164 init_mau_crypto_units();
165#endif /* CONFIG_CRYPTO */
166}