summaryrefslogtreecommitdiffstats
path: root/qemu/roms/openbios/include/libopenbios/bindings.h
diff options
context:
space:
mode:
Diffstat (limited to 'qemu/roms/openbios/include/libopenbios/bindings.h')
-rw-r--r--qemu/roms/openbios/include/libopenbios/bindings.h157
1 files changed, 0 insertions, 157 deletions
diff --git a/qemu/roms/openbios/include/libopenbios/bindings.h b/qemu/roms/openbios/include/libopenbios/bindings.h
deleted file mode 100644
index 4ec978912..000000000
--- a/qemu/roms/openbios/include/libopenbios/bindings.h
+++ /dev/null
@@ -1,157 +0,0 @@
-/*
- * Creation Date: <2003/12/19 23:09:56 samuel>
- * Time-stamp: <2004/01/07 19:36:42 samuel>
- *
- * <bindings.h>
- *
- * Forth bindings
- *
- * Copyright (C) 2003, 2004 Samuel Rydh (samuel@ibrium.se)
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU General Public License
- * version 2
- *
- */
-
-#ifndef _H_BINDINGS
-#define _H_BINDINGS
-
-#include "kernel/stack.h"
-#include "kernel/kernel.h"
-
-#define PUSH3(a,b,c) do { PUSH((a)); PUSH((b)); PUSH((c)); } while(0)
-#define PUSH2(a,b) do { PUSH((a)); PUSH((b)); } while(0)
-#define RET( v ) do { PUSH(v); return; } while(0)
-
-/* initialization */
-extern int initialize_forth( void );
-
-/* panic */
-extern int forth_segv_handler( char *segv_addr );
-
-/* active package */
-extern phandle_t find_dev( const char *path );
-extern phandle_t get_cur_dev( void );
-extern phandle_t activate_device( const char *str );
-extern void device_end( void );
-extern void activate_dev( phandle_t ph );
-
-
-/* ihandle related */
-extern phandle_t ih_to_phandle( ihandle_t ih );
-extern ihandle_t my_parent( void );
-extern ihandle_t my_self( void );
-extern char *my_args_copy( void );
-
-extern xt_t find_package_method( const char *meth, phandle_t ph );
-extern xt_t find_ih_method( const char *method, ihandle_t ih );
-extern xt_t find_parent_method( const char *method );
-extern void call_package( xt_t xt, ihandle_t ihandle );
-extern void call_parent( xt_t xt );
-extern void call_parent_method( const char *method );
-
-/* package */
-extern ihandle_t open_package( const char *argstr, phandle_t ph );
-extern ihandle_t open_dev( const char *spec );
-extern void close_package( ihandle_t ih );
-extern void close_dev( ihandle_t ih );
-extern char *get_path_from_ph( phandle_t ph );
-
-/* property access */
-extern void set_property( phandle_t ph, const char *name,
- const char *buf, int len );
-extern void set_int_property( phandle_t ph, const char *name,
- u32 val );
-extern u32 get_int_property( phandle_t ph, const char *name,
- int *retlen );
-extern char *get_property( phandle_t ph, const char *name,
- int *retlen );
-
-/* device tree iteration */
-extern phandle_t dt_iter_begin( void );
-extern phandle_t dt_iterate( phandle_t last_tree );
-extern phandle_t dt_iterate_type( phandle_t last_tree,
- const char *type );
-static inline phandle_t dt_find_type( const char *type ) {
- return dt_iterate_type( 0, type );
-}
-
-/* forth bindings */
-extern cell feval( const char *str );
-extern void bind_xtfunc( const char *name, xt_t xt,
- ucell arg, void (*func)(void) );
-extern void bind_func( const char *name, void (*func)(void) );
-extern xt_t bind_noname_func( void (*func)(void) );
-extern void push_str( const char *str );
-extern char *pop_fstr_copy( void );
-
-extern int _fword( const char *word, xt_t *cache_xt );
-extern cell _eword( const char *word, xt_t *cache_xt, int nargs );
-extern int _selfword( const char *method, xt_t *cache_xt );
-extern int _parword( const char *method, xt_t *cache_xt );
-
-#define fword(w) ({ static xt_t cache_xt = 0; _fword(w, &cache_xt); })
-#define eword(w, nargs) ({ static xt_t cache_xt = 0; _eword(w, &cache_xt, nargs); })
-#define selfword(w) ({ static xt_t cache_xt = 0; _selfword(w, &cache_xt); })
-#define parword(w) ({ static xt_t cache_xt = 0; _parword(w, &cache_xt); })
-
-extern void throw( int error );
-
-
-/* node bindings */
-extern void make_openable( int only_parents );
-
-
-typedef struct {
- const char *name;
- void *func;
-} method_t;
-
-#define REGISTER_NAMED_NODE( name, path ) do { \
- bind_new_node( name##_flags_, name##_size_, \
- path, name##_m, sizeof(name##_m)/sizeof(method_t)); \
- } while(0)
-
-#define REGISTER_NAMED_NODE_PHANDLE( name, path, phandle ) do { \
- phandle = \
- bind_new_node( name##_flags_, name##_size_, \
- path, name##_m, sizeof(name##_m)/sizeof(method_t)); \
- } while(0)
-
-#define REGISTER_NODE_METHODS( name, path ) do { \
- const char *paths[1]; \
- \
- paths[0] = path; \
- bind_node( name##_flags_, name##_size_, \
- paths, 1, name##_m, sizeof(name##_m)/sizeof(method_t)); \
- } while(0)
-
-#define DECLARE_UNNAMED_NODE( name, flags, size ) \
-static const int name##_flags_ = flags; \
-static const int name##_size_ = size;
-
-#define DECLARE_NODE( name, flags, size, paths... ) \
-static const char * const name##_p[] = { paths }; \
-DECLARE_UNNAMED_NODE(name, flags, size)
-
-#define NODE_METHODS( name ) \
-static const method_t name##_m[]
-
-#define REGISTER_NODE( name ) do { \
- bind_node( name##_flags_, name##_size_, \
- name##_p, sizeof(name##_p)/sizeof(char*), \
- name##_m, sizeof(name##_m)/sizeof(method_t) ); \
- } while(0)
-
-extern void bind_node( int flags, int size, const char * const *paths, int npaths,
- const method_t *methods, int nmethods );
-
-extern phandle_t bind_new_node( int flags, int size, const char *name,
- const method_t *methods, int nmethods );
-
-#define INSTALL_OPEN 1 /* install trivial open and close methods */
-
-
-
-#endif /* _H_BINDINGS */