Initial commit of OpenSPARC T2 architecture model.
[OpenSPARC-T2-SAM] / obp / tools / promif / common / prom_node.c
CommitLineData
920dae64
AT
1/*
2* ========== Copyright Header Begin ==========================================
3*
4* Hypervisor Software File: prom_node.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 (c) 2000-2003 Sun Microsystems, Inc.
46 * All rights reserved.
47 * Use is subject to license terms.
48 */
49
50#pragma ident "@(#)prom_node.c 1.1 00/07/22 SMI"
51
52#include <sys/promif.h>
53#include <sys/promimpl.h>
54
55/*
56 * Routines for walking the device tree
57 */
58dnode_t
59prom_nextnode(register dnode_t nodeid)
60{
61 cell_t ci[5];
62
63 ci[0] = p1275_ptr2cell("peer"); /* Service name */
64 ci[1] = (cell_t)1; /* #argument cells */
65 ci[2] = (cell_t)1; /* #result cells */
66 ci[3] = p1275_dnode2cell(nodeid); /* Arg1: input phandle */
67 ci[4] = p1275_dnode2cell(OBP_NONODE); /* Res1: Prime result */
68
69 (void) p1275_cif_handler(&ci);
70
71 return (p1275_cell2dnode(ci[4])); /* Res1: peer phandle */
72}
73
74dnode_t
75prom_childnode(register dnode_t nodeid)
76{
77 cell_t ci[5];
78
79 ci[0] = p1275_ptr2cell("child"); /* Service name */
80 ci[1] = (cell_t)1; /* #argument cells */
81 ci[2] = (cell_t)1; /* #result cells */
82 ci[3] = p1275_dnode2cell(nodeid); /* Arg1: input phandle */
83 ci[4] = p1275_dnode2cell(OBP_NONODE); /* Res1: Prime result */
84
85 (void) p1275_cif_handler(&ci);
86
87 return (p1275_cell2dnode(ci[4])); /* Res1: child phandle */
88}
89
90dnode_t
91prom_parentnode(register dnode_t nodeid)
92{
93 cell_t ci[5];
94
95 ci[0] = p1275_ptr2cell("parent"); /* Service name */
96 ci[1] = (cell_t)1; /* #argument cells */
97 ci[2] = (cell_t)1; /* #result cells */
98 ci[3] = p1275_dnode2cell(nodeid); /* Arg1: input phandle */
99 ci[4] = p1275_dnode2cell(OBP_NONODE); /* Res1: Prime result */
100
101 (void) p1275_cif_handler(&ci);
102
103 return (p1275_cell2dnode(ci[4])); /* Res1: parent phandle */
104}
105
106dnode_t
107prom_finddevice(char *path)
108{
109 cell_t ci[5];
110
111 ci[0] = p1275_ptr2cell("finddevice"); /* Service name */
112 ci[1] = (cell_t)1; /* #argument cells */
113 ci[2] = (cell_t)1; /* #result cells */
114 ci[3] = p1275_ptr2cell(path); /* Arg1: pathname */
115 ci[4] = p1275_dnode2cell(OBP_BADNODE); /* Res1: Prime result */
116
117 (void) p1275_cif_handler(&ci);
118
119 return ((dnode_t)p1275_cell2dnode(ci[4])); /* Res1: phandle */
120}