OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-stable/] [newlib-1.18.0/] [libgloss/] [or32/] [read.c] - Rev 816

Go to most recent revision | Compare with Previous | Blame | View Log

/* read.c. Implementation of the _read syscall for newlib
 
   Copyright (C) 2004, Jacob Bower
   Copyright (C) 2010, Embecosm Limited <info@embecosm.com>
 
   Contributor Jeremy Bennett <jeremy.bennett@embecosm.com>
 
   This file is part of Newlib.
 
   The original work by Jacob Bower is provided as-is without any kind of
   warranty. Use it at your own risk!
 
   All subsequent work is bound by version 3 of the GPL as follows.
 
   This program is free software; you can redistribute it and/or modify it
   under the terms of the GNU General Public License as published by the Free
   Software Foundation; either version 3 of the License, or (at your option)
   any later version.
 
   This program 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 General Public License for
   more details.
 
   You should have received a copy of the GNU General Public License along
   with this program.  If not, see <http:#www.gnu.org/licenses/>.             */
/* -------------------------------------------------------------------------- */
/* This program is commented throughout in a fashion suitable for processing
   with Doxygen.                                                              */
/* -------------------------------------------------------------------------- */
 
#include <errno.h>
#include <unistd.h>
 
#include "or1k-support.h"
 
#undef errno
extern int  errno;
 
 
/* -------------------------------------------------------------------------- */
/*!Read from a file.
 
   Depending on board support, we may attempt to read from UART.
 
   Remember that this function is *not* reentrant, so no static state should
   be held.
 
   @param[in] file  The fileno to read.
   @param[in] buf   Buffer into which to read.
   @param[in] len   Number of bytes to read.
 
   @return  0 to indicate EOF if the file is stdin, otherwise -1 to indicate
            failure, with an error code in the global variable errno.         */
/* -------------------------------------------------------------------------- */
int
_read (int   file,
       char *buf,
       int   len)
{
	if (STDIN_FILENO == file)
	{
 
		if (BOARD_HAS_UART)
		{
			/* UART supported. Read from it */
 
 
			int  i;
 
			for (i = 0; i < len; i++)
			{
				buf[i] = __uart_getc ();
#ifdef UART_AUTO_ECHO
				__uart_putc (buf[i]);
#endif
				/* Return partial buffer if we get EOL */
				if ('\n' == buf[i])
				{
					return  i;
				}
			}
 
			return  i;			/* Filled the buffer */
		}
		else
		{
			return  0;			/* EOF */
		}
	}
	else
	{
		errno = EBADF;
		return  -1;
	}
}	/* _read () */
 

Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.