65 #include <amxc/amxc.h>
66 #include <amxp/amxp.h>
68 #include <amxd/amxd_common.h>
69 #include <amxd/amxd_dm.h>
70 #include <amxd/amxd_path.h>
71 #include <amxd/amxd_object.h>
88 amxc_var_t* params = NULL;
89 int retval = amxd_status_unknown_error;
92 amxc_var_set_type(&args, AMXC_VAR_ID_HTABLE);
94 if((rel_path != NULL) && (*rel_path != 0)) {
95 amxc_var_add_key(cstring_t, &args,
"rel_path", rel_path);
98 amxc_var_add_key(uint32_t, &args,
"index", index);
99 amxc_var_add_key(cstring_t, &args,
"name", name);
100 params = amxc_var_add_key(amxc_htable_t, &args,
"parameters", NULL);
101 amxc_var_move(params, values);
102 amxc_var_add_key(uint32_t, &args,
"access",
bus_ctx->
access);
105 when_failed(retval, exit);
106 retval =
amxb_invoke(invoke_ctx, &args, ret, NULL, NULL, timeout);
107 when_failed(retval, exit);
110 amxc_var_clean(&args);
122 int retval = amxd_status_unknown_error;
124 bool lobject =
false;
127 const char* rel_path = NULL;
129 amxd_path_init(&path, NULL);
133 amxd_path_setf(&path,
true,
"%s",
object);
135 while(amxd_path_get_type(&path) == amxd_path_reference) {
137 when_failed(retval, exit);
140 fixed = amxd_path_get_fixed_part(&path,
true);
141 rel_path = amxd_path_get(&path, AMXD_OBJECT_TERMINATE);
146 if(amxc_var_is_null(values)) {
147 amxc_var_set_type(values, AMXC_VAR_ID_HTABLE);
152 name, values, ret, timeout);
160 amxd_path_clean(&path);
Ambiorix bus agnostic API header file.
static int amxb_invoke_add(amxb_bus_ctx_t *const bus_ctx, const char *object, const char *rel_path, uint32_t index, const char *name, amxc_var_t *values, amxc_var_t *ret, int timeout)
Ambiorix Bus Backend Interface.
#define amxb_is_valid_be_func(ft, member, ptr)
int PRIVATE amxb_follow_reference(amxb_bus_ctx_t *const bus_ctx, amxd_path_t *reference, int timeout)
bool PRIVATE amxb_is_local_object(amxb_bus_ctx_t *ctx, const char *obj_path)
int amxb_new_invoke(amxb_invoke_t **invoke_ctx, amxb_bus_ctx_t *const ctx, const char *object, const char *interface, const char *method)
Prepares a remote function invocation.
void amxb_free_invoke(amxb_invoke_t **invoke_ctx)
Deletes a function invoke context, and frees allocated memory.
int amxb_invoke(amxb_invoke_t *invoke_ctx, amxc_var_t *args, amxc_var_t *ret, amxb_be_cb_fn_t fn, void *priv, int timeout)
Invokes a remote function, as defined by the function invoke context.
int amxb_add(amxb_bus_ctx_t *const bus_ctx, const char *object, uint32_t index, const char *name, amxc_var_t *values, amxc_var_t *ret, int timeout)
Adds an instance to a multi-instance object.
The back-end interface structure.
const amxb_be_funcs_t * bus_fn
static amxb_bus_ctx_t * bus_ctx