1997-05-26 22:28:25 +00:00
|
|
|
/* Copyright (C) 1994, 1997 Free Software Foundation, Inc.
|
|
|
|
This file is part of the GNU C Library.
|
1994-08-25 00:09:09 +00:00
|
|
|
Contributed by Joel Sherrill (jsherril@redstone-emh2.army.mil),
|
|
|
|
On-Line Applications Research Corporation.
|
|
|
|
|
1997-05-26 22:28:25 +00:00
|
|
|
The GNU C Library is free software; you can redistribute it and/or
|
2001-07-06 04:56:23 +00:00
|
|
|
modify it under the terms of the GNU Lesser General Public
|
|
|
|
License as published by the Free Software Foundation; either
|
|
|
|
version 2.1 of the License, or (at your option) any later version.
|
1997-05-26 22:28:25 +00:00
|
|
|
|
|
|
|
The GNU C Library is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
2001-07-06 04:56:23 +00:00
|
|
|
Lesser General Public License for more details.
|
1997-05-26 22:28:25 +00:00
|
|
|
|
2001-07-06 04:56:23 +00:00
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
|
|
License along with the GNU C Library; if not, write to the Free
|
|
|
|
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
|
|
|
|
02111-1307 USA. */
|
1997-05-26 22:28:25 +00:00
|
|
|
|
1994-08-25 00:09:09 +00:00
|
|
|
#include <standalone.h>
|
1994-11-15 06:48:25 +00:00
|
|
|
#include "i960ca.h"
|
1994-08-25 00:09:09 +00:00
|
|
|
|
|
|
|
/* _Board_Initialize()
|
|
|
|
|
1997-05-26 22:28:25 +00:00
|
|
|
This routine initializes the board.
|
1994-08-25 00:09:09 +00:00
|
|
|
|
|
|
|
NOTE: Only tested on a Cyclone CVME961 but should be OK on any i960ca board. */
|
|
|
|
|
1997-05-26 22:28:25 +00:00
|
|
|
void
|
|
|
|
_Board_Initialize ()
|
1994-08-25 00:09:09 +00:00
|
|
|
{
|
|
|
|
struct i80960ca_prcb *prcb; /* ptr to processor control block */
|
|
|
|
struct i80960ca_ctltbl *ctl_tbl; /* ptr to control table */
|
|
|
|
|
|
|
|
static inline struct i80960ca_prcb *get_prcb()
|
|
|
|
{ register struct i80960ca_prcb *_prcb = 0;
|
|
|
|
asm volatile( "calls 5; \
|
|
|
|
mov g0,%0" \
|
|
|
|
: "=d" (_prcb) \
|
|
|
|
: "0" (_prcb) );
|
|
|
|
return ( _prcb );
|
|
|
|
}
|
|
|
|
|
1997-05-26 22:28:25 +00:00
|
|
|
prcb = get_prcb ();
|
1994-08-25 00:09:09 +00:00
|
|
|
ctl_tbl = prcb->control_tbl;
|
|
|
|
|
|
|
|
/* The following configures the data breakpoint (which must be set
|
|
|
|
* before this is executed) to break on writes only.
|
|
|
|
*/
|
|
|
|
|
|
|
|
ctl_tbl->bpcon &= ~0x00cc0000;
|
1997-05-26 22:28:25 +00:00
|
|
|
reload_ctl_group (6);
|
1994-08-25 00:09:09 +00:00
|
|
|
|
|
|
|
/* bit 31 of the Register Cache Control can be set to
|
|
|
|
* enable an alternative caching algorithm. It does
|
|
|
|
* not appear to help our applications.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Configure Number of Register Caches */
|
|
|
|
|
|
|
|
prcb->reg_cache_cfg = 8;
|
1997-05-26 22:28:25 +00:00
|
|
|
soft_reset (prcb);
|
1994-08-25 00:09:09 +00:00
|
|
|
}
|