si.c 1.87 KB

/*====================================================================
 * si.c
 *
 * Copyright 1995, Silicon Graphics, Inc.
 * All Rights Reserved.
 *
 * This is UNPUBLISHED PROPRIETARY SOURCE CODE of Silicon Graphics,
 * Inc.; the contents of this file may not be disclosed to third
 * parties, copied or duplicated in any form, in whole or in part,
 * without the prior written permission of Silicon Graphics, Inc.
 *
 * RESTRICTED RIGHTS LEGEND:
 * Use, duplication or disclosure by the Government is subject to
 * restrictions as set forth in subdivision (c)(1)(ii) of the Rights
 * in Technical Data and Computer Software clause at DFARS
 * 252.227-7013, and/or in similar or successor clauses in the FAR,
 * DOD or NASA FAR Supplement. Unpublished - rights reserved under the
 * Copyright Laws of the United States.
 *====================================================================*/

/**************************************************************************
 *
 *  $Revision: 1.1.1.2 $
 *  $Date: 2002/10/29 08:06:43 $
 *  $Source: /root/leakn64/depot/rf/sw/bbplayer/libultra/monegi/si/si.c,v $
 *
 **************************************************************************/


#include "osint.h"
#include "rcp.h"
#include "assert.h"


/***********************************************************************
 *
 * Note: The SI DRAM address reg (SI_DRAM_ADDR_REG) supports only 24-bit 
 *	 address; the most significant byte and the least significant 2 bits 
 *	 are masked off. The address needs to be 32-bit aligned.
 */

/*
 * Name:   __osSiDeviceBusy
 *
 * Description:
 *	Determine if the serial interface is busy performing IO operation.
 *
 * Globals Referenced: 
 *	None
 */
int
__osSiDeviceBusy(void)
{
    register u32 stat;

    stat = IO_READ(SI_STATUS_REG);
    if (stat & (SI_STATUS_DMA_BUSY | SI_STATUS_RD_BUSY)) 
        return(1);
    else
        return(0);

}  /* __osSiDeviceBusy */