lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Date:	Wed, 26 Aug 2009 14:27:17 +0200
From:	Peter Oberparleiter <oberpar@...ux.vnet.ibm.com>
To:	michal.simek@...alogix.com
CC:	Linux Kernel list <linux-kernel@...r.kernel.org>,
	"subrata@...ux.vnet.ibm.com" <subrata@...ux.vnet.ibm.com>
Subject: Re: Gcov and lcov

Hi,

Michal Simek wrote:
> First of all there should be DEBUG_FS instead of DEBUG in documentation.
> diff --git a/Documentation/gcov.txt b/Documentation/gcov.txt
> index 40ec633..e7ca647 100644
> --- a/Documentation/gcov.txt
> +++ b/Documentation/gcov.txt
> @@ -47,7 +47,7 @@ Possible uses:
> 
>  Configure the kernel with:
> 
> -        CONFIG_DEBUGFS=y
> +        CONFIG_DEBUG_FS=y
>          CONFIG_GCOV_KERNEL=y

Thanks for pointing this out. This was reported before and will be fixed 
in a future kernel release.

> I am missing any option to be possible to stop capture coveradge data.

There is currently no way to turn gcov-based profiling off during run-time.

> I am running in on Microblaze and it takes me a lot of time to grap all
> gcda data from debugfs.

If you don't need coverage data for all of the kernel source, you can 
turn off option CONFIG_GCOV_PROFILE_ALL and only enable profiling for 
those directories or files which are of interest to you. This should 
greatly reduce the number of files that you need to copy and also the 
overall kernel-slowdown.

See the help text for configuration option CONFIG_GCOV_KERNEL for a 
description of how to turn profiling on for single directories or files.

> Then I would like to use lcov and generate html sites. This could be
> possible but I haven't found
> a way how to do it.
> 
> I used lcov --capture --directory . --output-file out
> 
> There is this mishmash in version string
> /home/projects/xils/_full/software/linux-monstr_eu-commit/kernel/spinlock.gcno:version
> '401*', prefer '401p'
> /home/projects/xils/_full/software/linux-monstr_eu-commit/kernel/spinlock.gcda:version
> '401*', prefer version '401p'
> 
> and then genhtml out which end with fault because my out file contain
> wrong patches where is part of path repeated.
> arch/microblaze/kernel/arch/microblaze/kernel

The warning messages you are seeing indicate that the version of gcov 
used for analyzing and the version of gcc used for compiling differ. You 
need to specify the correct gcov tool binary (the one that comes with 
the compiler used to compile the kernel) by using lcov's --gcov-tool option.

Also current lcov releases only contain support for the gcov-kernel 
infrastructure as provided by the external gcov-kernel patch. I added 
support for the new upstream infrastructure to the CVS version[*] of lcov.

Using the CVS version, you can do the following:

On the test machine:
	lcov -c --to-package coveragedata

This will create a file coveragedata which includes all .gcda files. 
Copy this file to the build machine and do:
	lcov -c --from-package coveragedata -o data.info

This will allow you to do the actual analysis of coverage data on the 
build machine. See the man page for lcov for a detailed description of 
this approach.


Regards,
   Peter Oberparleiter

[*] See http://ltp.sourceforge.net/coverage/lcov.php for instructions on 
how to obtain the CVS version of lcov

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ