mirror of
git://sourceware.org/git/newlib-cygwin.git
synced 2025-01-16 19:40:07 +08:00
7d592bb178
Kazunori Asayama <asayama@sm.sony.co.jp> * configure.host: Enable SPU specific stdio directory. * libc/machine/spu/Makefile.am: Add objects. * libc/machine/spu/Makefile.in: Regenerated. * libc/machine/spu/c99ppe.h: Add macros and function declarations to initialize SPU specific stdio stuffs. * libc/machine/spu/stdio.c: Add functions to manage Cell SPU specific FILE structures. * libc/machine/spu/perror.c: Add initialization routine of stdio stuffs. * libc/machine/spu/printf.c: Ditto. * libc/machine/spu/putchar.c: Ditto. * libc/machine/spu/puts.c: Ditto. * libc/machine/spu/vprintf.c: Ditto. * libc/machine/spu/clearerr.c: New file. Add a stdio function implementation. * libc/machine/spu/feof.c: Ditto. * libc/machine/spu/ferror.c: Ditto. * libc/machine/spu/fileno.c: Ditto. * libc/machine/spu/fopen.c: Ditto. * libc/machine/spu/fclose.c: Ditto. * libc/machine/spu/freopen.c: Ditto. * libc/machine/spu/fflush.c: Ditto. * libc/machine/spu/fseek.c: Ditto. * libc/machine/spu/ftell.c: Ditto. * libc/machine/spu/rewind.c: Ditto. * libc/machine/spu/fgetpos.c: Ditto. * libc/machine/spu/fsetpos.c: Ditto. * libc/machine/spu/fread.c: Ditto. * libc/machine/spu/fwrite.c: Ditto. * libc/machine/spu/getc.c: Ditto. * libc/machine/spu/getchar.c: Ditto. * libc/machine/spu/gets.c: Ditto. * libc/machine/spu/fgetc.c: Ditto. * libc/machine/spu/fgets.c: Ditto. * libc/machine/spu/ungetc.c: Ditto. * libc/machine/spu/putc.c: Ditto. * libc/machine/spu/fputc.c: Ditto. * libc/machine/spu/fputs.c: Ditto. * libc/machine/spu/vfprintf.c: Ditto. * libc/machine/spu/vfscanf.c: Ditto. * libc/machine/spu/fprintf.c: Ditto. * libc/machine/spu/fscanf.c: Ditto. * libc/machine/spu/scanf.c: Ditto. * libc/machine/spu/vscanf.c: Ditto. * libc/machine/spu/setbuf.c: Ditto. * libc/machine/spu/setvbuf.c: Ditto. * libc/machine/spu/tmpfile.c: Ditto. 2007-02-01 Jeff Johnston <jjohnstn@redhat.com> * libc/include/sys/config.h[__SPU__]: Define __CUSTOM_FILE_IO__. * libc/include/stdio.h[!__CUSTOM_FILE_IO__]: Add flag check around stdio macros that manipulate fields in the normal file structure. * libc/include/sys/reent.h[__CUSTOM_FILE_IO__]: Include <sys/custom_file.h> to define custom FILE structure. * libc/include/sys/custom_file.h: New default header file that generates error if not overridden when __CUSTOM_FILE_IO__ set. * libc/machine/spu/sys/custom_file.h: New file.
125 lines
3.5 KiB
C
125 lines
3.5 KiB
C
/*
|
|
(C) Copyright IBM Corp. 2006
|
|
|
|
All rights reserved.
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
modification, are permitted provided that the following conditions are met:
|
|
|
|
* Redistributions of source code must retain the above copyright notice,
|
|
this list of conditions and the following disclaimer.
|
|
* Redistributions in binary form must reproduce the above copyright
|
|
notice, this list of conditions and the following disclaimer in the
|
|
documentation and/or other materials provided with the distribution.
|
|
* Neither the name of IBM nor the names of its contributors may be
|
|
used to endorse or promote products derived from this software without
|
|
specific prior written permission.
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
Author: Joel Schopp <jschopp@austin.ibm.com>
|
|
*/
|
|
|
|
#include <errno.h>
|
|
|
|
#define SPE_C99_SIGNALCODE 0x2100
|
|
|
|
#define SPE_C99_OP_SHIFT 24
|
|
#define SPE_C99_OP_MASK 0xff
|
|
#define SPE_C99_DATA_MASK 0xffffff
|
|
|
|
enum {
|
|
SPE_C99_CLEARERR=0x01,
|
|
SPE_C99_FCLOSE,
|
|
SPE_C99_FEOF,
|
|
SPE_C99_FERROR,
|
|
SPE_C99_FFLUSH,
|
|
SPE_C99_FGETC,
|
|
SPE_C99_FGETPOS,
|
|
SPE_C99_FGETS,
|
|
SPE_C99_FILENO,
|
|
SPE_C99_FOPEN, //implemented
|
|
SPE_C99_FPUTC,
|
|
SPE_C99_FPUTS,
|
|
SPE_C99_FREAD,
|
|
SPE_C99_FREOPEN,
|
|
SPE_C99_FSEEK,
|
|
SPE_C99_FSETPOS,
|
|
SPE_C99_FTELL,
|
|
SPE_C99_FWRITE,
|
|
SPE_C99_GETC,
|
|
SPE_C99_GETCHAR,
|
|
SPE_C99_GETS,
|
|
SPE_C99_PERROR,
|
|
SPE_C99_PUTC,
|
|
SPE_C99_PUTCHAR,
|
|
SPE_C99_PUTS,
|
|
SPE_C99_REMOVE,
|
|
SPE_C99_RENAME,
|
|
SPE_C99_REWIND,
|
|
SPE_C99_SETBUF,
|
|
SPE_C99_SETVBUF,
|
|
SPE_C99_SYSTEM, //not yet implemented in newlib
|
|
SPE_C99_TMPFILE,
|
|
SPE_C99_TMPNAM,
|
|
SPE_C99_UNGETC,
|
|
SPE_C99_VFPRINTF,
|
|
SPE_C99_VFSCANF,
|
|
SPE_C99_VPRINTF,
|
|
SPE_C99_VSCANF,
|
|
SPE_C99_VSNPRINTF,
|
|
SPE_C99_VSPRINTF,
|
|
SPE_C99_VSSCANF,
|
|
SPE_C99_LAST_OPCODE,
|
|
};
|
|
#define SPE_C99_NR_OPCODES ((SPE_C99_LAST_OPCODE - SPE_C99_CLEARERR) + 1)
|
|
|
|
#define SPE_STDIN 1
|
|
#define SPE_STDOUT 2
|
|
#define SPE_STDERR 3
|
|
#define SPE_FOPEN_MAX FOPEN_MAX
|
|
|
|
struct spe_reg128{
|
|
unsigned int slot[4];
|
|
};
|
|
|
|
static void
|
|
send_to_ppe(int signalcode, int opcode, void *data)
|
|
{
|
|
|
|
unsigned int combined = ( ( opcode<<24 )&0xff000000 ) | ( ( unsigned int )data & 0x00ffffff );
|
|
struct spe_reg128* ret = data;
|
|
|
|
__vector unsigned int stopfunc = {
|
|
signalcode, /* stop 0x210x*/
|
|
(unsigned int) combined,
|
|
0x4020007f, /* nop */
|
|
0x35000000 /* bi $0 */
|
|
};
|
|
|
|
void (*f) (void) = (void *) &stopfunc;
|
|
asm ("sync":::"memory");
|
|
f();
|
|
errno = ret->slot[3];
|
|
return;
|
|
}
|
|
|
|
void _EXFUN(__sinit,(struct _reent *));
|
|
FILE *_EXFUN(__sfp,(struct _reent *));
|
|
#define __sfp_free(fp) ( (fp)->_fp = 0 )
|
|
|
|
#define CHECK_INIT(ptr) \
|
|
do { if ((ptr) && !(ptr)->__sdidinit) __sinit (ptr); } while (0)
|
|
#define CHECK_STD_INIT(ptr) /* currently, do nothing */
|
|
#define CHECK_STR_INIT(ptr) /* currently, do nothing */
|