mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-03 05:18:29 +03:00
clvmd ia64 alignment fixes etc. (pjc)
This commit is contained in:
parent
0357f18ef0
commit
a951e97ae9
@ -200,7 +200,7 @@ static int lock_vg(struct local_client *client)
|
|||||||
if (status)
|
if (status)
|
||||||
status = errno;
|
status = errno;
|
||||||
else
|
else
|
||||||
dm_hash_insert(lock_hash, lockname, (void *)lkid);
|
dm_hash_insert(lock_hash, lockname, (void *)(long)lkid);
|
||||||
}
|
}
|
||||||
|
|
||||||
return status;
|
return status;
|
||||||
@ -224,7 +224,7 @@ int do_pre_command(struct local_client *client)
|
|||||||
switch (header->cmd) {
|
switch (header->cmd) {
|
||||||
case CLVMD_CMD_TEST:
|
case CLVMD_CMD_TEST:
|
||||||
status = sync_lock("CLVMD_TEST", LKM_EXMODE, 0, &lockid);
|
status = sync_lock("CLVMD_TEST", LKM_EXMODE, 0, &lockid);
|
||||||
client->bits.localsock.private = (void *) lockid;
|
client->bits.localsock.private = (void *)(long)lockid;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case CLVMD_CMD_LOCK_VG:
|
case CLVMD_CMD_LOCK_VG:
|
||||||
|
@ -325,7 +325,8 @@ int main(int argc, char *argv[])
|
|||||||
/* This needs to be started after cluster initialisation
|
/* This needs to be started after cluster initialisation
|
||||||
as it may need to take out locks */
|
as it may need to take out locks */
|
||||||
DEBUGLOG("starting LVM thread\n");
|
DEBUGLOG("starting LVM thread\n");
|
||||||
pthread_create(&lvm_thread, NULL, lvm_thread_fn, (void *)using_gulm);
|
pthread_create(&lvm_thread, NULL, lvm_thread_fn,
|
||||||
|
(void *)(long)using_gulm);
|
||||||
|
|
||||||
/* Tell the rest of the cluster our version number */
|
/* Tell the rest of the cluster our version number */
|
||||||
/* CMAN can do this immediately, gulm needs to wait until
|
/* CMAN can do this immediately, gulm needs to wait until
|
||||||
@ -412,16 +413,17 @@ static int local_pipe_callback(struct local_client *thisfd, char *buf,
|
|||||||
|
|
||||||
len = read(thisfd->fd, buffer, sizeof(int));
|
len = read(thisfd->fd, buffer, sizeof(int));
|
||||||
|
|
||||||
DEBUGLOG("read on PIPE %d: %d bytes: status: %d\n",
|
|
||||||
thisfd->fd, len, *(int *) buffer);
|
|
||||||
|
|
||||||
if (len == sizeof(int)) {
|
if (len == sizeof(int)) {
|
||||||
status = *(int *) buffer;
|
memcpy(&status, buffer, sizeof(int));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
DEBUGLOG("read on PIPE %d: %d bytes: status: %d\n",
|
||||||
|
thisfd->fd, len, status);
|
||||||
|
|
||||||
/* EOF on pipe or an error, close it */
|
/* EOF on pipe or an error, close it */
|
||||||
if (len <= 0) {
|
if (len <= 0) {
|
||||||
int jstat;
|
int jstat;
|
||||||
|
void *ret = &status;
|
||||||
close(thisfd->fd);
|
close(thisfd->fd);
|
||||||
|
|
||||||
/* Clear out the cross-link */
|
/* Clear out the cross-link */
|
||||||
@ -431,9 +433,7 @@ static int local_pipe_callback(struct local_client *thisfd, char *buf,
|
|||||||
|
|
||||||
/* Reap child thread */
|
/* Reap child thread */
|
||||||
if (thisfd->bits.pipe.threadid) {
|
if (thisfd->bits.pipe.threadid) {
|
||||||
jstat =
|
jstat = pthread_join(thisfd->bits.pipe.threadid, &ret);
|
||||||
pthread_join(thisfd->bits.pipe.threadid,
|
|
||||||
(void **) &status);
|
|
||||||
thisfd->bits.pipe.threadid = 0;
|
thisfd->bits.pipe.threadid = 0;
|
||||||
if (thisfd->bits.pipe.client != NULL)
|
if (thisfd->bits.pipe.client != NULL)
|
||||||
thisfd->bits.pipe.client->bits.localsock.
|
thisfd->bits.pipe.client->bits.localsock.
|
||||||
@ -674,7 +674,7 @@ static void main_loop(int local_sock, int cmd_timeout)
|
|||||||
close(local_sock);
|
close(local_sock);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void wait_for_child(int c_pipe, int timeout)
|
static __attribute__ ((noreturn)) void wait_for_child(int c_pipe, int timeout)
|
||||||
{
|
{
|
||||||
int child_status;
|
int child_status;
|
||||||
int sstat;
|
int sstat;
|
||||||
@ -1139,8 +1139,8 @@ static int distribute_command(struct local_client *thisfd)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Process a command from a remote node and return the result */
|
/* Process a command from a remote node and return the result */
|
||||||
void process_remote_command(struct clvm_header *msg, int msglen, int fd,
|
static void process_remote_command(struct clvm_header *msg, int msglen, int fd,
|
||||||
char *csid)
|
char *csid)
|
||||||
{
|
{
|
||||||
char *replyargs;
|
char *replyargs;
|
||||||
char nodename[max_cluster_member_name_len];
|
char nodename[max_cluster_member_name_len];
|
||||||
@ -1164,11 +1164,12 @@ void process_remote_command(struct clvm_header *msg, int msglen, int fd,
|
|||||||
(struct clvm_header *) malloc(msg->arglen +
|
(struct clvm_header *) malloc(msg->arglen +
|
||||||
sizeof(struct clvm_header));
|
sizeof(struct clvm_header));
|
||||||
if (newmsg) {
|
if (newmsg) {
|
||||||
if (system_lv_read_data
|
ssize_t len;
|
||||||
(nodename, (char *) newmsg,
|
if (system_lv_read_data(nodename, (char *) newmsg,
|
||||||
(size_t *) &msglen) == 0) {
|
&len) == 0) {
|
||||||
msg = newmsg;
|
msg = newmsg;
|
||||||
msg_malloced = 1;
|
msg_malloced = 1;
|
||||||
|
msglen = len;
|
||||||
} else {
|
} else {
|
||||||
struct clvm_header head;
|
struct clvm_header head;
|
||||||
DEBUGLOG("System LV read failed\n");
|
DEBUGLOG("System LV read failed\n");
|
||||||
@ -1214,8 +1215,11 @@ void process_remote_command(struct clvm_header *msg, int msglen, int fd,
|
|||||||
/* Version check is internal - don't bother exposing it in
|
/* Version check is internal - don't bother exposing it in
|
||||||
clvmd-command.c */
|
clvmd-command.c */
|
||||||
if (msg->cmd == CLVMD_CMD_VERSION) {
|
if (msg->cmd == CLVMD_CMD_VERSION) {
|
||||||
int *version_nums = (int *) msg->args;
|
int version_nums[3];
|
||||||
char node[256];
|
char node[256];
|
||||||
|
|
||||||
|
memcpy(version_nums, msg->args, sizeof(version_nums));
|
||||||
|
|
||||||
clops->name_from_csid(csid, node);
|
clops->name_from_csid(csid, node);
|
||||||
DEBUGLOG("Remote node %s is version %d.%d.%d\n",
|
DEBUGLOG("Remote node %s is version %d.%d.%d\n",
|
||||||
node,
|
node,
|
||||||
@ -1387,7 +1391,7 @@ static void add_reply_to_list(struct local_client *client, int status,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* This is the thread that runs the PRE and post commands for a particular connection */
|
/* This is the thread that runs the PRE and post commands for a particular connection */
|
||||||
static void *pre_and_post_thread(void *arg)
|
static __attribute__ ((noreturn)) void *pre_and_post_thread(void *arg)
|
||||||
{
|
{
|
||||||
struct local_client *client = (struct local_client *) arg;
|
struct local_client *client = (struct local_client *) arg;
|
||||||
int status;
|
int status;
|
||||||
@ -1455,7 +1459,6 @@ static void *pre_and_post_thread(void *arg)
|
|||||||
}
|
}
|
||||||
DEBUGLOG("Subthread finished\n");
|
DEBUGLOG("Subthread finished\n");
|
||||||
pthread_exit((void *) 0);
|
pthread_exit((void *) 0);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Process a command on the local node and store the result */
|
/* Process a command on the local node and store the result */
|
||||||
@ -1564,7 +1567,7 @@ static void send_local_reply(struct local_client *client, int status, int fd)
|
|||||||
if (thisreply->status)
|
if (thisreply->status)
|
||||||
clientreply->flags |= CLVMD_FLAG_NODEERRS;
|
clientreply->flags |= CLVMD_FLAG_NODEERRS;
|
||||||
|
|
||||||
*(int *) ptr = thisreply->status;
|
memcpy(ptr, &thisreply->status, sizeof(int));
|
||||||
ptr += sizeof(int);
|
ptr += sizeof(int);
|
||||||
|
|
||||||
if (thisreply->replymsg) {
|
if (thisreply->replymsg) {
|
||||||
@ -1620,19 +1623,22 @@ static void send_version_message()
|
|||||||
{
|
{
|
||||||
char message[sizeof(struct clvm_header) + sizeof(int) * 3];
|
char message[sizeof(struct clvm_header) + sizeof(int) * 3];
|
||||||
struct clvm_header *msg = (struct clvm_header *) message;
|
struct clvm_header *msg = (struct clvm_header *) message;
|
||||||
int *version_nums = (int *) msg->args;
|
int version_nums[3];
|
||||||
|
|
||||||
msg->cmd = CLVMD_CMD_VERSION;
|
msg->cmd = CLVMD_CMD_VERSION;
|
||||||
msg->status = 0;
|
msg->status = 0;
|
||||||
msg->flags = 0;
|
msg->flags = 0;
|
||||||
msg->clientid = 0;
|
msg->clientid = 0;
|
||||||
msg->arglen = sizeof(int) * 3;
|
msg->arglen = sizeof(version_nums);
|
||||||
|
|
||||||
version_nums[0] = htonl(CLVMD_MAJOR_VERSION);
|
version_nums[0] = htonl(CLVMD_MAJOR_VERSION);
|
||||||
version_nums[1] = htonl(CLVMD_MINOR_VERSION);
|
version_nums[1] = htonl(CLVMD_MINOR_VERSION);
|
||||||
version_nums[2] = htonl(CLVMD_PATCH_VERSION);
|
version_nums[2] = htonl(CLVMD_PATCH_VERSION);
|
||||||
|
|
||||||
|
memcpy(&msg->args, version_nums, sizeof(version_nums));
|
||||||
|
|
||||||
hton_clvm(msg);
|
hton_clvm(msg);
|
||||||
|
|
||||||
clops->cluster_send_message(message, sizeof(message), NULL,
|
clops->cluster_send_message(message, sizeof(message), NULL,
|
||||||
"Error Sending version number");
|
"Error Sending version number");
|
||||||
}
|
}
|
||||||
@ -1689,11 +1695,11 @@ static int process_work_item(struct lvm_thread_cmd *cmd)
|
|||||||
/*
|
/*
|
||||||
* Routine that runs in the "LVM thread".
|
* Routine that runs in the "LVM thread".
|
||||||
*/
|
*/
|
||||||
static void *lvm_thread_fn(void *arg)
|
static __attribute__ ((noreturn)) void *lvm_thread_fn(void *arg)
|
||||||
{
|
{
|
||||||
struct list *cmdl, *tmp;
|
struct list *cmdl, *tmp;
|
||||||
sigset_t ss;
|
sigset_t ss;
|
||||||
int using_gulm = (int)arg;
|
int using_gulm = (int)(long)arg;
|
||||||
|
|
||||||
/* Don't let anyone else to do work until we are started */
|
/* Don't let anyone else to do work until we are started */
|
||||||
pthread_mutex_lock(&lvm_start_mutex);
|
pthread_mutex_lock(&lvm_start_mutex);
|
||||||
@ -1737,7 +1743,6 @@ static void *lvm_thread_fn(void *arg)
|
|||||||
}
|
}
|
||||||
pthread_mutex_unlock(&lvm_thread_mutex);
|
pthread_mutex_unlock(&lvm_thread_mutex);
|
||||||
}
|
}
|
||||||
return NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Pass down some work to the LVM thread */
|
/* Pass down some work to the LVM thread */
|
||||||
|
@ -183,7 +183,6 @@ static int _cluster_request(char cmd, const char *node, void *data, int len,
|
|||||||
lvm_response_t ** response, int *num)
|
lvm_response_t ** response, int *num)
|
||||||
{
|
{
|
||||||
char outbuf[sizeof(struct clvm_header) + len + strlen(node) + 1];
|
char outbuf[sizeof(struct clvm_header) + len + strlen(node) + 1];
|
||||||
int *outptr;
|
|
||||||
char *inptr;
|
char *inptr;
|
||||||
char *retbuf = NULL;
|
char *retbuf = NULL;
|
||||||
int status;
|
int status;
|
||||||
@ -223,17 +222,14 @@ static int _cluster_request(char cmd, const char *node, void *data, int len,
|
|||||||
* With an extra pair of INTs on the front to sanity
|
* With an extra pair of INTs on the front to sanity
|
||||||
* check the pointer when we are given it back to free
|
* check the pointer when we are given it back to free
|
||||||
*/
|
*/
|
||||||
outptr = dm_malloc(sizeof(lvm_response_t) * num_responses +
|
*response = dm_malloc(sizeof(lvm_response_t) * num_responses +
|
||||||
sizeof(int) * 2);
|
sizeof(int) * 2);
|
||||||
if (!outptr) {
|
if (!*response) {
|
||||||
errno = ENOMEM;
|
errno = ENOMEM;
|
||||||
status = 0;
|
status = 0;
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
*response = (lvm_response_t *) (outptr + 2);
|
|
||||||
outptr[0] = LVM_SIGNATURE;
|
|
||||||
outptr[1] = num_responses;
|
|
||||||
rarray = *response;
|
rarray = *response;
|
||||||
|
|
||||||
/* Unpack the response into an lvm_response_t array */
|
/* Unpack the response into an lvm_response_t array */
|
||||||
@ -252,7 +248,7 @@ static int _cluster_request(char cmd, const char *node, void *data, int len,
|
|||||||
int j;
|
int j;
|
||||||
for (j = 0; j < i; j++)
|
for (j = 0; j < i; j++)
|
||||||
dm_free(rarray[i].response);
|
dm_free(rarray[i].response);
|
||||||
free(outptr);
|
free(*response);
|
||||||
errno = ENOMEM;
|
errno = ENOMEM;
|
||||||
status = -1;
|
status = -1;
|
||||||
goto out;
|
goto out;
|
||||||
@ -274,25 +270,15 @@ static int _cluster_request(char cmd, const char *node, void *data, int len,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Free reply array */
|
/* Free reply array */
|
||||||
static int _cluster_free_request(lvm_response_t * response)
|
static int _cluster_free_request(lvm_response_t * response, int num)
|
||||||
{
|
{
|
||||||
int *ptr = (int *) response - 2;
|
|
||||||
int i;
|
int i;
|
||||||
int num;
|
|
||||||
|
|
||||||
/* Check it's ours to free */
|
|
||||||
if (response == NULL || *ptr != LVM_SIGNATURE) {
|
|
||||||
errno = EINVAL;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
num = ptr[1];
|
|
||||||
|
|
||||||
for (i = 0; i < num; i++) {
|
for (i = 0; i < num; i++) {
|
||||||
dm_free(response[i].response);
|
dm_free(response[i].response);
|
||||||
}
|
}
|
||||||
|
|
||||||
dm_free(ptr);
|
dm_free(response);
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
@ -327,7 +313,7 @@ int refresh_clvmd()
|
|||||||
}
|
}
|
||||||
|
|
||||||
saved_errno = errno;
|
saved_errno = errno;
|
||||||
_cluster_free_request(response);
|
_cluster_free_request(response, num_responses);
|
||||||
errno = saved_errno;
|
errno = saved_errno;
|
||||||
|
|
||||||
return status;
|
return status;
|
||||||
|
@ -196,7 +196,6 @@ static int _cluster_request(char cmd, const char *node, void *data, int len,
|
|||||||
lvm_response_t ** response, int *num)
|
lvm_response_t ** response, int *num)
|
||||||
{
|
{
|
||||||
char outbuf[sizeof(struct clvm_header) + len + strlen(node) + 1] __attribute((aligned(8)));
|
char outbuf[sizeof(struct clvm_header) + len + strlen(node) + 1] __attribute((aligned(8)));
|
||||||
int *outptr;
|
|
||||||
char *inptr;
|
char *inptr;
|
||||||
char *retbuf = NULL;
|
char *retbuf = NULL;
|
||||||
int status;
|
int status;
|
||||||
@ -236,17 +235,13 @@ static int _cluster_request(char cmd, const char *node, void *data, int len,
|
|||||||
* With an extra pair of INTs on the front to sanity
|
* With an extra pair of INTs on the front to sanity
|
||||||
* check the pointer when we are given it back to free
|
* check the pointer when we are given it back to free
|
||||||
*/
|
*/
|
||||||
outptr = dm_malloc(sizeof(lvm_response_t) * num_responses +
|
*response = dm_malloc(sizeof(lvm_response_t) * num_responses);
|
||||||
sizeof(int) * 2);
|
if (!*response) {
|
||||||
if (!outptr) {
|
|
||||||
errno = ENOMEM;
|
errno = ENOMEM;
|
||||||
status = 0;
|
status = 0;
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
*response = (lvm_response_t *) (outptr + 2);
|
|
||||||
outptr[0] = LVM_SIGNATURE;
|
|
||||||
outptr[1] = num_responses;
|
|
||||||
rarray = *response;
|
rarray = *response;
|
||||||
|
|
||||||
/* Unpack the response into an lvm_response_t array */
|
/* Unpack the response into an lvm_response_t array */
|
||||||
@ -265,7 +260,7 @@ static int _cluster_request(char cmd, const char *node, void *data, int len,
|
|||||||
int j;
|
int j;
|
||||||
for (j = 0; j < i; j++)
|
for (j = 0; j < i; j++)
|
||||||
dm_free(rarray[i].response);
|
dm_free(rarray[i].response);
|
||||||
free(outptr);
|
free(*response);
|
||||||
errno = ENOMEM;
|
errno = ENOMEM;
|
||||||
status = -1;
|
status = -1;
|
||||||
goto out;
|
goto out;
|
||||||
@ -287,25 +282,15 @@ static int _cluster_request(char cmd, const char *node, void *data, int len,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Free reply array */
|
/* Free reply array */
|
||||||
static int _cluster_free_request(lvm_response_t * response)
|
static int _cluster_free_request(lvm_response_t * response, int num)
|
||||||
{
|
{
|
||||||
int *ptr = (int *) response - 2;
|
|
||||||
int i;
|
int i;
|
||||||
int num;
|
|
||||||
|
|
||||||
/* Check it's ours to free */
|
|
||||||
if (response == NULL || *ptr != LVM_SIGNATURE) {
|
|
||||||
errno = EINVAL;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
num = ptr[1];
|
|
||||||
|
|
||||||
for (i = 0; i < num; i++) {
|
for (i = 0; i < num; i++) {
|
||||||
dm_free(response[i].response);
|
dm_free(response[i].response);
|
||||||
}
|
}
|
||||||
|
|
||||||
dm_free(ptr);
|
dm_free(response);
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
@ -374,7 +359,7 @@ static int _lock_for_cluster(unsigned char cmd, unsigned int flags, char *name)
|
|||||||
}
|
}
|
||||||
|
|
||||||
saved_errno = errno;
|
saved_errno = errno;
|
||||||
_cluster_free_request(response);
|
_cluster_free_request(response, num_responses);
|
||||||
errno = saved_errno;
|
errno = saved_errno;
|
||||||
|
|
||||||
return status;
|
return status;
|
||||||
|
Loading…
Reference in New Issue
Block a user