mirror of
https://github.com/adtools/clib2.git
synced 2025-12-08 14:59:05 +00:00
- Moved the Workbench console stream initialization into the
initialization code for the stdin/stdout/stderr streams and out of the program parameter setup. - The current program name is now set up in the stdlib initialization function. - Simplified the machine test code; moved the FPU check into the math initialization code. - Added more safety checks to verify that file descriptor file handles are valid. git-svn-id: file:///Users/olsen/Code/migration-svn-zu-git/logical-line-staging/clib2/trunk@14864 87f5fb63-7c3d-0410-a384-fd976d0f7a62
This commit is contained in:
@ -1,5 +1,5 @@
|
||||
#
|
||||
# $Id: GNUmakefile.68k,v 1.34 2005-03-03 14:20:55 obarthel Exp $
|
||||
# $Id: GNUmakefile.68k,v 1.35 2005-03-07 11:16:42 obarthel Exp $
|
||||
#
|
||||
# :ts=8
|
||||
#
|
||||
@ -225,6 +225,7 @@ C_LIB = \
|
||||
stdio_initializefd.o \
|
||||
stdio_initializeiob.o \
|
||||
stdio_init_exit.o \
|
||||
stdio_file_init.o \
|
||||
stdio_iobhookentry.o \
|
||||
stdio_lock.o \
|
||||
stdio_locksemaphorename.o \
|
||||
@ -332,7 +333,7 @@ C_LIB = \
|
||||
stdlib_stacksafezone.o \
|
||||
stdlib_stacksize.o \
|
||||
stdlib_stack_usage.o \
|
||||
stdlib_startup.o \
|
||||
stdlib_arg.o \
|
||||
stdlib_stdio_window_spec.o \
|
||||
stdlib_strtol.o \
|
||||
stdlib_strtoll.o \
|
||||
@ -458,6 +459,7 @@ UNIX_LIB = \
|
||||
stdio_fflush.o \
|
||||
stdio_fopen.o \
|
||||
stdio_init_exit.o \
|
||||
stdio_file_init.o \
|
||||
stdio_locksemaphorename.o \
|
||||
stdio_openiob.o \
|
||||
stdio_popen.o \
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
#
|
||||
# $Id: GNUmakefile.os4,v 1.35 2005-03-05 17:55:26 obarthel Exp $
|
||||
# $Id: GNUmakefile.os4,v 1.36 2005-03-07 11:16:43 obarthel Exp $
|
||||
#
|
||||
# :ts=8
|
||||
#
|
||||
@ -229,6 +229,7 @@ C_LIB = \
|
||||
stdio_initializefd.o \
|
||||
stdio_initializeiob.o \
|
||||
stdio_init_exit.o \
|
||||
stdio_file_init.o \
|
||||
stdio_iobhookentry.o \
|
||||
stdio_lock.o \
|
||||
stdio_locksemaphorename.o \
|
||||
@ -336,7 +337,7 @@ C_LIB = \
|
||||
stdlib_stacksafezone.o \
|
||||
stdlib_stacksize.o \
|
||||
stdlib_stack_usage.o \
|
||||
stdlib_startup.o \
|
||||
stdlib_arg.o \
|
||||
stdlib_stdio_window_spec.o \
|
||||
stdlib_strtol.o \
|
||||
stdlib_strtoll.o \
|
||||
@ -462,6 +463,7 @@ UNIX_LIB = \
|
||||
stdio_fdhookentry.o \
|
||||
stdio_fflush.o \
|
||||
stdio_fopen.o \
|
||||
stdio_file_init.o \
|
||||
stdio_init_exit.o \
|
||||
stdio_locksemaphorename.o \
|
||||
stdio_openiob.o \
|
||||
|
||||
@ -6,6 +6,22 @@
|
||||
code can spend less time in Forbid() state and, heaven forbid,
|
||||
refrain from allocating memory while in that state.
|
||||
|
||||
- Split the general stdio initialization/cleanup code from the
|
||||
initialization of the stdin/stdout/stderr streams.
|
||||
|
||||
- Moved the Workbench console stream initialization into the
|
||||
initialization code for the stdin/stdout/stderr streams and
|
||||
out of the program parameter setup.
|
||||
|
||||
- The current program name is now set up in the stdlib
|
||||
initialization function.
|
||||
|
||||
- Simplified the machine test code; moved the FPU check into
|
||||
the math initialization code.
|
||||
|
||||
- Added more safety checks to verify that file descriptor
|
||||
file handles are valid.
|
||||
|
||||
|
||||
c.lib 1.189 (5.3.2005)
|
||||
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* $Id: math_init_exit.c,v 1.7 2005-02-03 16:56:15 obarthel Exp $
|
||||
* $Id: math_init_exit.c,v 1.8 2005-03-07 11:16:43 obarthel Exp $
|
||||
*
|
||||
* :ts=4
|
||||
*
|
||||
@ -41,6 +41,10 @@
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
#include <exec/execbase.h>
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
#include <proto/exec.h>
|
||||
|
||||
/****************************************************************************/
|
||||
@ -89,6 +93,17 @@ __math_init(void)
|
||||
{
|
||||
int result = ERROR;
|
||||
|
||||
#if defined(M68881_FLOATING_POINT_SUPPORT)
|
||||
{
|
||||
if(FLAG_IS_CLEAR(((struct ExecBase *)SysBase)->AttnFlags,AFF_68881))
|
||||
{
|
||||
__show_error("This program requires a floating point processor.");
|
||||
|
||||
goto out;
|
||||
}
|
||||
}
|
||||
#endif /* M68881_FLOATING_POINT_SUPPORT */
|
||||
|
||||
#if defined(IEEE_FLOATING_POINT_SUPPORT)
|
||||
{
|
||||
char * failed_library = NULL;
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* $Id: mount_fstatfs.c,v 1.8 2005-02-28 13:22:53 obarthel Exp $
|
||||
* $Id: mount_fstatfs.c,v 1.9 2005-03-07 11:16:43 obarthel Exp $
|
||||
*
|
||||
* :ts=4
|
||||
*
|
||||
@ -97,6 +97,12 @@ fstatfs(int file_descriptor, struct statfs *buf)
|
||||
goto out;
|
||||
}
|
||||
|
||||
if(fd->fd_DefaultFile == ZERO)
|
||||
{
|
||||
__set_errno(EBADF);
|
||||
goto out;
|
||||
}
|
||||
|
||||
PROFILE_OFF();
|
||||
parent_dir = __safe_parent_of_file_handle(fd->fd_DefaultFile);
|
||||
PROFILE_ON();
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
#
|
||||
# $Id: smakefile,v 1.28 2005-03-03 14:20:55 obarthel Exp $
|
||||
# $Id: smakefile,v 1.29 2005-03-07 11:16:43 obarthel Exp $
|
||||
#
|
||||
# :ts=8
|
||||
#
|
||||
@ -329,6 +329,7 @@ STDIO_OBJ = \
|
||||
stdio_grow_file.o \
|
||||
stdio_initializefd.o \
|
||||
stdio_initializeiob.o \
|
||||
stdio_file_init.o \
|
||||
stdio_init_exit.o \
|
||||
stdio_iobhookentry.o \
|
||||
stdio_lock.o \
|
||||
@ -439,7 +440,7 @@ STDLIB_OBJ = \
|
||||
stdlib_stacksafezone.o \
|
||||
stdlib_stacksize.o \
|
||||
stdlib_stack_usage.o \
|
||||
stdlib_startup.o \
|
||||
stdlib_arg.o \
|
||||
stdlib_strtod.o \
|
||||
stdlib_strtol.o \
|
||||
stdlib_strtoul.o \
|
||||
@ -701,7 +702,7 @@ stdlib_atexit.o : stdlib_atexit.c stdlib_mem_debug.h
|
||||
|
||||
stdlib_setenv.o : stdlib_setenv.c stdlib_mem_debug.h
|
||||
|
||||
stdlib_startup.o : stdlib_startup.c stdlib_mem_debug.h
|
||||
stdlib_arg.o : stdlib_arg.c stdlib_mem_debug.h
|
||||
|
||||
stdlib_system.o : stdlib_system.c stdlib_mem_debug.h
|
||||
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* $Id: stat_fchmod.c,v 1.7 2005-02-28 13:22:53 obarthel Exp $
|
||||
* $Id: stat_fchmod.c,v 1.8 2005-03-07 11:16:43 obarthel Exp $
|
||||
*
|
||||
* :ts=4
|
||||
*
|
||||
@ -80,6 +80,12 @@ fchmod(int file_descriptor, mode_t mode)
|
||||
goto out;
|
||||
}
|
||||
|
||||
if(fd->fd_DefaultFile == ZERO)
|
||||
{
|
||||
__set_errno(EBADF);
|
||||
goto out;
|
||||
}
|
||||
|
||||
protection = 0;
|
||||
|
||||
if(FLAG_IS_SET(mode,S_IRUSR))
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* $Id: stdio_fdhookentry.c,v 1.16 2005-03-03 14:20:55 obarthel Exp $
|
||||
* $Id: stdio_fdhookentry.c,v 1.17 2005-03-07 11:16:43 obarthel Exp $
|
||||
*
|
||||
* :ts=4
|
||||
*
|
||||
@ -59,6 +59,7 @@ __fd_hook_entry(
|
||||
{
|
||||
D_S(struct FileInfoBlock,fib);
|
||||
BOOL fib_is_valid = FALSE;
|
||||
struct FileHandle * fh;
|
||||
off_t current_position;
|
||||
off_t new_position;
|
||||
int new_mode;
|
||||
@ -72,20 +73,20 @@ __fd_hook_entry(
|
||||
|
||||
__fd_lock(fd);
|
||||
|
||||
if(fd->fd_DefaultFile == ZERO)
|
||||
{
|
||||
SHOWMSG("file is closed");
|
||||
|
||||
fam->fam_Error = EBADF;
|
||||
goto out;
|
||||
}
|
||||
|
||||
switch(fam->fam_Action)
|
||||
{
|
||||
case file_action_read:
|
||||
|
||||
SHOWMSG("file_action_read");
|
||||
|
||||
if(fd->fd_DefaultFile == ZERO)
|
||||
{
|
||||
SHOWMSG("file is closed");
|
||||
|
||||
fam->fam_Error = EBADF;
|
||||
break;
|
||||
}
|
||||
|
||||
assert( fam->fam_Data != NULL );
|
||||
assert( fam->fam_Size > 0 );
|
||||
|
||||
@ -102,7 +103,7 @@ __fd_hook_entry(
|
||||
D(("read failed ioerr=%ld",IoErr()));
|
||||
|
||||
fam->fam_Error = __translate_io_error_to_errno(IoErr());
|
||||
break;
|
||||
goto out;
|
||||
}
|
||||
|
||||
if(FLAG_IS_SET(fd->fd_Flags,FDF_CACHE_POSITION))
|
||||
@ -114,14 +115,6 @@ __fd_hook_entry(
|
||||
|
||||
SHOWMSG("file_action_write");
|
||||
|
||||
if(fd->fd_DefaultFile == ZERO)
|
||||
{
|
||||
SHOWMSG("file is closed");
|
||||
|
||||
fam->fam_Error = EBADF;
|
||||
break;
|
||||
}
|
||||
|
||||
assert( fam->fam_Data != NULL );
|
||||
assert( fam->fam_Size > 0 );
|
||||
|
||||
@ -153,7 +146,7 @@ __fd_hook_entry(
|
||||
D(("write failed ioerr=%ld",IoErr()));
|
||||
|
||||
fam->fam_Error = __translate_io_error_to_errno(IoErr());
|
||||
break;
|
||||
goto out;
|
||||
}
|
||||
|
||||
if(FLAG_IS_SET(fd->fd_Flags,FDF_CACHE_POSITION))
|
||||
@ -172,15 +165,6 @@ __fd_hook_entry(
|
||||
}
|
||||
else
|
||||
{
|
||||
/* Is this file open in the first place? */
|
||||
if(fd->fd_DefaultFile == ZERO)
|
||||
{
|
||||
SHOWMSG("file is closed");
|
||||
|
||||
fam->fam_Error = EBADF;
|
||||
break;
|
||||
}
|
||||
|
||||
/* The following is almost guaranteed not to fail. */
|
||||
result = 0;
|
||||
|
||||
@ -389,7 +373,7 @@ __fd_hook_entry(
|
||||
if(current_position < 0)
|
||||
{
|
||||
fam->fam_Error = EBADF;
|
||||
break;
|
||||
goto out;
|
||||
}
|
||||
}
|
||||
|
||||
@ -438,24 +422,24 @@ __fd_hook_entry(
|
||||
if(NOT fib_is_valid && CANNOT __safe_examine_file_handle(fd->fd_DefaultFile,fib))
|
||||
{
|
||||
fam->fam_Error = __translate_io_error_to_errno(IoErr());
|
||||
break;
|
||||
goto out;
|
||||
}
|
||||
|
||||
if(new_position <= fib->fib_Size)
|
||||
{
|
||||
fam->fam_Error = __translate_io_error_to_errno(IoErr());
|
||||
break;
|
||||
goto out;
|
||||
}
|
||||
|
||||
if(__grow_file_size(fd,new_position - fib->fib_Size) < 0)
|
||||
{
|
||||
fam->fam_Error = __translate_io_error_to_errno(IoErr());
|
||||
break;
|
||||
goto out;
|
||||
}
|
||||
}
|
||||
#else
|
||||
{
|
||||
break;
|
||||
goto out;
|
||||
}
|
||||
#endif /* UNIX_PATH_SEMANTICS */
|
||||
}
|
||||
@ -488,7 +472,7 @@ __fd_hook_entry(
|
||||
if(CANNOT SetMode(fd->fd_DefaultFile,mode))
|
||||
{
|
||||
fam->fam_Error = __translate_io_error_to_errno(IoErr());
|
||||
break;
|
||||
goto out;
|
||||
}
|
||||
|
||||
result = 0;
|
||||
@ -508,30 +492,19 @@ __fd_hook_entry(
|
||||
|
||||
SHOWMSG("file_action_examine");
|
||||
|
||||
if(fd->fd_DefaultFile != ZERO)
|
||||
if(CANNOT __safe_examine_file_handle(fd->fd_DefaultFile,fam->fam_FileInfo))
|
||||
{
|
||||
struct FileHandle * fh;
|
||||
SHOWMSG("couldn't examine the file");
|
||||
|
||||
if(CANNOT __safe_examine_file_handle(fd->fd_DefaultFile,fam->fam_FileInfo))
|
||||
{
|
||||
SHOWMSG("couldn't examine the file");
|
||||
|
||||
fam->fam_Error = __translate_io_error_to_errno(IoErr());
|
||||
break;
|
||||
}
|
||||
|
||||
fh = BADDR(fd->fd_DefaultFile);
|
||||
|
||||
fam->fam_FileSystem = fh->fh_Type;
|
||||
|
||||
result = 0;
|
||||
fam->fam_Error = __translate_io_error_to_errno(IoErr());
|
||||
goto out;
|
||||
}
|
||||
else
|
||||
{
|
||||
SHOWMSG("file is already closed");
|
||||
|
||||
fam->fam_Error = EBADF;
|
||||
}
|
||||
fh = BADDR(fd->fd_DefaultFile);
|
||||
|
||||
fam->fam_FileSystem = fh->fh_Type;
|
||||
|
||||
result = 0;
|
||||
|
||||
break;
|
||||
|
||||
@ -543,6 +516,8 @@ __fd_hook_entry(
|
||||
break;
|
||||
}
|
||||
|
||||
out:
|
||||
|
||||
__fd_unlock(fd);
|
||||
|
||||
if(buffer != NULL)
|
||||
|
||||
363
library/stdio_file_init.c
Normal file
363
library/stdio_file_init.c
Normal file
@ -0,0 +1,363 @@
|
||||
/*
|
||||
* $Id: stdio_file_init.c,v 1.1 2005-03-07 11:16:43 obarthel Exp $
|
||||
*
|
||||
* :ts=4
|
||||
*
|
||||
* Portable ISO 'C' (1994) runtime library for the Amiga computer
|
||||
* Copyright (c) 2002-2005 by Olaf Barthel <olsen@sourcery.han.de>
|
||||
* 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.
|
||||
*
|
||||
* - Neither the name of Olaf Barthel nor the names of 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.
|
||||
*/
|
||||
|
||||
#ifndef _STDLIB_MEM_DEBUG_H
|
||||
#include "stdlib_mem_debug.h"
|
||||
#endif /* _STDLIB_MEM_DEBUG_H */
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
#ifndef _STDIO_HEADERS_H
|
||||
#include "stdio_headers.h"
|
||||
#endif /* _STDIO_HEADERS_H */
|
||||
|
||||
#ifndef _UNISTD_HEADERS_H
|
||||
#include "unistd_headers.h"
|
||||
#endif /* _UNISTD_HEADERS_H */
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
static struct MsgPort * old_console_task;
|
||||
static BOOL restore_console_task;
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
static BOOL restore_streams;
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
static BPTR old_output;
|
||||
static BPTR old_input;
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
static BPTR output;
|
||||
static BPTR input;
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
CLIB_DESTRUCTOR(workbench_exit)
|
||||
{
|
||||
ENTER();
|
||||
|
||||
PROFILE_OFF();
|
||||
|
||||
/* Now clean up after the streams set up for Workbench startup... */
|
||||
if(restore_console_task)
|
||||
{
|
||||
SetConsoleTask((struct MsgPort *)old_console_task);
|
||||
old_console_task = NULL;
|
||||
|
||||
restore_console_task = FALSE;
|
||||
}
|
||||
|
||||
if(restore_streams)
|
||||
{
|
||||
SelectInput(old_input);
|
||||
old_input = ZERO;
|
||||
|
||||
SelectOutput(old_output);
|
||||
old_output = ZERO;
|
||||
|
||||
restore_streams = FALSE;
|
||||
}
|
||||
|
||||
if(input != ZERO)
|
||||
{
|
||||
Close(input);
|
||||
input = ZERO;
|
||||
}
|
||||
|
||||
if(output != ZERO)
|
||||
{
|
||||
Close(output);
|
||||
output = ZERO;
|
||||
}
|
||||
|
||||
PROFILE_ON();
|
||||
|
||||
LEAVE();
|
||||
}
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
STATIC int
|
||||
wb_file_init(void)
|
||||
{
|
||||
int result = -1;
|
||||
|
||||
PROFILE_OFF();
|
||||
|
||||
__original_current_directory = CurrentDir(__WBenchMsg->sm_ArgList[0].wa_Lock);
|
||||
__current_directory_changed = TRUE;
|
||||
|
||||
if (__stdio_window_specification != NULL)
|
||||
{
|
||||
input = Open(__stdio_window_specification,MODE_NEWFILE);
|
||||
}
|
||||
else if (__WBenchMsg->sm_ToolWindow != NULL)
|
||||
{
|
||||
input = Open(__WBenchMsg->sm_ToolWindow,MODE_NEWFILE);
|
||||
}
|
||||
else
|
||||
{
|
||||
static const char console_prefix[] = "CON:20/20/600/150/";
|
||||
static const char console_suffix[] = " Output/AUTO/CLOSE/WAIT";
|
||||
STRPTR window_specifier;
|
||||
STRPTR tool_name;
|
||||
size_t len;
|
||||
|
||||
tool_name = FilePart(__WBenchMsg->sm_ArgList[0].wa_Name);
|
||||
|
||||
len = strlen(console_prefix) + strlen(tool_name) + strlen(console_suffix);
|
||||
|
||||
window_specifier = malloc(len+1);
|
||||
if(window_specifier == NULL)
|
||||
goto out;
|
||||
|
||||
strcpy(window_specifier,console_prefix);
|
||||
strcat(window_specifier,tool_name);
|
||||
strcat(window_specifier,console_suffix);
|
||||
|
||||
input = Open(window_specifier,MODE_NEWFILE);
|
||||
|
||||
free(window_specifier);
|
||||
}
|
||||
|
||||
if(input == ZERO)
|
||||
input = Open("NIL:",MODE_NEWFILE);
|
||||
|
||||
if(input != ZERO)
|
||||
{
|
||||
struct FileHandle * fh = BADDR(input);
|
||||
|
||||
old_console_task = SetConsoleTask(fh->fh_Type);
|
||||
|
||||
output = Open("CONSOLE:",MODE_NEWFILE);
|
||||
if(output != ZERO)
|
||||
restore_console_task = TRUE;
|
||||
else
|
||||
SetConsoleTask((struct MsgPort *)old_console_task);
|
||||
}
|
||||
|
||||
if(output == ZERO)
|
||||
output = Open("NIL:",MODE_NEWFILE);
|
||||
|
||||
if(input == ZERO || output == ZERO)
|
||||
goto out;
|
||||
|
||||
old_input = SelectInput(input);
|
||||
old_output = SelectOutput(output);
|
||||
|
||||
restore_streams = TRUE;
|
||||
|
||||
result = 0;
|
||||
|
||||
out:
|
||||
|
||||
PROFILE_ON();
|
||||
|
||||
return(result);
|
||||
}
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
int
|
||||
__stdio_file_init(void)
|
||||
{
|
||||
struct SignalSemaphore * stdio_lock;
|
||||
struct SignalSemaphore * fd_lock;
|
||||
BPTR default_file;
|
||||
ULONG fd_flags,iob_flags;
|
||||
int result = ERROR;
|
||||
char * buffer;
|
||||
char * aligned_buffer;
|
||||
int i;
|
||||
|
||||
ENTER();
|
||||
|
||||
/* If we were invoked from Workbench, set up the standard I/O streams. */
|
||||
if(__WBenchMsg != NULL)
|
||||
{
|
||||
if(wb_file_init() < 0)
|
||||
goto out;
|
||||
}
|
||||
|
||||
/* Now initialize the standard I/O streams (input, output, error). */
|
||||
for(i = STDIN_FILENO ; i <= STDERR_FILENO ; i++)
|
||||
{
|
||||
PROFILE_OFF();
|
||||
|
||||
switch(i)
|
||||
{
|
||||
case STDIN_FILENO:
|
||||
|
||||
iob_flags = IOBF_IN_USE | IOBF_READ | IOBF_NO_NUL | IOBF_BUFFER_MODE_LINE;
|
||||
fd_flags = FDF_IN_USE | FDF_READ | FDF_NO_CLOSE;
|
||||
default_file = Input();
|
||||
break;
|
||||
|
||||
case STDOUT_FILENO:
|
||||
|
||||
iob_flags = IOBF_IN_USE | IOBF_WRITE | IOBF_NO_NUL | IOBF_BUFFER_MODE_LINE;
|
||||
fd_flags = FDF_IN_USE | FDF_WRITE | FDF_NO_CLOSE;
|
||||
default_file = Output();
|
||||
break;
|
||||
|
||||
case STDERR_FILENO:
|
||||
default:
|
||||
|
||||
iob_flags = IOBF_IN_USE | IOBF_WRITE | IOBF_NO_NUL | IOBF_BUFFER_MODE_NONE;
|
||||
fd_flags = FDF_IN_USE | FDF_WRITE;
|
||||
default_file = ZERO; /* NOTE: this is really initialized later; see below... */
|
||||
break;
|
||||
}
|
||||
|
||||
PROFILE_ON();
|
||||
|
||||
/* Allocate a little more memory than necessary. */
|
||||
buffer = malloc(BUFSIZ + (CACHE_LINE_SIZE-1));
|
||||
if(buffer == NULL)
|
||||
goto out;
|
||||
|
||||
#if defined(__THREAD_SAFE)
|
||||
{
|
||||
/* Allocate memory for an arbitration mechanism, then
|
||||
initialize it. */
|
||||
stdio_lock = __create_semaphore();
|
||||
fd_lock = __create_semaphore();
|
||||
|
||||
if(stdio_lock == NULL || fd_lock == NULL)
|
||||
{
|
||||
__delete_semaphore(stdio_lock);
|
||||
__delete_semaphore(fd_lock);
|
||||
|
||||
goto out;
|
||||
}
|
||||
}
|
||||
#else
|
||||
{
|
||||
stdio_lock = NULL;
|
||||
fd_lock = NULL;
|
||||
}
|
||||
#endif /* __THREAD_SAFE */
|
||||
|
||||
/* Check if this stream is attached to a console window. */
|
||||
if(default_file != ZERO)
|
||||
{
|
||||
PROFILE_OFF();
|
||||
|
||||
if(IsInteractive(default_file))
|
||||
SET_FLAG(fd_flags,FDF_IS_INTERACTIVE);
|
||||
|
||||
PROFILE_ON();
|
||||
}
|
||||
|
||||
/* Align the buffer start address to a cache line boundary. */
|
||||
aligned_buffer = (char *)((ULONG)(buffer + (CACHE_LINE_SIZE-1)) & ~(CACHE_LINE_SIZE-1));
|
||||
|
||||
__initialize_fd(__fd[i],__fd_hook_entry,default_file,fd_flags,fd_lock);
|
||||
|
||||
__initialize_iob(__iob[i],__iob_hook_entry,
|
||||
buffer,
|
||||
aligned_buffer,BUFSIZ,
|
||||
i,
|
||||
i,
|
||||
iob_flags,
|
||||
stdio_lock);
|
||||
}
|
||||
|
||||
/* If the program was launched from Workbench, we continue by
|
||||
duplicating the default output stream for use as the
|
||||
standard error stream. */
|
||||
if(__WBenchMsg != NULL)
|
||||
{
|
||||
PROFILE_OFF();
|
||||
__fd[STDERR_FILENO]->fd_DefaultFile = Output();
|
||||
PROFILE_ON();
|
||||
|
||||
SET_FLAG(__fd[STDERR_FILENO]->fd_Flags,FDF_NO_CLOSE);
|
||||
}
|
||||
else
|
||||
{
|
||||
BPTR ces;
|
||||
|
||||
PROFILE_OFF();
|
||||
|
||||
/* Figure out what the default error output stream is. */
|
||||
#if defined(__amigaos4__)
|
||||
{
|
||||
ces = ErrorOutput();
|
||||
}
|
||||
#else
|
||||
{
|
||||
struct Process * this_process = (struct Process *)FindTask(NULL);
|
||||
|
||||
ces = this_process->pr_CES;
|
||||
}
|
||||
#endif /* __amigaos4__ */
|
||||
|
||||
PROFILE_ON();
|
||||
|
||||
/* Is the standard error stream configured? If so, use it.
|
||||
Otherwise, try to duplicate the standard output stream. */
|
||||
if(ces != ZERO)
|
||||
{
|
||||
__fd[STDERR_FILENO]->fd_DefaultFile = ces;
|
||||
|
||||
SET_FLAG(__fd[STDERR_FILENO]->fd_Flags,FDF_NO_CLOSE);
|
||||
}
|
||||
else
|
||||
{
|
||||
__fd[STDERR_FILENO]->fd_DefaultFile = Open("CONSOLE:",MODE_NEWFILE);
|
||||
}
|
||||
}
|
||||
|
||||
PROFILE_OFF();
|
||||
|
||||
/* Figure out if the standard error stream is bound to a console. */
|
||||
if(__fd[STDERR_FILENO]->fd_DefaultFile != ZERO)
|
||||
{
|
||||
if(IsInteractive(__fd[STDERR_FILENO]->fd_DefaultFile))
|
||||
SET_FLAG(__fd[STDERR_FILENO]->fd_Flags,FDF_IS_INTERACTIVE);
|
||||
}
|
||||
|
||||
PROFILE_ON();
|
||||
|
||||
result = OK;
|
||||
|
||||
out:
|
||||
|
||||
RETURN(result);
|
||||
return(result);
|
||||
}
|
||||
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* $Id: stdio_init_exit.c,v 1.23 2005-03-04 09:07:09 obarthel Exp $
|
||||
* $Id: stdio_init_exit.c,v 1.24 2005-03-07 11:16:43 obarthel Exp $
|
||||
*
|
||||
* :ts=4
|
||||
*
|
||||
@ -47,16 +47,6 @@
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
#include "stdlib_protos.h"
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
#ifndef ID_RAWCON
|
||||
#define ID_RAWCON 0x52415700L /* "RAW\0" */
|
||||
#endif /* ID_RAWCON */
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
void
|
||||
__close_all_files(void)
|
||||
{
|
||||
@ -115,16 +105,9 @@ CLIB_DESTRUCTOR(__stdio_exit)
|
||||
int
|
||||
__stdio_init(void)
|
||||
{
|
||||
const int num_standard_files = (STDERR_FILENO-STDIN_FILENO+1);
|
||||
const int num_standard_files = (STDERR_FILENO - STDIN_FILENO + 1);
|
||||
|
||||
struct SignalSemaphore * stdio_lock;
|
||||
struct SignalSemaphore * fd_lock;
|
||||
BPTR default_file;
|
||||
ULONG fd_flags,iob_flags;
|
||||
int result = ERROR;
|
||||
char * buffer;
|
||||
char * aligned_buffer;
|
||||
int i;
|
||||
|
||||
ENTER();
|
||||
|
||||
@ -137,143 +120,6 @@ __stdio_init(void)
|
||||
if(__grow_fd_table(num_standard_files) < 0)
|
||||
goto out;
|
||||
|
||||
/* Now initialize the standard I/O streams (input, output, error). */
|
||||
for(i = STDIN_FILENO ; i <= STDERR_FILENO ; i++)
|
||||
{
|
||||
PROFILE_OFF();
|
||||
|
||||
switch(i)
|
||||
{
|
||||
case STDIN_FILENO:
|
||||
|
||||
iob_flags = IOBF_IN_USE | IOBF_READ | IOBF_NO_NUL | IOBF_BUFFER_MODE_LINE;
|
||||
fd_flags = FDF_IN_USE | FDF_READ | FDF_NO_CLOSE;
|
||||
default_file = Input();
|
||||
break;
|
||||
|
||||
case STDOUT_FILENO:
|
||||
|
||||
iob_flags = IOBF_IN_USE | IOBF_WRITE | IOBF_NO_NUL | IOBF_BUFFER_MODE_LINE;
|
||||
fd_flags = FDF_IN_USE | FDF_WRITE | FDF_NO_CLOSE;
|
||||
default_file = Output();
|
||||
break;
|
||||
|
||||
case STDERR_FILENO:
|
||||
default:
|
||||
|
||||
iob_flags = IOBF_IN_USE | IOBF_WRITE | IOBF_NO_NUL | IOBF_BUFFER_MODE_NONE;
|
||||
fd_flags = FDF_IN_USE | FDF_WRITE;
|
||||
default_file = ZERO; /* NOTE: this is really initialized later; see below... */
|
||||
break;
|
||||
}
|
||||
|
||||
PROFILE_ON();
|
||||
|
||||
/* Allocate a little more memory than necessary. */
|
||||
buffer = malloc(BUFSIZ + (CACHE_LINE_SIZE-1));
|
||||
if(buffer == NULL)
|
||||
goto out;
|
||||
|
||||
#if defined(__THREAD_SAFE)
|
||||
{
|
||||
/* Allocate memory for an arbitration mechanism, then
|
||||
initialize it. */
|
||||
stdio_lock = __create_semaphore();
|
||||
fd_lock = __create_semaphore();
|
||||
|
||||
if(stdio_lock == NULL || fd_lock == NULL)
|
||||
{
|
||||
__delete_semaphore(stdio_lock);
|
||||
__delete_semaphore(fd_lock);
|
||||
|
||||
goto out;
|
||||
}
|
||||
}
|
||||
#else
|
||||
{
|
||||
stdio_lock = NULL;
|
||||
fd_lock = NULL;
|
||||
}
|
||||
#endif /* __THREAD_SAFE */
|
||||
|
||||
/* Check if this stream is attached to a console window. */
|
||||
if(default_file != ZERO)
|
||||
{
|
||||
PROFILE_OFF();
|
||||
|
||||
if(IsInteractive(default_file))
|
||||
SET_FLAG(fd_flags,FDF_IS_INTERACTIVE);
|
||||
|
||||
PROFILE_ON();
|
||||
}
|
||||
|
||||
/* Align the buffer start address to a cache line boundary. */
|
||||
aligned_buffer = (char *)((ULONG)(buffer + (CACHE_LINE_SIZE-1)) & ~(CACHE_LINE_SIZE-1));
|
||||
|
||||
__initialize_fd(__fd[i],__fd_hook_entry,default_file,fd_flags,fd_lock);
|
||||
|
||||
__initialize_iob(__iob[i],__iob_hook_entry,
|
||||
buffer,
|
||||
aligned_buffer,BUFSIZ,
|
||||
i,
|
||||
i,
|
||||
iob_flags,
|
||||
stdio_lock);
|
||||
}
|
||||
|
||||
/* If the program was launched from Workbench, we continue by
|
||||
duplicating the default output stream for use as the
|
||||
standard error stream. */
|
||||
if(__WBenchMsg != NULL)
|
||||
{
|
||||
PROFILE_OFF();
|
||||
__fd[STDERR_FILENO]->fd_DefaultFile = Output();
|
||||
PROFILE_ON();
|
||||
|
||||
SET_FLAG(__fd[STDERR_FILENO]->fd_Flags,FDF_NO_CLOSE);
|
||||
}
|
||||
else
|
||||
{
|
||||
BPTR ces;
|
||||
|
||||
/* Figure out what the default error output stream is. */
|
||||
#if defined(__amigaos4__)
|
||||
{
|
||||
ces = ErrorOutput();
|
||||
}
|
||||
#else
|
||||
{
|
||||
struct Process * this_process = (struct Process *)FindTask(NULL);
|
||||
|
||||
ces = this_process->pr_CES;
|
||||
}
|
||||
#endif /* __amigaos4__ */
|
||||
|
||||
/* Is the standard error stream configured? If so, use it.
|
||||
Otherwise, try to duplicate the standard output stream. */
|
||||
if(ces != ZERO)
|
||||
{
|
||||
__fd[STDERR_FILENO]->fd_DefaultFile = ces;
|
||||
|
||||
SET_FLAG(__fd[STDERR_FILENO]->fd_Flags,FDF_NO_CLOSE);
|
||||
}
|
||||
else
|
||||
{
|
||||
__fd[STDERR_FILENO]->fd_DefaultFile = Open("CONSOLE:",MODE_NEWFILE);
|
||||
}
|
||||
}
|
||||
|
||||
PROFILE_OFF();
|
||||
|
||||
/* Figure out if the standard error stream is bound to a console. */
|
||||
if(__fd[STDERR_FILENO]->fd_DefaultFile != ZERO)
|
||||
{
|
||||
if(IsInteractive(__fd[STDERR_FILENO]->fd_DefaultFile))
|
||||
SET_FLAG(__fd[STDERR_FILENO]->fd_Flags,FDF_IS_INTERACTIVE);
|
||||
}
|
||||
|
||||
PROFILE_ON();
|
||||
|
||||
result = OK;
|
||||
|
||||
out:
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* $Id: stdio_protos.h,v 1.12 2005-03-04 09:07:09 obarthel Exp $
|
||||
* $Id: stdio_protos.h,v 1.13 2005-03-07 11:16:43 obarthel Exp $
|
||||
*
|
||||
* :ts=4
|
||||
*
|
||||
@ -215,4 +215,9 @@ extern void __remove_fd_alias(struct fd * fd);
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
/* stdio_file_init.c */
|
||||
extern int __stdio_file_init(void);
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
#endif /* _STDIO_PROTOS_H */
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* $Id: stdlib_startup.c,v 1.8 2005-03-03 09:32:09 obarthel Exp $
|
||||
* $Id: stdlib_arg.c,v 1.1 2005-03-07 11:16:43 obarthel Exp $
|
||||
*
|
||||
* :ts=4
|
||||
*
|
||||
@ -41,12 +41,13 @@
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
#ifndef _STDLIB_HEADERS_H
|
||||
#include "stdlib_headers.h"
|
||||
#endif /* _STDLIB_HEADERS_H */
|
||||
|
||||
#ifndef _UNISTD_HEADERS_H
|
||||
#include "unistd_headers.h"
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
#include <exec/execbase.h>
|
||||
#endif /* _UNISTD_HEADERS_H */
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
@ -62,25 +63,6 @@
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
static struct MsgPort * old_console_task;
|
||||
static BOOL restore_console_task;
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
static BOOL restore_streams;
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
static BPTR old_output;
|
||||
static BPTR old_input;
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
static BPTR output;
|
||||
static BPTR input;
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
char ** __argv;
|
||||
int __argc;
|
||||
|
||||
@ -129,35 +111,19 @@ is_final_quote_character(const unsigned char * str)
|
||||
/****************************************************************************/
|
||||
|
||||
int
|
||||
__startup_init(void)
|
||||
__arg_init(void)
|
||||
{
|
||||
int result = -1;
|
||||
int result = ERROR;
|
||||
|
||||
/* Shell startup? */
|
||||
if(__WBenchMsg == NULL)
|
||||
{
|
||||
size_t number_of_arguments;
|
||||
unsigned char * command_name;
|
||||
size_t command_name_len;
|
||||
unsigned char * arg_str;
|
||||
size_t arg_len;
|
||||
unsigned char * command_line;
|
||||
unsigned char * str;
|
||||
|
||||
/* Make a copy of the current command name string. */
|
||||
command_name_len = (size_t)((UBYTE *)BADDR(Cli()->cli_CommandName))[0];
|
||||
|
||||
__free_program_name = TRUE;
|
||||
|
||||
command_name = AllocVec((ULONG)(command_name_len + 1),MEMF_ANY);
|
||||
if(command_name == NULL)
|
||||
goto out;
|
||||
|
||||
if(CANNOT GetProgramName(command_name,command_name_len + 1))
|
||||
goto out;
|
||||
|
||||
__program_name = (char *)command_name;
|
||||
|
||||
/* Get the shell parameter string and find out
|
||||
how long it is, stripping a trailing line
|
||||
feed and blank spaces if necessary. */
|
||||
@ -242,7 +208,7 @@ __startup_init(void)
|
||||
goto out;
|
||||
|
||||
/* The first parameter is the program name. */
|
||||
__argv[0] = command_name;
|
||||
__argv[0] = __program_name;
|
||||
|
||||
str = command_line;
|
||||
|
||||
@ -341,130 +307,20 @@ __startup_init(void)
|
||||
assert( str <= &command_line[arg_len] );
|
||||
|
||||
__argv[__argc] = NULL;
|
||||
|
||||
/* If necessary, expand wildcard patterns found in the command
|
||||
line string into file and directory names. */
|
||||
if(__wildcard_expand_init() < 0)
|
||||
goto out;
|
||||
}
|
||||
else
|
||||
{
|
||||
PROFILE_OFF();
|
||||
|
||||
__program_name = (char *)__WBenchMsg->sm_ArgList[0].wa_Name;
|
||||
|
||||
__original_current_directory = CurrentDir(__WBenchMsg->sm_ArgList[0].wa_Lock);
|
||||
__current_directory_changed = TRUE;
|
||||
|
||||
if (__stdio_window_specification != NULL)
|
||||
{
|
||||
input = Open(__stdio_window_specification,MODE_NEWFILE);
|
||||
}
|
||||
else if (__WBenchMsg->sm_ToolWindow != NULL)
|
||||
{
|
||||
input = Open(__WBenchMsg->sm_ToolWindow,MODE_NEWFILE);
|
||||
}
|
||||
else
|
||||
{
|
||||
static const char console_prefix[] = "CON:20/20/600/150/";
|
||||
static const char console_suffix[] = " Output/AUTO/CLOSE/WAIT";
|
||||
STRPTR window_specifier;
|
||||
STRPTR tool_name;
|
||||
size_t len;
|
||||
|
||||
tool_name = FilePart(__WBenchMsg->sm_ArgList[0].wa_Name);
|
||||
|
||||
len = strlen(console_prefix) + strlen(tool_name) + strlen(console_suffix);
|
||||
|
||||
window_specifier = malloc(len+1);
|
||||
if(window_specifier == NULL)
|
||||
goto out;
|
||||
|
||||
strcpy(window_specifier,console_prefix);
|
||||
strcat(window_specifier,tool_name);
|
||||
strcat(window_specifier,console_suffix);
|
||||
|
||||
input = Open(window_specifier,MODE_NEWFILE);
|
||||
|
||||
free(window_specifier);
|
||||
}
|
||||
|
||||
if(input == ZERO)
|
||||
input = Open("NIL:",MODE_NEWFILE);
|
||||
|
||||
if(input != ZERO)
|
||||
{
|
||||
struct FileHandle * fh = BADDR(input);
|
||||
|
||||
old_console_task = SetConsoleTask(fh->fh_Type);
|
||||
|
||||
output = Open("CONSOLE:",MODE_NEWFILE);
|
||||
if(output != ZERO)
|
||||
restore_console_task = TRUE;
|
||||
else
|
||||
SetConsoleTask((struct MsgPort *)old_console_task);
|
||||
}
|
||||
|
||||
if(output == ZERO)
|
||||
output = Open("NIL:",MODE_NEWFILE);
|
||||
|
||||
if(input == ZERO || output == ZERO)
|
||||
goto out;
|
||||
|
||||
old_input = SelectInput(input);
|
||||
old_output = SelectOutput(output);
|
||||
|
||||
restore_streams = TRUE;
|
||||
|
||||
__argv = (char **)__WBenchMsg;
|
||||
|
||||
PROFILE_ON();
|
||||
}
|
||||
|
||||
result = 0;
|
||||
result = OK;
|
||||
|
||||
out:
|
||||
|
||||
return(result);
|
||||
}
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
CLIB_DESTRUCTOR(__startup_exit)
|
||||
{
|
||||
ENTER();
|
||||
|
||||
PROFILE_OFF();
|
||||
|
||||
/* Now clean up after the streams set up for the Workbench
|
||||
startup... */
|
||||
if(restore_console_task)
|
||||
{
|
||||
SetConsoleTask((struct MsgPort *)old_console_task);
|
||||
old_console_task = NULL;
|
||||
|
||||
restore_console_task = FALSE;
|
||||
}
|
||||
|
||||
if(restore_streams)
|
||||
{
|
||||
SelectInput(old_input);
|
||||
old_input = ZERO;
|
||||
|
||||
SelectOutput(old_output);
|
||||
old_output = ZERO;
|
||||
|
||||
restore_streams = FALSE;
|
||||
}
|
||||
|
||||
if(input != ZERO)
|
||||
{
|
||||
Close(input);
|
||||
input = ZERO;
|
||||
}
|
||||
|
||||
if(output != ZERO)
|
||||
{
|
||||
Close(output);
|
||||
output = ZERO;
|
||||
}
|
||||
|
||||
PROFILE_ON();
|
||||
|
||||
LEAVE();
|
||||
}
|
||||
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* $Id: stdlib_data.c,v 1.5 2005-01-02 09:07:08 obarthel Exp $
|
||||
* $Id: stdlib_data.c,v 1.6 2005-03-07 11:16:43 obarthel Exp $
|
||||
*
|
||||
* :ts=4
|
||||
*
|
||||
@ -47,11 +47,6 @@ struct WBStartup * __WBenchMsg;
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
char * __program_name;
|
||||
BOOL __free_program_name;
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
BOOL __stack_overflow;
|
||||
ULONG __stk_maxsize;
|
||||
ULONG __stk_extensions;
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* $Id: stdlib_headers.h,v 1.12 2005-03-03 09:32:08 obarthel Exp $
|
||||
* $Id: stdlib_headers.h,v 1.13 2005-03-07 11:16:43 obarthel Exp $
|
||||
*
|
||||
* :ts=4
|
||||
*
|
||||
@ -240,10 +240,6 @@ extern BOOL NOCOMMON __is_resident;
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
extern BOOL NOCOMMON __free_program_name;
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
extern UBYTE NOCOMMON __shell_escape_character;
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* $Id: stdlib_init_exit.c,v 1.5 2005-02-27 21:58:21 obarthel Exp $
|
||||
* $Id: stdlib_init_exit.c,v 1.6 2005-03-07 11:16:43 obarthel Exp $
|
||||
*
|
||||
* :ts=4
|
||||
*
|
||||
@ -43,6 +43,14 @@
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
static BOOL free_program_name;
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
char * __program_name;
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
void
|
||||
__stdlib_exit(void)
|
||||
{
|
||||
@ -50,7 +58,7 @@ __stdlib_exit(void)
|
||||
|
||||
__memory_exit();
|
||||
|
||||
if(__free_program_name && __program_name != NULL)
|
||||
if(free_program_name && __program_name != NULL)
|
||||
{
|
||||
FreeVec(__program_name);
|
||||
__program_name = NULL;
|
||||
@ -64,11 +72,35 @@ __stdlib_exit(void)
|
||||
int
|
||||
__stdlib_init(void)
|
||||
{
|
||||
int result;
|
||||
int result = ERROR;
|
||||
|
||||
ENTER();
|
||||
|
||||
result = __memory_init();
|
||||
if(__WBenchMsg == NULL)
|
||||
{
|
||||
const size_t program_name_size = 256;
|
||||
|
||||
/* Make a copy of the current command name string. */
|
||||
__program_name = AllocVec((ULONG)program_name_size,MEMF_ANY);
|
||||
if(__program_name == NULL)
|
||||
goto out;
|
||||
|
||||
free_program_name = TRUE;
|
||||
|
||||
if(CANNOT GetProgramName(__program_name,program_name_size))
|
||||
goto out;
|
||||
}
|
||||
else
|
||||
{
|
||||
__program_name = (char *)__WBenchMsg->sm_ArgList[0].wa_Name;
|
||||
}
|
||||
|
||||
if(__memory_init() < 0)
|
||||
goto out;
|
||||
|
||||
result = OK;
|
||||
|
||||
out:
|
||||
|
||||
RETURN(result);
|
||||
return(result);
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* $Id: stdlib_machine_test.c,v 1.2 2005-01-02 09:07:18 obarthel Exp $
|
||||
* $Id: stdlib_machine_test.c,v 1.3 2005-03-07 11:16:43 obarthel Exp $
|
||||
*
|
||||
* :ts=4
|
||||
*
|
||||
@ -48,38 +48,14 @@ __machine_test(void)
|
||||
|
||||
#if defined(M68020)
|
||||
{
|
||||
const struct ExecBase * UNUSED ex = (const struct ExecBase *)SysBase;
|
||||
|
||||
#if defined(M68881_FLOATING_POINT_SUPPORT)
|
||||
{
|
||||
if(FLAG_IS_CLEAR(ex->AttnFlags,AFF_68881) || FLAG_IS_CLEAR(ex->AttnFlags,AFF_68020))
|
||||
{
|
||||
__show_error("This program requires a floating point processor and an MC68020 CPU, or better.");
|
||||
|
||||
goto out;
|
||||
}
|
||||
}
|
||||
#endif /* M68881_FLOATING_POINT_SUPPORT */
|
||||
|
||||
if(FLAG_IS_CLEAR(ex->AttnFlags,AFF_68020))
|
||||
if(FLAG_IS_CLEAR(((struct ExecBase *)SysBase)->AttnFlags,AFF_68020))
|
||||
{
|
||||
__show_error("This program requires an MC68020 CPU, or better.");
|
||||
|
||||
goto out;
|
||||
}
|
||||
}
|
||||
#elif defined(M68881_FLOATING_POINT_SUPPORT)
|
||||
{
|
||||
const struct ExecBase * UNUSED ex = (const struct ExecBase *)SysBase;
|
||||
|
||||
if(FLAG_IS_CLEAR(ex->AttnFlags,AFF_68881))
|
||||
{
|
||||
__show_error("This program requires a floating point processor.");
|
||||
|
||||
goto out;
|
||||
}
|
||||
}
|
||||
#endif /* M68881_FLOATING_POINT_SUPPORT */
|
||||
#endif /* M68020 */
|
||||
|
||||
result = OK;
|
||||
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* $Id: stdlib_main.c,v 1.11 2005-02-25 10:14:21 obarthel Exp $
|
||||
* $Id: stdlib_main.c,v 1.12 2005-03-07 11:16:43 obarthel Exp $
|
||||
*
|
||||
* :ts=4
|
||||
*
|
||||
@ -117,12 +117,12 @@ call_main(void)
|
||||
{
|
||||
__stdlib_init,
|
||||
__stk_init,
|
||||
__startup_init,
|
||||
__stdio_init,
|
||||
__stdio_file_init,
|
||||
__machine_test,
|
||||
__math_init,
|
||||
__socket_init,
|
||||
__wildcard_expand_init,
|
||||
__arg_init,
|
||||
|
||||
NULL
|
||||
};
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* $Id: stdlib_protos.h,v 1.11 2005-03-03 14:20:55 obarthel Exp $
|
||||
* $Id: stdlib_protos.h,v 1.12 2005-03-07 11:16:43 obarthel Exp $
|
||||
*
|
||||
* :ts=4
|
||||
*
|
||||
@ -132,8 +132,8 @@ void _fini(void);
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
/* stdlib_startup.c */
|
||||
extern int __startup_init(void);
|
||||
/* stdlib_arg.c */
|
||||
extern int __arg_init(void);
|
||||
|
||||
/****************************************************************************/
|
||||
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* $Id: unistd_fchown.c,v 1.7 2005-02-28 13:22:53 obarthel Exp $
|
||||
* $Id: unistd_fchown.c,v 1.8 2005-03-07 11:16:43 obarthel Exp $
|
||||
*
|
||||
* :ts=4
|
||||
*
|
||||
@ -80,6 +80,12 @@ fchown(int file_descriptor, uid_t owner, gid_t group)
|
||||
goto out;
|
||||
}
|
||||
|
||||
if(fd->fd_DefaultFile == ZERO)
|
||||
{
|
||||
__set_errno(EBADF);
|
||||
goto out;
|
||||
}
|
||||
|
||||
if(owner > 65535 || group > 65535)
|
||||
{
|
||||
SHOWMSG("owner or group not OK");
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* $Id: unistd_fdatasync.c,v 1.3 2005-02-21 10:22:02 obarthel Exp $
|
||||
* $Id: unistd_fdatasync.c,v 1.4 2005-03-07 11:16:43 obarthel Exp $
|
||||
*
|
||||
* :ts=4
|
||||
*
|
||||
@ -77,6 +77,12 @@ fdatasync(int file_descriptor)
|
||||
goto out;
|
||||
}
|
||||
|
||||
if(fd->fd_DefaultFile == ZERO)
|
||||
{
|
||||
__set_errno(EBADF);
|
||||
goto out;
|
||||
}
|
||||
|
||||
__sync_fd(fd,0); /* flush just the data */
|
||||
|
||||
result = 0;
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* $Id: unistd_fsync.c,v 1.3 2005-02-21 10:22:02 obarthel Exp $
|
||||
* $Id: unistd_fsync.c,v 1.4 2005-03-07 11:16:43 obarthel Exp $
|
||||
*
|
||||
* :ts=4
|
||||
*
|
||||
@ -76,6 +76,12 @@ fsync(int file_descriptor)
|
||||
goto out;
|
||||
}
|
||||
|
||||
if(fd->fd_DefaultFile == ZERO)
|
||||
{
|
||||
__set_errno(EBADF);
|
||||
goto out;
|
||||
}
|
||||
|
||||
__sync_fd(fd,1); /* flush everything */
|
||||
|
||||
result = 0;
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* $Id: unistd_ftruncate.c,v 1.6 2005-02-28 13:22:53 obarthel Exp $
|
||||
* $Id: unistd_ftruncate.c,v 1.7 2005-03-07 11:16:43 obarthel Exp $
|
||||
*
|
||||
* :ts=4
|
||||
*
|
||||
@ -77,6 +77,12 @@ ftruncate(int file_descriptor, off_t length)
|
||||
goto out;
|
||||
}
|
||||
|
||||
if(fd->fd_DefaultFile == ZERO)
|
||||
{
|
||||
__set_errno(EBADF);
|
||||
goto out;
|
||||
}
|
||||
|
||||
if(length < 0)
|
||||
{
|
||||
SHOWMSG("invalid length");
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* $Id: unistd_sync_fd.c,v 1.2 2005-02-28 13:22:53 obarthel Exp $
|
||||
* $Id: unistd_sync_fd.c,v 1.3 2005-03-07 11:16:43 obarthel Exp $
|
||||
*
|
||||
* :ts=4
|
||||
*
|
||||
@ -54,20 +54,17 @@ __sync_fd(struct fd * fd,int mode)
|
||||
|
||||
__fd_lock(fd);
|
||||
|
||||
if(fd->fd_DefaultFile != ZERO)
|
||||
/* The mode tells us what to flush. 0 means "flush just the data", and
|
||||
everything else means "flush everything. */
|
||||
Flush(fd->fd_DefaultFile);
|
||||
|
||||
if(mode != 0)
|
||||
{
|
||||
/* The mode tells us what to flush. 0 means "flush just the data", and
|
||||
everything else means "flush everything. */
|
||||
Flush(fd->fd_DefaultFile);
|
||||
struct FileHandle * fh = BADDR(fd->fd_DefaultFile);
|
||||
|
||||
if(mode != 0)
|
||||
{
|
||||
struct FileHandle * fh = BADDR(fd->fd_DefaultFile);
|
||||
|
||||
/* Verify that this file is not bound to "NIL:". */
|
||||
if(fh->fh_Type != NULL)
|
||||
DoPkt(fh->fh_Type,ACTION_FLUSH, 0,0,0,0,0);
|
||||
}
|
||||
/* Verify that this file is not bound to "NIL:". */
|
||||
if(fh->fh_Type != NULL)
|
||||
DoPkt(fh->fh_Type,ACTION_FLUSH, 0,0,0,0,0);
|
||||
}
|
||||
|
||||
__fd_unlock(fd);
|
||||
|
||||
Reference in New Issue
Block a user