dmesg.c 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. /* See LICENSE file for copyright and license details. */
  2. #include <sys/klog.h>
  3. #include <stdio.h>
  4. #include <stdlib.h>
  5. #include <string.h>
  6. #include <unistd.h>
  7. #include "util.h"
  8. enum {
  9. SYSLOG_ACTION_READ_ALL = 3,
  10. SYSLOG_ACTION_CLEAR = 5,
  11. SYSLOG_ACTION_CONSOLE_LEVEL = 8,
  12. SYSLOG_ACTION_SIZE_BUFFER = 10
  13. };
  14. static void
  15. dmesg_show(const void *buf, size_t n)
  16. {
  17. const char *p = buf;
  18. ssize_t r;
  19. r = write(1, p, n);
  20. if (r < 0)
  21. eprintf("write:");
  22. if (r > 0 && p[r - 1] != '\n')
  23. putchar('\n');
  24. }
  25. static void
  26. usage(void)
  27. {
  28. eprintf("usage: %s [-Ccr] [-n level]\n", argv0);
  29. }
  30. int
  31. main(int argc, char *argv[])
  32. {
  33. int n;
  34. char *buf;
  35. int cflag = 0;
  36. long level;
  37. ARGBEGIN {
  38. case 'C':
  39. if (klogctl(SYSLOG_ACTION_CLEAR, NULL, 0) < 0)
  40. eprintf("klogctl:");
  41. return 0;
  42. case 'c':
  43. cflag = 1;
  44. break;
  45. case 'r':
  46. break;
  47. case 'n':
  48. level = estrtol(EARGF(usage()), 10);
  49. if (klogctl(SYSLOG_ACTION_CONSOLE_LEVEL, NULL, level) < 0)
  50. eprintf("klogctl:");
  51. return 0;
  52. default:
  53. usage();
  54. } ARGEND;
  55. n = klogctl(SYSLOG_ACTION_SIZE_BUFFER, NULL, 0);
  56. if (n < 0)
  57. eprintf("klogctl:");
  58. buf = emalloc(n);
  59. n = klogctl(SYSLOG_ACTION_READ_ALL, buf, n);
  60. if (n < 0)
  61. eprintf("klogctl:");
  62. dmesg_show(buf, n);
  63. if (cflag && klogctl(SYSLOG_ACTION_CLEAR, NULL, 0) < 0)
  64. eprintf("klogctl:");
  65. free(buf);
  66. return 0;
  67. }