ipcrm.c 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. /* ipcrm.c - remove msg que, sem or shared memory
  2. *
  3. * Copyright 2014 Ashwini Kumar <ak.ashwini1981@gmail.com>
  4. *
  5. * See http://pubs.opengroup.org/onlinepubs/9699919799/utilities/ipcrm.html
  6. USE_IPCRM(NEWTOY(ipcrm, "m*M*s*S*q*Q*", TOYFLAG_USR|TOYFLAG_BIN))
  7. config IPCRM
  8. bool "ipcrm"
  9. default n
  10. help
  11. usage: ipcrm [ [-q msqid] [-m shmid] [-s semid]
  12. [-Q msgkey] [-M shmkey] [-S semkey] ... ]
  13. -mM Remove memory segment after last detach
  14. -qQ Remove message queue
  15. -sS Remove semaphore
  16. */
  17. #define FOR_ipcrm
  18. #include "toys.h"
  19. #include <sys/ipc.h>
  20. #include <sys/shm.h>
  21. #include <sys/sem.h>
  22. #include <sys/msg.h>
  23. GLOBALS(
  24. struct arg_list *qkey;
  25. struct arg_list *qid;
  26. struct arg_list *skey;
  27. struct arg_list *sid;
  28. struct arg_list *mkey;
  29. struct arg_list *mid;
  30. )
  31. static void do_ipcrm(int key, int ipc, char *name)
  32. {
  33. char *c;
  34. int id, ret = 0;
  35. id = strtol(name, &c, 0);
  36. if (*c) {
  37. error_msg("invalid number :%s", name);
  38. return;
  39. }
  40. if (key) {
  41. if (id == IPC_PRIVATE) {
  42. error_msg("illegal key (%s)", name);
  43. return;
  44. }
  45. id = ((ipc == 1)?shmget(id, 0, 0) :
  46. (ipc == 2)? msgget(id, 0): semget(id, 0, 0));
  47. if (id < 0) {
  48. perror_msg("key (%s)", name);
  49. return;
  50. }
  51. }
  52. if (ipc == 1) ret = shmctl(id, IPC_RMID, NULL);
  53. else if (ipc == 2) ret = msgctl(id, IPC_RMID, NULL);
  54. else if (ipc == 3) ret = semctl(id, 0, IPC_RMID, NULL);
  55. if (ret < 0) perror_msg("%s (%s)", ((key)? "key": "id"), name);
  56. }
  57. void ipcrm_main(void)
  58. {
  59. ++toys.argv;
  60. if (toys.optc && (!strcmp(*toys.argv, "shm") ||
  61. !strcmp(*toys.argv, "sem") || !strcmp(*toys.argv, "msg"))) {
  62. int t = (toys.argv[0][1] == 'h')? 1 : (toys.argv[0][1] == 's')? 2:3;
  63. while (*(++toys.argv)) do_ipcrm(0, t, *toys.argv);
  64. } else {
  65. struct arg_list *tmp;
  66. for (tmp = TT.mkey; tmp; tmp = tmp->next) do_ipcrm(1, 1, tmp->arg);
  67. for (tmp = TT.mid; tmp; tmp = tmp->next) do_ipcrm(0, 1, tmp->arg);
  68. for (tmp = TT.qkey; tmp; tmp = tmp->next) do_ipcrm(1, 2, tmp->arg);
  69. for (tmp = TT.qid; tmp; tmp = tmp->next) do_ipcrm(0, 2, tmp->arg);
  70. for (tmp = TT.skey; tmp; tmp = tmp->next) do_ipcrm(1, 3, tmp->arg);
  71. for (tmp = TT.sid; tmp; tmp = tmp->next) do_ipcrm(0, 3, tmp->arg);
  72. if (toys.optc) help_exit("unknown argument: %s", *toys.optargs);
  73. }
  74. }