mirror of
https://github.com/systemd/systemd.git
synced 2025-01-05 13:18:06 +03:00
sd-varlink: expose api to get input/output fd separately
This commit is contained in:
parent
32c3e1379d
commit
2afcc034c7
@ -1062,8 +1062,10 @@ global:
|
|||||||
|
|
||||||
LIBSYSTEMD_258 {
|
LIBSYSTEMD_258 {
|
||||||
global:
|
global:
|
||||||
|
sd_device_enumerator_add_all_parents;
|
||||||
sd_json_variant_type_from_string;
|
sd_json_variant_type_from_string;
|
||||||
sd_json_variant_type_to_string;
|
sd_json_variant_type_to_string;
|
||||||
|
sd_varlink_get_input_fd;
|
||||||
|
sd_varlink_get_output_fd;
|
||||||
sd_varlink_reset_fds;
|
sd_varlink_reset_fds;
|
||||||
sd_device_enumerator_add_all_parents;
|
|
||||||
} LIBSYSTEMD_257;
|
} LIBSYSTEMD_257;
|
||||||
|
@ -1673,6 +1673,30 @@ _public_ int sd_varlink_get_fd(sd_varlink *v) {
|
|||||||
return v->input_fd;
|
return v->input_fd;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_public_ int sd_varlink_get_input_fd(sd_varlink *v) {
|
||||||
|
|
||||||
|
assert_return(v, -EINVAL);
|
||||||
|
|
||||||
|
if (v->state == VARLINK_DISCONNECTED)
|
||||||
|
return varlink_log_errno(v, SYNTHETIC_ERRNO(ENOTCONN), "Not connected.");
|
||||||
|
if (v->input_fd < 0)
|
||||||
|
return varlink_log_errno(v, SYNTHETIC_ERRNO(EBADF), "No valid input fd.");
|
||||||
|
|
||||||
|
return v->input_fd;
|
||||||
|
}
|
||||||
|
|
||||||
|
_public_ int sd_varlink_get_output_fd(sd_varlink *v) {
|
||||||
|
|
||||||
|
assert_return(v, -EINVAL);
|
||||||
|
|
||||||
|
if (v->state == VARLINK_DISCONNECTED)
|
||||||
|
return varlink_log_errno(v, SYNTHETIC_ERRNO(ENOTCONN), "Not connected.");
|
||||||
|
if (v->output_fd < 0)
|
||||||
|
return varlink_log_errno(v, SYNTHETIC_ERRNO(EBADF), "No valid output fd.");
|
||||||
|
|
||||||
|
return v->output_fd;
|
||||||
|
}
|
||||||
|
|
||||||
_public_ int sd_varlink_get_events(sd_varlink *v) {
|
_public_ int sd_varlink_get_events(sd_varlink *v) {
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
|
@ -96,6 +96,8 @@ sd_varlink* sd_varlink_ref(sd_varlink *link);
|
|||||||
sd_varlink* sd_varlink_unref(sd_varlink *v);
|
sd_varlink* sd_varlink_unref(sd_varlink *v);
|
||||||
|
|
||||||
int sd_varlink_get_fd(sd_varlink *v);
|
int sd_varlink_get_fd(sd_varlink *v);
|
||||||
|
int sd_varlink_get_input_fd(sd_varlink *v);
|
||||||
|
int sd_varlink_get_output_fd(sd_varlink *v);
|
||||||
int sd_varlink_get_events(sd_varlink *v);
|
int sd_varlink_get_events(sd_varlink *v);
|
||||||
int sd_varlink_get_timeout(sd_varlink *v, uint64_t *ret);
|
int sd_varlink_get_timeout(sd_varlink *v, uint64_t *ret);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user