|
Message-ID: <20171107203933.GV18478@eros> Date: Wed, 8 Nov 2017 07:39:33 +1100 From: "Tobin C. Harding" <me@...in.cc> To: Petr Mladek <pmladek@...e.com> Cc: kernel-hardening@...ts.openwall.com, "Jason A. Donenfeld" <Jason@...c4.com>, Theodore Ts'o <tytso@....edu>, Linus Torvalds <torvalds@...ux-foundation.org>, Kees Cook <keescook@...omium.org>, Paolo Bonzini <pbonzini@...hat.com>, Tycho Andersen <tycho@...ker.com>, "Roberts, William C" <william.c.roberts@...el.com>, Tejun Heo <tj@...nel.org>, Jordan Glover <Golden_Miller83@...tonmail.ch>, Greg KH <gregkh@...uxfoundation.org>, Joe Perches <joe@...ches.com>, Ian Campbell <ijc@...lion.org.uk>, Sergey Senozhatsky <sergey.senozhatsky@...il.com>, Catalin Marinas <catalin.marinas@....com>, Will Deacon <wilal.deacon@....com>, Steven Rostedt <rostedt@...dmis.org>, Chris Fries <cfries@...gle.com>, Dave Weinstein <olorin@...gle.com>, Daniel Micay <danielmicay@...il.com>, Djalal Harouni <tixxdz@...il.com>, linux-kernel@...r.kernel.org, Network Development <netdev@...r.kernel.org>, David Miller <davem@...emloft.net> Subject: Re: [PATCH v4] scripts: add leaking_addresses.pl On Tue, Nov 07, 2017 at 04:51:29PM +0100, Petr Mladek wrote: > On Tue 2017-11-07 21:32:11, Tobin C. Harding wrote: > > Currently we are leaking addresses from the kernel to user space. This > > script is an attempt to find some of those leakages. Script parses > > `dmesg` output and /proc and /sys files for hex strings that look like > > kernel addresses. > > > > Only works for 64 bit kernels, the reason being that kernel addresses > > on 64 bit kernels have 'ffff' as the leading bit pattern making greping > > possible. On 32 kernels we don't have this luxury. > > > > Scripts is _slightly_ smarter than a straight grep, we check for false > > positives (all 0's or all 1's, and vsyscall start/finish addresses). > > > > Output is saved to file to expedite repeated formatting/viewing of > > output. > > > > diff --git a/scripts/leaking_addresses.pl b/scripts/leaking_addresses.pl > > new file mode 100755 > > index 000000000000..282c0cc2bdea > > --- /dev/null > > +++ b/scripts/leaking_addresses.pl > > +sub help > > +{ > > + my ($exitcode) = @_; > > + > > + print << "EOM"; > > +Usage: $P COMMAND [OPTIONS] > > +Version: $V > > + > > +Commands: > > + > > + scan Scan the kernel (savesg raw results to file and runs `format`). > > + format Parse results file and format output. > > + > > +Options: > > + -o, --output=<path> Accepts absolute or relative filename or directory name. > > IMHO, this is pretty non-standard. I would support only -o file. Then you do > not need to solve problems with replacing an existing file. The user > would know exactly what file will be generated. > > > > + --suppress-dmesg Don't show dmesg results. > > The apostrophe breaks highlighting of the rest of the code ;-) > > > > + --squash-by-path Show one result per unique path. > > + --raw Show raw results. > > + --send-report Submit raw results for someone else to worry about. > > + -d, --debug Display debugging output. > > + -h, --help, --version Display this help and exit. > > + > > +Scans the running (64 bit) kernel for potential leaking addresses. > > +} > > This bracket should not be here. The help text is limited > by "EOM" below. > > > > + > > +EOM > > + exit($exitcode); > > +} > > [...] > > > +sub cache_path > > +{ > > + my ($paths, $line) = @_; > > + > > + my $index = index($line, ':'); > > There are paths with the double dot, for example: > /sys/devices/pci0000:00/0000:00:1d.0/usb2/2-1/2-1.6/2-1.6:1.0/input/input4/uevent > Then the file name is wrongly detected, in my example as "pci0000" > > It seems that searching for ": " sub-string works rather well. > I mean using: > > my $index = index($line, ': '); > > > + my $path = substr($line, 0, $index); > > + > > + if (!$paths->{$path}) { > > + $paths->{$path} = (); > > + } > > + push @{$paths->{$path}}, $line; > > It would make sense to use the same trick from cache_filename > and remove path from the cached text. I mean: > > $index += 2; # skip ': ' > push @{$paths->{$path}}, substr($line, $index); > > > +} > > + > > +sub cache_filename > > +{ > > + my ($files, $line) = @_; > > + > > + my $index = index($line, ':'); > > Same problem with the double dot in the path name. > The following helped me: > > my $index = index($line, ': '); > > > + my $path = substr($line, 0, $index); > > + my $filename = basename($path); > > + if (!$files->{$filename}) { > > + $files->{$filename} = (); > > + } > > + $index += 2; # skip ': ' > > + push @{$files->{$filename}}, substr($line, $index); > > +} > > This is what caught my eye when trying the script. Awesome. Thank you very much. All comments will be addressed for the next spin. thanks, Tobin.
Powered by blists - more mailing lists
Confused about mailing lists and their use? Read about mailing lists on Wikipedia and check out these guidelines on proper formatting of your messages.