Initial commit of OpenSPARC T2 architecture model.
[OpenSPARC-T2-SAM] / obp / obp / forth.mk
CommitLineData
920dae64
AT
1# ========== Copyright Header Begin ==========================================
2#
3# Hypervisor Software File: forth.mk
4#
5# Copyright (c) 2006 Sun Microsystems, Inc. All Rights Reserved.
6#
7# - Do no alter or remove copyright notices
8#
9# - Redistribution and use of this software in source and binary forms, with
10# or without modification, are permitted provided that the following
11# conditions are met:
12#
13# - Redistribution of source code must retain the above copyright notice,
14# this list of conditions and the following disclaimer.
15#
16# - Redistribution in binary form must reproduce the above copyright notice,
17# this list of conditions and the following disclaimer in the
18# documentation and/or other materials provided with the distribution.
19#
20# Neither the name of Sun Microsystems, Inc. or the names of contributors
21# may be used to endorse or promote products derived from this software
22# without specific prior written permission.
23#
24# This software is provided "AS IS," without a warranty of any kind.
25# ALL EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES,
26# INCLUDING ANY IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A
27# PARTICULAR PURPOSE OR NON-INFRINGEMENT, ARE HEREBY EXCLUDED. SUN
28# MICROSYSTEMS, INC. ("SUN") AND ITS LICENSORS SHALL NOT BE LIABLE FOR
29# ANY DAMAGES SUFFERED BY LICENSEE AS A RESULT OF USING, MODIFYING OR
30# DISTRIBUTING THIS SOFTWARE OR ITS DERIVATIVES. IN NO EVENT WILL SUN
31# OR ITS LICENSORS BE LIABLE FOR ANY LOST REVENUE, PROFIT OR DATA, OR
32# FOR DIRECT, INDIRECT, SPECIAL, CONSEQUENTIAL, INCIDENTAL OR PUNITIVE
33# DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY,
34# ARISING OUT OF THE USE OF OR INABILITY TO USE THIS SOFTWARE, EVEN IF
35# SUN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
36#
37# You acknowledge that this software is not designed, licensed or
38# intended for use in the design, construction, operation or maintenance of
39# any nuclear facility.
40#
41# ========== Copyright Header End ============================================
42# id: @(#)forth.mk 1.6 02/05/02
43# purpose:
44# copyright: Copyright 1996-2002 Sun Microsystems, Inc. All Rights Reserved
45# copyright: Use is subject to license terms.
46
47CPU = sparc
48FORTHDIR = ${BP}/os/unix/sparc
49FORTH = ${FORTHDIR}/forth
50MAKEDI = ${TOOLS}/makedi -c
51
52# These are the absolute paths to the various forth engines
53FMKERNEL = ${BP}/fm/kernel/${CPU}
54BOOTSTRAPKERNEL = ${FMKERNEL}/kernel
55K32T32 = ${FMKERNEL}/k32t32
56K32T16S2 = ${FMKERNEL}/k32t16s2
57K32T16S4 = ${FMKERNEL}/k32t16s4
58K64T32 = ${FMKERNEL}/k64t32
59K64T16S2 = ${FMKERNEL}/k64t16s2
60K64T16S4 = ${FMKERNEL}/k64t16s4
61K64MINI = ${FMKERNEL}/k64mini
62
63# These are the absolute paths to the various forth engines
64BOOTSTRAPFORTH = ${BP}/os/sun/sparc/forth32
65F32T32 = ${BP}/os/sun/sparc/f32t32
66F32T16S2 = ${BP}/os/sun/sparc/f32t16s2
67F32T16S4 = ${BP}/os/sun/sparc/f32t16s4
68F64T32 = ${BP}/os/sun/sparc/f64t32
69F64T16S2 = ${BP}/os/sun/sparc/f64t16s2
70F64T16S4 = ${BP}/os/sun/sparc/f64t16s4
71
72# Which forth engine the tokenizer and tools should use.
73FORTHDIC = ${F32T32}.dic
74
75COMPILER = ${FORTH} -d ${FORTHDIC}
76FORTHTOOL = ${COMPILER} ${FFLAGS} -s "${FTHFLAGS}"
77TOKENIZER = ${BP}/pkg/tokenizr
78TOKENIZEDIC = ${TOKENIZER}/sparc/tokenize.dic
79TOKENIZE = ${FORTH} -d ${TOKENIZEDIC} -D tokenizer? ${FFLAGS}
80
81# MAGIC files:
82# When you build do a touch <thing> and you get more uinformation
83# VERBOSE = show the filenames as they load
84# NOTIFY = make compile echo lines show up.
85#
86NOTIFY:sh = if [ -f NOTIFY ]; \
87 then /bin/echo "/bin/echo"; \
88 else /bin/echo "/bin/true"; fi;
89
90VERBOSE:sh = if [ -f VERBOSE ];\
91 then /bin/echo "-v" ;\
92 else /bin/echo ; fi ;
93
94FTHFLAGS =
95
96include ${ROOT}/lib/depend.mk
97include ${ROOT}/bin/depend.mk
98include ${BP}/os/unix/sparc/depend.mk # Native 32 compile
99include ${BP}/os/unix/sparcv9/depend.mk # Native 64 compile
100include ${BP}/os/unix/simforth/sparc/depend.mk # simforth wrapper
101include ${BP}/fm/kernel/${CPU}/depend.mk # all the forth Kernels
102include ${BP}/os/sun/sparc/depend.mk # Forth engines
103include ${TOKENIZER}/${CPU}/depend.mk # Tokenizer