blob: a02de5a47a36614a8a831ebad347958d846ba895 [file] [log] [blame]
Rob Landley28964802008-01-19 17:08:39 -06001/* vi: set sw=4 ts=4:
2 *
Rob Landleyb5b82d92007-11-20 01:06:29 -06003 * dmesg.c - display/control kernel ring buffer.
4 *
Rob Landleyfece5cb2007-12-03 20:05:57 -06005 * Copyright 2006, 2007 Rob Landley <rob@landley.net>
6 *
7 * Not in SUSv3.
Rob Landley28964802008-01-19 17:08:39 -06008
Rob Landley55928b12008-01-19 17:43:27 -06009USE_DMESG(NEWTOY(dmesg, "s#n#c", TOYFLAG_BIN))
10
Rob Landley28964802008-01-19 17:08:39 -060011config DMESG
12 bool "dmesg"
13 default y
14 help
15 usage: dmesg [-n level] [-s bufsize] | -c
16
17 Print or control the kernel ring buffer.
18
19 -n Set kernel logging level (1-9).
20 -s Size of buffer to read (in bytes), default 16384.
21 -c Clear the ring buffer after printing.
22*/
Rob Landleyb5b82d92007-11-20 01:06:29 -060023
24#include "toys.h"
25#include <sys/klog.h>
26
27#define TT toy.dmesg
28
Rob Landleyefda21c2007-11-29 18:14:37 -060029void dmesg_main(void)
Rob Landleyb5b82d92007-11-20 01:06:29 -060030{
31 // For -n just tell kernel to which messages to keep.
32 if (toys.optflags & 2) {
33 if (klogctl(8, NULL, TT.level))
34 error_exit("klogctl");
35 } else {
36 int size, i, last = '\n';
37 char *data;
38
39 // Figure out how much data we need, and fetch it.
40 size = TT.size;
41 if (size<2) size = 16384;
42 data = xmalloc(size);
43 size = klogctl(3 + (toys.optflags&1), data, size);
44 if (size < 0) error_exit("klogctl");
45
46 // Display data, filtering out level markers.
47 for (i=0; i<size; ) {
48 if (last=='\n' && data[i]=='<') i += 3;
Rob Landleyefda21c2007-11-29 18:14:37 -060049 else xputc(last = data[i++]);
Rob Landleyb5b82d92007-11-20 01:06:29 -060050 }
Rob Landleyefda21c2007-11-29 18:14:37 -060051 if (last!='\n') xputc('\n');
Rob Landleyb5b82d92007-11-20 01:06:29 -060052 if (CFG_TOYBOX_FREE) free(data);
53 }
Rob Landleyb5b82d92007-11-20 01:06:29 -060054}