00001 /* 00002 * Copyright (C) 2001-2003 by egnite Software GmbH. All rights reserved. 00003 * 00004 * Redistribution and use in source and binary forms, with or without 00005 * modification, are permitted provided that the following conditions 00006 * are met: 00007 * 00008 * 1. Redistributions of source code must retain the above copyright 00009 * notice, this list of conditions and the following disclaimer. 00010 * 2. Redistributions in binary form must reproduce the above copyright 00011 * notice, this list of conditions and the following disclaimer in the 00012 * documentation and/or other materials provided with the distribution. 00013 * 3. Neither the name of the copyright holders nor the names of 00014 * contributors may be used to endorse or promote products derived 00015 * from this software without specific prior written permission. 00016 * 00017 * THIS SOFTWARE IS PROVIDED BY EGNITE SOFTWARE GMBH AND CONTRIBUTORS 00018 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 00019 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 00020 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL EGNITE 00021 * SOFTWARE GMBH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 00022 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 00023 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS 00024 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED 00025 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 00026 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF 00027 * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 00028 * SUCH DAMAGE. 00029 * 00030 * For additional information see http://www.ethernut.de/ 00031 * 00032 */ 00033 00034 /* 00035 * $Log$ 00036 * Revision 1.3 2009/01/17 15:37:52 haraldkipp 00037 * Added some NUTASSERT macros to check function parameters. 00038 * 00039 * Revision 1.2 2004/04/15 10:23:24 haraldkipp 00040 * Distinguish between read error and end of file 00041 * 00042 * Revision 1.1.1.1 2003/05/09 14:40:27 haraldkipp 00043 * Initial using 3.2.1 00044 * 00045 * Revision 1.1 2003/02/04 17:49:05 harald 00046 * *** empty log message *** 00047 * 00048 */ 00049 00050 00051 #include "nut_io.h" 00052 00053 #include <sys/nutdebug.h> 00054 #include <io.h> 00055 00060 00075 size_t fread(void *buffer, size_t size, size_t count, FILE * stream) 00076 { 00077 size_t rc; 00078 size_t nu = 0; 00079 00080 NUTASSERT(stream != NULL); 00081 NUTASSERT(buffer != NULL); 00082 if (size > 1) 00083 count *= size; 00084 if (stream->iob_flags & _IOUNG) { 00085 stream->iob_flags &= ~_IOUNG; 00086 *((char *) buffer) = (char) stream->iob_unget; 00087 buffer = ((char *) buffer) + 1; 00088 count--; 00089 nu++; 00090 } 00091 rc = (size_t) _read(stream->iob_fd, buffer, count); 00092 if (rc == 0) { 00093 stream->iob_flags |= _IOEOF; 00094 } 00095 else if(rc == (size_t)-1) { 00096 stream->iob_flags |= _IOERR; 00097 rc = 0; 00098 } 00099 rc += nu; 00100 if (size > 1) { 00101 rc /= size; 00102 } 00103 return rc; 00104 } 00105