All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH v3 0/3] Enable MC/DC support for GCC/GCOV
@ 2025-04-01  1:17 Volodymyr Babchuk
  2025-04-01  1:17 ` [PATCH v3 3/3] xen: debug: gcov: add condition coverage support Volodymyr Babchuk
                   ` (2 more replies)
  0 siblings, 3 replies; 13+ messages in thread
From: Volodymyr Babchuk @ 2025-04-01  1:17 UTC (permalink / raw)
  To: xen-devel@lists.xenproject.org
  Cc: Volodymyr Babchuk, Andrew Cooper, Anthony PERARD, Michal Orzel,
	Jan Beulich, Julien Grall, Roger Pau Monné,
	Stefano Stabellini

This series enables MC/DC for Xen when building with GCC.

Condition coverage, also known as MC/DC (modified condition/decision
coverage) is a coverage metric that tracks separate outcomes in
boolean expressions. This metric is used in critical software
components, so it natural to collect it for Xen.

Second patch in the series ("xen: x86: irq: use do-while loop in
create_irq()") deals with unexpected GCC issue. As was discussed in
the previous version, I changed "for" loop to "do {} while".

This series support only GCC, although Clang, starting with clang 18.
supports similar feature. But Clang 18 uses raw profiling format
version 10, while Xen supports only version 4, and there are quite
substantial changes in headers and structures, so adding new version
format is non-trivial. Also, Xen built for aarch64 with clang 19.1.17
and code coverage enabled, completely hangs up during boot, so there
is clearly more work required.

Another problem with clang-based MC/DC support is that it has multiple
issues which will prevent use it in a meaningfull way:

https://github.com/llvm/llvm-project/issues?q=is%3Aissue%20state%3Aopen%20MC%2FDC

But at least we can have MC/DC with GCOV.

Changes in v3:
 - Check if gcc accepts -fcondition-coverage
 - Clarify why we use do { } loop
 - Add Jan's R-b tag for PATCH 1/3

Changes in v2:
 - Check for gcc 14, not gcc 14.1
 - Reworked irq.c patch


Volodymyr Babchuk (3):
  xen: gcov: add support for gcc 14
  xen: x86: irq: use do-while loop in create_irq()
  xen: debug: gcov: add condition coverage support

 xen/Kconfig                     |  5 +++++
 xen/Kconfig.debug               |  9 +++++++++
 xen/Rules.mk                    |  3 +++
 xen/arch/x86/irq.c              | 17 +++++++++++++----
 xen/common/coverage/gcc_4_7.c   |  4 +++-
 xen/common/coverage/gcov_base.c |  5 +++++
 6 files changed, 38 insertions(+), 5 deletions(-)

-- 
2.48.1

^ permalink raw reply	[flat|nested] 13+ messages in thread

end of thread, other threads:[~2025-04-07 10:37 UTC | newest]

Thread overview: 13+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-04-01  1:17 [PATCH v3 0/3] Enable MC/DC support for GCC/GCOV Volodymyr Babchuk
2025-04-01  1:17 ` [PATCH v3 3/3] xen: debug: gcov: add condition coverage support Volodymyr Babchuk
2025-04-03  7:30   ` Jan Beulich
2025-04-03 13:15     ` Anthony PERARD
2025-04-03 14:18       ` Jan Beulich
2025-04-05  3:30     ` Volodymyr Babchuk
2025-04-07  7:19       ` Jan Beulich
2025-04-07  9:57       ` Anthony PERARD
2025-04-07 10:37         ` Volodymyr Babchuk
2025-04-01  1:17 ` [PATCH v3 2/3] xen: x86: irq: use do-while loop in create_irq() Volodymyr Babchuk
2025-04-01  6:33   ` Jan Beulich
2025-04-01  1:17 ` [PATCH v3 1/3] xen: gcov: add support for gcc 14 Volodymyr Babchuk
2025-04-01  6:27   ` Jan Beulich

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.