2 Copyright © 1995-2007, The AROS Development Team. All rights reserved.
5 Desc: DOS function LoadSeg()
15 #include <dos/dosextens.h>
16 #include <proto/dos.h>
17 #include <aros/debug.h>
18 #include "dos_intern.h"
20 /*****************************************************************************
23 #include <proto/dos.h>
25 AROS_LH1(BPTR
, LoadSeg
,
28 AROS_LHA(CONST_STRPTR
, name
, D1
),
31 struct DosLibrary
*, DOSBase
, 25, Dos
)
34 Loads an executable file into memory. Each hunk of the loadfile
35 is loaded into its own memory section and a handle on all of them
36 is returned. The segments can be freed with UnLoadSeg().
39 name - NUL terminated name of the file.
42 Handle to the loaded executable or NULL if the load failed.
43 IoErr() gives additional information in that case.
46 This function is built on top of InternalLoadSeg()
57 *****************************************************************************/
61 void (* FunctionArray
[3])();
64 FunctionArray
[0] = __AROS_GETVECADDR(DOSBase
,7); /* Read() */
65 FunctionArray
[1] = __AROS_GETVECADDR(SysBase
,33); /* AllocMem() */
66 FunctionArray
[2] = __AROS_GETVECADDR(SysBase
,35); /* FreeMem() */
69 D(bug("[LoadSeg] Opening '%s'...\n", name
));
70 file
= Open (name
, FMF_READ
);
74 D(bug("[LoadSeg] Loading '%s'...\n", name
));
76 segs
= InternalLoadSeg(file
, NULL
, (void *)FunctionArray
, NULL
);
81 bug("[LoadSeg] Failed to load '%s'\n", name
);
85 bug("[LoadSeg] Failed to open '%s'\n", name
));