mirror of
https://github.com/checkpoint-restore/criu
synced 2025-08-22 18:07:57 +00:00
protobuf: use generic show function for ipc messages
Signed-off-by: Stanislav Kinsbursky <skinsbursky@openvz.org> Signed-off-by: Pavel Emelyanov <xemul@parallels.com>
This commit is contained in:
parent
26eb254f96
commit
49ea3128db
67
ipc_ns.c
67
ipc_ns.c
@ -177,25 +177,19 @@ static int dump_ipc_sem(int fd)
|
|||||||
return info.semusz;
|
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);
|
nr++, msg->mtype, msg->msize);
|
||||||
}
|
}
|
||||||
|
|
||||||
#define pr_info_ipc_msg(nr, msg) pr_ipc_msg(LOG_INFO, nr, msg)
|
static void pr_info_ipc_msg_entry(const IpcMsgEntry *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)
|
|
||||||
{
|
{
|
||||||
pr_ipc_desc_entry(loglevel, msg->desc);
|
pr_ipc_desc_entry(LOG_INFO, msg->desc);
|
||||||
print_on_level(loglevel, "qbytes: %-10d qnum: %-10d\n",
|
print_on_level(LOG_INFO, "qbytes: %-10d qnum: %-10d\n",
|
||||||
msg->qbytes, msg->qnum);
|
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)
|
static int dump_ipc_msg_queue_messages(int fd, const IpcMsgEntry *entry, size_t cbytes)
|
||||||
{
|
{
|
||||||
void *msg_array, *ptr;
|
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);
|
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");
|
IpcMsg *e = obj;
|
||||||
while (1) {
|
|
||||||
int ret;
|
|
||||||
IpcMsgEntry *entry;
|
|
||||||
int msg_nr = 0;
|
|
||||||
|
|
||||||
ret = pb_read_eof(fd, &entry, ipc_msg_entry);
|
if (show_pages_content) {
|
||||||
if (ret <= 0)
|
pr_msg("\n");
|
||||||
return;
|
print_image_data(fd, round_up(e->msize, sizeof(u64)));
|
||||||
|
} else
|
||||||
|
lseek(fd, round_up(e->msize, sizeof(u64)), SEEK_CUR);
|
||||||
|
}
|
||||||
|
|
||||||
pr_msg_ipc_msg_entry(entry);
|
static void ipc_msg_handler(int fd, void *obj, int show_pages_content)
|
||||||
|
{
|
||||||
|
IpcMsgEntry *e = obj;
|
||||||
|
int msg_nr = 0;
|
||||||
|
|
||||||
while (msg_nr < entry->qnum) {
|
pr_msg("\n");
|
||||||
IpcMsg *msg;
|
while (msg_nr++ < e->qnum)
|
||||||
|
pb_show_plain_payload(fd, ipc_msg, ipc_msg_data_handler,
|
||||||
|
show_pages_content);
|
||||||
|
|
||||||
ret = pb_read(fd, &msg, ipc_msg);
|
|
||||||
if (ret <= 0)
|
|
||||||
break;
|
|
||||||
|
|
||||||
pr_msg_ipc_msg(msg_nr, msg);
|
|
||||||
|
|
||||||
if (lseek(fd, round_up(msg->msize, sizeof(u64)), SEEK_CUR) == (off_t) -1)
|
|
||||||
ret = -1;
|
|
||||||
ipc_msg__free_unpacked(msg, NULL);
|
|
||||||
msg_nr++;
|
|
||||||
|
|
||||||
if (ret < 0)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
ipc_msg_entry__free_unpacked(entry, NULL);
|
|
||||||
if (ret < 0)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void show_ipc_msg(int fd, struct cr_options *o)
|
void show_ipc_msg(int fd, struct cr_options *o)
|
||||||
{
|
{
|
||||||
pr_img_head(CR_FD_IPCNS);
|
pb_show_plain_payload(fd, ipc_msg_entry, ipc_msg_handler, o->show_pages_content);
|
||||||
show_ipc_msg_entries(fd);
|
|
||||||
pr_img_tail(CR_FD_IPCNS);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void show_ipc_shm_entries(int fd)
|
static void show_ipc_shm_entries(int fd)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user