diff options
Diffstat (limited to '')
-rw-r--r-- | src/mds-registry/slave.c | 9 | ||||
-rw-r--r-- | src/mds-registry/slave.h | 3 |
2 files changed, 7 insertions, 5 deletions
diff --git a/src/mds-registry/slave.c b/src/mds-registry/slave.c index f98dc20..bda6ca6 100644 --- a/src/mds-registry/slave.c +++ b/src/mds-registry/slave.c @@ -345,10 +345,11 @@ void slave_destroy(slave_t* restrict this) */ size_t slave_marshal_size(const slave_t* restrict this) { - size_t rc = 2 * sizeof(int) + sizeof(ssize_t) + sizeof(size_t) + sizeof(uint64_t); + size_t rc; hash_entry_t* restrict entry; size_t n; + rc = sizeof(int) + sizeof(sig_atomic_t) + sizeof(ssize_t) + sizeof(size_t) + sizeof(uint64_t); rc += sizeof(int) + sizeof(time_t) + sizeof(long); rc += (strlen(this->client_id) + strlen(this->message_id) + 2) * sizeof(char); @@ -375,7 +376,7 @@ size_t slave_marshal(const slave_t* restrict this, char* restrict data) size_t n; buf_set_next(data, int, SLAVE_T_VERSION); - buf_set_next(data, int, this->closed); + buf_set_next(data, sig_atomic_t, this->closed); buf_set_next(data, ssize_t, this->node); buf_set_next(data, uint64_t, this->client); buf_set_next(data, int, this->timed); @@ -422,7 +423,7 @@ size_t slave_unmarshal(slave_t* restrict this, char* restrict data) /* buf_get_next(data, int, SLAVE_T_VERSION); */ buf_next(data, int, 1); - buf_get_next(data, int, this->closed); + buf_get_next(data, sig_atomic_t, this->closed); buf_get_next(data, ssize_t, this->node); buf_get_next(data, uint64_t, this->client); buf_get_next(data, int, this->timed); @@ -483,7 +484,7 @@ size_t slave_unmarshal_skip(char* restrict data) /* buf_get_next(data, int, SLAVE_T_VERSION); */ buf_next(data, int, 1); - buf_next(data, int, 1); + buf_next(data, sig_atomic_t, 1); buf_next(data, ssize_t, 1); buf_next(data, uint64_t, 1); buf_next(data, int, 1); diff --git a/src/mds-registry/slave.h b/src/mds-registry/slave.h index 9f08f07..cb30b94 100644 --- a/src/mds-registry/slave.h +++ b/src/mds-registry/slave.h @@ -25,6 +25,7 @@ #include <stdint.h> #include <pthread.h> #include <time.h> +#include <signal.h> @@ -63,7 +64,7 @@ typedef struct slave /** * Whether the client has been closed */ - volatile int closed; + volatile sig_atomic_t closed; /** * The slave thread |