1 /* Copyright (C) 1994, 1997 Free Software Foundation, Inc.
2 This file is part of the GNU C Library.
3 Contributed by Joel Sherrill (jsherril@redstone-emh2.army.mil),
4 On-Line Applications Research Corporation.
6 The GNU C Library is free software; you can redistribute it and/or
7 modify it under the terms of the GNU Lesser General Public
8 License as published by the Free Software Foundation; either
9 version 2.1 of the License, or (at your option) any later version.
11 The GNU C Library is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 Lesser General Public License for more details.
16 You should have received a copy of the GNU Lesser General Public
17 License along with the GNU C Library; if not, write to the Free
18 Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
21 #include <standalone.h>
24 /* _Board_Initialize()
26 This routine initializes the board.
28 NOTE: Only tested on a Cyclone CVME961 but should be OK on any i960ca board. */
33 struct i80960ca_prcb
*prcb
; /* ptr to processor control block */
34 struct i80960ca_ctltbl
*ctl_tbl
; /* ptr to control table */
36 static inline struct i80960ca_prcb
*get_prcb()
37 { register struct i80960ca_prcb
*_prcb
= 0;
38 asm volatile( "calls 5; \
46 ctl_tbl
= prcb
->control_tbl
;
48 /* The following configures the data breakpoint (which must be set
49 * before this is executed) to break on writes only.
52 ctl_tbl
->bpcon
&= ~0x00cc0000;
55 /* bit 31 of the Register Cache Control can be set to
56 * enable an alternative caching algorithm. It does
57 * not appear to help our applications.
60 /* Configure Number of Register Caches */
62 prcb
->reg_cache_cfg
= 8;