X-Git-Url: https://git.liburcu.org/?a=blobdiff_plain;f=ust-consumerd%2Fust-consumerd.c;h=c96139455d24ecdbb54014f9f829b42819ef2f5f;hb=5343b2860738c675311ce5949bdf9e31afc76fa4;hp=fae4efafa87f06e02c80ef09080a0b2e8afabaf0;hpb=9dc7b7ff797a5cbb1e9ffd59e053a04562f306c4;p=ust.git diff --git a/ust-consumerd/ust-consumerd.c b/ust-consumerd/ust-consumerd.c index fae4efa..c961394 100644 --- a/ust-consumerd/ust-consumerd.c +++ b/ust-consumerd/ust-consumerd.c @@ -33,6 +33,7 @@ #include #include "ust/ustconsumer.h" +#include "../libustconsumer/lowlevel.h" #include "usterr.h" char *sock_path=NULL; @@ -144,7 +145,7 @@ int on_read_partial_subbuffer(struct ustconsumer_callbacks *data, struct buffer_ result = patient_write(buf_local->file_fd, buf->mem + subbuf_index * buf->subbuf_size, valid_length); if(result == -1) { ERR("Error writing to buffer file"); - return; + return result; } /* pad with empty bytes */ @@ -154,11 +155,11 @@ int on_read_partial_subbuffer(struct ustconsumer_callbacks *data, struct buffer_ result = patient_write(buf_local->file_fd, tmp, pad_size); if(result == -1) { ERR("Error writing to buffer file"); - return; + return result; } free(tmp); } - + return result; } int on_open_buffer(struct ustconsumer_callbacks *data, struct buffer_info *buf) @@ -209,7 +210,11 @@ int on_open_buffer(struct ustconsumer_callbacks *data, struct buffer_info *buf) trace_path, buf->pid, buf->pidunique, buf->name); return 1; } +again: result = fd = open(tmp, O_WRONLY | O_CREAT | O_TRUNC | O_EXCL, 00600); + if (result == -1 && errno == EINTR) + goto again; + if(result == -1) { PERROR("open"); ERR("failed opening trace file %s", tmp); @@ -224,7 +229,12 @@ int on_open_buffer(struct ustconsumer_callbacks *data, struct buffer_info *buf) int on_close_buffer(struct ustconsumer_callbacks *data, struct buffer_info *buf) { struct buffer_info_local *buf_local = buf->user_data; - int result = close(buf_local->file_fd); + int result; + +again: + result = close(buf_local->file_fd); + if (result == -1 && errno == EINTR) + goto again; free(buf_local); if(result == -1) { PERROR("close"); @@ -234,7 +244,7 @@ int on_close_buffer(struct ustconsumer_callbacks *data, struct buffer_info *buf) int on_put_error(struct ustconsumer_callbacks *data, struct buffer_info *buf) { - unwrite_last_subbuffer(buf); + return unwrite_last_subbuffer(buf); } struct ustconsumer_callbacks *new_callbacks()