Renamed "struct rld_export_t" to "struct rld_export", "struct uspace_prog_args_t"

to "struct uspace_program_args", prog_name & prog_path to program_name and
program_path.
Moved the MAGIC_APPNAME to a BeOS compatible MAGIG_APP_NAME from rld_priv.h
to this place.
Removed the dlxxx() exports in the rld_export structure - instead, they will
be implemented using the basic runtime linker API which is a slightly extended
version of the standard BeOS calls (load_add_on() has a "flags" paramater to
allow implementation of dlopen()).
Completed the export API to be able to completely support the BeOS API.


git-svn-id: file:///srv/svn/repos/haiku/trunk/current@2420 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Axel Dörfler 2003-01-12 16:22:09 +00:00
parent 30f9b99833
commit ef6d88af27

View File

@ -2,28 +2,29 @@
** Copyright 2002, Manuel J. Petit. All rights reserved. ** Copyright 2002, Manuel J. Petit. All rights reserved.
** Distributed under the terms of the NewOS License. ** Distributed under the terms of the NewOS License.
*/ */
#ifndef __newos__kernel__user_runtime__hh__ #ifndef KERNEL_USER_RUNTIME_H_
#define __newos__kernel__user_runtime__hh__ #define KERNEL_USER_RUNTIME_H_
#include <image.h>
#include <defines.h> #include <defines.h>
#define MAGIC_APP_NAME "_APP_"
struct rld_export_t struct rld_export
{ {
int (*dl_open )(char const *path, unsigned flags); // runtime linker API export
int (*dl_close)(int lib, unsigned flags); image_id (*load_add_on)(char const *path, uint32 flags);
void *(*dl_sym )(int lib, char const *sym, unsigned flags); status_t (*unload_add_on)(image_id imageID);
status_t (*get_image_symbol)(image_id imageID, char const *symbolName,
int (*load_addon)(char const *path, unsigned flags); int32 symbolType, void **_location);
int (*unload_addon)(int add_on, unsigned flags); status_t (*get_nth_image_symbol)(image_id imageID, int32 num, char const *symbolName,
void *(*addon_symbol)(int lib, char const *sym, unsigned flags); int32 *nameLength, int32 *symbolType, void **_location);
}; };
struct uspace_prog_args_t struct uspace_program_args
{ {
char prog_name[SYS_MAX_OS_NAME_LEN]; char program_name[SYS_MAX_OS_NAME_LEN];
char prog_path[SYS_MAX_PATH_LEN]; char program_path[SYS_MAX_PATH_LEN];
int argc; int argc;
int envc; int envc;
char **argv; char **argv;
@ -32,13 +33,12 @@ struct uspace_prog_args_t
/* /*
* hooks into rld for POSIX and BeOS library/module loading * hooks into rld for POSIX and BeOS library/module loading
*/ */
struct rld_export_t *rld_export; struct rld_export *rld_export;
}; };
typedef void (libinit_f)(unsigned, struct uspace_prog_args_t const *); typedef void (libinit_f)(unsigned, struct uspace_program_args const *);
void INIT_BEFORE_CTORS(unsigned, struct uspace_prog_args_t const *); //void INIT_BEFORE_CTORS(unsigned, struct uspace_prog_args const *);
void INIT_AFTER_CTORS(unsigned, struct uspace_prog_args_t const *); //void INIT_AFTER_CTORS(unsigned, struct uspace_prog_args const *);
#endif /* KERNEL_USER_RUNTIME_H_ */
#endif