Commit 49ea3128 authored by Kinsbursky Stanislav's avatar Kinsbursky Stanislav Committed by Pavel Emelyanov

protobuf: use generic show function for ipc messages

Signed-off-by: 's avatarStanislav Kinsbursky <skinsbursky@openvz.org>
Signed-off-by: 's avatarPavel Emelyanov <xemul@parallels.com>
parent 26eb254f
......@@ -177,25 +177,19 @@ static int dump_ipc_sem(int fd)
return info.semusz;
}
static void pr_ipc_msg(unsigned int loglevel, int nr, const IpcMsg *msg)
static void pr_info_ipc_msg(int nr, const IpcMsg *msg)
{
print_on_level(loglevel, " %-5d: type: %-20ld size: %-10d\n",
print_on_level(LOG_INFO, " %-5d: type: %-20ld size: %-10d\n",
nr++, msg->mtype, msg->msize);
}
#define pr_info_ipc_msg(nr, msg) pr_ipc_msg(LOG_INFO, nr, msg)
#define pr_msg_ipc_msg(nr, msg) pr_ipc_msg(LOG_MSG, nr, msg)
static void pr_ipc_msg_entry(unsigned int loglevel, const IpcMsgEntry *msg)
static void pr_info_ipc_msg_entry(const IpcMsgEntry *msg)
{
pr_ipc_desc_entry(loglevel, msg->desc);
print_on_level(loglevel, "qbytes: %-10d qnum: %-10d\n",
pr_ipc_desc_entry(LOG_INFO, msg->desc);
print_on_level(LOG_INFO, "qbytes: %-10d qnum: %-10d\n",
msg->qbytes, msg->qnum);
}
#define pr_info_ipc_msg_entry(msg) pr_ipc_msg_entry(LOG_INFO, msg)
#define pr_msg_ipc_msg_entry(msg) pr_ipc_msg_entry(LOG_MSG, msg)
static int dump_ipc_msg_queue_messages(int fd, const IpcMsgEntry *entry, size_t cbytes)
{
void *msg_array, *ptr;
......@@ -498,49 +492,32 @@ void show_ipc_sem(int fd, struct cr_options *o)
pb_show_plain_payload(fd, ipc_sem_entry, ipc_sem_handler, 0);
}
static void show_ipc_msg_entries(int fd)
static void ipc_msg_data_handler(int fd, void *obj, int show_pages_content)
{
pr_msg("\nMessage queues:\n");
while (1) {
int ret;
IpcMsgEntry *entry;
int msg_nr = 0;
ret = pb_read_eof(fd, &entry, ipc_msg_entry);
if (ret <= 0)
return;
pr_msg_ipc_msg_entry(entry);
while (msg_nr < entry->qnum) {
IpcMsg *msg;
ret = pb_read(fd, &msg, ipc_msg);
if (ret <= 0)
break;
IpcMsg *e = obj;
pr_msg_ipc_msg(msg_nr, msg);
if (show_pages_content) {
pr_msg("\n");
print_image_data(fd, round_up(e->msize, sizeof(u64)));
} else
lseek(fd, round_up(e->msize, sizeof(u64)), SEEK_CUR);
}
if (lseek(fd, round_up(msg->msize, sizeof(u64)), SEEK_CUR) == (off_t) -1)
ret = -1;
ipc_msg__free_unpacked(msg, NULL);
msg_nr++;
static void ipc_msg_handler(int fd, void *obj, int show_pages_content)
{
IpcMsgEntry *e = obj;
int msg_nr = 0;
if (ret < 0)
break;
}
pr_msg("\n");
while (msg_nr++ < e->qnum)
pb_show_plain_payload(fd, ipc_msg, ipc_msg_data_handler,
show_pages_content);
ipc_msg_entry__free_unpacked(entry, NULL);
if (ret < 0)
break;
}
}
void show_ipc_msg(int fd, struct cr_options *o)
{
pr_img_head(CR_FD_IPCNS);
show_ipc_msg_entries(fd);
pr_img_tail(CR_FD_IPCNS);
pb_show_plain_payload(fd, ipc_msg_entry, ipc_msg_handler, o->show_pages_content);
}
static void show_ipc_shm_entries(int fd)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment