1
0
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:
Alasdair Kergon 2006-12-01 23:10:26 +00:00
parent 0357f18ef0
commit a951e97ae9
4 changed files with 42 additions and 66 deletions

View File

@ -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:

View File

@ -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 */

View File

@ -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;

View File

@ -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;