ipcs: silly trick with strings. saves ~200 bytes.

This commit is contained in:
Denis Vlasenko 2006-09-10 18:26:51 +00:00
parent 1bfca7bac7
commit 5983914c1b
2 changed files with 39 additions and 40 deletions

View File

@ -136,13 +136,13 @@ static void do_shm(void)
maxid = shmctl(0, SHM_INFO, (struct shmid_ds *) (void *) &shm_info); maxid = shmctl(0, SHM_INFO, (struct shmid_ds *) (void *) &shm_info);
if (maxid < 0) { if (maxid < 0) {
bb_printf("kernel not configured for shared memory\n"); bb_printf("kernel not configured for %s\n", "shared memory");
return; return;
} }
switch (format) { switch (format) {
case LIMITS: case LIMITS:
bb_printf("------ Shared Memory Limits --------\n"); bb_printf("------ Shared Memory %s --------\n", "Limits");
if ((shmctl(0, IPC_INFO, (struct shmid_ds *) (void *) &shminfo)) < 0) if ((shmctl(0, IPC_INFO, (struct shmid_ds *) (void *) &shminfo)) < 0)
return; return;
/* glibc 2.1.3 and all earlier libc's have ints as fields /* glibc 2.1.3 and all earlier libc's have ints as fields
@ -158,12 +158,12 @@ static void do_shm(void)
return; return;
case STATUS: case STATUS:
bb_printf("------ Shared Memory Status --------\n" bb_printf("------ Shared Memory %s --------\n", "Status");
"segments allocated %d\n" bb_printf( "segments allocated %d\n"
"pages allocated %ld\n" "pages allocated %ld\n"
"pages resident %ld\n" "pages resident %ld\n"
"pages swapped %ld\n" "pages swapped %ld\n"
"Swap performance: %ld attempts\t %ld successes\n", "Swap performance: %ld attempts\t%ld successes\n",
shm_info.used_ids, shm_info.used_ids,
shm_info.shm_tot, shm_info.shm_tot,
shm_info.shm_rss, shm_info.shm_rss,
@ -172,26 +172,26 @@ static void do_shm(void)
return; return;
case CREATOR: case CREATOR:
bb_printf("------ Shared Memory Segment Creators/Owners --------\n" bb_printf("------ Shared Memory %s --------\n", "Segment Creators/Owners");
"%-10s %-10s %-10s %-10s %-10s %-10s\n", bb_printf( "%-10s %-10s %-10s %-10s %-10s %-10s\n",
"shmid", "perms", "cuid", "cgid", "uid", "gid"); "shmid", "perms", "cuid", "cgid", "uid", "gid");
break; break;
case TIME: case TIME:
bb_printf("------ Shared Memory Attach/Detach/Change Times --------\n" bb_printf("------ Shared Memory %s --------\n", "Attach/Detach/Change Times");
"%-10s %-10s %-20s %-20s %-20s\n", bb_printf( "%-10s %-10s %-20s %-20s %-20s\n",
"shmid", "owner", "attached", "detached", "changed"); "shmid", "owner", "attached", "detached", "changed");
break; break;
case PID: case PID:
bb_printf("------ Shared Memory Creator/Last-op --------\n" bb_printf("------ Shared Memory %s --------\n", "Creator/Last-op");
"%-10s %-10s %-10s %-10s\n", bb_printf( "%-10s %-10s %-10s %-10s\n",
"shmid", "owner", "cpid", "lpid"); "shmid", "owner", "cpid", "lpid");
break; break;
default: default:
bb_printf("------ Shared Memory Segments --------\n" bb_printf("------ Shared Memory %s --------\n", "Segments");
"%-10s %-10s %-10s %-10s %-10s %-10s %-12s\n", bb_printf( "%-10s %-10s %-10s %-10s %-10s %-10s %-12s\n",
"key", "shmid", "owner", "perms", "bytes", "nattch", "key", "shmid", "owner", "perms", "bytes", "nattch",
"status"); "status");
break; break;
@ -264,13 +264,13 @@ static void do_sem(void)
arg.array = (ushort *) (void *) &seminfo; arg.array = (ushort *) (void *) &seminfo;
maxid = semctl(0, 0, SEM_INFO, arg); maxid = semctl(0, 0, SEM_INFO, arg);
if (maxid < 0) { if (maxid < 0) {
bb_printf("kernel not configured for semaphores\n"); bb_printf("kernel not configured for %s\n", "semaphores");
return; return;
} }
switch (format) { switch (format) {
case LIMITS: case LIMITS:
bb_printf("------ Semaphore Limits --------\n"); bb_printf("------ Semaphore %s --------\n", "Limits");
arg.array = (ushort *) (void *) &seminfo; /* damn union */ arg.array = (ushort *) (void *) &seminfo; /* damn union */
if ((semctl(0, 0, IPC_INFO, arg)) < 0) if ((semctl(0, 0, IPC_INFO, arg)) < 0)
return; return;
@ -285,21 +285,21 @@ static void do_sem(void)
return; return;
case STATUS: case STATUS:
bb_printf("------ Semaphore Status --------\n" bb_printf("------ Semaphore %s --------\n", "Status");
"used arrays = %d\n" bb_printf( "used arrays = %d\n"
"allocated semaphores = %d\n", "allocated semaphores = %d\n",
seminfo.semusz, seminfo.semaem); seminfo.semusz, seminfo.semaem);
return; return;
case CREATOR: case CREATOR:
bb_printf("------ Semaphore Arrays Creators/Owners --------\n" bb_printf("------ Semaphore %s --------\n", "Arrays Creators/Owners");
"%-10s %-10s %-10s %-10s %-10s %-10s\n", bb_printf( "%-10s %-10s %-10s %-10s %-10s %-10s\n",
"semid", "perms", "cuid", "cgid", "uid", "gid"); "semid", "perms", "cuid", "cgid", "uid", "gid");
break; break;
case TIME: case TIME:
bb_printf("------ Shared Memory Operation/Change Times --------\n" bb_printf("------ Shared Memory %s --------\n", "Operation/Change Times");
"%-8s %-10s %-26.24s %-26.24s\n", bb_printf( "%-8s %-10s %-26.24s %-26.24s\n",
"shmid", "owner", "last-op", "last-changed"); "shmid", "owner", "last-op", "last-changed");
break; break;
@ -307,8 +307,8 @@ static void do_sem(void)
break; break;
default: default:
bb_printf("------ Semaphore Arrays --------\n" bb_printf("------ Semaphore %s --------\n", "Arrays");
"%-10s %-10s %-10s %-10s %-10s\n", bb_printf( "%-10s %-10s %-10s %-10s %-10s\n",
"key", "semid", "owner", "perms", "nsems"); "key", "semid", "owner", "perms", "nsems");
break; break;
} }
@ -368,7 +368,7 @@ static void do_msg(void)
maxid = msgctl(0, MSG_INFO, (struct msqid_ds *) (void *) &msginfo); maxid = msgctl(0, MSG_INFO, (struct msqid_ds *) (void *) &msginfo);
if (maxid < 0) { if (maxid < 0) {
bb_printf("kernel not configured for message queues\n"); bb_printf("kernel not configured for %s\n", "message queues");
return; return;
} }
@ -376,42 +376,42 @@ static void do_msg(void)
case LIMITS: case LIMITS:
if ((msgctl(0, IPC_INFO, (struct msqid_ds *) (void *) &msginfo)) < 0) if ((msgctl(0, IPC_INFO, (struct msqid_ds *) (void *) &msginfo)) < 0)
return; return;
bb_printf("------ Messages: Limits --------\n" bb_printf("------ Message%s --------\n", "s: Limits");
"max queues system wide = %d\n" bb_printf( "max queues system wide = %d\n"
"max size of message (bytes) = %d\n" "max size of message (bytes) = %d\n"
"default max size of queue (bytes) = %d\n", "default max size of queue (bytes) = %d\n",
msginfo.msgmni, msginfo.msgmax, msginfo.msgmnb); msginfo.msgmni, msginfo.msgmax, msginfo.msgmnb);
return; return;
case STATUS: case STATUS:
bb_printf("------ Messages: Status --------\n" bb_printf("------ Message%s --------\n", "s: Status");
"allocated queues = %d\n" bb_printf( "allocated queues = %d\n"
"used headers = %d\n" "used headers = %d\n"
"used space = %d bytes\n", "used space = %d bytes\n",
msginfo.msgpool, msginfo.msgmap, msginfo.msgtql); msginfo.msgpool, msginfo.msgmap, msginfo.msgtql);
return; return;
case CREATOR: case CREATOR:
bb_printf("------ Message Queues: Creators/Owners --------\n" bb_printf("------ Message%s --------\n", " Queues: Creators/Owners");
"%-10s %-10s %-10s %-10s %-10s %-10s\n", bb_printf( "%-10s %-10s %-10s %-10s %-10s %-10s\n",
"msqid", "perms", "cuid", "cgid", "uid", "gid"); "msqid", "perms", "cuid", "cgid", "uid", "gid");
break; break;
case TIME: case TIME:
bb_printf("------ Message Queues Send/Recv/Change Times --------\n" bb_printf("------ Message%s --------\n", " Queues Send/Recv/Change Times");
"%-8s %-10s %-20s %-20s %-20s\n", bb_printf( "%-8s %-10s %-20s %-20s %-20s\n",
"msqid", "owner", "send", "recv", "change"); "msqid", "owner", "send", "recv", "change");
break; break;
case PID: case PID:
bb_printf("------ Message Queues PIDs --------\n" bb_printf("------ Message%s --------\n", " Queues PIDs");
"%-10s %-10s %-10s %-10s\n", bb_printf( "%-10s %-10s %-10s %-10s\n",
"msqid", "owner", "lspid", "lrpid"); "msqid", "owner", "lspid", "lrpid");
break; break;
default: default:
bb_printf("------ Message Queues --------\n" bb_printf("------ Message%s --------\n", " Queues");
"%-10s %-10s %-10s %-10s %-12s %-12s\n", bb_printf( "%-10s %-10s %-10s %-10s %-12s %-12s\n",
"key", "msqid", "owner", "perms", "used-bytes", "messages"); "key", "msqid", "owner", "perms", "used-bytes", "messages");
break; break;
} }

View File

@ -17,12 +17,11 @@ extern int pivot_root(const char * new_root,const char * put_old);
int pivot_root_main(int argc, char **argv) int pivot_root_main(int argc, char **argv)
{ {
if (argc != 3) if (argc != 3)
bb_show_usage(); bb_show_usage();
if (pivot_root(argv[1],argv[2]) < 0) if (pivot_root(argv[1],argv[2]) < 0)
bb_perror_msg_and_die("pivot_root"); bb_perror_msg_and_die("pivot_root");
return EXIT_SUCCESS; return EXIT_SUCCESS;
} }