Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux
1
fork

Configure Feed

Select the types of activity you want to include in your feed.

kernel/panic: initialize taint_flags[] using a macro

Make it easier to extend struct taint_flags in follow-up.

Link: https://lkml.kernel.org/r/8a2498285d37953cfad9dce939ed3abef61051bd.1717146197.git.jani.nikula@intel.com
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Reviewed-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>

authored by

Jani Nikula and committed by
Andrew Morton
f36fc96c aff1db0e

+27 -19
+27 -19
kernel/panic.c
··· 471 471 472 472 EXPORT_SYMBOL(panic); 473 473 474 + #define TAINT_FLAG(taint, _c_true, _c_false, _module) \ 475 + [ TAINT_##taint ] = { \ 476 + .c_true = _c_true, .c_false = _c_false, \ 477 + .module = _module, \ 478 + } 479 + 474 480 /* 475 481 * TAINT_FORCED_RMMOD could be a per-module flag but the module 476 482 * is being removed anyway. 477 483 */ 478 484 const struct taint_flag taint_flags[TAINT_FLAGS_COUNT] = { 479 - [ TAINT_PROPRIETARY_MODULE ] = { 'P', 'G', true }, 480 - [ TAINT_FORCED_MODULE ] = { 'F', ' ', true }, 481 - [ TAINT_CPU_OUT_OF_SPEC ] = { 'S', ' ', false }, 482 - [ TAINT_FORCED_RMMOD ] = { 'R', ' ', false }, 483 - [ TAINT_MACHINE_CHECK ] = { 'M', ' ', false }, 484 - [ TAINT_BAD_PAGE ] = { 'B', ' ', false }, 485 - [ TAINT_USER ] = { 'U', ' ', false }, 486 - [ TAINT_DIE ] = { 'D', ' ', false }, 487 - [ TAINT_OVERRIDDEN_ACPI_TABLE ] = { 'A', ' ', false }, 488 - [ TAINT_WARN ] = { 'W', ' ', false }, 489 - [ TAINT_CRAP ] = { 'C', ' ', true }, 490 - [ TAINT_FIRMWARE_WORKAROUND ] = { 'I', ' ', false }, 491 - [ TAINT_OOT_MODULE ] = { 'O', ' ', true }, 492 - [ TAINT_UNSIGNED_MODULE ] = { 'E', ' ', true }, 493 - [ TAINT_SOFTLOCKUP ] = { 'L', ' ', false }, 494 - [ TAINT_LIVEPATCH ] = { 'K', ' ', true }, 495 - [ TAINT_AUX ] = { 'X', ' ', true }, 496 - [ TAINT_RANDSTRUCT ] = { 'T', ' ', true }, 497 - [ TAINT_TEST ] = { 'N', ' ', true }, 485 + TAINT_FLAG(PROPRIETARY_MODULE, 'P', 'G', true), 486 + TAINT_FLAG(FORCED_MODULE, 'F', ' ', true), 487 + TAINT_FLAG(CPU_OUT_OF_SPEC, 'S', ' ', false), 488 + TAINT_FLAG(FORCED_RMMOD, 'R', ' ', false), 489 + TAINT_FLAG(MACHINE_CHECK, 'M', ' ', false), 490 + TAINT_FLAG(BAD_PAGE, 'B', ' ', false), 491 + TAINT_FLAG(USER, 'U', ' ', false), 492 + TAINT_FLAG(DIE, 'D', ' ', false), 493 + TAINT_FLAG(OVERRIDDEN_ACPI_TABLE, 'A', ' ', false), 494 + TAINT_FLAG(WARN, 'W', ' ', false), 495 + TAINT_FLAG(CRAP, 'C', ' ', true), 496 + TAINT_FLAG(FIRMWARE_WORKAROUND, 'I', ' ', false), 497 + TAINT_FLAG(OOT_MODULE, 'O', ' ', true), 498 + TAINT_FLAG(UNSIGNED_MODULE, 'E', ' ', true), 499 + TAINT_FLAG(SOFTLOCKUP, 'L', ' ', false), 500 + TAINT_FLAG(LIVEPATCH, 'K', ' ', true), 501 + TAINT_FLAG(AUX, 'X', ' ', true), 502 + TAINT_FLAG(RANDSTRUCT, 'T', ' ', true), 503 + TAINT_FLAG(TEST, 'N', ' ', true), 498 504 }; 505 + 506 + #undef TAINT_FLAG 499 507 500 508 static void print_tainted_seq(struct seq_buf *s) 501 509 {